diff options
Diffstat (limited to 'docs/doxygen/nel/quat_8h-source.html')
-rw-r--r-- | docs/doxygen/nel/quat_8h-source.html | 555 |
1 files changed, 555 insertions, 0 deletions
diff --git a/docs/doxygen/nel/quat_8h-source.html b/docs/doxygen/nel/quat_8h-source.html new file mode 100644 index 00000000..e2b530e8 --- /dev/null +++ b/docs/doxygen/nel/quat_8h-source.html @@ -0,0 +1,555 @@ +<!doctype html public "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"> +<HTML> +<HEAD> + <TITLE>nevrax.org : docs</TITLE> + <LINK REL=stylesheet TYPE="text/css" HREF="http://www.nevrax.org/inc/css/nevrax.css"> + <link href="doxygen.css" rel="stylesheet" type="text/css"> +</HEAD> +<BODY MARGINHEIGHT="0" MARGINWIDTH="0"> + +<!-- uplinks --> +<TABLE CELLSPACING=0 CELLPADDING=0 BORDER=0> + <TR> + <TD WIDTH=16><IMG SRC="http://www.nevrax.org/inc/img/pixel.gif" WIDTH="16" HEIGHT="16" BORDER=0 ALT=""></TD> + <TD WIDTH=140 BGCOLOR=#dddddd><IMG SRC="http://www.nevrax.org/inc/img/pixel.gif" WIDTH="140" HEIGHT="16" BORDER=0 ALT=""></TD> + <TD WIDTH=16><IMG SRC="http://www.nevrax.org/inc/img/pixel.gif" WIDTH="16" HEIGHT="16" BORDER=0 ALT=""></TD> + <TD><IMG width=6 height=14 SRC="http://www.nevrax.org/inc/img/reddots.gif" ALT="#" VSPACE=2 HSPACE=2 BORDER=0 ></TD><TD VALIGN=middle> <A CLASS=uplinks HREF=http://www.nevrax.org><b>Home</B></FONT></A> </TD> + <TD><IMG width=6 height=14 SRC="http://www.nevrax.org/inc/img/reddots.gif" ALT="#" VSPACE=2 HSPACE=2 BORDER=0 ></TD><TD VALIGN=middle> <A CLASS=uplinks HREF=http://www.nevrax.com><b>nevrax.com</B></FONT></A> </TD> + </TR> +</TABLE> + +<!-- banner Nevrax --> +<TABLE CELLSPACING=0 CELLPADDING=0 BORDER=0 WIDTH=100%> + <TR><TD BGCOLOR="#000000" BACKGROUND="http://www.nevrax.org/inc/img/black_banner.jpg"><A HREF="http://www.nevrax.org"><IMG SRC="http://www.nevrax.org/inc/img/nevrax.gif" WIDTH="170" HEIGHT="45" BORDER=0 ALT="Nevrax" ></A></TD></TR> +</TABLE> + +<!-- main table --> +<TABLE CELLSPACING=0 CELLPADDING=0 BORDER=0 height=100%> + <TR> + <TD WIDTH=16><IMG SRC="http://www.nevrax.org/inc/img/pixel.gif" WIDTH="16" HEIGHT="10" BORDER=0 ALT=""></TD> + <TD WIDTH=140 BGCOLOR=#dddddd VALIGN=TOP ALIGN=middle><IMG SRC="http://www.nevrax.org/inc/img/pixel.gif" WIDTH="140" HEIGHT="10" BORDER=0 ALT=""> + + <!------ Begin Box ------> + <TABLE BORDER=0 CELLSPACING=0 CELLPADDING=0 BGCOLOR=black><TR><TD><TABLE border=0 cellspacing=2 cellpadding=0 width=120><tr><TD ALIGN=middle bgcolor=black> + <FONT COLOR=white FACE="sans-serif"><B>Nevrax.org</B></FONT></TD></TR><tr><td colspan=2 bgcolor=#FFFFFF> + <TABLE cellspacing=0 cellpadding=1 border=0> + <tr><td ALIGN=middle><a class='linkbox' href="http://www.nevrax.org/news/" TITLE="Rubrique news"><img width=13 height=15 hspace=5 border=0 src=http://www.nevrax.org/inc/img/picto-news.gif ALT=#></A></td><td><a class='linkbox' href="http://www.nevrax.org/news/" TITLE="News">News</a></td></tr> + <tr><td ALIGN=middle><a class='linkbox' href="http://www.nevrax.org/mail/" TITLE="Rubrique mail"><img width=15 height=11 hspace=5 border=0 src=http://www.nevrax.org/inc/img/picto-mail.gif ALT=#></A></td><td><a class='linkbox' href="http://www.nevrax.org/mail/" TITLE="Mailing list archive">Mailing-list</a></td></tr> + <tr><td ALIGN=middle><a class='linkbox' href="http://www.nevrax.org/docs/" TITLE="Rubrique docs"><img width=14 height=16 hspace=5 border=0 src=http://www.nevrax.org/inc/img/picto-docs.gif ALT=#></A></td><td><a class='linkbox' href="http://www.nevrax.org/docs/" TITLE="Documentation">Documentation</a></td></tr> + <tr><td ALIGN=middle><a class='linkbox' href="http://www.nevrax.org/cvs/" TITLE="Rubrique cvs"><img width=13 height=17 hspace=5 border=0 src=http://www.nevrax.org/inc/img/picto-cvs.gif ALT=#></A></td><td><a class='linkbox' href="http://www.nevrax.org/cvs/" TITLE="CVS Web">CVS</a></td></tr> + <tr><td ALIGN=middle><a class='linkbox' href="http://www.nevrax.org/bugs/" TITLE="Rubrique bugs"><img width=20 height=16 hspace=5 border=0 src=http://www.nevrax.org/inc/img/picto-bugs.gif ALT=#></A></td><td><a class='linkbox' href="http://www.nevrax.org/bugs/" TITLE="Bugtracking">Bugs</a></td></tr> + <tr><td ALIGN=middle><a class='linkbox' href="http://www.nevrax.org/GPL.php3" TITLE="Rubrique license"><img width=18 height=12 hspace=5 border=0 src=http://www.nevrax.org/inc/img/picto-gpl.gif ALT=#></A></td><td><a class='linkbox' href="http://www.nevrax.org/GPL.php3" TITLE="License">License</a></td></tr> + </TABLE> + </TD></TR></TABLE></TD></TR></TABLE> + <!------ End Box ------> + + </TD> + <TD WIDTH=15><IMG SRC="http://www.nevrax.org/inc/img/pixel.gif" WIDTH="16" HEIGHT="16" BORDER=0 ALT=""></TD> + <TD ALIGN=left valign=top><IMG SRC="http://www.nevrax.org/inc/img/pixel.gif" WIDTH="140" HEIGHT="10" BORDER=0 ALT=""> + +<!-- title --> +<TABLE background="http://www.nevrax.org/inc/img/redline.gif" CELLSPACING=0 CELLPADDING=0 BORDER=0 width=100%><tr><td> +<A HREF="http://www.nevrax.org/docs/"><img src="http://www.nevrax.org/inc/img/t_docs.gif" ALT="Docs" HEIGHT=20 BORDER=0></A> +</td><td><IMG SRC="http://www.nevrax.org/inc/img/pixel.gif" WIDTH="1" HEIGHT="1" BORDER=0 ALT=""> +</td></tr></table> + + +<!-- block --> +<TABLE bgcolor="#dddddd" CELLSPACING=0 CELLPADDING=0 BORDER=0 width=100%><tr><td width=1% valign=middle><img width=6 height=14 hspace=2 vspace=2 src="http://www.nevrax.org/inc/img/reddots.gif"></TD> + <TD><B>Documentation</B></TD> + <TD ALIGN=RIGHT> </td> +</tr></table> +<!-- Generated by Doxygen 1.2.14 --> +<center> +<a class="qindex" href="index.html">Main Page</a> <a class="qindex" href="namespaces.html">Namespace List</a> <a class="qindex" href="hierarchy.html">Class Hierarchy</a> <a class="qindex" href="classes.html">Alphabetical List</a> <a class="qindex" href="annotated.html">Compound List</a> <a class="qindex" href="files.html">File List</a> <a class="qindex" href="namespacemembers.html">Namespace Members</a> <a class="qindex" href="functions.html">Compound Members</a> <a class="qindex" href="globals.html">File Members</a> <a class="qindex" href="pages.html">Related Pages</a> <a class="qindexRef" doxygen="_cgi:http://www.nevrax.org/cgi-bin/nel-search.cgi" href="http://www.nevrax.org/cgi-bin/nel-search.cgi">Search</a> </center> +<hr><h1>quat.h</h1><a href="quat_8h.html">Go to the documentation of this file.</a><div class="fragment"><pre>00001 +00007 <font class="comment">/* Copyright, 2000 Nevrax Ltd.</font> +00008 <font class="comment"> *</font> +00009 <font class="comment"> * This file is part of NEVRAX NEL.</font> +00010 <font class="comment"> * NEVRAX NEL is free software; you can redistribute it and/or modify</font> +00011 <font class="comment"> * it under the terms of the GNU General Public License as published by</font> +00012 <font class="comment"> * the Free Software Foundation; either version 2, or (at your option)</font> +00013 <font class="comment"> * any later version.</font> +00014 <font class="comment"></font> +00015 <font class="comment"> * NEVRAX NEL is distributed in the hope that it will be useful, but</font> +00016 <font class="comment"> * WITHOUT ANY WARRANTY; without even the implied warranty of</font> +00017 <font class="comment"> * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU</font> +00018 <font class="comment"> * General Public License for more details.</font> +00019 <font class="comment"></font> +00020 <font class="comment"> * You should have received a copy of the GNU General Public License</font> +00021 <font class="comment"> * along with NEVRAX NEL; see the file COPYING. If not, write to the</font> +00022 <font class="comment"> * Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,</font> +00023 <font class="comment"> * MA 02111-1307, USA.</font> +00024 <font class="comment"> */</font> +00025 +00026 <font class="preprocessor">#ifndef NL_QUAT_H </font> +00027 <font class="preprocessor"></font><font class="preprocessor">#define NL_QUAT_H </font> +00028 <font class="preprocessor"></font> +00029 <font class="preprocessor">#include "<a class="code" href="types__nl_8h.html">nel/misc/types_nl.h</a>"</font> +00030 <font class="preprocessor">#include "<a class="code" href="vector_8h.html">nel/misc/vector.h</a>"</font> +00031 <font class="preprocessor">#include "<a class="code" href="stream_8h.html">nel/misc/stream.h</a>"</font> +00032 <font class="preprocessor">#include <math.h></font> +00033 +00034 <font class="keyword">namespace </font>NLMISC +00035 { +00036 +00037 +00038 <font class="comment">// ***************************************************************************</font> +00039 <font class="keyword">const</font> <font class="keywordtype">double</font> <a class="code" href="namespaceNLMISC.html#a171">QuatEpsilon</a>= 0.000001; +00040 +00041 +00042 +00043 <font class="comment">// ***************************************************************************</font> +<a name="l00050"></a><a class="code" href="structNLMISC_1_1CAngleAxis.html">00050</a> <font class="comment"></font><font class="keyword">struct </font>CAngleAxis +00051 { +<a name="l00052"></a><a class="code" href="structNLMISC_1_1CAngleAxis.html#m0">00052</a> CVector <a class="code" href="structNLMISC_1_1CAngleAxis.html#m0">Axis</a>; +<a name="l00053"></a><a class="code" href="structNLMISC_1_1CAngleAxis.html#m1">00053</a> <font class="keywordtype">float</font> <a class="code" href="structNLMISC_1_1CAngleAxis.html#m1">Angle</a>; +00054 +<a name="l00055"></a><a class="code" href="structNLMISC_1_1CAngleAxis.html#a0">00055</a> <a class="code" href="structNLMISC_1_1CAngleAxis.html#a0">CAngleAxis</a>() {} +<a name="l00056"></a><a class="code" href="structNLMISC_1_1CAngleAxis.html#a1">00056</a> <a class="code" href="structNLMISC_1_1CAngleAxis.html#a0">CAngleAxis</a>(CVector axis, <font class="keywordtype">float</font> ang) : <a class="code" href="structNLMISC_1_1CAngleAxis.html#m0">Axis</a>(axis), <a class="code" href="structNLMISC_1_1CAngleAxis.html#m1">Angle</a>(ang) {} +00057 +<a name="l00059"></a><a class="code" href="structNLMISC_1_1CAngleAxis.html#a2">00059</a> <font class="keywordtype">void</font> <a class="code" href="structNLMISC_1_1CAngleAxis.html#a2">serial</a>(IStream &f) +00060 { +00061 f.serial(<a class="code" href="structNLMISC_1_1CAngleAxis.html#m0">Axis</a>); +00062 f.serial(<a class="code" href="structNLMISC_1_1CAngleAxis.html#m1">Angle</a>); +00063 } +00064 }; +00065 +00066 +00067 <font class="comment">// ***************************************************************************</font> +<a name="l00074"></a><a class="code" href="classNLMISC_1_1CQuatT.html">00074</a> <font class="comment"></font><font class="keyword">template</font> <<font class="keyword">class</font> T> <font class="keyword">class </font>CQuatT +00075 { +00076 <font class="keyword">public</font>: +<a name="l00077"></a><a class="code" href="classNLMISC_1_1CQuatT.html#m2">00077</a> T <a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>,<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>,<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>,<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>; +00078 +00079 +00080 <font class="keyword">public</font>: +00081 +00083 <font class="comment">// @{</font> +<a name="l00084"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">00084</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>() : <a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>((T)0.0),<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>((T)0.0),<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>((T)0.0),<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>((T)1.0) {} +<a name="l00085"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z310_1">00085</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>(T X, T Y, T Z, T W) : <a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>(X), <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>(Y), <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>(Z), <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>(W) {} +<a name="l00087"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z310_2">00087</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>(<font class="keyword">const</font> CVector &axis, <font class="keywordtype">float</font> angle) {<a class="code" href="classNLMISC_1_1CQuatT.html#z315_3">setAngleAxis</a>(axis, angle);} +<a name="l00089"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z310_3">00089</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>(<font class="keyword">const</font> CAngleAxis &aa) {<a class="code" href="classNLMISC_1_1CQuatT.html#z315_3">setAngleAxis</a>(aa);} +00090 <font class="comment">// @}</font> +00091 +00092 +00094 <font class="comment">// @{</font> +<a name="l00095"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z311_0">00095</a> <font class="keywordtype">void</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z311_0">set</a>(T X, T Y, T Z, T W) {<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>= X; <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>= Y; <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>= Z; <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>= W;} +00096 <font class="comment">// @}</font> +00097 +00099 <font class="comment">// @{</font> +<a name="l00100"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z312_0">00100</a> <font class="keywordtype">bool</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z312_0">operator==</a>(<font class="keyword">const</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>& a)<font class="keyword"> const </font>{<font class="keywordflow">return</font> (<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>==0 && <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>==0 && <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>==0 && <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>==1.0f);} +00101 <font class="keywordtype">bool</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z312_1">equal</a>(<font class="keyword">const</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>& a, <font class="keywordtype">float</font> epsilon = 1E-6f) <font class="keyword">const</font>; +<a name="l00102"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z312_2">00102</a> <font class="keywordtype">void</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z312_2">identity</a>() {<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a> = <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a> = <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a> = 0.0f ; <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a> = 1.0f; } +<a name="l00103"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z312_3">00103</a> <font class="keywordtype">bool</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z312_3">isIdentity</a>()<font class="keyword"> const </font>{<font class="keywordflow">return</font> (<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>==0.0f && <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>==0.0f && <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>==0.0f && <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>==1.0f);} +00104 <font class="comment">// @}</font> +00105 +00107 <font class="comment">// @{</font> +<a name="l00108"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z313_0">00108</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>& <a class="code" href="classNLMISC_1_1CQuatT.html#z313_0">operator+=</a>(<font class="keyword">const</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>&o) {<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>+=o.x; <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>+=o.y; <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>+=o.z; <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>+=o.w; <font class="keywordflow">return</font> *<font class="keyword">this</font>;} +<a name="l00109"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z313_1">00109</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>& <a class="code" href="classNLMISC_1_1CQuatT.html#z313_1">operator-=</a>(<font class="keyword">const</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>&o) {<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>-=o.x; <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>-=o.y; <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>-=o.z; <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>-=o.w; <font class="keywordflow">return</font> *<font class="keyword">this</font>;} +<a name="l00110"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z313_2">00110</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>& <a class="code" href="classNLMISC_1_1CQuatT.html#z313_2">operator*=</a>(T f) {<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>*=f;<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>*=f;<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>*=f;<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>*=f; <font class="keywordflow">return</font> *<font class="keyword">this</font>;} +<a name="l00111"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z313_3">00111</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>& <a class="code" href="classNLMISC_1_1CQuatT.html#z313_3">operator/=</a>(T f) {<font class="keywordtype">double</font> oof= 1.0/f; <a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>=(T)(<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>*oof); <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>=(T)(<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>*oof); <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>= (T)(<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>*oof); <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>=(T)(<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>*oof); <font class="keywordflow">return</font> *<font class="keyword">this</font>;} +<a name="l00112"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z313_4">00112</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z313_9">operator+</a>(<font class="keyword">const</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>&o)<font class="keyword"> const </font>{<font class="keywordflow">return</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>(<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>+o.x,<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>+o.y,<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>+o.z,<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>+o.w);} +<a name="l00113"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z313_5">00113</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z313_8">operator-</a>(<font class="keyword">const</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>&o)<font class="keyword"> const </font>{<font class="keywordflow">return</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>(<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>-o.x,<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>-o.y,<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>-o.z,<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>-o.w);} +<a name="l00114"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z313_6">00114</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z313_6">operator*</a>(T f)<font class="keyword"> const </font>{<font class="keywordflow">return</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>(<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>*f,<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>*f,<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>*f,<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>*f);} +<a name="l00115"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z313_7">00115</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z313_7">operator/</a>(T f)<font class="keyword"> const </font>{<font class="keywordtype">double</font> oof= 1.0/f; <font class="keywordflow">return</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>(<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>*oof,<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>*oof,<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>*oof,<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>*oof);} +<a name="l00116"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z313_8">00116</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z313_8">operator-</a>()<font class="keyword"> const </font>{<font class="keywordflow">return</font>(<a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>(-<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>,-<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>,-<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>,-<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>)); } +<a name="l00117"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z313_9">00117</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z313_9">operator+</a>()<font class="keyword"> const </font>{<font class="keywordflow">return</font> *<font class="keyword">this</font>; } +<a name="l00119"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z313_10">00119</a> T <a class="code" href="classNLMISC_1_1CQuatT.html#z313_10">sqrnorm</a>()<font class="keyword"> const </font>{<font class="keywordflow">return</font> (<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>*<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a> + <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>*<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a> + <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>*<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a> + <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>*<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>);} +<a name="l00121"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z313_11">00121</a> T <a class="code" href="classNLMISC_1_1CQuatT.html#z313_11">norm</a>()<font class="keyword"> const </font>{<font class="keywordflow">return</font> (T)sqrt(<a class="code" href="classNLMISC_1_1CQuatT.html#z313_10">sqrnorm</a>());} +00123 <font class="keywordtype">void</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z313_12">normalize</a>(); +<a name="l00125"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z313_13">00125</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z313_13">normed</a>()<font class="keyword"> const </font>{<a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> ret= *<font class="keyword">this</font>; ret.normalize(); <font class="keywordflow">return</font> ret;} +00126 <font class="comment">// @}</font> +00127 +00128 +00130 <font class="comment">// @{</font> +00132 <font class="comment"> CQuatT operator*(const CQuatT&) const; </font> +00133 <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>& <a class="code" href="classNLMISC_1_1CQuatT.html#z313_2">operator*=</a>(<font class="keyword">const</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>&); +00135 <font class="keywordtype">void</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z314_2">invert</a>(); +<a name="l00137"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z314_3">00137</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z314_3">inverted</a>()<font class="keyword"> const </font>{<a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> ret= *<font class="keyword">this</font>; ret.invert(); <font class="keywordflow">return</font> ret;} +<a name="l00139"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z314_4">00139</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z314_4">conjugate</a>()<font class="keyword"> const </font>{<font class="keywordflow">return</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a>(-<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>, -<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>, -<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>, <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>);} +00140 <font class="comment">// @}</font> +00141 +00142 +00144 <font class="comment">// @{</font> +<a name="l00146"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z315_0">00146</a> <font class="comment"> CVector getAxis() const {CVector ret((float)x,(float)y,(float)z); return ret.normed();}</font> +<a name="l00148"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z315_1">00148</a> <font class="comment"> float getAngle() const {return (float)(2*acos(w/norm()));}</font> +<a name="l00150"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z315_2">00150</a> <font class="comment"> CAngleAxis getAngleAxis() const {return CAngleAxis(getAxis(), getAngle());}</font> +00151 +00153 <font class="keywordtype">void</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z315_3">setAngleAxis</a>(<font class="keyword">const</font> CVector &axis, <font class="keywordtype">float</font> angle); +<a name="l00155"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z315_4">00155</a> <font class="keywordtype">void</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z315_3">setAngleAxis</a>(<font class="keyword">const</font> CAngleAxis &angAxis) {<a class="code" href="classNLMISC_1_1CQuatT.html#z315_3">setAngleAxis</a>(angAxis.Axis, angAxis.Angle);} +00156 <font class="comment">// @}</font> +00157 +00158 +00160 <font class="comment">// @{</font> +00162 <font class="comment"> CQuatT log();</font> +00164 <font class="comment"> CQuatT exp();</font> +00166 <font class="comment"> void makeClosest(const CQuatT &o);</font> +<a name="l00168"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z316_3">00168</a> <font class="comment"> void serial(IStream &f)</font> +00169 { +00170 f.serial(<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>,<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>,<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>,<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>); +00171 } +00172 <font class="comment">// @}</font> +00173 +00174 +00175 <font class="keyword">public</font>: +00176 +00178 <font class="comment">// @{</font> +00180 <font class="comment"> static T dotProduct(const CQuatT<T> &q0, const CQuatT<T> &q1);</font> +00184 <font class="comment"></font> <font class="keyword">static</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z317_1">slerp</a>(<font class="keyword">const</font> CQuatT<T>& q0, <font class="keyword">const</font> CQuatT<T>& q1, <font class="keywordtype">float</font> <a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>); +00188 <font class="keyword">static</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z317_2">squad</a>(<font class="keyword">const</font> CQuatT<T>& q0, <font class="keyword">const</font> CQuatT<T>& tgtQ0, <font class="keyword">const</font> CQuatT<T>& tgtQ1, <font class="keyword">const</font> CQuatT<T>& q1, <font class="keywordtype">float</font> <a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>); +00191 <font class="keyword">static</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z317_3">squadrev</a>(<font class="keyword">const</font> CAngleAxis &rot, <font class="keyword">const</font> CQuatT<T>& q0, <font class="keyword">const</font> CQuatT<T>& tgtQ0, <font class="keyword">const</font> CQuatT<T>& tgtQ1, <font class="keyword">const</font> CQuatT<T>& q1, <font class="keywordtype">float</font> <a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>); +00192 +00194 <font class="keyword">static</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> <a class="code" href="classNLMISC_1_1CQuatT.html#z317_4">lnDif</a>(<font class="keyword">const</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> &q0, <font class="keyword">const</font> <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a> &q1); +00195 +00196 <font class="comment">// @}</font> +00197 +00198 +00199 }; +00200 +00201 +00202 +00203 <font class="comment">// ***************************************************************************</font> +00204 +00205 +00207 <font class="comment">// @{</font> +00208 +00210 <font class="keyword">template</font> <<font class="keyword">class</font> T> +00211 <font class="keyword">inline</font> CQuatT<T> <a class="code" href="namespaceNLMISC.html#a273">operator*</a>(T f, <font class="keyword">const</font> CQuatT<T> &o) {<font class="keywordflow">return</font> o*f;} +00212 +00213 <font class="comment">// @}</font> +00214 +00215 +00216 +00217 <font class="comment">// ***************************************************************************</font> +00218 <font class="comment">// ***************************************************************************</font> +00219 <font class="comment">// Template implementation.</font> +00220 <font class="comment">// ***************************************************************************</font> +00221 <font class="comment">// ***************************************************************************</font> +00222 +00223 +00224 +00225 <font class="comment">// ***************************************************************************</font> +00226 <font class="keyword">template</font> <<font class="keyword">class</font> T> +<a name="l00227"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z312_1">00227</a> <font class="keyword">inline</font> <font class="keywordtype">bool</font> CQuatT<T>::equal(<font class="keyword">const</font> CQuatT<T>& a, <font class="keywordtype">float</font> epsilon)<font class="keyword"> const</font> +00228 <font class="keyword"></font>{ +00229 <font class="keywordflow">if</font> (fabs(<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>-a.x)<epsilon && +00230 fabs(<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>-a.y)<epsilon && +00231 fabs(<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>-a.z)<epsilon && +00232 fabs(<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>-a.w)<epsilon ) +00233 { +00234 <font class="keywordflow">return</font> <font class="keyword">true</font>; +00235 } +00236 <font class="keywordflow">return</font> <font class="keyword">false</font>; +00237 } +00238 +00239 +00240 <font class="comment">// ***************************************************************************</font> +00241 <font class="keyword">template</font> <<font class="keyword">class</font> T> +<a name="l00242"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z314_0">00242</a> <font class="keyword">inline</font> CQuatT<T> CQuatT<T>::operator*(<font class="keyword">const</font> CQuatT<T>& o)<font class="keyword"> const</font> +00243 <font class="keyword"></font>{ +00244 <font class="comment">// wres= ww´ - v·v´</font> +00245 <font class="comment">// vres= wv´ + w´v + v^v´ ] </font> +00246 <font class="keywordflow">return</font> CQuatT<T>( +00247 (<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>*o.x) +(<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>*o.w) + (<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>*o.z)-(<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>*o.y), +00248 (<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>*o.y) +(<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>*o.w) + (<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>*o.x)-(<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>*o.z), +00249 (<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>*o.z) +(<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>*o.w) + (<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>*o.y)-(<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>*o.x), +00250 (<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>*o.w)-(<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>*o.x)-(<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>*o.y)-(<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>*o.z) ); +00251 +00252 } +00253 +00254 <font class="comment">// ***************************************************************************</font> +00255 <font class="keyword">template</font> <<font class="keyword">class</font> T> +<a name="l00256"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z314_1">00256</a> <font class="keyword">inline</font> CQuatT<T>& CQuatT<T>::operator*=(<font class="keyword">const</font> CQuatT<T>& o) +00257 { +00258 *<font class="keyword">this</font>= *<font class="keyword">this</font> * o; +00259 <font class="keywordflow">return</font> *<font class="keyword">this</font>; +00260 } +00261 +00262 +00263 <font class="comment">// ***************************************************************************</font> +00264 <font class="keyword">template</font> <<font class="keyword">class</font> T> +<a name="l00265"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z314_2">00265</a> <font class="keyword">inline</font> <font class="keywordtype">void</font> CQuatT<T>::invert() +00266 { +00267 <font class="comment">// Must invert the norm.</font> +00268 T f= <a class="code" href="classNLMISC_1_1CQuatT.html#z313_10">sqrnorm</a>(); +00269 <font class="keywordflow">if</font>(f!=0) +00270 { +00271 *<font class="keyword">this</font>/=f; +00272 } +00273 +00274 *<font class="keyword">this</font>= <a class="code" href="classNLMISC_1_1CQuatT.html#z314_4">conjugate</a>(); +00275 } +00276 +00277 +00278 <font class="comment">// ***************************************************************************</font> +00279 <font class="keyword">template</font> <<font class="keyword">class</font> T> +<a name="l00280"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z313_12">00280</a> <font class="keyword">inline</font> <font class="keywordtype">void</font> CQuatT<T>::normalize() +00281 { +00282 T f= <a class="code" href="classNLMISC_1_1CQuatT.html#z313_11">norm</a>(); +00283 <font class="keywordflow">if</font>(f==0) +00284 <a class="code" href="classNLMISC_1_1CQuatT.html#z312_2">identity</a>(); +00285 <font class="keywordflow">else</font> +00286 { +00287 *<font class="keyword">this</font>/=f; +00288 } +00289 } +00290 +00291 +00292 <font class="comment">// ***************************************************************************</font> +00293 <font class="keyword">template</font> <<font class="keyword">class</font> T> +<a name="l00294"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z315_3">00294</a> <font class="keyword">inline</font> <font class="keywordtype">void</font> CQuatT<T>::setAngleAxis(<font class="keyword">const</font> CVector &axis, <font class="keywordtype">float</font> angle) +00295 { +00296 CVector <a class="code" href="driver__opengl__extension__def_8h.html#a368">v</a>= axis; +00297 <a class="code" href="driver__opengl__extension__def_8h.html#a368">v</a>.normalize(); +00298 <font class="keywordtype">double</font> ca= cos(angle/2); +00299 <font class="keywordtype">double</font> sa= sin(angle/2); +00300 <a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>= (T)(<a class="code" href="driver__opengl__extension__def_8h.html#a368">v</a>.x*sa); +00301 <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>= (T)(<a class="code" href="driver__opengl__extension__def_8h.html#a368">v</a>.y*sa); +00302 <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>= (T)(<a class="code" href="driver__opengl__extension__def_8h.html#a368">v</a>.z*sa); +00303 <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>= (T)(ca); +00304 } +00305 +00306 +00307 <font class="comment">// ***************************************************************************</font> +00308 <font class="keyword">template</font> <<font class="keyword">class</font> T> +<a name="l00309"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z317_0">00309</a> T CQuatT<T>::dotProduct(<font class="keyword">const</font> CQuatT<T> &q0, <font class="keyword">const</font> CQuatT<T> &q1) +00310 { +00311 <font class="keywordflow">return</font> q0.x*q1.x + q0.y*q1.y + q0.z*q1.z + q0.w*q1.w; +00312 } +00313 +00314 +00315 <font class="comment">// ***************************************************************************</font> +00316 <font class="keyword">template</font> <<font class="keyword">class</font> T> +<a name="l00317"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z317_1">00317</a> CQuatT<T> CQuatT<T>::slerp(<font class="keyword">const</font> CQuatT<T>& q0, <font class="keyword">const</font> CQuatT<T>& q1, <font class="keywordtype">float</font> <a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>) +00318 { +00319 <font class="comment">// omega is the 4D angle between q0 and q1.</font> +00320 <font class="keywordtype">double</font> omega, cosom,sinom; +00321 T factq0= 1; +00322 T s0,s1; +00323 +00324 cosom = CQuatT<T>::dotProduct(q0, q1); +00325 +00326 <font class="comment">// Make q0 and q1 on the same hemisphere.</font> +00327 <font class="comment">/*if(cosom<0)</font> +00328 <font class="comment"> {</font> +00329 <font class="comment"> cosom= -cosom;</font> +00330 <font class="comment"> factq0= -1;</font> +00331 <font class="comment"> }*/</font> +00332 <font class="comment">// ????</font> +00333 +00334 <font class="keywordflow">if</font> ( cosom < 1.0 - NLMISC::QuatEpsilon) +00335 { +00336 omega = acos(cosom); +00337 sinom = sin(omega); +00338 s0 = (T) (sin((1.0f - <a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>)*omega) / sinom); +00339 s1 = (T) (sin(<a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>*omega) / sinom); +00340 } +00341 <font class="keywordflow">else</font> +00342 { <font class="comment">// q0 and q1 are nearly the same => sinom nearly 0. We can't slerp.</font> +00343 <font class="comment">// just linear interpolate.</font> +00344 s0 = (T)(1.0 - <a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>); +00345 s1 = <a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>; +00346 } +00347 +00348 <font class="keywordflow">return</font> q0*(factq0*s0) + q1*s1; +00349 +00350 } +00351 +00352 +00353 <font class="comment">// ***************************************************************************</font> +00354 <font class="keyword">template</font> <<font class="keyword">class</font> T> +<a name="l00355"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z317_2">00355</a> CQuatT<T> CQuatT<T>::squad(<font class="keyword">const</font> CQuatT<T>& q0, <font class="keyword">const</font> CQuatT<T>& tgtQ0, <font class="keyword">const</font> CQuatT<T>& tgtQ1, <font class="keyword">const</font> CQuatT<T>& q1, <font class="keywordtype">float</font> <a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>) +00356 { +00357 <font class="keywordflow">return</font> CQuatT<T>::slerp( +00358 CQuatT<T>::<a class="code" href="classNLMISC_1_1CQuatT.html#z317_1">slerp</a>(q0, q1, <a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>), +00359 CQuatT<T>::<a class="code" href="classNLMISC_1_1CQuatT.html#z317_1">slerp</a>(tgtQ0, tgtQ1, <a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>), +00360 2.f*(1.f-<a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>)*<a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>); +00361 } +00362 +00363 +00364 <font class="comment">// ***************************************************************************</font> +00365 <font class="keyword">template</font> <<font class="keyword">class</font> T> +<a name="l00366"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z317_3">00366</a> CQuatT<T> CQuatT<T>::squadrev(<font class="keyword">const</font> CAngleAxis &rot, <font class="keyword">const</font> CQuatT<T>& q0, <font class="keyword">const</font> CQuatT<T>& tgtQ0, <font class="keyword">const</font> CQuatT<T>& tgtQ1, <font class="keyword">const</font> CQuatT<T>& q1, <font class="keywordtype">float</font> <a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>) +00367 { +00368 <font class="keywordtype">float</font> <a class="code" href="driver__opengl__extension__def_8h.html#a383">s</a>,<a class="code" href="driver__opengl__extension__def_8h.html#a368">v</a>; +00369 <font class="keywordtype">float</font> omega = rot.Angle* 0.5f; +00370 <font class="keywordtype">float</font> nrevs = 0.0f; +00371 CQuatT<T> ret,qaxis,pp,qq; +00372 +00373 <font class="comment">// just one rev?</font> +00374 <font class="comment">//==============</font> +00375 <font class="keywordflow">if</font> (omega<<a class="code" href="namespaceNLMISC.html#a7">Pi</a>-<a class="code" href="namespaceNLMISC.html#a171">QuatEpsilon</a>) +00376 { +00377 ret = CQuatT<T>::squad(q0,tgtQ0,tgtQ1,q1,<a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>); +00378 <font class="keywordflow">return</font> ret; +00379 } +00380 +00381 +00382 <font class="comment">// multirev.</font> +00383 <font class="comment">//==============</font> +00384 +00385 <font class="comment">// rotation of 180° around rot.Axis. (=> sin(a/2)==sin(Pi/2)==1, and c(a/2)=0).</font> +00386 qaxis.set(rot.Axis.x, rot.Axis.y, rot.Axis.z, 0); +00387 +00388 <font class="comment">// the number of revisions (float!)</font> +00389 nrevs= (float)(omega/<a class="code" href="namespaceNLMISC.html#a7">Pi</a>); +00390 <font class="comment">// Angle>2Pi. squad from 0 to Pi, slerp from Pi to Angle-Pi, squad from Angle-Pi to Angle.</font> +00391 <a class="code" href="driver__opengl__extension__def_8h.html#a383">s</a> = <a class="code" href="driver__opengl__extension__def_8h.html#a384">t</a>*2*nrevs; +00392 +00393 +00394 <font class="comment">// So for s, squad from 0 to 1, slerp from 1 to 2*nrevs-1, squad from 2*nrevs-1 to 2*nrevs.</font> +00395 <font class="keywordflow">if</font> (<a class="code" href="driver__opengl__extension__def_8h.html#a383">s</a> < 1.0f) +00396 { +00397 <font class="comment">// first part.</font> +00398 pp = q0*qaxis; +00399 ret = CQuatT<T>::squad(q0,tgtQ0,pp,pp,<a class="code" href="driver__opengl__extension__def_8h.html#a383">s</a>); +00400 } +00401 <font class="keywordflow">else</font> +00402 { +00403 <a class="code" href="driver__opengl__extension__def_8h.html#a368">v</a> = <a class="code" href="driver__opengl__extension__def_8h.html#a383">s</a> - (2.0f*nrevs - 1.0f); +00404 <font class="keywordflow">if</font>( <a class="code" href="driver__opengl__extension__def_8h.html#a368">v</a> <= 0.0f) +00405 { +00406 <font class="comment">// middle part</font> +00407 <font class="keywordflow">while</font> (<a class="code" href="driver__opengl__extension__def_8h.html#a383">s</a> >= 2.0f) <a class="code" href="driver__opengl__extension__def_8h.html#a383">s</a> -= 2.0f; +00408 pp = q0*qaxis; +00409 <font class="comment">// s vary from 1 to 2. This is still correct for slerp().</font> +00410 ret = CQuatT<T>::slerp(q0,pp,<a class="code" href="driver__opengl__extension__def_8h.html#a383">s</a>); +00411 } +00412 <font class="keywordflow">else</font> +00413 { +00414 <font class="comment">// Last part.</font> +00415 qq = - q1*qaxis; +00416 ret= CQuatT<T>::squad(qq,qq,tgtQ1,q1,<a class="code" href="driver__opengl__extension__def_8h.html#a368">v</a>); +00417 } +00418 } +00419 +00420 <font class="keywordflow">return</font> ret; +00421 } +00422 +00423 +00424 +00425 <font class="comment">// ***************************************************************************</font> +00426 <font class="keyword">template</font> <<font class="keyword">class</font> T> +<a name="l00427"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z316_0">00427</a> CQuatT<T> CQuatT<T>::log() +00428 { +00429 <font class="keywordtype">double</font> len; +00430 len = sqrt (<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>*<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a> + <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>*<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a> + <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>*<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>); +00431 +00432 <font class="keywordflow">if</font> (len < <a class="code" href="namespaceNLMISC.html#a171">QuatEpsilon</a>) +00433 <font class="keywordflow">return</font> CQuatT<T>(0.f, 0.f, 0.f, 0.f); +00434 <font class="keywordflow">else</font> +00435 { +00436 <font class="keywordtype">double</font> div = (float) acos (<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>) / len; +00437 <font class="keywordflow">return</font> CQuatT<T>( (T)(<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>*div), (T)(<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>*div), (T)(<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>*div), 0.f); +00438 } +00439 +00440 } +00441 +00442 +00443 <font class="comment">// ***************************************************************************</font> +00444 <font class="keyword">template</font> <<font class="keyword">class</font> T> +<a name="l00445"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z316_1">00445</a> CQuatT<T> CQuatT<T>::exp() +00446 { +00447 <font class="keywordtype">double</font> len; +00448 len = sqrt (<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>*<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a> + <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>*<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a> + <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>*<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>); +00449 +00450 <font class="keywordflow">if</font> (len < <a class="code" href="namespaceNLMISC.html#a171">QuatEpsilon</a>) +00451 <font class="keywordflow">return</font> CQuatT<T>(0.f, 0.f, 0.f, 1.f); +00452 <font class="keywordflow">else</font> +00453 { +00454 <font class="keywordtype">double</font> len1 = sin(len) / len; +00455 <font class="keywordflow">return</font> CQuatT<T>( (T)(<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>*len1), (T)(<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>*len1), (T)(<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>*len1), (T)cos(len)); +00456 } +00457 } +00458 +00459 +00460 <font class="comment">// ***************************************************************************</font> +00461 <font class="keyword">template</font> <<font class="keyword">class</font> T> +<a name="l00462"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z317_4">00462</a> CQuatT<T> CQuatT<T>::lnDif(<font class="keyword">const</font> CQuatT<T> &q0, <font class="keyword">const</font> CQuatT<T> &q1) +00463 { +00464 CQuatT<T> dif = q0.inverted()*q1; +00465 dif.normalize(); +00466 +00467 <font class="keywordflow">return</font> dif.log(); +00468 } +00469 +00470 +00471 <font class="comment">// ***************************************************************************</font> +00472 <font class="keyword">template</font> <<font class="keyword">class</font> T> +<a name="l00473"></a><a class="code" href="classNLMISC_1_1CQuatT.html#z316_2">00473</a> <font class="keywordtype">void</font> CQuatT<T>::makeClosest(<font class="keyword">const</font> CQuatT<T> &o) +00474 { +00475 <font class="keywordflow">if</font>( <a class="code" href="classNLMISC_1_1CQuatT.html#z317_0">dotProduct</a>(*<font class="keyword">this</font>, o) < 0 ) +00476 *<font class="keyword">this</font>= -(*this); +00477 } +00478 +00479 +00480 +00481 <font class="comment">// ***************************************************************************</font> +00482 <font class="comment">// ***************************************************************************</font> +00483 <font class="comment">// CQuat/CQuatD</font> +00484 <font class="comment">// ***************************************************************************</font> +00485 <font class="comment">// ***************************************************************************</font> +00486 +00487 +00488 +00489 <font class="comment">// ***************************************************************************</font> +<a name="l00496"></a><a class="code" href="classNLMISC_1_1CQuat.html">00496</a> <font class="comment"></font><font class="keyword">class </font>CQuat : <font class="keyword">public</font> CQuatT<float> +00497 { +00498 <font class="keyword">public</font>: +00499 <font class="keyword">static</font> <font class="keyword">const</font> <a class="code" href="classNLMISC_1_1CQuat.html#z318_1">CQuat</a> <a class="code" href="classNLMISC_1_1CQuat.html#p0">Identity</a>; +00500 +00502 <font class="comment">// @{</font> +<a name="l00503"></a><a class="code" href="classNLMISC_1_1CQuat.html#z318_0">00503</a> <a class="code" href="classNLMISC_1_1CQuat.html#z318_1">CQuat</a> &<a class="code" href="classNLMISC_1_1CQuat.html#z318_0">operator=</a>(<font class="keyword">const</font> CQuatT<float> &o) {<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>=o.x; <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>=o.y; <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>=o.z; <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>=o.w; <font class="keywordflow">return</font> *<font class="keyword">this</font>;} +<a name="l00504"></a><a class="code" href="classNLMISC_1_1CQuat.html#z318_1">00504</a> <a class="code" href="classNLMISC_1_1CQuat.html#z318_2">CQuat</a>(<font class="keyword">const</font> CQuatT<float> &o) : <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a><float>(o) {} +<a name="l00505"></a><a class="code" href="classNLMISC_1_1CQuat.html#z318_2">00505</a> <a class="code" href="classNLMISC_1_1CQuat.html#z318_2">CQuat</a>() {} +<a name="l00506"></a><a class="code" href="classNLMISC_1_1CQuat.html#z318_3">00506</a> <a class="code" href="classNLMISC_1_1CQuat.html#z318_2">CQuat</a>(<font class="keywordtype">float</font> X, <font class="keywordtype">float</font> Y, <font class="keywordtype">float</font> Z, <font class="keywordtype">float</font> W) : <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a><float>(X,Y,Z,W) {} +<a name="l00508"></a><a class="code" href="classNLMISC_1_1CQuat.html#z318_4">00508</a> <a class="code" href="classNLMISC_1_1CQuat.html#z318_2">CQuat</a>(<font class="keyword">const</font> CVector &axis, <font class="keywordtype">float</font> angle) : <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a><float>(axis, angle) {} +<a name="l00510"></a><a class="code" href="classNLMISC_1_1CQuat.html#z318_5">00510</a> <a class="code" href="classNLMISC_1_1CQuat.html#z318_2">CQuat</a>(<font class="keyword">const</font> CAngleAxis &aa) : <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a><float>(aa) {} +00511 <font class="comment">// @}</font> +00512 +00513 }; +00514 +00515 +00516 <font class="comment">// ***************************************************************************</font> +<a name="l00523"></a><a class="code" href="classNLMISC_1_1CQuatD.html">00523</a> <font class="comment"></font><font class="keyword">class </font>CQuatD : <font class="keyword">public</font> CQuatT<double> +00524 { +00525 <font class="keyword">public</font>: +00526 <font class="keyword">static</font> <font class="keyword">const</font> <a class="code" href="classNLMISC_1_1CQuatD.html#z319_1">CQuatD</a> <a class="code" href="classNLMISC_1_1CQuatD.html#p0">Identity</a>; +00527 +00529 <font class="comment">// @{</font> +<a name="l00530"></a><a class="code" href="classNLMISC_1_1CQuatD.html#z319_0">00530</a> <a class="code" href="classNLMISC_1_1CQuatD.html#z319_1">CQuatD</a> &<a class="code" href="classNLMISC_1_1CQuatD.html#z319_0">operator=</a>(<font class="keyword">const</font> CQuatT<double> &o) {<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>=o.x; <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>=o.y; <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>=o.z; <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>=o.w; <font class="keywordflow">return</font> *<font class="keyword">this</font>;} +<a name="l00531"></a><a class="code" href="classNLMISC_1_1CQuatD.html#z319_1">00531</a> <a class="code" href="classNLMISC_1_1CQuatD.html#z319_2">CQuatD</a>(<font class="keyword">const</font> CQuatT<double> &o) : <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a><double>(o) {} +<a name="l00532"></a><a class="code" href="classNLMISC_1_1CQuatD.html#z319_2">00532</a> <a class="code" href="classNLMISC_1_1CQuatD.html#z319_2">CQuatD</a>() {} +<a name="l00533"></a><a class="code" href="classNLMISC_1_1CQuatD.html#z319_3">00533</a> <a class="code" href="classNLMISC_1_1CQuatD.html#z319_2">CQuatD</a>(<font class="keywordtype">double</font> X, <font class="keywordtype">double</font> Y, <font class="keywordtype">double</font> Z, <font class="keywordtype">double</font> W) : <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a><double>(X,Y,Z,W) {} +<a name="l00535"></a><a class="code" href="classNLMISC_1_1CQuatD.html#z319_4">00535</a> <a class="code" href="classNLMISC_1_1CQuatD.html#z319_2">CQuatD</a>(<font class="keyword">const</font> CVector &axis, <font class="keywordtype">float</font> angle) : <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a><double>(axis, angle) {} +<a name="l00537"></a><a class="code" href="classNLMISC_1_1CQuatD.html#z319_5">00537</a> <a class="code" href="classNLMISC_1_1CQuatD.html#z319_2">CQuatD</a>(<font class="keyword">const</font> CAngleAxis &aa) : <a class="code" href="classNLMISC_1_1CQuatT.html#z310_0">CQuatT</a><double>(aa) {} +00538 <font class="comment">// @}</font> +00539 +00540 +00542 <font class="comment">// @{</font> +<a name="l00543"></a><a class="code" href="classNLMISC_1_1CQuatD.html#z320_0">00543</a> <a class="code" href="classNLMISC_1_1CQuatD.html#z319_2">CQuatD</a>(<font class="keyword">const</font> CQuat &o) {<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>=o.x; <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>=o.y; <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>=o.z; <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>=o.w;} +<a name="l00544"></a><a class="code" href="classNLMISC_1_1CQuatD.html#z320_1">00544</a> <a class="code" href="classNLMISC_1_1CQuatD.html#z319_1">CQuatD</a> &<a class="code" href="classNLMISC_1_1CQuatD.html#z319_0">operator=</a>(<font class="keyword">const</font> CQuatT<float> &o) {<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>=o.x; <a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>=o.y; <a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>=o.z; <a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>=o.w; <font class="keywordflow">return</font> *<font class="keyword">this</font>;} +<a name="l00545"></a><a class="code" href="classNLMISC_1_1CQuatD.html#z320_2">00545</a> operator CQuat()<font class="keyword"> const </font>{<font class="keywordflow">return</font> CQuat((<font class="keywordtype">float</font>)<a class="code" href="classNLMISC_1_1CQuatT.html#m0">x</a>, (<font class="keywordtype">float</font>)<a class="code" href="classNLMISC_1_1CQuatT.html#m1">y</a>, (<font class="keywordtype">float</font>)<a class="code" href="classNLMISC_1_1CQuatT.html#m2">z</a>, (<font class="keywordtype">float</font>)<a class="code" href="classNLMISC_1_1CQuatT.html#m3">w</a>);} +00546 <font class="comment">// @}</font> +00547 +00548 }; +00549 +00550 +00551 +00552 +00553 +00554 } <font class="comment">// NLMISC</font> +00555 +00556 <font class="preprocessor">#endif // NL_QUAT_H </font> +00557 <font class="preprocessor"></font> +</pre></div> + +<!-- footer --> +<BR><FONT Size=+5> </FONT> +</TD> +<TD WIDTH=15><IMG SRC=http://www.nevrax.org/inc/img/pixel.gif WIDTH=15 HEIGHT=15 BORDER=0 ALT=""></TD> +</TR> +</TABLE> +</BODY> +</HTML> |