diff options
author | Andrey Lihatskiy <alihatskiy@productengine.com> | 2024-05-15 11:16:27 +0300 |
---|---|---|
committer | Andrey Lihatskiy <alihatskiy@productengine.com> | 2024-05-15 11:16:27 +0300 |
commit | bccc10db9a90d365c353baebf443fde2030ce970 (patch) | |
tree | 2c2e1fd94b29667a809f8d7285d049f5ff5d424d /indra/llmath/llquaternion2.h | |
parent | 531cd34f670170ade57f8813fe48012b61a1d3c2 (diff) | |
parent | bb3c36f5cbc0c3b542045fd27255eee24e03da22 (diff) |
Merge branch 'main' into marchcat/x-b-merge
# Conflicts:
# autobuild.xml
# indra/cmake/ConfigurePkgConfig.cmake
# indra/cmake/ICU4C.cmake
# indra/media_plugins/gstreamer010/llmediaimplgstreamer_syms.cpp
# indra/media_plugins/gstreamer010/llmediaimplgstreamer_syms.h
# indra/media_plugins/gstreamer010/llmediaimplgstreamertriviallogging.h
# indra/media_plugins/gstreamer010/llmediaimplgstreamervidplug.cpp
# indra/media_plugins/gstreamer010/llmediaimplgstreamervidplug.h
# indra/media_plugins/gstreamer010/media_plugin_gstreamer010.cpp
# indra/newview/llappviewerlinux_api.h
# indra/newview/llappviewerlinux_api_dbus.cpp
# indra/newview/llappviewerlinux_api_dbus.h
# indra/newview/llfloateremojipicker.cpp
# indra/newview/lloutfitslist.cpp
Diffstat (limited to 'indra/llmath/llquaternion2.h')
-rw-r--r-- | indra/llmath/llquaternion2.h | 96 |
1 files changed, 48 insertions, 48 deletions
diff --git a/indra/llmath/llquaternion2.h b/indra/llmath/llquaternion2.h index fd9c0cf3ab..902bfb7134 100644 --- a/indra/llmath/llquaternion2.h +++ b/indra/llmath/llquaternion2.h @@ -1,31 +1,31 @@ -/** +/** * @file llquaternion2.h * @brief LLQuaternion2 class header file - SIMD-enabled quaternion class * * $LicenseInfo:firstyear=2010&license=viewerlgpl$ * Second Life Viewer Source Code * Copyright (C) 2010, Linden Research, Inc. - * + * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; * version 2.1 of the License only. - * + * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. - * + * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA - * + * * Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA * $/LicenseInfo$ */ -#ifndef LL_QUATERNION2_H -#define LL_QUATERNION2_H +#ifndef LL_QUATERNION2_H +#define LL_QUATERNION2_H ///////////////////////////// // LLQuaternion2 @@ -44,61 +44,61 @@ class LLQuaternion2 { public: - ////////////////////////// - // Ctors - ////////////////////////// - - // Ctor - LLQuaternion2() {} + ////////////////////////// + // Ctors + ////////////////////////// + + // Ctor + LLQuaternion2() {} + + // Ctor from LLQuaternion + explicit LLQuaternion2( const class LLQuaternion& quat ); - // Ctor from LLQuaternion - explicit LLQuaternion2( const class LLQuaternion& quat ); + ////////////////////////// + // Get/Set + ////////////////////////// - ////////////////////////// - // Get/Set - ////////////////////////// + // Load from an LLQuaternion + inline void operator=( const LLQuaternion& quat ) + { + mQ.loadua( quat.mQ ); + } - // Load from an LLQuaternion - inline void operator=( const LLQuaternion& quat ) - { - mQ.loadua( quat.mQ ); - } + // Return the internal LLVector4a representation of the quaternion + inline const LLVector4a& getVector4a() const; + inline LLVector4a& getVector4aRw(); - // Return the internal LLVector4a representation of the quaternion - inline const LLVector4a& getVector4a() const; - inline LLVector4a& getVector4aRw(); + ///////////////////////// + // Quaternion modification + ///////////////////////// - ///////////////////////// - // Quaternion modification - ///////////////////////// - - // Set this quaternion to the conjugate of src - inline void setConjugate(const LLQuaternion2& src); + // Set this quaternion to the conjugate of src + inline void setConjugate(const LLQuaternion2& src); - // Renormalizes the quaternion. Assumes it has nonzero length. - inline void normalize(); + // Renormalizes the quaternion. Assumes it has nonzero length. + inline void normalize(); - // Quantize this quaternion to 8 bit precision - inline void quantize8(); + // Quantize this quaternion to 8 bit precision + inline void quantize8(); - // Quantize this quaternion to 16 bit precision - inline void quantize16(); + // Quantize this quaternion to 16 bit precision + inline void quantize16(); - ///////////////////////// - // Quaternion inspection - ///////////////////////// + ///////////////////////// + // Quaternion inspection + ///////////////////////// - // Return true if this quaternion is equal to 'rhs'. - // Note! Quaternions exhibit "double-cover", so any rotation has two equally valid - // quaternion representations and they will NOT compare equal. - inline bool equals(const LLQuaternion2& rhs, F32 tolerance = F_APPROXIMATELY_ZERO ) const; + // Return true if this quaternion is equal to 'rhs'. + // Note! Quaternions exhibit "double-cover", so any rotation has two equally valid + // quaternion representations and they will NOT compare equal. + inline bool equals(const LLQuaternion2& rhs, F32 tolerance = F_APPROXIMATELY_ZERO ) const; - // Return true if all components are finite and the quaternion is normalized - inline bool isOkRotation() const; + // Return true if all components are finite and the quaternion is normalized + inline bool isOkRotation() const; protected: - LLVector4a mQ; + LLVector4a mQ; }; |