2
0

a00171.html 103 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
  5. <meta http-equiv="X-UA-Compatible" content="IE=9"/>
  6. <meta name="generator" content="Doxygen 1.8.10"/>
  7. <title>0.9.9 API documenation: GLM_GTC_packing</title>
  8. <link href="tabs.css" rel="stylesheet" type="text/css"/>
  9. <script type="text/javascript" src="jquery.js"></script>
  10. <script type="text/javascript" src="dynsections.js"></script>
  11. <link href="search/search.css" rel="stylesheet" type="text/css"/>
  12. <script type="text/javascript" src="search/searchdata.js"></script>
  13. <script type="text/javascript" src="search/search.js"></script>
  14. <script type="text/javascript">
  15. $(document).ready(function() { init_search(); });
  16. </script>
  17. <link href="doxygen.css" rel="stylesheet" type="text/css" />
  18. </head>
  19. <body>
  20. <div id="top"><!-- do not remove this div, it is closed by doxygen! -->
  21. <div id="titlearea">
  22. <table cellspacing="0" cellpadding="0">
  23. <tbody>
  24. <tr style="height: 56px;">
  25. <td id="projectlogo"><img alt="Logo" src="logo-mini.png"/></td>
  26. <td id="projectalign" style="padding-left: 0.5em;">
  27. <div id="projectname">0.9.9 API documenation
  28. </div>
  29. </td>
  30. </tr>
  31. </tbody>
  32. </table>
  33. </div>
  34. <!-- end header part -->
  35. <!-- Generated by Doxygen 1.8.10 -->
  36. <script type="text/javascript">
  37. var searchBox = new SearchBox("searchBox", "search",false,'Search');
  38. </script>
  39. <div id="navrow1" class="tabs">
  40. <ul class="tablist">
  41. <li><a href="index.html"><span>Main&#160;Page</span></a></li>
  42. <li><a href="modules.html"><span>Modules</span></a></li>
  43. <li><a href="files.html"><span>Files</span></a></li>
  44. <li>
  45. <div id="MSearchBox" class="MSearchBoxInactive">
  46. <span class="left">
  47. <img id="MSearchSelect" src="search/mag_sel.png"
  48. onmouseover="return searchBox.OnSearchSelectShow()"
  49. onmouseout="return searchBox.OnSearchSelectHide()"
  50. alt=""/>
  51. <input type="text" id="MSearchField" value="Search" accesskey="S"
  52. onfocus="searchBox.OnSearchFieldFocus(true)"
  53. onblur="searchBox.OnSearchFieldFocus(false)"
  54. onkeyup="searchBox.OnSearchFieldChange(event)"/>
  55. </span><span class="right">
  56. <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
  57. </span>
  58. </div>
  59. </li>
  60. </ul>
  61. </div>
  62. </div><!-- top -->
  63. <!-- window showing the filter options -->
  64. <div id="MSearchSelectWindow"
  65. onmouseover="return searchBox.OnSearchSelectShow()"
  66. onmouseout="return searchBox.OnSearchSelectHide()"
  67. onkeydown="return searchBox.OnSearchSelectKey(event)">
  68. </div>
  69. <!-- iframe showing the search results (closed by default) -->
  70. <div id="MSearchResultsWindow">
  71. <iframe src="javascript:void(0)" frameborder="0"
  72. name="MSearchResults" id="MSearchResults">
  73. </iframe>
  74. </div>
  75. <div class="header">
  76. <div class="summary">
  77. <a href="#func-members">Functions</a> </div>
  78. <div class="headertitle">
  79. <div class="title">GLM_GTC_packing<div class="ingroups"><a class="el" href="a00153.html">GTC Extensions (Stable)</a></div></div> </div>
  80. </div><!--header-->
  81. <div class="contents">
  82. <p>This extension provides a set of function to convert vertors to packed formats.
  83. <a href="#details">More...</a></p>
  84. <table class="memberdecls">
  85. <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="func-members"></a>
  86. Functions</h2></td></tr>
  87. <tr class="memitem:ga4944ad465ff950e926d49621f916c78d"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint32&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga4944ad465ff950e926d49621f916c78d">packF2x11_1x10</a> (vec3 const &amp;v)</td></tr>
  88. <tr class="memdesc:ga4944ad465ff950e926d49621f916c78d"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, converts the first two components of the normalized floating-point value v into 11-bit signless floating-point values. <a href="a00171.html#ga4944ad465ff950e926d49621f916c78d">More...</a><br /></td></tr>
  89. <tr class="separator:ga4944ad465ff950e926d49621f916c78d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  90. <tr class="memitem:ga3f648fc205467792dc6d8c59c748f8a6"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint32&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga3f648fc205467792dc6d8c59c748f8a6">packF3x9_E1x5</a> (vec3 const &amp;v)</td></tr>
  91. <tr class="memdesc:ga3f648fc205467792dc6d8c59c748f8a6"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, converts the first two components of the normalized floating-point value v into 11-bit signless floating-point values. <a href="a00171.html#ga3f648fc205467792dc6d8c59c748f8a6">More...</a><br /></td></tr>
  92. <tr class="separator:ga3f648fc205467792dc6d8c59c748f8a6"><td class="memSeparator" colspan="2">&#160;</td></tr>
  93. <tr class="memitem:ga896d806b72e390eb953786cca3632ec9"><td class="memTemplParams" colspan="2">template&lt;precision P, template&lt; typename, precision &gt; class vecType&gt; </td></tr>
  94. <tr class="memitem:ga896d806b72e390eb953786cca3632ec9"><td class="memTemplItemLeft" align="right" valign="top">GLM_FUNC_DECL vecType&lt; uint16, P &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="a00171.html#ga896d806b72e390eb953786cca3632ec9">packHalf</a> (vecType&lt; float, P &gt; const &amp;v)</td></tr>
  95. <tr class="memdesc:ga896d806b72e390eb953786cca3632ec9"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns an unsigned integer vector obtained by converting the components of a floating-point vector to the 16-bit floating-point representation found in the OpenGL Specification. <a href="a00171.html#ga896d806b72e390eb953786cca3632ec9">More...</a><br /></td></tr>
  96. <tr class="separator:ga896d806b72e390eb953786cca3632ec9"><td class="memSeparator" colspan="2">&#160;</td></tr>
  97. <tr class="memitem:ga43f2093b6ff192a79058ff7834fc3528"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint16&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga43f2093b6ff192a79058ff7834fc3528">packHalf1x16</a> (float v)</td></tr>
  98. <tr class="memdesc:ga43f2093b6ff192a79058ff7834fc3528"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns an unsigned integer obtained by converting the components of a floating-point scalar to the 16-bit floating-point representation found in the OpenGL Specification, and then packing this 16-bit value into a 16-bit unsigned integer. <a href="a00171.html#ga43f2093b6ff192a79058ff7834fc3528">More...</a><br /></td></tr>
  99. <tr class="separator:ga43f2093b6ff192a79058ff7834fc3528"><td class="memSeparator" colspan="2">&#160;</td></tr>
  100. <tr class="memitem:gafe2f7b39caf8f5ec555e1c059ec530e6"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint64&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#gafe2f7b39caf8f5ec555e1c059ec530e6">packHalf4x16</a> (vec4 const &amp;v)</td></tr>
  101. <tr class="memdesc:gafe2f7b39caf8f5ec555e1c059ec530e6"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns an unsigned integer obtained by converting the components of a four-component floating-point vector to the 16-bit floating-point representation found in the OpenGL Specification, and then packing these four 16-bit values into a 64-bit unsigned integer. <a href="a00171.html#gafe2f7b39caf8f5ec555e1c059ec530e6">More...</a><br /></td></tr>
  102. <tr class="separator:gafe2f7b39caf8f5ec555e1c059ec530e6"><td class="memSeparator" colspan="2">&#160;</td></tr>
  103. <tr class="memitem:ga06ecb6afb902dba45419008171db9023"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint32&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga06ecb6afb902dba45419008171db9023">packI3x10_1x2</a> (ivec4 const &amp;v)</td></tr>
  104. <tr class="memdesc:ga06ecb6afb902dba45419008171db9023"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns an unsigned integer obtained by converting the components of a four-component signed integer vector to the 10-10-10-2-bit signed integer representation found in the OpenGL Specification, and then packing these four values into a 32-bit unsigned integer. <a href="a00171.html#ga06ecb6afb902dba45419008171db9023">More...</a><br /></td></tr>
  105. <tr class="separator:ga06ecb6afb902dba45419008171db9023"><td class="memSeparator" colspan="2">&#160;</td></tr>
  106. <tr class="memitem:ga540fc5d8654b7bcfe207ac2491f161d1"><td class="memTemplParams" colspan="2">template&lt;typename T , precision P&gt; </td></tr>
  107. <tr class="memitem:ga540fc5d8654b7bcfe207ac2491f161d1"><td class="memTemplItemLeft" align="right" valign="top">GLM_FUNC_DECL tvec4&lt; T, P &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="a00171.html#ga540fc5d8654b7bcfe207ac2491f161d1">packRGBM</a> (tvec3&lt; T, P &gt; const &amp;rgb)</td></tr>
  108. <tr class="memdesc:ga540fc5d8654b7bcfe207ac2491f161d1"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns an unsigned integer vector obtained by converting the components of a floating-point vector to the 16-bit floating-point representation found in the OpenGL Specification. <a href="a00171.html#ga540fc5d8654b7bcfe207ac2491f161d1">More...</a><br /></td></tr>
  109. <tr class="separator:ga540fc5d8654b7bcfe207ac2491f161d1"><td class="memSeparator" colspan="2">&#160;</td></tr>
  110. <tr class="memitem:ga1be760860697db386b36513aeafe9d5e"><td class="memTemplParams" colspan="2">template&lt;typename intType , typename floatType , precision P, template&lt; typename, precision &gt; class vecType&gt; </td></tr>
  111. <tr class="memitem:ga1be760860697db386b36513aeafe9d5e"><td class="memTemplItemLeft" align="right" valign="top">GLM_FUNC_DECL vecType&lt; intType, P &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="a00171.html#ga1be760860697db386b36513aeafe9d5e">packSnorm</a> (vecType&lt; floatType, P &gt; const &amp;v)</td></tr>
  112. <tr class="memdesc:ga1be760860697db386b36513aeafe9d5e"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert each component of the normalized floating-point vector into signed integer values. <a href="a00171.html#ga1be760860697db386b36513aeafe9d5e">More...</a><br /></td></tr>
  113. <tr class="separator:ga1be760860697db386b36513aeafe9d5e"><td class="memSeparator" colspan="2">&#160;</td></tr>
  114. <tr class="memitem:gab22f8bcfdb5fc65af4701b25f143c1af"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint16&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#gab22f8bcfdb5fc65af4701b25f143c1af">packSnorm1x16</a> (float v)</td></tr>
  115. <tr class="memdesc:gab22f8bcfdb5fc65af4701b25f143c1af"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, converts the normalized floating-point value v into 16-bit integer value. <a href="a00171.html#gab22f8bcfdb5fc65af4701b25f143c1af">More...</a><br /></td></tr>
  116. <tr class="separator:gab22f8bcfdb5fc65af4701b25f143c1af"><td class="memSeparator" colspan="2">&#160;</td></tr>
  117. <tr class="memitem:gae3592e0795e62aaa1865b3a10496a7a1"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint8&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#gae3592e0795e62aaa1865b3a10496a7a1">packSnorm1x8</a> (float s)</td></tr>
  118. <tr class="memdesc:gae3592e0795e62aaa1865b3a10496a7a1"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, converts the normalized floating-point value v into 8-bit integer value. <a href="a00171.html#gae3592e0795e62aaa1865b3a10496a7a1">More...</a><br /></td></tr>
  119. <tr class="separator:gae3592e0795e62aaa1865b3a10496a7a1"><td class="memSeparator" colspan="2">&#160;</td></tr>
  120. <tr class="memitem:ga6be3cfb2cce3702f03e91bbeb5286d7e"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint16&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga6be3cfb2cce3702f03e91bbeb5286d7e">packSnorm2x8</a> (vec2 const &amp;v)</td></tr>
  121. <tr class="memdesc:ga6be3cfb2cce3702f03e91bbeb5286d7e"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, converts each component of the normalized floating-point value v into 8-bit integer values. <a href="a00171.html#ga6be3cfb2cce3702f03e91bbeb5286d7e">More...</a><br /></td></tr>
  122. <tr class="separator:ga6be3cfb2cce3702f03e91bbeb5286d7e"><td class="memSeparator" colspan="2">&#160;</td></tr>
  123. <tr class="memitem:gab997545661877d2c7362a5084d3897d3"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint32&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#gab997545661877d2c7362a5084d3897d3">packSnorm3x10_1x2</a> (vec4 const &amp;v)</td></tr>
  124. <tr class="memdesc:gab997545661877d2c7362a5084d3897d3"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, converts the first three components of the normalized floating-point value v into 10-bit signed integer values. <a href="a00171.html#gab997545661877d2c7362a5084d3897d3">More...</a><br /></td></tr>
  125. <tr class="separator:gab997545661877d2c7362a5084d3897d3"><td class="memSeparator" colspan="2">&#160;</td></tr>
  126. <tr class="memitem:ga358943934d21da947d5bcc88c2ab7832"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint64&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga358943934d21da947d5bcc88c2ab7832">packSnorm4x16</a> (vec4 const &amp;v)</td></tr>
  127. <tr class="memdesc:ga358943934d21da947d5bcc88c2ab7832"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, converts each component of the normalized floating-point value v into 16-bit integer values. <a href="a00171.html#ga358943934d21da947d5bcc88c2ab7832">More...</a><br /></td></tr>
  128. <tr class="separator:ga358943934d21da947d5bcc88c2ab7832"><td class="memSeparator" colspan="2">&#160;</td></tr>
  129. <tr class="memitem:gada3d88d59f0f458f9c51a9fd359a4bc0"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint32&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#gada3d88d59f0f458f9c51a9fd359a4bc0">packU3x10_1x2</a> (uvec4 const &amp;v)</td></tr>
  130. <tr class="memdesc:gada3d88d59f0f458f9c51a9fd359a4bc0"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns an unsigned integer obtained by converting the components of a four-component unsigned integer vector to the 10-10-10-2-bit unsigned integer representation found in the OpenGL Specification, and then packing these four values into a 32-bit unsigned integer. <a href="a00171.html#gada3d88d59f0f458f9c51a9fd359a4bc0">More...</a><br /></td></tr>
  131. <tr class="separator:gada3d88d59f0f458f9c51a9fd359a4bc0"><td class="memSeparator" colspan="2">&#160;</td></tr>
  132. <tr class="memitem:gacb9a3df68172c1193c9d701a3fa4d88b"><td class="memTemplParams" colspan="2">template&lt;typename uintType , typename floatType , precision P, template&lt; typename, precision &gt; class vecType&gt; </td></tr>
  133. <tr class="memitem:gacb9a3df68172c1193c9d701a3fa4d88b"><td class="memTemplItemLeft" align="right" valign="top">GLM_FUNC_DECL vecType&lt; uintType, P &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="a00171.html#gacb9a3df68172c1193c9d701a3fa4d88b">packUnorm</a> (vecType&lt; floatType, P &gt; const &amp;v)</td></tr>
  134. <tr class="memdesc:gacb9a3df68172c1193c9d701a3fa4d88b"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert each component of the normalized floating-point vector into unsigned integer values. <a href="a00171.html#gacb9a3df68172c1193c9d701a3fa4d88b">More...</a><br /></td></tr>
  135. <tr class="separator:gacb9a3df68172c1193c9d701a3fa4d88b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  136. <tr class="memitem:ga9f82737bf2a44bedff1d286b76837886"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint16&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga9f82737bf2a44bedff1d286b76837886">packUnorm1x16</a> (float v)</td></tr>
  137. <tr class="memdesc:ga9f82737bf2a44bedff1d286b76837886"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, converts the normalized floating-point value v into a 16-bit integer value. <a href="a00171.html#ga9f82737bf2a44bedff1d286b76837886">More...</a><br /></td></tr>
  138. <tr class="separator:ga9f82737bf2a44bedff1d286b76837886"><td class="memSeparator" colspan="2">&#160;</td></tr>
  139. <tr class="memitem:ga768e0337dd6246773f14aa0a421fe9a8"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint16&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga768e0337dd6246773f14aa0a421fe9a8">packUnorm1x5_1x6_1x5</a> (vec3 const &amp;v)</td></tr>
  140. <tr class="memdesc:ga768e0337dd6246773f14aa0a421fe9a8"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert each component of the normalized floating-point vector into unsigned integer values. <a href="a00171.html#ga768e0337dd6246773f14aa0a421fe9a8">More...</a><br /></td></tr>
  141. <tr class="separator:ga768e0337dd6246773f14aa0a421fe9a8"><td class="memSeparator" colspan="2">&#160;</td></tr>
  142. <tr class="memitem:ga4b2fa60df3460403817d28b082ee0736"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint8&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga4b2fa60df3460403817d28b082ee0736">packUnorm1x8</a> (float v)</td></tr>
  143. <tr class="memdesc:ga4b2fa60df3460403817d28b082ee0736"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, converts the normalized floating-point value v into a 8-bit integer value. <a href="a00171.html#ga4b2fa60df3460403817d28b082ee0736">More...</a><br /></td></tr>
  144. <tr class="separator:ga4b2fa60df3460403817d28b082ee0736"><td class="memSeparator" colspan="2">&#160;</td></tr>
  145. <tr class="memitem:ga7f9abdb50f9be1aa1c14912504a0d98d"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint8&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga7f9abdb50f9be1aa1c14912504a0d98d">packUnorm2x3_1x2</a> (vec3 const &amp;v)</td></tr>
  146. <tr class="memdesc:ga7f9abdb50f9be1aa1c14912504a0d98d"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert each component of the normalized floating-point vector into unsigned integer values. <a href="a00171.html#ga7f9abdb50f9be1aa1c14912504a0d98d">More...</a><br /></td></tr>
  147. <tr class="separator:ga7f9abdb50f9be1aa1c14912504a0d98d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  148. <tr class="memitem:gab6bbd5be3b8e6db538ecb33a7844481c"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint8&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#gab6bbd5be3b8e6db538ecb33a7844481c">packUnorm2x4</a> (vec2 const &amp;v)</td></tr>
  149. <tr class="memdesc:gab6bbd5be3b8e6db538ecb33a7844481c"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert each component of the normalized floating-point vector into unsigned integer values. <a href="a00171.html#gab6bbd5be3b8e6db538ecb33a7844481c">More...</a><br /></td></tr>
  150. <tr class="separator:gab6bbd5be3b8e6db538ecb33a7844481c"><td class="memSeparator" colspan="2">&#160;</td></tr>
  151. <tr class="memitem:ga9a666b1c688ab54100061ed06526de6e"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint16&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga9a666b1c688ab54100061ed06526de6e">packUnorm2x8</a> (vec2 const &amp;v)</td></tr>
  152. <tr class="memdesc:ga9a666b1c688ab54100061ed06526de6e"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, converts each component of the normalized floating-point value v into 8-bit integer values. <a href="a00171.html#ga9a666b1c688ab54100061ed06526de6e">More...</a><br /></td></tr>
  153. <tr class="separator:ga9a666b1c688ab54100061ed06526de6e"><td class="memSeparator" colspan="2">&#160;</td></tr>
  154. <tr class="memitem:ga8a1ee625d2707c60530fb3fca2980b19"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint32&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga8a1ee625d2707c60530fb3fca2980b19">packUnorm3x10_1x2</a> (vec4 const &amp;v)</td></tr>
  155. <tr class="memdesc:ga8a1ee625d2707c60530fb3fca2980b19"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, converts the first three components of the normalized floating-point value v into 10-bit unsigned integer values. <a href="a00171.html#ga8a1ee625d2707c60530fb3fca2980b19">More...</a><br /></td></tr>
  156. <tr class="separator:ga8a1ee625d2707c60530fb3fca2980b19"><td class="memSeparator" colspan="2">&#160;</td></tr>
  157. <tr class="memitem:gaec4112086d7fb133bea104a7c237de52"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint16&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#gaec4112086d7fb133bea104a7c237de52">packUnorm3x5_1x1</a> (vec4 const &amp;v)</td></tr>
  158. <tr class="memdesc:gaec4112086d7fb133bea104a7c237de52"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert each component of the normalized floating-point vector into unsigned integer values. <a href="a00171.html#gaec4112086d7fb133bea104a7c237de52">More...</a><br /></td></tr>
  159. <tr class="separator:gaec4112086d7fb133bea104a7c237de52"><td class="memSeparator" colspan="2">&#160;</td></tr>
  160. <tr class="memitem:ga1f63c264e7ab63264e2b2a99fd393897"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint64&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga1f63c264e7ab63264e2b2a99fd393897">packUnorm4x16</a> (vec4 const &amp;v)</td></tr>
  161. <tr class="memdesc:ga1f63c264e7ab63264e2b2a99fd393897"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, converts each component of the normalized floating-point value v into 16-bit integer values. <a href="a00171.html#ga1f63c264e7ab63264e2b2a99fd393897">More...</a><br /></td></tr>
  162. <tr class="separator:ga1f63c264e7ab63264e2b2a99fd393897"><td class="memSeparator" colspan="2">&#160;</td></tr>
  163. <tr class="memitem:gad3e7e3ce521513584a53aedc5f9765c1"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uint16&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#gad3e7e3ce521513584a53aedc5f9765c1">packUnorm4x4</a> (vec4 const &amp;v)</td></tr>
  164. <tr class="memdesc:gad3e7e3ce521513584a53aedc5f9765c1"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert each component of the normalized floating-point vector into unsigned integer values. <a href="a00171.html#gad3e7e3ce521513584a53aedc5f9765c1">More...</a><br /></td></tr>
  165. <tr class="separator:gad3e7e3ce521513584a53aedc5f9765c1"><td class="memSeparator" colspan="2">&#160;</td></tr>
  166. <tr class="memitem:ga2b1fd1e854705b1345e98409e0a25e50"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL vec3&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga2b1fd1e854705b1345e98409e0a25e50">unpackF2x11_1x10</a> (uint32 p)</td></tr>
  167. <tr class="memdesc:ga2b1fd1e854705b1345e98409e0a25e50"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, unpacks a single 32-bit unsigned integer p into two 11-bit signless floating-point values and one 10-bit signless floating-point value . <a href="a00171.html#ga2b1fd1e854705b1345e98409e0a25e50">More...</a><br /></td></tr>
  168. <tr class="separator:ga2b1fd1e854705b1345e98409e0a25e50"><td class="memSeparator" colspan="2">&#160;</td></tr>
  169. <tr class="memitem:gab9e60ebe3ad3eeced6a9ec6eb876d74e"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL vec3&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#gab9e60ebe3ad3eeced6a9ec6eb876d74e">unpackF3x9_E1x5</a> (uint32 p)</td></tr>
  170. <tr class="memdesc:gab9e60ebe3ad3eeced6a9ec6eb876d74e"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, unpacks a single 32-bit unsigned integer p into two 11-bit signless floating-point values and one 10-bit signless floating-point value . <a href="a00171.html#gab9e60ebe3ad3eeced6a9ec6eb876d74e">More...</a><br /></td></tr>
  171. <tr class="separator:gab9e60ebe3ad3eeced6a9ec6eb876d74e"><td class="memSeparator" colspan="2">&#160;</td></tr>
  172. <tr class="memitem:gaf3f9387834f8d8beadfe723c1dd247a7"><td class="memTemplParams" colspan="2">template&lt;precision P, template&lt; typename, precision &gt; class vecType&gt; </td></tr>
  173. <tr class="memitem:gaf3f9387834f8d8beadfe723c1dd247a7"><td class="memTemplItemLeft" align="right" valign="top">GLM_FUNC_DECL vecType&lt; float, P &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="a00171.html#gaf3f9387834f8d8beadfe723c1dd247a7">unpackHalf</a> (vecType&lt; uint16, P &gt; const &amp;p)</td></tr>
  174. <tr class="memdesc:gaf3f9387834f8d8beadfe723c1dd247a7"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns a floating-point vector with components obtained by reinterpreting an integer vector as 16-bit floating-point numbers and converting them to 32-bit floating-point values. <a href="a00171.html#gaf3f9387834f8d8beadfe723c1dd247a7">More...</a><br /></td></tr>
  175. <tr class="separator:gaf3f9387834f8d8beadfe723c1dd247a7"><td class="memSeparator" colspan="2">&#160;</td></tr>
  176. <tr class="memitem:gac37dedaba24b00adb4ec6e8f92c19dbf"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#gac37dedaba24b00adb4ec6e8f92c19dbf">unpackHalf1x16</a> (uint16 v)</td></tr>
  177. <tr class="memdesc:gac37dedaba24b00adb4ec6e8f92c19dbf"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns a floating-point scalar with components obtained by unpacking a 16-bit unsigned integer into a 16-bit value, interpreted as a 16-bit floating-point number according to the OpenGL Specification, and converting it to 32-bit floating-point values. <a href="a00171.html#gac37dedaba24b00adb4ec6e8f92c19dbf">More...</a><br /></td></tr>
  178. <tr class="separator:gac37dedaba24b00adb4ec6e8f92c19dbf"><td class="memSeparator" colspan="2">&#160;</td></tr>
  179. <tr class="memitem:ga57dfc41b2eb20b0ac00efae7d9c49dcd"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL vec4&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga57dfc41b2eb20b0ac00efae7d9c49dcd">unpackHalf4x16</a> (uint64 p)</td></tr>
  180. <tr class="memdesc:ga57dfc41b2eb20b0ac00efae7d9c49dcd"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns a four-component floating-point vector with components obtained by unpacking a 64-bit unsigned integer into four 16-bit values, interpreting those values as 16-bit floating-point numbers according to the OpenGL Specification, and converting them to 32-bit floating-point values. <a href="a00171.html#ga57dfc41b2eb20b0ac00efae7d9c49dcd">More...</a><br /></td></tr>
  181. <tr class="separator:ga57dfc41b2eb20b0ac00efae7d9c49dcd"><td class="memSeparator" colspan="2">&#160;</td></tr>
  182. <tr class="memitem:ga9a05330e5490be0908d3b117d82aff56"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL ivec4&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga9a05330e5490be0908d3b117d82aff56">unpackI3x10_1x2</a> (uint32 p)</td></tr>
  183. <tr class="memdesc:ga9a05330e5490be0908d3b117d82aff56"><td class="mdescLeft">&#160;</td><td class="mdescRight">Unpacks a single 32-bit unsigned integer p into three 10-bit and one 2-bit signed integers. <a href="a00171.html#ga9a05330e5490be0908d3b117d82aff56">More...</a><br /></td></tr>
  184. <tr class="separator:ga9a05330e5490be0908d3b117d82aff56"><td class="memSeparator" colspan="2">&#160;</td></tr>
  185. <tr class="memitem:ga44274002723e379ad5c4ece8300a9308"><td class="memTemplParams" colspan="2">template&lt;typename T , precision P&gt; </td></tr>
  186. <tr class="memitem:ga44274002723e379ad5c4ece8300a9308"><td class="memTemplItemLeft" align="right" valign="top">GLM_FUNC_DECL tvec3&lt; T, P &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="a00171.html#ga44274002723e379ad5c4ece8300a9308">unpackRGBM</a> (tvec4&lt; T, P &gt; const &amp;rgbm)</td></tr>
  187. <tr class="memdesc:ga44274002723e379ad5c4ece8300a9308"><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns a floating-point vector with components obtained by reinterpreting an integer vector as 16-bit floating-point numbers and converting them to 32-bit floating-point values. <a href="a00171.html#ga44274002723e379ad5c4ece8300a9308">More...</a><br /></td></tr>
  188. <tr class="separator:ga44274002723e379ad5c4ece8300a9308"><td class="memSeparator" colspan="2">&#160;</td></tr>
  189. <tr class="memitem:ga63eeec0d416e48462f341f4a7a9a45fe"><td class="memTemplParams" colspan="2">template&lt;typename intType , typename floatType , precision P, template&lt; typename, precision &gt; class vecType&gt; </td></tr>
  190. <tr class="memitem:ga63eeec0d416e48462f341f4a7a9a45fe"><td class="memTemplItemLeft" align="right" valign="top">GLM_FUNC_DECL vecType&lt; floatType, P &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="a00171.html#ga63eeec0d416e48462f341f4a7a9a45fe">unpackSnorm</a> (vecType&lt; intType, P &gt; const &amp;v)</td></tr>
  191. <tr class="memdesc:ga63eeec0d416e48462f341f4a7a9a45fe"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert each signed integer components of a vector to normalized floating-point values. <a href="a00171.html#ga63eeec0d416e48462f341f4a7a9a45fe">More...</a><br /></td></tr>
  192. <tr class="separator:ga63eeec0d416e48462f341f4a7a9a45fe"><td class="memSeparator" colspan="2">&#160;</td></tr>
  193. <tr class="memitem:ga96dd15002370627a443c835ab03a766c"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga96dd15002370627a443c835ab03a766c">unpackSnorm1x16</a> (uint16 p)</td></tr>
  194. <tr class="memdesc:ga96dd15002370627a443c835ab03a766c"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, unpacks a single 16-bit unsigned integer p into a single 16-bit signed integers. <a href="a00171.html#ga96dd15002370627a443c835ab03a766c">More...</a><br /></td></tr>
  195. <tr class="separator:ga96dd15002370627a443c835ab03a766c"><td class="memSeparator" colspan="2">&#160;</td></tr>
  196. <tr class="memitem:ga4851ff86678aa1c7ace9d67846894285"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga4851ff86678aa1c7ace9d67846894285">unpackSnorm1x8</a> (uint8 p)</td></tr>
  197. <tr class="memdesc:ga4851ff86678aa1c7ace9d67846894285"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, unpacks a single 8-bit unsigned integer p into a single 8-bit signed integers. <a href="a00171.html#ga4851ff86678aa1c7ace9d67846894285">More...</a><br /></td></tr>
  198. <tr class="separator:ga4851ff86678aa1c7ace9d67846894285"><td class="memSeparator" colspan="2">&#160;</td></tr>
  199. <tr class="memitem:ga8b128e89be449fc71336968a66bf6e1a"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL vec2&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga8b128e89be449fc71336968a66bf6e1a">unpackSnorm2x8</a> (uint16 p)</td></tr>
  200. <tr class="memdesc:ga8b128e89be449fc71336968a66bf6e1a"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, unpacks a single 16-bit unsigned integer p into a pair of 8-bit signed integers. <a href="a00171.html#ga8b128e89be449fc71336968a66bf6e1a">More...</a><br /></td></tr>
  201. <tr class="separator:ga8b128e89be449fc71336968a66bf6e1a"><td class="memSeparator" colspan="2">&#160;</td></tr>
  202. <tr class="memitem:ga7a4fbf79be9740e3c57737bc2af05e5b"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL vec4&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga7a4fbf79be9740e3c57737bc2af05e5b">unpackSnorm3x10_1x2</a> (uint32 p)</td></tr>
  203. <tr class="memdesc:ga7a4fbf79be9740e3c57737bc2af05e5b"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, unpacks a single 32-bit unsigned integer p into four 16-bit signed integers. <a href="a00171.html#ga7a4fbf79be9740e3c57737bc2af05e5b">More...</a><br /></td></tr>
  204. <tr class="separator:ga7a4fbf79be9740e3c57737bc2af05e5b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  205. <tr class="memitem:gaaddf9c353528fe896106f7181219c7f4"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL vec4&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#gaaddf9c353528fe896106f7181219c7f4">unpackSnorm4x16</a> (uint64 p)</td></tr>
  206. <tr class="memdesc:gaaddf9c353528fe896106f7181219c7f4"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, unpacks a single 64-bit unsigned integer p into four 16-bit signed integers. <a href="a00171.html#gaaddf9c353528fe896106f7181219c7f4">More...</a><br /></td></tr>
  207. <tr class="separator:gaaddf9c353528fe896106f7181219c7f4"><td class="memSeparator" colspan="2">&#160;</td></tr>
  208. <tr class="memitem:ga48df3042a7d079767f5891a1bfd8a60a"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL uvec4&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga48df3042a7d079767f5891a1bfd8a60a">unpackU3x10_1x2</a> (uint32 p)</td></tr>
  209. <tr class="memdesc:ga48df3042a7d079767f5891a1bfd8a60a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Unpacks a single 32-bit unsigned integer p into three 10-bit and one 2-bit unsigned integers. <a href="a00171.html#ga48df3042a7d079767f5891a1bfd8a60a">More...</a><br /></td></tr>
  210. <tr class="separator:ga48df3042a7d079767f5891a1bfd8a60a"><td class="memSeparator" colspan="2">&#160;</td></tr>
  211. <tr class="memitem:gad3d7e1ec7fcfb7ae341658e2ce1c3bd9"><td class="memTemplParams" colspan="2">template&lt;typename uintType , typename floatType , precision P, template&lt; typename, precision &gt; class vecType&gt; </td></tr>
  212. <tr class="memitem:gad3d7e1ec7fcfb7ae341658e2ce1c3bd9"><td class="memTemplItemLeft" align="right" valign="top">GLM_FUNC_DECL vecType&lt; floatType, P &gt;&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="a00171.html#gad3d7e1ec7fcfb7ae341658e2ce1c3bd9">unpackUnorm</a> (vecType&lt; uintType, P &gt; const &amp;v)</td></tr>
  213. <tr class="memdesc:gad3d7e1ec7fcfb7ae341658e2ce1c3bd9"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert each unsigned integer components of a vector to normalized floating-point values. <a href="a00171.html#gad3d7e1ec7fcfb7ae341658e2ce1c3bd9">More...</a><br /></td></tr>
  214. <tr class="separator:gad3d7e1ec7fcfb7ae341658e2ce1c3bd9"><td class="memSeparator" colspan="2">&#160;</td></tr>
  215. <tr class="memitem:ga83d34160a5cb7bcb5339823210fc7501"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga83d34160a5cb7bcb5339823210fc7501">unpackUnorm1x16</a> (uint16 p)</td></tr>
  216. <tr class="memdesc:ga83d34160a5cb7bcb5339823210fc7501"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, unpacks a single 16-bit unsigned integer p into a of 16-bit unsigned integers. <a href="a00171.html#ga83d34160a5cb7bcb5339823210fc7501">More...</a><br /></td></tr>
  217. <tr class="separator:ga83d34160a5cb7bcb5339823210fc7501"><td class="memSeparator" colspan="2">&#160;</td></tr>
  218. <tr class="memitem:gab3bc08ecfc0f3339be93fb2b3b56d88a"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL vec3&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#gab3bc08ecfc0f3339be93fb2b3b56d88a">unpackUnorm1x5_1x6_1x5</a> (uint16 p)</td></tr>
  219. <tr class="memdesc:gab3bc08ecfc0f3339be93fb2b3b56d88a"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert each unsigned integer components of a vector to normalized floating-point values. <a href="a00171.html#gab3bc08ecfc0f3339be93fb2b3b56d88a">More...</a><br /></td></tr>
  220. <tr class="separator:gab3bc08ecfc0f3339be93fb2b3b56d88a"><td class="memSeparator" colspan="2">&#160;</td></tr>
  221. <tr class="memitem:ga1319207e30874fb4931a9ee913983ee1"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL float&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga1319207e30874fb4931a9ee913983ee1">unpackUnorm1x8</a> (uint8 p)</td></tr>
  222. <tr class="memdesc:ga1319207e30874fb4931a9ee913983ee1"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert a single 8-bit integer to a normalized floating-point value. <a href="a00171.html#ga1319207e30874fb4931a9ee913983ee1">More...</a><br /></td></tr>
  223. <tr class="separator:ga1319207e30874fb4931a9ee913983ee1"><td class="memSeparator" colspan="2">&#160;</td></tr>
  224. <tr class="memitem:ga6abd5a9014df3b5ce4059008d2491260"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL vec3&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga6abd5a9014df3b5ce4059008d2491260">unpackUnorm2x3_1x2</a> (uint8 p)</td></tr>
  225. <tr class="memdesc:ga6abd5a9014df3b5ce4059008d2491260"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert each unsigned integer components of a vector to normalized floating-point values. <a href="a00171.html#ga6abd5a9014df3b5ce4059008d2491260">More...</a><br /></td></tr>
  226. <tr class="separator:ga6abd5a9014df3b5ce4059008d2491260"><td class="memSeparator" colspan="2">&#160;</td></tr>
  227. <tr class="memitem:ga2e50476132fe5f27f08e273d9c70d85b"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL vec2&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga2e50476132fe5f27f08e273d9c70d85b">unpackUnorm2x4</a> (uint8 p)</td></tr>
  228. <tr class="memdesc:ga2e50476132fe5f27f08e273d9c70d85b"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert each unsigned integer components of a vector to normalized floating-point values. <a href="a00171.html#ga2e50476132fe5f27f08e273d9c70d85b">More...</a><br /></td></tr>
  229. <tr class="separator:ga2e50476132fe5f27f08e273d9c70d85b"><td class="memSeparator" colspan="2">&#160;</td></tr>
  230. <tr class="memitem:ga637cbe3913dd95c6e7b4c99c61bd611f"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL vec2&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga637cbe3913dd95c6e7b4c99c61bd611f">unpackUnorm2x8</a> (uint16 p)</td></tr>
  231. <tr class="memdesc:ga637cbe3913dd95c6e7b4c99c61bd611f"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, unpacks a single 16-bit unsigned integer p into a pair of 8-bit unsigned integers. <a href="a00171.html#ga637cbe3913dd95c6e7b4c99c61bd611f">More...</a><br /></td></tr>
  232. <tr class="separator:ga637cbe3913dd95c6e7b4c99c61bd611f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  233. <tr class="memitem:ga5156d3060355fe332865da2c7f78815f"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL vec4&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga5156d3060355fe332865da2c7f78815f">unpackUnorm3x10_1x2</a> (uint32 p)</td></tr>
  234. <tr class="memdesc:ga5156d3060355fe332865da2c7f78815f"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, unpacks a single 32-bit unsigned integer p into four 16-bit signed integers. <a href="a00171.html#ga5156d3060355fe332865da2c7f78815f">More...</a><br /></td></tr>
  235. <tr class="separator:ga5156d3060355fe332865da2c7f78815f"><td class="memSeparator" colspan="2">&#160;</td></tr>
  236. <tr class="memitem:ga5ff95ff5bc16f396432ab67243dbae4d"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL vec4&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga5ff95ff5bc16f396432ab67243dbae4d">unpackUnorm3x5_1x1</a> (uint16 p)</td></tr>
  237. <tr class="memdesc:ga5ff95ff5bc16f396432ab67243dbae4d"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert each unsigned integer components of a vector to normalized floating-point values. <a href="a00171.html#ga5ff95ff5bc16f396432ab67243dbae4d">More...</a><br /></td></tr>
  238. <tr class="separator:ga5ff95ff5bc16f396432ab67243dbae4d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  239. <tr class="memitem:ga2ae149c5d2473ac1e5f347bb654a242d"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL vec4&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#ga2ae149c5d2473ac1e5f347bb654a242d">unpackUnorm4x16</a> (uint64 p)</td></tr>
  240. <tr class="memdesc:ga2ae149c5d2473ac1e5f347bb654a242d"><td class="mdescLeft">&#160;</td><td class="mdescRight">First, unpacks a single 64-bit unsigned integer p into four 16-bit unsigned integers. <a href="a00171.html#ga2ae149c5d2473ac1e5f347bb654a242d">More...</a><br /></td></tr>
  241. <tr class="separator:ga2ae149c5d2473ac1e5f347bb654a242d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  242. <tr class="memitem:gac58ee89d0e224bb6df5e8bbb18843a2d"><td class="memItemLeft" align="right" valign="top">GLM_FUNC_DECL vec4&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="a00171.html#gac58ee89d0e224bb6df5e8bbb18843a2d">unpackUnorm4x4</a> (uint16 p)</td></tr>
  243. <tr class="memdesc:gac58ee89d0e224bb6df5e8bbb18843a2d"><td class="mdescLeft">&#160;</td><td class="mdescRight">Convert each unsigned integer components of a vector to normalized floating-point values. <a href="a00171.html#gac58ee89d0e224bb6df5e8bbb18843a2d">More...</a><br /></td></tr>
  244. <tr class="separator:gac58ee89d0e224bb6df5e8bbb18843a2d"><td class="memSeparator" colspan="2">&#160;</td></tr>
  245. </table>
  246. <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
  247. <p>This extension provides a set of function to convert vertors to packed formats. </p>
  248. <p>&lt;<a class="el" href="a00081.html" title="GLM_GTC_packing ">glm/gtc/packing.hpp</a>&gt; need to be included to use these features. </p>
  249. <h2 class="groupheader">Function Documentation</h2>
  250. <a class="anchor" id="ga4944ad465ff950e926d49621f916c78d"></a>
  251. <div class="memitem">
  252. <div class="memproto">
  253. <table class="memname">
  254. <tr>
  255. <td class="memname">GLM_FUNC_DECL uint32 glm::packF2x11_1x10 </td>
  256. <td>(</td>
  257. <td class="paramtype"><a class="el" href="a00156.html#gaa8ea2429bb3cb41a715258a447f39897">vec3</a> const &amp;&#160;</td>
  258. <td class="paramname"><em>v</em></td><td>)</td>
  259. <td></td>
  260. </tr>
  261. </table>
  262. </div><div class="memdoc">
  263. <p>First, converts the first two components of the normalized floating-point value v into 11-bit signless floating-point values. </p>
  264. <p>Then, converts the third component of the normalized floating-point value v into a 10-bit signless floating-point value. Then, the results are packed into the returned 32-bit unsigned integer.</p>
  265. <p>The first vector component specifies the 11 least-significant bits of the result; the last component specifies the 10 most-significant bits.</p>
  266. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  267. <dd>
  268. vec3 unpackF2x11_1x10(uint32 const &amp; p) </dd></dl>
  269. </div>
  270. </div>
  271. <a class="anchor" id="ga3f648fc205467792dc6d8c59c748f8a6"></a>
  272. <div class="memitem">
  273. <div class="memproto">
  274. <table class="memname">
  275. <tr>
  276. <td class="memname">GLM_FUNC_DECL uint32 glm::packF3x9_E1x5 </td>
  277. <td>(</td>
  278. <td class="paramtype"><a class="el" href="a00156.html#gaa8ea2429bb3cb41a715258a447f39897">vec3</a> const &amp;&#160;</td>
  279. <td class="paramname"><em>v</em></td><td>)</td>
  280. <td></td>
  281. </tr>
  282. </table>
  283. </div><div class="memdoc">
  284. <p>First, converts the first two components of the normalized floating-point value v into 11-bit signless floating-point values. </p>
  285. <p>Then, converts the third component of the normalized floating-point value v into a 10-bit signless floating-point value. Then, the results are packed into the returned 32-bit unsigned integer.</p>
  286. <p>The first vector component specifies the 11 least-significant bits of the result; the last component specifies the 10 most-significant bits.</p>
  287. <p>packF3x9_E1x5 allows encoding into RGBE / RGB9E5 format</p>
  288. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  289. <dd>
  290. vec3 unpackF3x9_E1x5(uint32 const &amp; p) </dd></dl>
  291. </div>
  292. </div>
  293. <a class="anchor" id="ga896d806b72e390eb953786cca3632ec9"></a>
  294. <div class="memitem">
  295. <div class="memproto">
  296. <table class="memname">
  297. <tr>
  298. <td class="memname">GLM_FUNC_DECL vecType&lt;uint16, P&gt; glm::packHalf </td>
  299. <td>(</td>
  300. <td class="paramtype">vecType&lt; float, P &gt; const &amp;&#160;</td>
  301. <td class="paramname"><em>v</em></td><td>)</td>
  302. <td></td>
  303. </tr>
  304. </table>
  305. </div><div class="memdoc">
  306. <p>Returns an unsigned integer vector obtained by converting the components of a floating-point vector to the 16-bit floating-point representation found in the OpenGL Specification. </p>
  307. <p>The first vector component specifies the 16 least-significant bits of the result; the forth component specifies the 16 most-significant bits.</p>
  308. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  309. <dd>
  310. vecType&lt;float, P&gt; unpackHalf(vecType&lt;uint16, P&gt; const &amp; p) </dd>
  311. <dd>
  312. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  313. </div>
  314. </div>
  315. <a class="anchor" id="ga43f2093b6ff192a79058ff7834fc3528"></a>
  316. <div class="memitem">
  317. <div class="memproto">
  318. <table class="memname">
  319. <tr>
  320. <td class="memname">GLM_FUNC_DECL uint16 glm::packHalf1x16 </td>
  321. <td>(</td>
  322. <td class="paramtype">float&#160;</td>
  323. <td class="paramname"><em>v</em></td><td>)</td>
  324. <td></td>
  325. </tr>
  326. </table>
  327. </div><div class="memdoc">
  328. <p>Returns an unsigned integer obtained by converting the components of a floating-point scalar to the 16-bit floating-point representation found in the OpenGL Specification, and then packing this 16-bit value into a 16-bit unsigned integer. </p>
  329. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  330. <dd>
  331. uint32 packHalf2x16(vec2 const &amp; v) </dd>
  332. <dd>
  333. uint64 packHalf4x16(vec4 const &amp; v) </dd>
  334. <dd>
  335. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/packHalf2x16.xml">GLSL packHalf2x16 man page</a> </dd>
  336. <dd>
  337. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  338. </div>
  339. </div>
  340. <a class="anchor" id="gafe2f7b39caf8f5ec555e1c059ec530e6"></a>
  341. <div class="memitem">
  342. <div class="memproto">
  343. <table class="memname">
  344. <tr>
  345. <td class="memname">GLM_FUNC_DECL uint64 glm::packHalf4x16 </td>
  346. <td>(</td>
  347. <td class="paramtype"><a class="el" href="a00156.html#gafbab23070ca47932487d25332adc7d7c">vec4</a> const &amp;&#160;</td>
  348. <td class="paramname"><em>v</em></td><td>)</td>
  349. <td></td>
  350. </tr>
  351. </table>
  352. </div><div class="memdoc">
  353. <p>Returns an unsigned integer obtained by converting the components of a four-component floating-point vector to the 16-bit floating-point representation found in the OpenGL Specification, and then packing these four 16-bit values into a 64-bit unsigned integer. </p>
  354. <p>The first vector component specifies the 16 least-significant bits of the result; the forth component specifies the 16 most-significant bits.</p>
  355. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  356. <dd>
  357. uint16 packHalf1x16(float const &amp; v) </dd>
  358. <dd>
  359. uint32 packHalf2x16(vec2 const &amp; v) </dd>
  360. <dd>
  361. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/packHalf2x16.xml">GLSL packHalf2x16 man page</a> </dd>
  362. <dd>
  363. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  364. </div>
  365. </div>
  366. <a class="anchor" id="ga06ecb6afb902dba45419008171db9023"></a>
  367. <div class="memitem">
  368. <div class="memproto">
  369. <table class="memname">
  370. <tr>
  371. <td class="memname">GLM_FUNC_DECL uint32 glm::packI3x10_1x2 </td>
  372. <td>(</td>
  373. <td class="paramtype"><a class="el" href="a00156.html#gaaa26c41d168dc00be0fe55f4d0a34224">ivec4</a> const &amp;&#160;</td>
  374. <td class="paramname"><em>v</em></td><td>)</td>
  375. <td></td>
  376. </tr>
  377. </table>
  378. </div><div class="memdoc">
  379. <p>Returns an unsigned integer obtained by converting the components of a four-component signed integer vector to the 10-10-10-2-bit signed integer representation found in the OpenGL Specification, and then packing these four values into a 32-bit unsigned integer. </p>
  380. <p>The first vector component specifies the 10 least-significant bits of the result; the forth component specifies the 2 most-significant bits.</p>
  381. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  382. <dd>
  383. uint32 packI3x10_1x2(uvec4 const &amp; v) </dd>
  384. <dd>
  385. uint32 packSnorm3x10_1x2(vec4 const &amp; v) </dd>
  386. <dd>
  387. uint32 packUnorm3x10_1x2(vec4 const &amp; v) </dd>
  388. <dd>
  389. ivec4 unpackI3x10_1x2(uint32 const &amp; p) </dd></dl>
  390. </div>
  391. </div>
  392. <a class="anchor" id="ga540fc5d8654b7bcfe207ac2491f161d1"></a>
  393. <div class="memitem">
  394. <div class="memproto">
  395. <table class="memname">
  396. <tr>
  397. <td class="memname">GLM_FUNC_DECL tvec4&lt;T, P&gt; glm::packRGBM </td>
  398. <td>(</td>
  399. <td class="paramtype">tvec3&lt; T, P &gt; const &amp;&#160;</td>
  400. <td class="paramname"><em>rgb</em></td><td>)</td>
  401. <td></td>
  402. </tr>
  403. </table>
  404. </div><div class="memdoc">
  405. <p>Returns an unsigned integer vector obtained by converting the components of a floating-point vector to the 16-bit floating-point representation found in the OpenGL Specification. </p>
  406. <p>The first vector component specifies the 16 least-significant bits of the result; the forth component specifies the 16 most-significant bits.</p>
  407. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  408. <dd>
  409. tvec3&lt;T, P&gt; unpackRGBM(tvec4&lt;T, P&gt; const &amp; p) </dd>
  410. <dd>
  411. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  412. </div>
  413. </div>
  414. <a class="anchor" id="ga1be760860697db386b36513aeafe9d5e"></a>
  415. <div class="memitem">
  416. <div class="memproto">
  417. <table class="memname">
  418. <tr>
  419. <td class="memname">GLM_FUNC_DECL vecType&lt;intType, P&gt; glm::packSnorm </td>
  420. <td>(</td>
  421. <td class="paramtype">vecType&lt; floatType, P &gt; const &amp;&#160;</td>
  422. <td class="paramname"><em>v</em></td><td>)</td>
  423. <td></td>
  424. </tr>
  425. </table>
  426. </div><div class="memdoc">
  427. <p>Convert each component of the normalized floating-point vector into signed integer values. </p>
  428. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  429. <dd>
  430. vecType&lt;floatType, P&gt; unpackSnorm(vecType&lt;intType, P&gt; const &amp; p); </dd></dl>
  431. </div>
  432. </div>
  433. <a class="anchor" id="gab22f8bcfdb5fc65af4701b25f143c1af"></a>
  434. <div class="memitem">
  435. <div class="memproto">
  436. <table class="memname">
  437. <tr>
  438. <td class="memname">GLM_FUNC_DECL uint16 glm::packSnorm1x16 </td>
  439. <td>(</td>
  440. <td class="paramtype">float&#160;</td>
  441. <td class="paramname"><em>v</em></td><td>)</td>
  442. <td></td>
  443. </tr>
  444. </table>
  445. </div><div class="memdoc">
  446. <p>First, converts the normalized floating-point value v into 16-bit integer value. </p>
  447. <p>Then, the results are packed into the returned 16-bit unsigned integer.</p>
  448. <p>The conversion to fixed point is done as follows: packSnorm1x8: round(clamp(s, -1, +1) * 32767.0)</p>
  449. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  450. <dd>
  451. uint32 packSnorm2x16(vec2 const &amp; v) </dd>
  452. <dd>
  453. uint64 packSnorm4x16(vec4 const &amp; v) </dd>
  454. <dd>
  455. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/packSnorm4x8.xml">GLSL packSnorm4x8 man page</a> </dd>
  456. <dd>
  457. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  458. </div>
  459. </div>
  460. <a class="anchor" id="gae3592e0795e62aaa1865b3a10496a7a1"></a>
  461. <div class="memitem">
  462. <div class="memproto">
  463. <table class="memname">
  464. <tr>
  465. <td class="memname">GLM_FUNC_DECL uint8 glm::packSnorm1x8 </td>
  466. <td>(</td>
  467. <td class="paramtype">float&#160;</td>
  468. <td class="paramname"><em>s</em></td><td>)</td>
  469. <td></td>
  470. </tr>
  471. </table>
  472. </div><div class="memdoc">
  473. <p>First, converts the normalized floating-point value v into 8-bit integer value. </p>
  474. <p>Then, the results are packed into the returned 8-bit unsigned integer.</p>
  475. <p>The conversion to fixed point is done as follows: packSnorm1x8: round(clamp(s, -1, +1) * 127.0)</p>
  476. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  477. <dd>
  478. uint16 packSnorm2x8(vec2 const &amp; v) </dd>
  479. <dd>
  480. uint32 packSnorm4x8(vec4 const &amp; v) </dd>
  481. <dd>
  482. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/packSnorm4x8.xml">GLSL packSnorm4x8 man page</a> </dd>
  483. <dd>
  484. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  485. </div>
  486. </div>
  487. <a class="anchor" id="ga6be3cfb2cce3702f03e91bbeb5286d7e"></a>
  488. <div class="memitem">
  489. <div class="memproto">
  490. <table class="memname">
  491. <tr>
  492. <td class="memname">GLM_FUNC_DECL uint16 glm::packSnorm2x8 </td>
  493. <td>(</td>
  494. <td class="paramtype"><a class="el" href="a00156.html#ga09d0200e8ff86391d8804b4fefd5f1da">vec2</a> const &amp;&#160;</td>
  495. <td class="paramname"><em>v</em></td><td>)</td>
  496. <td></td>
  497. </tr>
  498. </table>
  499. </div><div class="memdoc">
  500. <p>First, converts each component of the normalized floating-point value v into 8-bit integer values. </p>
  501. <p>Then, the results are packed into the returned 16-bit unsigned integer.</p>
  502. <p>The conversion for component c of v to fixed point is done as follows: packSnorm2x8: round(clamp(c, -1, +1) * 127.0)</p>
  503. <p>The first component of the vector will be written to the least significant bits of the output; the last component will be written to the most significant bits.</p>
  504. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  505. <dd>
  506. uint8 packSnorm1x8(float const &amp; v) </dd>
  507. <dd>
  508. uint32 packSnorm4x8(vec4 const &amp; v) </dd>
  509. <dd>
  510. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/packSnorm4x8.xml">GLSL packSnorm4x8 man page</a> </dd>
  511. <dd>
  512. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  513. </div>
  514. </div>
  515. <a class="anchor" id="gab997545661877d2c7362a5084d3897d3"></a>
  516. <div class="memitem">
  517. <div class="memproto">
  518. <table class="memname">
  519. <tr>
  520. <td class="memname">GLM_FUNC_DECL uint32 glm::packSnorm3x10_1x2 </td>
  521. <td>(</td>
  522. <td class="paramtype"><a class="el" href="a00156.html#gafbab23070ca47932487d25332adc7d7c">vec4</a> const &amp;&#160;</td>
  523. <td class="paramname"><em>v</em></td><td>)</td>
  524. <td></td>
  525. </tr>
  526. </table>
  527. </div><div class="memdoc">
  528. <p>First, converts the first three components of the normalized floating-point value v into 10-bit signed integer values. </p>
  529. <p>Then, converts the forth component of the normalized floating-point value v into 2-bit signed integer values. Then, the results are packed into the returned 32-bit unsigned integer.</p>
  530. <p>The conversion for component c of v to fixed point is done as follows: packSnorm3x10_1x2(xyz): round(clamp(c, -1, +1) * 511.0) packSnorm3x10_1x2(w): round(clamp(c, -1, +1) * 1.0)</p>
  531. <p>The first vector component specifies the 10 least-significant bits of the result; the forth component specifies the 2 most-significant bits.</p>
  532. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  533. <dd>
  534. vec4 unpackSnorm3x10_1x2(uint32 const &amp; p) </dd>
  535. <dd>
  536. uint32 packUnorm3x10_1x2(vec4 const &amp; v) </dd>
  537. <dd>
  538. uint32 packU3x10_1x2(uvec4 const &amp; v) </dd>
  539. <dd>
  540. uint32 packI3x10_1x2(ivec4 const &amp; v) </dd></dl>
  541. </div>
  542. </div>
  543. <a class="anchor" id="ga358943934d21da947d5bcc88c2ab7832"></a>
  544. <div class="memitem">
  545. <div class="memproto">
  546. <table class="memname">
  547. <tr>
  548. <td class="memname">GLM_FUNC_DECL uint64 glm::packSnorm4x16 </td>
  549. <td>(</td>
  550. <td class="paramtype"><a class="el" href="a00156.html#gafbab23070ca47932487d25332adc7d7c">vec4</a> const &amp;&#160;</td>
  551. <td class="paramname"><em>v</em></td><td>)</td>
  552. <td></td>
  553. </tr>
  554. </table>
  555. </div><div class="memdoc">
  556. <p>First, converts each component of the normalized floating-point value v into 16-bit integer values. </p>
  557. <p>Then, the results are packed into the returned 64-bit unsigned integer.</p>
  558. <p>The conversion for component c of v to fixed point is done as follows: packSnorm2x8: round(clamp(c, -1, +1) * 32767.0)</p>
  559. <p>The first component of the vector will be written to the least significant bits of the output; the last component will be written to the most significant bits.</p>
  560. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  561. <dd>
  562. uint16 packSnorm1x16(float const &amp; v) </dd>
  563. <dd>
  564. uint32 packSnorm2x16(vec2 const &amp; v) </dd>
  565. <dd>
  566. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/packSnorm4x8.xml">GLSL packSnorm4x8 man page</a> </dd>
  567. <dd>
  568. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  569. </div>
  570. </div>
  571. <a class="anchor" id="gada3d88d59f0f458f9c51a9fd359a4bc0"></a>
  572. <div class="memitem">
  573. <div class="memproto">
  574. <table class="memname">
  575. <tr>
  576. <td class="memname">GLM_FUNC_DECL uint32 glm::packU3x10_1x2 </td>
  577. <td>(</td>
  578. <td class="paramtype"><a class="el" href="a00156.html#gaa7c3a0e7ae50c34c3290415c115f251e">uvec4</a> const &amp;&#160;</td>
  579. <td class="paramname"><em>v</em></td><td>)</td>
  580. <td></td>
  581. </tr>
  582. </table>
  583. </div><div class="memdoc">
  584. <p>Returns an unsigned integer obtained by converting the components of a four-component unsigned integer vector to the 10-10-10-2-bit unsigned integer representation found in the OpenGL Specification, and then packing these four values into a 32-bit unsigned integer. </p>
  585. <p>The first vector component specifies the 10 least-significant bits of the result; the forth component specifies the 2 most-significant bits.</p>
  586. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  587. <dd>
  588. uint32 packI3x10_1x2(ivec4 const &amp; v) </dd>
  589. <dd>
  590. uint32 packSnorm3x10_1x2(vec4 const &amp; v) </dd>
  591. <dd>
  592. uint32 packUnorm3x10_1x2(vec4 const &amp; v) </dd>
  593. <dd>
  594. ivec4 unpackU3x10_1x2(uint32 const &amp; p) </dd></dl>
  595. </div>
  596. </div>
  597. <a class="anchor" id="gacb9a3df68172c1193c9d701a3fa4d88b"></a>
  598. <div class="memitem">
  599. <div class="memproto">
  600. <table class="memname">
  601. <tr>
  602. <td class="memname">GLM_FUNC_DECL vecType&lt;uintType, P&gt; glm::packUnorm </td>
  603. <td>(</td>
  604. <td class="paramtype">vecType&lt; floatType, P &gt; const &amp;&#160;</td>
  605. <td class="paramname"><em>v</em></td><td>)</td>
  606. <td></td>
  607. </tr>
  608. </table>
  609. </div><div class="memdoc">
  610. <p>Convert each component of the normalized floating-point vector into unsigned integer values. </p>
  611. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  612. <dd>
  613. vecType&lt;floatType, P&gt; unpackUnorm(vecType&lt;intType, P&gt; const &amp; p); </dd></dl>
  614. </div>
  615. </div>
  616. <a class="anchor" id="ga9f82737bf2a44bedff1d286b76837886"></a>
  617. <div class="memitem">
  618. <div class="memproto">
  619. <table class="memname">
  620. <tr>
  621. <td class="memname">GLM_FUNC_DECL uint16 glm::packUnorm1x16 </td>
  622. <td>(</td>
  623. <td class="paramtype">float&#160;</td>
  624. <td class="paramname"><em>v</em></td><td>)</td>
  625. <td></td>
  626. </tr>
  627. </table>
  628. </div><div class="memdoc">
  629. <p>First, converts the normalized floating-point value v into a 16-bit integer value. </p>
  630. <p>Then, the results are packed into the returned 16-bit unsigned integer.</p>
  631. <p>The conversion for component c of v to fixed point is done as follows: packUnorm1x16: round(clamp(c, 0, +1) * 65535.0)</p>
  632. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  633. <dd>
  634. uint16 packSnorm1x16(float const &amp; v) </dd>
  635. <dd>
  636. uint64 packSnorm4x16(vec4 const &amp; v) </dd>
  637. <dd>
  638. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/packUnorm4x8.xml">GLSL packUnorm4x8 man page</a> </dd>
  639. <dd>
  640. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  641. </div>
  642. </div>
  643. <a class="anchor" id="ga768e0337dd6246773f14aa0a421fe9a8"></a>
  644. <div class="memitem">
  645. <div class="memproto">
  646. <table class="memname">
  647. <tr>
  648. <td class="memname">GLM_FUNC_DECL uint16 glm::packUnorm1x5_1x6_1x5 </td>
  649. <td>(</td>
  650. <td class="paramtype"><a class="el" href="a00156.html#gaa8ea2429bb3cb41a715258a447f39897">vec3</a> const &amp;&#160;</td>
  651. <td class="paramname"><em>v</em></td><td>)</td>
  652. <td></td>
  653. </tr>
  654. </table>
  655. </div><div class="memdoc">
  656. <p>Convert each component of the normalized floating-point vector into unsigned integer values. </p>
  657. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  658. <dd>
  659. vec3 unpackUnorm1x5_1x6_1x5(uint16 p) </dd></dl>
  660. </div>
  661. </div>
  662. <a class="anchor" id="ga4b2fa60df3460403817d28b082ee0736"></a>
  663. <div class="memitem">
  664. <div class="memproto">
  665. <table class="memname">
  666. <tr>
  667. <td class="memname">GLM_FUNC_DECL uint8 glm::packUnorm1x8 </td>
  668. <td>(</td>
  669. <td class="paramtype">float&#160;</td>
  670. <td class="paramname"><em>v</em></td><td>)</td>
  671. <td></td>
  672. </tr>
  673. </table>
  674. </div><div class="memdoc">
  675. <p>First, converts the normalized floating-point value v into a 8-bit integer value. </p>
  676. <p>Then, the results are packed into the returned 8-bit unsigned integer.</p>
  677. <p>The conversion for component c of v to fixed point is done as follows: packUnorm1x8: round(clamp(c, 0, +1) * 255.0)</p>
  678. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  679. <dd>
  680. uint16 packUnorm2x8(vec2 const &amp; v) </dd>
  681. <dd>
  682. uint32 packUnorm4x8(vec4 const &amp; v) </dd>
  683. <dd>
  684. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/packUnorm4x8.xml">GLSL packUnorm4x8 man page</a> </dd>
  685. <dd>
  686. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  687. </div>
  688. </div>
  689. <a class="anchor" id="ga7f9abdb50f9be1aa1c14912504a0d98d"></a>
  690. <div class="memitem">
  691. <div class="memproto">
  692. <table class="memname">
  693. <tr>
  694. <td class="memname">GLM_FUNC_DECL uint8 glm::packUnorm2x3_1x2 </td>
  695. <td>(</td>
  696. <td class="paramtype"><a class="el" href="a00156.html#gaa8ea2429bb3cb41a715258a447f39897">vec3</a> const &amp;&#160;</td>
  697. <td class="paramname"><em>v</em></td><td>)</td>
  698. <td></td>
  699. </tr>
  700. </table>
  701. </div><div class="memdoc">
  702. <p>Convert each component of the normalized floating-point vector into unsigned integer values. </p>
  703. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  704. <dd>
  705. vec3 unpackUnorm2x3_1x2(uint8 p) </dd></dl>
  706. </div>
  707. </div>
  708. <a class="anchor" id="gab6bbd5be3b8e6db538ecb33a7844481c"></a>
  709. <div class="memitem">
  710. <div class="memproto">
  711. <table class="memname">
  712. <tr>
  713. <td class="memname">GLM_FUNC_DECL uint8 glm::packUnorm2x4 </td>
  714. <td>(</td>
  715. <td class="paramtype"><a class="el" href="a00156.html#ga09d0200e8ff86391d8804b4fefd5f1da">vec2</a> const &amp;&#160;</td>
  716. <td class="paramname"><em>v</em></td><td>)</td>
  717. <td></td>
  718. </tr>
  719. </table>
  720. </div><div class="memdoc">
  721. <p>Convert each component of the normalized floating-point vector into unsigned integer values. </p>
  722. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  723. <dd>
  724. vec2 unpackUnorm2x4(uint8 p) </dd></dl>
  725. </div>
  726. </div>
  727. <a class="anchor" id="ga9a666b1c688ab54100061ed06526de6e"></a>
  728. <div class="memitem">
  729. <div class="memproto">
  730. <table class="memname">
  731. <tr>
  732. <td class="memname">GLM_FUNC_DECL uint16 glm::packUnorm2x8 </td>
  733. <td>(</td>
  734. <td class="paramtype"><a class="el" href="a00156.html#ga09d0200e8ff86391d8804b4fefd5f1da">vec2</a> const &amp;&#160;</td>
  735. <td class="paramname"><em>v</em></td><td>)</td>
  736. <td></td>
  737. </tr>
  738. </table>
  739. </div><div class="memdoc">
  740. <p>First, converts each component of the normalized floating-point value v into 8-bit integer values. </p>
  741. <p>Then, the results are packed into the returned 16-bit unsigned integer.</p>
  742. <p>The conversion for component c of v to fixed point is done as follows: packUnorm2x8: round(clamp(c, 0, +1) * 255.0)</p>
  743. <p>The first component of the vector will be written to the least significant bits of the output; the last component will be written to the most significant bits.</p>
  744. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  745. <dd>
  746. uint8 packUnorm1x8(float const &amp; v) </dd>
  747. <dd>
  748. uint32 packUnorm4x8(vec4 const &amp; v) </dd>
  749. <dd>
  750. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/packUnorm4x8.xml">GLSL packUnorm4x8 man page</a> </dd>
  751. <dd>
  752. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  753. </div>
  754. </div>
  755. <a class="anchor" id="ga8a1ee625d2707c60530fb3fca2980b19"></a>
  756. <div class="memitem">
  757. <div class="memproto">
  758. <table class="memname">
  759. <tr>
  760. <td class="memname">GLM_FUNC_DECL uint32 glm::packUnorm3x10_1x2 </td>
  761. <td>(</td>
  762. <td class="paramtype"><a class="el" href="a00156.html#gafbab23070ca47932487d25332adc7d7c">vec4</a> const &amp;&#160;</td>
  763. <td class="paramname"><em>v</em></td><td>)</td>
  764. <td></td>
  765. </tr>
  766. </table>
  767. </div><div class="memdoc">
  768. <p>First, converts the first three components of the normalized floating-point value v into 10-bit unsigned integer values. </p>
  769. <p>Then, converts the forth component of the normalized floating-point value v into 2-bit signed uninteger values. Then, the results are packed into the returned 32-bit unsigned integer.</p>
  770. <p>The conversion for component c of v to fixed point is done as follows: packUnorm3x10_1x2(xyz): round(clamp(c, 0, +1) * 1023.0) packUnorm3x10_1x2(w): round(clamp(c, 0, +1) * 3.0)</p>
  771. <p>The first vector component specifies the 10 least-significant bits of the result; the forth component specifies the 2 most-significant bits.</p>
  772. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  773. <dd>
  774. vec4 unpackUnorm3x10_1x2(uint32 const &amp; p) </dd>
  775. <dd>
  776. uint32 packUnorm3x10_1x2(vec4 const &amp; v) </dd>
  777. <dd>
  778. uint32 packU3x10_1x2(uvec4 const &amp; v) </dd>
  779. <dd>
  780. uint32 packI3x10_1x2(ivec4 const &amp; v) </dd></dl>
  781. </div>
  782. </div>
  783. <a class="anchor" id="gaec4112086d7fb133bea104a7c237de52"></a>
  784. <div class="memitem">
  785. <div class="memproto">
  786. <table class="memname">
  787. <tr>
  788. <td class="memname">GLM_FUNC_DECL uint16 glm::packUnorm3x5_1x1 </td>
  789. <td>(</td>
  790. <td class="paramtype"><a class="el" href="a00156.html#gafbab23070ca47932487d25332adc7d7c">vec4</a> const &amp;&#160;</td>
  791. <td class="paramname"><em>v</em></td><td>)</td>
  792. <td></td>
  793. </tr>
  794. </table>
  795. </div><div class="memdoc">
  796. <p>Convert each component of the normalized floating-point vector into unsigned integer values. </p>
  797. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  798. <dd>
  799. vec4 unpackUnorm3x5_1x1(uint16 p) </dd></dl>
  800. </div>
  801. </div>
  802. <a class="anchor" id="ga1f63c264e7ab63264e2b2a99fd393897"></a>
  803. <div class="memitem">
  804. <div class="memproto">
  805. <table class="memname">
  806. <tr>
  807. <td class="memname">GLM_FUNC_DECL uint64 glm::packUnorm4x16 </td>
  808. <td>(</td>
  809. <td class="paramtype"><a class="el" href="a00156.html#gafbab23070ca47932487d25332adc7d7c">vec4</a> const &amp;&#160;</td>
  810. <td class="paramname"><em>v</em></td><td>)</td>
  811. <td></td>
  812. </tr>
  813. </table>
  814. </div><div class="memdoc">
  815. <p>First, converts each component of the normalized floating-point value v into 16-bit integer values. </p>
  816. <p>Then, the results are packed into the returned 64-bit unsigned integer.</p>
  817. <p>The conversion for component c of v to fixed point is done as follows: packUnorm4x16: round(clamp(c, 0, +1) * 65535.0)</p>
  818. <p>The first component of the vector will be written to the least significant bits of the output; the last component will be written to the most significant bits.</p>
  819. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  820. <dd>
  821. uint16 packUnorm1x16(float const &amp; v) </dd>
  822. <dd>
  823. uint32 packUnorm2x16(vec2 const &amp; v) </dd>
  824. <dd>
  825. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/packUnorm4x8.xml">GLSL packUnorm4x8 man page</a> </dd>
  826. <dd>
  827. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  828. </div>
  829. </div>
  830. <a class="anchor" id="gad3e7e3ce521513584a53aedc5f9765c1"></a>
  831. <div class="memitem">
  832. <div class="memproto">
  833. <table class="memname">
  834. <tr>
  835. <td class="memname">GLM_FUNC_DECL uint16 glm::packUnorm4x4 </td>
  836. <td>(</td>
  837. <td class="paramtype"><a class="el" href="a00156.html#gafbab23070ca47932487d25332adc7d7c">vec4</a> const &amp;&#160;</td>
  838. <td class="paramname"><em>v</em></td><td>)</td>
  839. <td></td>
  840. </tr>
  841. </table>
  842. </div><div class="memdoc">
  843. <p>Convert each component of the normalized floating-point vector into unsigned integer values. </p>
  844. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  845. <dd>
  846. vec4 unpackUnorm4x4(uint16 p) </dd></dl>
  847. </div>
  848. </div>
  849. <a class="anchor" id="ga2b1fd1e854705b1345e98409e0a25e50"></a>
  850. <div class="memitem">
  851. <div class="memproto">
  852. <table class="memname">
  853. <tr>
  854. <td class="memname">GLM_FUNC_DECL vec3 glm::unpackF2x11_1x10 </td>
  855. <td>(</td>
  856. <td class="paramtype"><a class="el" href="a00177.html#ga5fa3ddcab56c789bc272ff5651faa12d">uint32</a>&#160;</td>
  857. <td class="paramname"><em>p</em></td><td>)</td>
  858. <td></td>
  859. </tr>
  860. </table>
  861. </div><div class="memdoc">
  862. <p>First, unpacks a single 32-bit unsigned integer p into two 11-bit signless floating-point values and one 10-bit signless floating-point value . </p>
  863. <p>Then, each component is converted to a normalized floating-point value to generate the returned three-component vector.</p>
  864. <p>The first component of the returned vector will be extracted from the least significant bits of the input; the last component will be extracted from the most significant bits.</p>
  865. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  866. <dd>
  867. uint32 packF2x11_1x10(vec3 const &amp; v) </dd></dl>
  868. </div>
  869. </div>
  870. <a class="anchor" id="gab9e60ebe3ad3eeced6a9ec6eb876d74e"></a>
  871. <div class="memitem">
  872. <div class="memproto">
  873. <table class="memname">
  874. <tr>
  875. <td class="memname">GLM_FUNC_DECL vec3 glm::unpackF3x9_E1x5 </td>
  876. <td>(</td>
  877. <td class="paramtype"><a class="el" href="a00177.html#ga5fa3ddcab56c789bc272ff5651faa12d">uint32</a>&#160;</td>
  878. <td class="paramname"><em>p</em></td><td>)</td>
  879. <td></td>
  880. </tr>
  881. </table>
  882. </div><div class="memdoc">
  883. <p>First, unpacks a single 32-bit unsigned integer p into two 11-bit signless floating-point values and one 10-bit signless floating-point value . </p>
  884. <p>Then, each component is converted to a normalized floating-point value to generate the returned three-component vector.</p>
  885. <p>The first component of the returned vector will be extracted from the least significant bits of the input; the last component will be extracted from the most significant bits.</p>
  886. <p>unpackF3x9_E1x5 allows decoding RGBE / RGB9E5 data</p>
  887. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  888. <dd>
  889. uint32 packF3x9_E1x5(vec3 const &amp; v) </dd></dl>
  890. </div>
  891. </div>
  892. <a class="anchor" id="gaf3f9387834f8d8beadfe723c1dd247a7"></a>
  893. <div class="memitem">
  894. <div class="memproto">
  895. <table class="memname">
  896. <tr>
  897. <td class="memname">GLM_FUNC_DECL vecType&lt;float, P&gt; glm::unpackHalf </td>
  898. <td>(</td>
  899. <td class="paramtype">vecType&lt; <a class="el" href="a00177.html#ga13471cbbe74e4303a57f3743d007b74d">uint16</a>, P &gt; const &amp;&#160;</td>
  900. <td class="paramname"><em>p</em></td><td>)</td>
  901. <td></td>
  902. </tr>
  903. </table>
  904. </div><div class="memdoc">
  905. <p>Returns a floating-point vector with components obtained by reinterpreting an integer vector as 16-bit floating-point numbers and converting them to 32-bit floating-point values. </p>
  906. <p>The first component of the vector is obtained from the 16 least-significant bits of v; the forth component is obtained from the 16 most-significant bits of v.</p>
  907. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  908. <dd>
  909. vecType&lt;uint16, P&gt; packHalf(vecType&lt;float, P&gt; const &amp; v) </dd>
  910. <dd>
  911. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  912. </div>
  913. </div>
  914. <a class="anchor" id="gac37dedaba24b00adb4ec6e8f92c19dbf"></a>
  915. <div class="memitem">
  916. <div class="memproto">
  917. <table class="memname">
  918. <tr>
  919. <td class="memname">GLM_FUNC_DECL float glm::unpackHalf1x16 </td>
  920. <td>(</td>
  921. <td class="paramtype"><a class="el" href="a00177.html#ga13471cbbe74e4303a57f3743d007b74d">uint16</a>&#160;</td>
  922. <td class="paramname"><em>v</em></td><td>)</td>
  923. <td></td>
  924. </tr>
  925. </table>
  926. </div><div class="memdoc">
  927. <p>Returns a floating-point scalar with components obtained by unpacking a 16-bit unsigned integer into a 16-bit value, interpreted as a 16-bit floating-point number according to the OpenGL Specification, and converting it to 32-bit floating-point values. </p>
  928. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  929. <dd>
  930. vec2 unpackHalf2x16(uint32 const &amp; v) </dd>
  931. <dd>
  932. vec4 unpackHalf4x16(uint64 const &amp; v) </dd>
  933. <dd>
  934. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/unpackHalf2x16.xml">GLSL unpackHalf2x16 man page</a> </dd>
  935. <dd>
  936. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  937. </div>
  938. </div>
  939. <a class="anchor" id="ga57dfc41b2eb20b0ac00efae7d9c49dcd"></a>
  940. <div class="memitem">
  941. <div class="memproto">
  942. <table class="memname">
  943. <tr>
  944. <td class="memname">GLM_FUNC_DECL vec4 glm::unpackHalf4x16 </td>
  945. <td>(</td>
  946. <td class="paramtype"><a class="el" href="a00177.html#gab630f76c26b50298187f7889104d4b9c">uint64</a>&#160;</td>
  947. <td class="paramname"><em>p</em></td><td>)</td>
  948. <td></td>
  949. </tr>
  950. </table>
  951. </div><div class="memdoc">
  952. <p>Returns a four-component floating-point vector with components obtained by unpacking a 64-bit unsigned integer into four 16-bit values, interpreting those values as 16-bit floating-point numbers according to the OpenGL Specification, and converting them to 32-bit floating-point values. </p>
  953. <p>The first component of the vector is obtained from the 16 least-significant bits of v; the forth component is obtained from the 16 most-significant bits of v.</p>
  954. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  955. <dd>
  956. float unpackHalf1x16(uint16 const &amp; v) </dd>
  957. <dd>
  958. vec2 unpackHalf2x16(uint32 const &amp; v) </dd>
  959. <dd>
  960. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/unpackHalf2x16.xml">GLSL unpackHalf2x16 man page</a> </dd>
  961. <dd>
  962. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  963. </div>
  964. </div>
  965. <a class="anchor" id="ga9a05330e5490be0908d3b117d82aff56"></a>
  966. <div class="memitem">
  967. <div class="memproto">
  968. <table class="memname">
  969. <tr>
  970. <td class="memname">GLM_FUNC_DECL ivec4 glm::unpackI3x10_1x2 </td>
  971. <td>(</td>
  972. <td class="paramtype"><a class="el" href="a00177.html#ga5fa3ddcab56c789bc272ff5651faa12d">uint32</a>&#160;</td>
  973. <td class="paramname"><em>p</em></td><td>)</td>
  974. <td></td>
  975. </tr>
  976. </table>
  977. </div><div class="memdoc">
  978. <p>Unpacks a single 32-bit unsigned integer p into three 10-bit and one 2-bit signed integers. </p>
  979. <p>The first component of the returned vector will be extracted from the least significant bits of the input; the last component will be extracted from the most significant bits.</p>
  980. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  981. <dd>
  982. uint32 packU3x10_1x2(uvec4 const &amp; v) </dd>
  983. <dd>
  984. vec4 unpackSnorm3x10_1x2(uint32 const &amp; p); </dd>
  985. <dd>
  986. uvec4 unpackI3x10_1x2(uint32 const &amp; p); </dd></dl>
  987. </div>
  988. </div>
  989. <a class="anchor" id="ga44274002723e379ad5c4ece8300a9308"></a>
  990. <div class="memitem">
  991. <div class="memproto">
  992. <table class="memname">
  993. <tr>
  994. <td class="memname">GLM_FUNC_DECL tvec3&lt;T, P&gt; glm::unpackRGBM </td>
  995. <td>(</td>
  996. <td class="paramtype">tvec4&lt; T, P &gt; const &amp;&#160;</td>
  997. <td class="paramname"><em>rgbm</em></td><td>)</td>
  998. <td></td>
  999. </tr>
  1000. </table>
  1001. </div><div class="memdoc">
  1002. <p>Returns a floating-point vector with components obtained by reinterpreting an integer vector as 16-bit floating-point numbers and converting them to 32-bit floating-point values. </p>
  1003. <p>The first component of the vector is obtained from the 16 least-significant bits of v; the forth component is obtained from the 16 most-significant bits of v.</p>
  1004. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1005. <dd>
  1006. tvec4&lt;T, P&gt; packRGBM(tvec3&lt;float, P&gt; const &amp; v) </dd>
  1007. <dd>
  1008. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  1009. </div>
  1010. </div>
  1011. <a class="anchor" id="ga63eeec0d416e48462f341f4a7a9a45fe"></a>
  1012. <div class="memitem">
  1013. <div class="memproto">
  1014. <table class="memname">
  1015. <tr>
  1016. <td class="memname">GLM_FUNC_DECL vecType&lt;floatType, P&gt; glm::unpackSnorm </td>
  1017. <td>(</td>
  1018. <td class="paramtype">vecType&lt; intType, P &gt; const &amp;&#160;</td>
  1019. <td class="paramname"><em>v</em></td><td>)</td>
  1020. <td></td>
  1021. </tr>
  1022. </table>
  1023. </div><div class="memdoc">
  1024. <p>Convert each signed integer components of a vector to normalized floating-point values. </p>
  1025. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1026. <dd>
  1027. vecType&lt;intType, P&gt; packSnorm(vecType&lt;floatType, P&gt; const &amp; v) </dd></dl>
  1028. </div>
  1029. </div>
  1030. <a class="anchor" id="ga96dd15002370627a443c835ab03a766c"></a>
  1031. <div class="memitem">
  1032. <div class="memproto">
  1033. <table class="memname">
  1034. <tr>
  1035. <td class="memname">GLM_FUNC_DECL float glm::unpackSnorm1x16 </td>
  1036. <td>(</td>
  1037. <td class="paramtype"><a class="el" href="a00177.html#ga13471cbbe74e4303a57f3743d007b74d">uint16</a>&#160;</td>
  1038. <td class="paramname"><em>p</em></td><td>)</td>
  1039. <td></td>
  1040. </tr>
  1041. </table>
  1042. </div><div class="memdoc">
  1043. <p>First, unpacks a single 16-bit unsigned integer p into a single 16-bit signed integers. </p>
  1044. <p>Then, each component is converted to a normalized floating-point value to generate the returned scalar.</p>
  1045. <p>The conversion for unpacked fixed-point value f to floating point is done as follows: unpackSnorm1x16: clamp(f / 32767.0, -1, +1)</p>
  1046. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1047. <dd>
  1048. vec2 unpackSnorm2x16(uint32 p) </dd>
  1049. <dd>
  1050. vec4 unpackSnorm4x16(uint64 p) </dd>
  1051. <dd>
  1052. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/unpackSnorm1x16.xml">GLSL unpackSnorm4x8 man page</a> </dd>
  1053. <dd>
  1054. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  1055. </div>
  1056. </div>
  1057. <a class="anchor" id="ga4851ff86678aa1c7ace9d67846894285"></a>
  1058. <div class="memitem">
  1059. <div class="memproto">
  1060. <table class="memname">
  1061. <tr>
  1062. <td class="memname">GLM_FUNC_DECL float glm::unpackSnorm1x8 </td>
  1063. <td>(</td>
  1064. <td class="paramtype"><a class="el" href="a00177.html#ga36475e31b1992cfde54c1a6f5a148865">uint8</a>&#160;</td>
  1065. <td class="paramname"><em>p</em></td><td>)</td>
  1066. <td></td>
  1067. </tr>
  1068. </table>
  1069. </div><div class="memdoc">
  1070. <p>First, unpacks a single 8-bit unsigned integer p into a single 8-bit signed integers. </p>
  1071. <p>Then, the value is converted to a normalized floating-point value to generate the returned scalar.</p>
  1072. <p>The conversion for unpacked fixed-point value f to floating point is done as follows: unpackSnorm1x8: clamp(f / 127.0, -1, +1)</p>
  1073. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1074. <dd>
  1075. vec2 unpackSnorm2x8(uint16 p) </dd>
  1076. <dd>
  1077. vec4 unpackSnorm4x8(uint32 p) </dd>
  1078. <dd>
  1079. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/unpackSnorm4x8.xml">GLSL unpackSnorm4x8 man page</a> </dd>
  1080. <dd>
  1081. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  1082. </div>
  1083. </div>
  1084. <a class="anchor" id="ga8b128e89be449fc71336968a66bf6e1a"></a>
  1085. <div class="memitem">
  1086. <div class="memproto">
  1087. <table class="memname">
  1088. <tr>
  1089. <td class="memname">GLM_FUNC_DECL vec2 glm::unpackSnorm2x8 </td>
  1090. <td>(</td>
  1091. <td class="paramtype"><a class="el" href="a00177.html#ga13471cbbe74e4303a57f3743d007b74d">uint16</a>&#160;</td>
  1092. <td class="paramname"><em>p</em></td><td>)</td>
  1093. <td></td>
  1094. </tr>
  1095. </table>
  1096. </div><div class="memdoc">
  1097. <p>First, unpacks a single 16-bit unsigned integer p into a pair of 8-bit signed integers. </p>
  1098. <p>Then, each component is converted to a normalized floating-point value to generate the returned two-component vector.</p>
  1099. <p>The conversion for unpacked fixed-point value f to floating point is done as follows: unpackSnorm2x8: clamp(f / 127.0, -1, +1)</p>
  1100. <p>The first component of the returned vector will be extracted from the least significant bits of the input; the last component will be extracted from the most significant bits.</p>
  1101. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1102. <dd>
  1103. float unpackSnorm1x8(uint8 p) </dd>
  1104. <dd>
  1105. vec4 unpackSnorm4x8(uint32 p) </dd>
  1106. <dd>
  1107. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/unpackSnorm4x8.xml">GLSL unpackSnorm4x8 man page</a> </dd>
  1108. <dd>
  1109. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  1110. </div>
  1111. </div>
  1112. <a class="anchor" id="ga7a4fbf79be9740e3c57737bc2af05e5b"></a>
  1113. <div class="memitem">
  1114. <div class="memproto">
  1115. <table class="memname">
  1116. <tr>
  1117. <td class="memname">GLM_FUNC_DECL vec4 glm::unpackSnorm3x10_1x2 </td>
  1118. <td>(</td>
  1119. <td class="paramtype"><a class="el" href="a00177.html#ga5fa3ddcab56c789bc272ff5651faa12d">uint32</a>&#160;</td>
  1120. <td class="paramname"><em>p</em></td><td>)</td>
  1121. <td></td>
  1122. </tr>
  1123. </table>
  1124. </div><div class="memdoc">
  1125. <p>First, unpacks a single 32-bit unsigned integer p into four 16-bit signed integers. </p>
  1126. <p>Then, each component is converted to a normalized floating-point value to generate the returned four-component vector.</p>
  1127. <p>The conversion for unpacked fixed-point value f to floating point is done as follows: unpackSnorm3x10_1x2(xyz): clamp(f / 511.0, -1, +1) unpackSnorm3x10_1x2(w): clamp(f / 511.0, -1, +1)</p>
  1128. <p>The first component of the returned vector will be extracted from the least significant bits of the input; the last component will be extracted from the most significant bits.</p>
  1129. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1130. <dd>
  1131. uint32 packSnorm3x10_1x2(vec4 const &amp; v) </dd>
  1132. <dd>
  1133. vec4 unpackUnorm3x10_1x2(uint32 const &amp; p)) </dd>
  1134. <dd>
  1135. uvec4 unpackI3x10_1x2(uint32 const &amp; p) </dd>
  1136. <dd>
  1137. uvec4 unpackU3x10_1x2(uint32 const &amp; p) </dd></dl>
  1138. </div>
  1139. </div>
  1140. <a class="anchor" id="gaaddf9c353528fe896106f7181219c7f4"></a>
  1141. <div class="memitem">
  1142. <div class="memproto">
  1143. <table class="memname">
  1144. <tr>
  1145. <td class="memname">GLM_FUNC_DECL vec4 glm::unpackSnorm4x16 </td>
  1146. <td>(</td>
  1147. <td class="paramtype"><a class="el" href="a00177.html#gab630f76c26b50298187f7889104d4b9c">uint64</a>&#160;</td>
  1148. <td class="paramname"><em>p</em></td><td>)</td>
  1149. <td></td>
  1150. </tr>
  1151. </table>
  1152. </div><div class="memdoc">
  1153. <p>First, unpacks a single 64-bit unsigned integer p into four 16-bit signed integers. </p>
  1154. <p>Then, each component is converted to a normalized floating-point value to generate the returned four-component vector.</p>
  1155. <p>The conversion for unpacked fixed-point value f to floating point is done as follows: unpackSnorm4x16: clamp(f / 32767.0, -1, +1)</p>
  1156. <p>The first component of the returned vector will be extracted from the least significant bits of the input; the last component will be extracted from the most significant bits.</p>
  1157. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1158. <dd>
  1159. float unpackSnorm1x16(uint16 p) </dd>
  1160. <dd>
  1161. vec2 unpackSnorm2x16(uint32 p) </dd>
  1162. <dd>
  1163. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/unpackSnorm2x16.xml">GLSL unpackSnorm4x8 man page</a> </dd>
  1164. <dd>
  1165. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  1166. </div>
  1167. </div>
  1168. <a class="anchor" id="ga48df3042a7d079767f5891a1bfd8a60a"></a>
  1169. <div class="memitem">
  1170. <div class="memproto">
  1171. <table class="memname">
  1172. <tr>
  1173. <td class="memname">GLM_FUNC_DECL uvec4 glm::unpackU3x10_1x2 </td>
  1174. <td>(</td>
  1175. <td class="paramtype"><a class="el" href="a00177.html#ga5fa3ddcab56c789bc272ff5651faa12d">uint32</a>&#160;</td>
  1176. <td class="paramname"><em>p</em></td><td>)</td>
  1177. <td></td>
  1178. </tr>
  1179. </table>
  1180. </div><div class="memdoc">
  1181. <p>Unpacks a single 32-bit unsigned integer p into three 10-bit and one 2-bit unsigned integers. </p>
  1182. <p>The first component of the returned vector will be extracted from the least significant bits of the input; the last component will be extracted from the most significant bits.</p>
  1183. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1184. <dd>
  1185. uint32 packU3x10_1x2(uvec4 const &amp; v) </dd>
  1186. <dd>
  1187. vec4 unpackSnorm3x10_1x2(uint32 const &amp; p); </dd>
  1188. <dd>
  1189. uvec4 unpackI3x10_1x2(uint32 const &amp; p); </dd></dl>
  1190. </div>
  1191. </div>
  1192. <a class="anchor" id="gad3d7e1ec7fcfb7ae341658e2ce1c3bd9"></a>
  1193. <div class="memitem">
  1194. <div class="memproto">
  1195. <table class="memname">
  1196. <tr>
  1197. <td class="memname">GLM_FUNC_DECL vecType&lt;floatType, P&gt; glm::unpackUnorm </td>
  1198. <td>(</td>
  1199. <td class="paramtype">vecType&lt; uintType, P &gt; const &amp;&#160;</td>
  1200. <td class="paramname"><em>v</em></td><td>)</td>
  1201. <td></td>
  1202. </tr>
  1203. </table>
  1204. </div><div class="memdoc">
  1205. <p>Convert each unsigned integer components of a vector to normalized floating-point values. </p>
  1206. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1207. <dd>
  1208. vecType&lt;intType, P&gt; packUnorm(vecType&lt;floatType, P&gt; const &amp; v) </dd></dl>
  1209. </div>
  1210. </div>
  1211. <a class="anchor" id="ga83d34160a5cb7bcb5339823210fc7501"></a>
  1212. <div class="memitem">
  1213. <div class="memproto">
  1214. <table class="memname">
  1215. <tr>
  1216. <td class="memname">GLM_FUNC_DECL float glm::unpackUnorm1x16 </td>
  1217. <td>(</td>
  1218. <td class="paramtype"><a class="el" href="a00177.html#ga13471cbbe74e4303a57f3743d007b74d">uint16</a>&#160;</td>
  1219. <td class="paramname"><em>p</em></td><td>)</td>
  1220. <td></td>
  1221. </tr>
  1222. </table>
  1223. </div><div class="memdoc">
  1224. <p>First, unpacks a single 16-bit unsigned integer p into a of 16-bit unsigned integers. </p>
  1225. <p>Then, the value is converted to a normalized floating-point value to generate the returned scalar.</p>
  1226. <p>The conversion for unpacked fixed-point value f to floating point is done as follows: unpackUnorm1x16: f / 65535.0</p>
  1227. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1228. <dd>
  1229. vec2 unpackUnorm2x16(uint32 p) </dd>
  1230. <dd>
  1231. vec4 unpackUnorm4x16(uint64 p) </dd>
  1232. <dd>
  1233. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/unpackUnorm2x16.xml">GLSL unpackUnorm2x16 man page</a> </dd>
  1234. <dd>
  1235. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  1236. </div>
  1237. </div>
  1238. <a class="anchor" id="gab3bc08ecfc0f3339be93fb2b3b56d88a"></a>
  1239. <div class="memitem">
  1240. <div class="memproto">
  1241. <table class="memname">
  1242. <tr>
  1243. <td class="memname">GLM_FUNC_DECL vec3 glm::unpackUnorm1x5_1x6_1x5 </td>
  1244. <td>(</td>
  1245. <td class="paramtype"><a class="el" href="a00177.html#ga13471cbbe74e4303a57f3743d007b74d">uint16</a>&#160;</td>
  1246. <td class="paramname"><em>p</em></td><td>)</td>
  1247. <td></td>
  1248. </tr>
  1249. </table>
  1250. </div><div class="memdoc">
  1251. <p>Convert each unsigned integer components of a vector to normalized floating-point values. </p>
  1252. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1253. <dd>
  1254. uint16 packUnorm1x5_1x6_1x5(vec3 const &amp; v) </dd></dl>
  1255. </div>
  1256. </div>
  1257. <a class="anchor" id="ga1319207e30874fb4931a9ee913983ee1"></a>
  1258. <div class="memitem">
  1259. <div class="memproto">
  1260. <table class="memname">
  1261. <tr>
  1262. <td class="memname">GLM_FUNC_DECL float glm::unpackUnorm1x8 </td>
  1263. <td>(</td>
  1264. <td class="paramtype"><a class="el" href="a00177.html#ga36475e31b1992cfde54c1a6f5a148865">uint8</a>&#160;</td>
  1265. <td class="paramname"><em>p</em></td><td>)</td>
  1266. <td></td>
  1267. </tr>
  1268. </table>
  1269. </div><div class="memdoc">
  1270. <p>Convert a single 8-bit integer to a normalized floating-point value. </p>
  1271. <p>The conversion for unpacked fixed-point value f to floating point is done as follows: unpackUnorm4x8: f / 255.0</p>
  1272. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1273. <dd>
  1274. vec2 unpackUnorm2x8(uint16 p) </dd>
  1275. <dd>
  1276. vec4 unpackUnorm4x8(uint32 p) </dd>
  1277. <dd>
  1278. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/unpackUnorm4x8.xml">GLSL unpackUnorm4x8 man page</a> </dd>
  1279. <dd>
  1280. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  1281. </div>
  1282. </div>
  1283. <a class="anchor" id="ga6abd5a9014df3b5ce4059008d2491260"></a>
  1284. <div class="memitem">
  1285. <div class="memproto">
  1286. <table class="memname">
  1287. <tr>
  1288. <td class="memname">GLM_FUNC_DECL vec3 glm::unpackUnorm2x3_1x2 </td>
  1289. <td>(</td>
  1290. <td class="paramtype"><a class="el" href="a00177.html#ga36475e31b1992cfde54c1a6f5a148865">uint8</a>&#160;</td>
  1291. <td class="paramname"><em>p</em></td><td>)</td>
  1292. <td></td>
  1293. </tr>
  1294. </table>
  1295. </div><div class="memdoc">
  1296. <p>Convert each unsigned integer components of a vector to normalized floating-point values. </p>
  1297. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1298. <dd>
  1299. uint8 packUnorm2x3_1x2(vec3 const &amp; v) </dd></dl>
  1300. </div>
  1301. </div>
  1302. <a class="anchor" id="ga2e50476132fe5f27f08e273d9c70d85b"></a>
  1303. <div class="memitem">
  1304. <div class="memproto">
  1305. <table class="memname">
  1306. <tr>
  1307. <td class="memname">GLM_FUNC_DECL vec2 glm::unpackUnorm2x4 </td>
  1308. <td>(</td>
  1309. <td class="paramtype"><a class="el" href="a00177.html#ga36475e31b1992cfde54c1a6f5a148865">uint8</a>&#160;</td>
  1310. <td class="paramname"><em>p</em></td><td>)</td>
  1311. <td></td>
  1312. </tr>
  1313. </table>
  1314. </div><div class="memdoc">
  1315. <p>Convert each unsigned integer components of a vector to normalized floating-point values. </p>
  1316. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1317. <dd>
  1318. uint8 packUnorm2x4(vec2 const &amp; v) </dd></dl>
  1319. </div>
  1320. </div>
  1321. <a class="anchor" id="ga637cbe3913dd95c6e7b4c99c61bd611f"></a>
  1322. <div class="memitem">
  1323. <div class="memproto">
  1324. <table class="memname">
  1325. <tr>
  1326. <td class="memname">GLM_FUNC_DECL vec2 glm::unpackUnorm2x8 </td>
  1327. <td>(</td>
  1328. <td class="paramtype"><a class="el" href="a00177.html#ga13471cbbe74e4303a57f3743d007b74d">uint16</a>&#160;</td>
  1329. <td class="paramname"><em>p</em></td><td>)</td>
  1330. <td></td>
  1331. </tr>
  1332. </table>
  1333. </div><div class="memdoc">
  1334. <p>First, unpacks a single 16-bit unsigned integer p into a pair of 8-bit unsigned integers. </p>
  1335. <p>Then, each component is converted to a normalized floating-point value to generate the returned two-component vector.</p>
  1336. <p>The conversion for unpacked fixed-point value f to floating point is done as follows: unpackUnorm4x8: f / 255.0</p>
  1337. <p>The first component of the returned vector will be extracted from the least significant bits of the input; the last component will be extracted from the most significant bits.</p>
  1338. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1339. <dd>
  1340. float unpackUnorm1x8(uint8 v) </dd>
  1341. <dd>
  1342. vec4 unpackUnorm4x8(uint32 p) </dd>
  1343. <dd>
  1344. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/unpackUnorm4x8.xml">GLSL unpackUnorm4x8 man page</a> </dd>
  1345. <dd>
  1346. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  1347. </div>
  1348. </div>
  1349. <a class="anchor" id="ga5156d3060355fe332865da2c7f78815f"></a>
  1350. <div class="memitem">
  1351. <div class="memproto">
  1352. <table class="memname">
  1353. <tr>
  1354. <td class="memname">GLM_FUNC_DECL vec4 glm::unpackUnorm3x10_1x2 </td>
  1355. <td>(</td>
  1356. <td class="paramtype"><a class="el" href="a00177.html#ga5fa3ddcab56c789bc272ff5651faa12d">uint32</a>&#160;</td>
  1357. <td class="paramname"><em>p</em></td><td>)</td>
  1358. <td></td>
  1359. </tr>
  1360. </table>
  1361. </div><div class="memdoc">
  1362. <p>First, unpacks a single 32-bit unsigned integer p into four 16-bit signed integers. </p>
  1363. <p>Then, each component is converted to a normalized floating-point value to generate the returned four-component vector.</p>
  1364. <p>The conversion for unpacked fixed-point value f to floating point is done as follows: unpackSnorm3x10_1x2(xyz): clamp(f / 1023.0, 0, +1) unpackSnorm3x10_1x2(w): clamp(f / 3.0, 0, +1)</p>
  1365. <p>The first component of the returned vector will be extracted from the least significant bits of the input; the last component will be extracted from the most significant bits.</p>
  1366. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1367. <dd>
  1368. uint32 packSnorm3x10_1x2(vec4 const &amp; v) </dd>
  1369. <dd>
  1370. vec4 unpackInorm3x10_1x2(uint32 const &amp; p)) </dd>
  1371. <dd>
  1372. uvec4 unpackI3x10_1x2(uint32 const &amp; p) </dd>
  1373. <dd>
  1374. uvec4 unpackU3x10_1x2(uint32 const &amp; p) </dd></dl>
  1375. </div>
  1376. </div>
  1377. <a class="anchor" id="ga5ff95ff5bc16f396432ab67243dbae4d"></a>
  1378. <div class="memitem">
  1379. <div class="memproto">
  1380. <table class="memname">
  1381. <tr>
  1382. <td class="memname">GLM_FUNC_DECL vec4 glm::unpackUnorm3x5_1x1 </td>
  1383. <td>(</td>
  1384. <td class="paramtype"><a class="el" href="a00177.html#ga13471cbbe74e4303a57f3743d007b74d">uint16</a>&#160;</td>
  1385. <td class="paramname"><em>p</em></td><td>)</td>
  1386. <td></td>
  1387. </tr>
  1388. </table>
  1389. </div><div class="memdoc">
  1390. <p>Convert each unsigned integer components of a vector to normalized floating-point values. </p>
  1391. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1392. <dd>
  1393. uint16 packUnorm3x5_1x1(vec4 const &amp; v) </dd></dl>
  1394. </div>
  1395. </div>
  1396. <a class="anchor" id="ga2ae149c5d2473ac1e5f347bb654a242d"></a>
  1397. <div class="memitem">
  1398. <div class="memproto">
  1399. <table class="memname">
  1400. <tr>
  1401. <td class="memname">GLM_FUNC_DECL vec4 glm::unpackUnorm4x16 </td>
  1402. <td>(</td>
  1403. <td class="paramtype"><a class="el" href="a00177.html#gab630f76c26b50298187f7889104d4b9c">uint64</a>&#160;</td>
  1404. <td class="paramname"><em>p</em></td><td>)</td>
  1405. <td></td>
  1406. </tr>
  1407. </table>
  1408. </div><div class="memdoc">
  1409. <p>First, unpacks a single 64-bit unsigned integer p into four 16-bit unsigned integers. </p>
  1410. <p>Then, each component is converted to a normalized floating-point value to generate the returned four-component vector.</p>
  1411. <p>The conversion for unpacked fixed-point value f to floating point is done as follows: unpackUnormx4x16: f / 65535.0</p>
  1412. <p>The first component of the returned vector will be extracted from the least significant bits of the input; the last component will be extracted from the most significant bits.</p>
  1413. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1414. <dd>
  1415. float unpackUnorm1x16(uint16 p) </dd>
  1416. <dd>
  1417. vec2 unpackUnorm2x16(uint32 p) </dd>
  1418. <dd>
  1419. <a href="http://www.opengl.org/sdk/docs/manglsl/xhtml/unpackUnorm2x16.xml">GLSL unpackUnorm2x16 man page</a> </dd>
  1420. <dd>
  1421. <a href="http://www.opengl.org/registry/doc/GLSLangSpec.4.20.8.pdf">GLSL 4.20.8 specification, section 8.4 Floating-Point Pack and Unpack Functions</a> </dd></dl>
  1422. </div>
  1423. </div>
  1424. <a class="anchor" id="gac58ee89d0e224bb6df5e8bbb18843a2d"></a>
  1425. <div class="memitem">
  1426. <div class="memproto">
  1427. <table class="memname">
  1428. <tr>
  1429. <td class="memname">GLM_FUNC_DECL vec4 glm::unpackUnorm4x4 </td>
  1430. <td>(</td>
  1431. <td class="paramtype"><a class="el" href="a00177.html#ga13471cbbe74e4303a57f3743d007b74d">uint16</a>&#160;</td>
  1432. <td class="paramname"><em>p</em></td><td>)</td>
  1433. <td></td>
  1434. </tr>
  1435. </table>
  1436. </div><div class="memdoc">
  1437. <p>Convert each unsigned integer components of a vector to normalized floating-point values. </p>
  1438. <dl class="section see"><dt>See also</dt><dd><a class="el" href="a00171.html" title="This extension provides a set of function to convert vertors to packed formats. ">GLM_GTC_packing</a> </dd>
  1439. <dd>
  1440. uint16 packUnorm4x4(vec4 const &amp; v) </dd></dl>
  1441. </div>
  1442. </div>
  1443. </div><!-- contents -->
  1444. <!-- start footer part -->
  1445. <hr class="footer"/><address class="footer"><small>
  1446. Generated by &#160;<a href="http://www.doxygen.org/index.html">
  1447. <img class="footer" src="doxygen.png" alt="doxygen"/>
  1448. </a> 1.8.10
  1449. </small></address>
  1450. </body>
  1451. </html>