00001 /************************************************************** ggt-head beg 00002 * 00003 * GGT: Generic Graphics Toolkit 00004 * 00005 * Original Authors: 00006 * Allen Bierbaum 00007 * 00008 * ----------------------------------------------------------------- 00009 * File: $RCSfile: EulerAngleOps.h,v $ 00010 * Date modified: $Date: 2003/03/03 00:54:04 $ 00011 * Version: $Revision: 1.4 $ 00012 * ----------------------------------------------------------------- 00013 * 00014 *********************************************************** ggt-head end */ 00015 /*************************************************************** ggt-cpr beg 00016 * 00017 * GGT: The Generic Graphics Toolkit 00018 * Copyright (C) 2001,2002 Allen Bierbaum 00019 * 00020 * This library is free software; you can redistribute it and/or 00021 * modify it under the terms of the GNU Lesser General Public 00022 * License as published by the Free Software Foundation; either 00023 * version 2.1 of the License, or (at your option) any later version. 00024 * 00025 * This library is distributed in the hope that it will be useful, 00026 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00027 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 00028 * Lesser General Public License for more details. 00029 * 00030 * You should have received a copy of the GNU Lesser General Public 00031 * License along with this library; if not, write to the Free Software 00032 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA 00033 * 00034 ************************************************************ ggt-cpr end */ 00035 #ifndef _GMTL_EULER_ANGLE_OPS_H_ 00036 #define _GMTL_EULER_ANGLE_OPS_H_ 00037 00038 #include <gmtl/EulerAngle.h> 00039 00040 namespace gmtl 00041 { 00042 00056 template<class DATA_TYPE, typename ROT_ORDER> 00057 inline bool operator==(const EulerAngle<DATA_TYPE, ROT_ORDER>& e1, 00058 const EulerAngle<DATA_TYPE, ROT_ORDER>& e2) 00059 { 00060 // @todo metaprogramming. 00061 if (e1[0] != e2[0]) return false; 00062 if (e1[1] != e2[1]) return false; 00063 if (e1[2] != e2[2]) return false; 00064 return true; 00065 } 00066 00075 template<class DATA_TYPE, typename ROT_ORDER> 00076 inline bool operator!=(const EulerAngle<DATA_TYPE, ROT_ORDER>& e1, 00077 const EulerAngle<DATA_TYPE, ROT_ORDER>& e2) 00078 { 00079 return(! (e1 == e2)); 00080 } 00081 00094 template<class DATA_TYPE, typename ROT_ORDER> 00095 inline bool isEqual( const EulerAngle<DATA_TYPE, ROT_ORDER>& e1, 00096 const EulerAngle<DATA_TYPE, ROT_ORDER>& e2, 00097 const DATA_TYPE& eps = (DATA_TYPE)0 ) 00098 { 00099 gmtlASSERT(eps >= (DATA_TYPE)0); 00100 00101 // @todo metaprogramming. 00102 if (!Math::isEqual( e1[0], e2[0], eps )) return false; 00103 if (!Math::isEqual( e1[1], e2[1], eps )) return false; 00104 if (!Math::isEqual( e1[2], e2[2], eps )) return false; 00105 return true; 00106 } 00107 00108 // @todo write isEquiv function for EulerAngle 00109 00110 00113 } // namespace 00114 00115 #endif