Blame Imath/ImathVec.h

Packit 8dc392
///////////////////////////////////////////////////////////////////////////
Packit 8dc392
//
Packit 8dc392
// Copyright (c) 2004-2012, Industrial Light & Magic, a division of Lucas
Packit 8dc392
// Digital Ltd. LLC
Packit 8dc392
// 
Packit 8dc392
// All rights reserved.
Packit 8dc392
// 
Packit 8dc392
// Redistribution and use in source and binary forms, with or without
Packit 8dc392
// modification, are permitted provided that the following conditions are
Packit 8dc392
// met:
Packit 8dc392
// *       Redistributions of source code must retain the above copyright
Packit 8dc392
// notice, this list of conditions and the following disclaimer.
Packit 8dc392
// *       Redistributions in binary form must reproduce the above
Packit 8dc392
// copyright notice, this list of conditions and the following disclaimer
Packit 8dc392
// in the documentation and/or other materials provided with the
Packit 8dc392
// distribution.
Packit 8dc392
// *       Neither the name of Industrial Light & Magic nor the names of
Packit 8dc392
// its contributors may be used to endorse or promote products derived
Packit 8dc392
// from this software without specific prior written permission. 
Packit 8dc392
// 
Packit 8dc392
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
Packit 8dc392
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
Packit 8dc392
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
Packit 8dc392
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
Packit 8dc392
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
Packit 8dc392
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
Packit 8dc392
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
Packit 8dc392
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
Packit 8dc392
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
Packit 8dc392
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Packit 8dc392
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Packit 8dc392
//
Packit 8dc392
///////////////////////////////////////////////////////////////////////////
Packit 8dc392
Packit 8dc392
Packit 8dc392
Packit 8dc392
#ifndef INCLUDED_IMATHVEC_H
Packit 8dc392
#define INCLUDED_IMATHVEC_H
Packit 8dc392
Packit 8dc392
//----------------------------------------------------
Packit 8dc392
//
Packit 8dc392
//	2D, 3D and 4D point/vector class templates
Packit 8dc392
//
Packit 8dc392
//----------------------------------------------------
Packit 8dc392
Packit 8dc392
#include "ImathExc.h"
Packit 8dc392
#include "ImathLimits.h"
Packit 8dc392
#include "ImathMath.h"
Packit 8dc392
#include "ImathNamespace.h"
Packit 8dc392
Packit 8dc392
#include <iostream>
Packit 8dc392
Packit 8dc392
#if (defined _WIN32 || defined _WIN64) && defined _MSC_VER
Packit 8dc392
// suppress exception specification warnings
Packit 8dc392
#pragma warning(push)
Packit 8dc392
#pragma warning(disable:4290)
Packit 8dc392
#endif
Packit 8dc392
Packit 8dc392
Packit 8dc392
IMATH_INTERNAL_NAMESPACE_HEADER_ENTER
Packit 8dc392
Packit 8dc392
template <class T> class Vec2;
Packit 8dc392
template <class T> class Vec3;
Packit 8dc392
template <class T> class Vec4;
Packit 8dc392
Packit 8dc392
enum InfException {INF_EXCEPTION};
Packit 8dc392
Packit 8dc392
Packit 8dc392
template <class T> class Vec2
Packit 8dc392
{
Packit 8dc392
  public:
Packit 8dc392
Packit 8dc392
    //-------------------
Packit 8dc392
    // Access to elements
Packit 8dc392
    //-------------------
Packit 8dc392
Packit 8dc392
    T			x, y;
Packit 8dc392
Packit 8dc392
    T &			operator [] (int i);
Packit 8dc392
    const T &		operator [] (int i) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //-------------
Packit 8dc392
    // Constructors
Packit 8dc392
    //-------------
Packit 8dc392
Packit 8dc392
    Vec2 ();                        // no initialization
Packit 8dc392
    explicit Vec2 (T a);            // (a a)
Packit 8dc392
    Vec2 (T a, T b);                // (a b)
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //---------------------------------
Packit 8dc392
    // Copy constructors and assignment
Packit 8dc392
    //---------------------------------
Packit 8dc392
Packit 8dc392
    Vec2 (const Vec2 &v);
Packit 8dc392
    template <class S> Vec2 (const Vec2<S> &v);
Packit 8dc392
Packit 8dc392
    const Vec2 &	operator = (const Vec2 &v);
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //----------------------
Packit 8dc392
    // Compatibility with Sb
Packit 8dc392
    //----------------------
Packit 8dc392
Packit 8dc392
    template <class S>
Packit 8dc392
    void		setValue (S a, S b);
Packit 8dc392
Packit 8dc392
    template <class S>
Packit 8dc392
    void		setValue (const Vec2<S> &v);
Packit 8dc392
Packit 8dc392
    template <class S>
Packit 8dc392
    void		getValue (S &a, S &b) const;
Packit 8dc392
Packit 8dc392
    template <class S>
Packit 8dc392
    void		getValue (Vec2<S> &v) const;
Packit 8dc392
Packit 8dc392
    T *			getValue ();
Packit 8dc392
    const T *		getValue () const;
Packit 8dc392
Packit 8dc392
    
Packit 8dc392
    //---------
Packit 8dc392
    // Equality
Packit 8dc392
    //---------
Packit 8dc392
Packit 8dc392
    template <class S>
Packit 8dc392
    bool		operator == (const Vec2<S> &v) const;
Packit 8dc392
Packit 8dc392
    template <class S>
Packit 8dc392
    bool		operator != (const Vec2<S> &v) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //-----------------------------------------------------------------------
Packit 8dc392
    // Compare two vectors and test if they are "approximately equal":
Packit 8dc392
    //
Packit 8dc392
    // equalWithAbsError (v, e)
Packit 8dc392
    //
Packit 8dc392
    //	    Returns true if the coefficients of this and v are the same with
Packit 8dc392
    //	    an absolute error of no more than e, i.e., for all i
Packit 8dc392
    //
Packit 8dc392
    //      abs (this[i] - v[i]) <= e
Packit 8dc392
    //
Packit 8dc392
    // equalWithRelError (v, e)
Packit 8dc392
    //
Packit 8dc392
    //	    Returns true if the coefficients of this and v are the same with
Packit 8dc392
    //	    a relative error of no more than e, i.e., for all i
Packit 8dc392
    //
Packit 8dc392
    //      abs (this[i] - v[i]) <= e * abs (this[i])
Packit 8dc392
    //-----------------------------------------------------------------------
Packit 8dc392
Packit 8dc392
    bool		equalWithAbsError (const Vec2<T> &v, T e) const;
Packit 8dc392
    bool		equalWithRelError (const Vec2<T> &v, T e) const;
Packit 8dc392
Packit 8dc392
    //------------
Packit 8dc392
    // Dot product
Packit 8dc392
    //------------
Packit 8dc392
Packit 8dc392
    T			dot (const Vec2 &v) const;
Packit 8dc392
    T			operator ^ (const Vec2 &v) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //------------------------------------------------
Packit 8dc392
    // Right-handed cross product, i.e. z component of
Packit 8dc392
    // Vec3 (this->x, this->y, 0) % Vec3 (v.x, v.y, 0)
Packit 8dc392
    //------------------------------------------------
Packit 8dc392
Packit 8dc392
    T			cross (const Vec2 &v) const;
Packit 8dc392
    T			operator % (const Vec2 &v) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //------------------------
Packit 8dc392
    // Component-wise addition
Packit 8dc392
    //------------------------
Packit 8dc392
Packit 8dc392
    const Vec2 &	operator += (const Vec2 &v);
Packit 8dc392
    Vec2		operator + (const Vec2 &v) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //---------------------------
Packit 8dc392
    // Component-wise subtraction
Packit 8dc392
    //---------------------------
Packit 8dc392
Packit 8dc392
    const Vec2 &	operator -= (const Vec2 &v);
Packit 8dc392
    Vec2		operator - (const Vec2 &v) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //------------------------------------
Packit 8dc392
    // Component-wise multiplication by -1
Packit 8dc392
    //------------------------------------
Packit 8dc392
Packit 8dc392
    Vec2		operator - () const;
Packit 8dc392
    const Vec2 &	negate ();
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //------------------------------
Packit 8dc392
    // Component-wise multiplication
Packit 8dc392
    //------------------------------
Packit 8dc392
Packit 8dc392
    const Vec2 &	operator *= (const Vec2 &v);
Packit 8dc392
    const Vec2 &	operator *= (T a);
Packit 8dc392
    Vec2		operator * (const Vec2 &v) const;
Packit 8dc392
    Vec2		operator * (T a) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //------------------------
Packit 8dc392
    // Component-wise division
Packit 8dc392
    //------------------------
Packit 8dc392
Packit 8dc392
    const Vec2 &	operator /= (const Vec2 &v);
Packit 8dc392
    const Vec2 &	operator /= (T a);
Packit 8dc392
    Vec2		operator / (const Vec2 &v) const;
Packit 8dc392
    Vec2		operator / (T a) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //----------------------------------------------------------------
Packit 8dc392
    // Length and normalization:  If v.length() is 0.0, v.normalize()
Packit 8dc392
    // and v.normalized() produce a null vector; v.normalizeExc() and
Packit 8dc392
    // v.normalizedExc() throw a NullVecExc.
Packit 8dc392
    // v.normalizeNonNull() and v.normalizedNonNull() are slightly
Packit 8dc392
    // faster than the other normalization routines, but if v.length()
Packit 8dc392
    // is 0.0, the result is undefined.
Packit 8dc392
    //----------------------------------------------------------------
Packit 8dc392
Packit 8dc392
    T			length () const;
Packit 8dc392
    T			length2 () const;
Packit 8dc392
Packit 8dc392
    const Vec2 &	normalize ();           // modifies *this
Packit 8dc392
    const Vec2 &	normalizeExc () throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
    const Vec2 &	normalizeNonNull ();
Packit 8dc392
Packit 8dc392
    Vec2<T>		normalized () const;	// does not modify *this
Packit 8dc392
    Vec2<T>		normalizedExc () const throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
    Vec2<T>		normalizedNonNull () const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //--------------------------------------------------------
Packit 8dc392
    // Number of dimensions, i.e. number of elements in a Vec2
Packit 8dc392
    //--------------------------------------------------------
Packit 8dc392
Packit 8dc392
    static unsigned int	dimensions() {return 2;}
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //-------------------------------------------------
Packit 8dc392
    // Limitations of type T (see also class limits<T>)
Packit 8dc392
    //-------------------------------------------------
Packit 8dc392
Packit 8dc392
    static T		baseTypeMin()		{return limits<T>::min();}
Packit 8dc392
    static T		baseTypeMax()		{return limits<T>::max();}
Packit 8dc392
    static T		baseTypeSmallest()	{return limits<T>::smallest();}
Packit 8dc392
    static T		baseTypeEpsilon()	{return limits<T>::epsilon();}
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //--------------------------------------------------------------
Packit 8dc392
    // Base type -- in templates, which accept a parameter, V, which
Packit 8dc392
    // could be either a Vec2<T>, a Vec3<T>, or a Vec4<T> you can 
Packit 8dc392
    // refer to T as V::BaseType
Packit 8dc392
    //--------------------------------------------------------------
Packit 8dc392
Packit 8dc392
    typedef T		BaseType;
Packit 8dc392
Packit 8dc392
  private:
Packit 8dc392
Packit 8dc392
    T			lengthTiny () const;
Packit 8dc392
};
Packit 8dc392
Packit 8dc392
Packit 8dc392
template <class T> class Vec3
Packit 8dc392
{
Packit 8dc392
  public:
Packit 8dc392
Packit 8dc392
    //-------------------
Packit 8dc392
    // Access to elements
Packit 8dc392
    //-------------------
Packit 8dc392
Packit 8dc392
    T			x, y, z;
Packit 8dc392
Packit 8dc392
    T &			operator [] (int i);
Packit 8dc392
    const T &		operator [] (int i) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //-------------
Packit 8dc392
    // Constructors
Packit 8dc392
    //-------------
Packit 8dc392
Packit 8dc392
    Vec3 ();			   // no initialization
Packit 8dc392
    explicit Vec3 (T a);           // (a a a)
Packit 8dc392
    Vec3 (T a, T b, T c);	   // (a b c)
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //---------------------------------
Packit 8dc392
    // Copy constructors and assignment
Packit 8dc392
    //---------------------------------
Packit 8dc392
Packit 8dc392
    Vec3 (const Vec3 &v);
Packit 8dc392
    template <class S> Vec3 (const Vec3<S> &v);
Packit 8dc392
Packit 8dc392
    const Vec3 &	operator = (const Vec3 &v);
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //---------------------------------------------------------
Packit 8dc392
    // Vec4 to Vec3 conversion, divides x, y and z by w:
Packit 8dc392
    //
Packit 8dc392
    // The one-argument conversion function divides by w even
Packit 8dc392
    // if w is zero.  The result depends on how the environment
Packit 8dc392
    // handles floating-point exceptions.
Packit 8dc392
    //
Packit 8dc392
    // The two-argument version thows an InfPointExc exception
Packit 8dc392
    // if w is zero or if division by w would overflow.
Packit 8dc392
    //---------------------------------------------------------
Packit 8dc392
Packit 8dc392
    template <class S> explicit Vec3 (const Vec4<S> &v);
Packit 8dc392
    template <class S> explicit Vec3 (const Vec4<S> &v, InfException);
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //----------------------
Packit 8dc392
    // Compatibility with Sb
Packit 8dc392
    //----------------------
Packit 8dc392
Packit 8dc392
    template <class S>
Packit 8dc392
    void		setValue (S a, S b, S c);
Packit 8dc392
Packit 8dc392
    template <class S>
Packit 8dc392
    void		setValue (const Vec3<S> &v);
Packit 8dc392
Packit 8dc392
    template <class S>
Packit 8dc392
    void		getValue (S &a, S &b, S &c) const;
Packit 8dc392
Packit 8dc392
    template <class S>
Packit 8dc392
    void		getValue (Vec3<S> &v) const;
Packit 8dc392
Packit 8dc392
    T *			getValue();
Packit 8dc392
    const T *		getValue() const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //---------
Packit 8dc392
    // Equality
Packit 8dc392
    //---------
Packit 8dc392
Packit 8dc392
    template <class S>
Packit 8dc392
    bool		operator == (const Vec3<S> &v) const;
Packit 8dc392
Packit 8dc392
    template <class S>
Packit 8dc392
    bool		operator != (const Vec3<S> &v) const;
Packit 8dc392
Packit 8dc392
    //-----------------------------------------------------------------------
Packit 8dc392
    // Compare two vectors and test if they are "approximately equal":
Packit 8dc392
    //
Packit 8dc392
    // equalWithAbsError (v, e)
Packit 8dc392
    //
Packit 8dc392
    //	    Returns true if the coefficients of this and v are the same with
Packit 8dc392
    //	    an absolute error of no more than e, i.e., for all i
Packit 8dc392
    //
Packit 8dc392
    //      abs (this[i] - v[i]) <= e
Packit 8dc392
    //
Packit 8dc392
    // equalWithRelError (v, e)
Packit 8dc392
    //
Packit 8dc392
    //	    Returns true if the coefficients of this and v are the same with
Packit 8dc392
    //	    a relative error of no more than e, i.e., for all i
Packit 8dc392
    //
Packit 8dc392
    //      abs (this[i] - v[i]) <= e * abs (this[i])
Packit 8dc392
    //-----------------------------------------------------------------------
Packit 8dc392
Packit 8dc392
    bool		equalWithAbsError (const Vec3<T> &v, T e) const;
Packit 8dc392
    bool		equalWithRelError (const Vec3<T> &v, T e) const;
Packit 8dc392
Packit 8dc392
    //------------
Packit 8dc392
    // Dot product
Packit 8dc392
    //------------
Packit 8dc392
Packit 8dc392
    T			dot (const Vec3 &v) const;
Packit 8dc392
    T			operator ^ (const Vec3 &v) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //---------------------------
Packit 8dc392
    // Right-handed cross product
Packit 8dc392
    //---------------------------
Packit 8dc392
Packit 8dc392
    Vec3		cross (const Vec3 &v) const;
Packit 8dc392
    const Vec3 &	operator %= (const Vec3 &v);
Packit 8dc392
    Vec3		operator % (const Vec3 &v) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //------------------------
Packit 8dc392
    // Component-wise addition
Packit 8dc392
    //------------------------
Packit 8dc392
Packit 8dc392
    const Vec3 &	operator += (const Vec3 &v);
Packit 8dc392
    Vec3		operator + (const Vec3 &v) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //---------------------------
Packit 8dc392
    // Component-wise subtraction
Packit 8dc392
    //---------------------------
Packit 8dc392
Packit 8dc392
    const Vec3 &	operator -= (const Vec3 &v);
Packit 8dc392
    Vec3		operator - (const Vec3 &v) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //------------------------------------
Packit 8dc392
    // Component-wise multiplication by -1
Packit 8dc392
    //------------------------------------
Packit 8dc392
Packit 8dc392
    Vec3		operator - () const;
Packit 8dc392
    const Vec3 &	negate ();
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //------------------------------
Packit 8dc392
    // Component-wise multiplication
Packit 8dc392
    //------------------------------
Packit 8dc392
Packit 8dc392
    const Vec3 &	operator *= (const Vec3 &v);
Packit 8dc392
    const Vec3 &	operator *= (T a);
Packit 8dc392
    Vec3		operator * (const Vec3 &v) const;
Packit 8dc392
    Vec3		operator * (T a) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //------------------------
Packit 8dc392
    // Component-wise division
Packit 8dc392
    //------------------------
Packit 8dc392
Packit 8dc392
    const Vec3 &	operator /= (const Vec3 &v);
Packit 8dc392
    const Vec3 &	operator /= (T a);
Packit 8dc392
    Vec3		operator / (const Vec3 &v) const;
Packit 8dc392
    Vec3		operator / (T a) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //----------------------------------------------------------------
Packit 8dc392
    // Length and normalization:  If v.length() is 0.0, v.normalize()
Packit 8dc392
    // and v.normalized() produce a null vector; v.normalizeExc() and
Packit 8dc392
    // v.normalizedExc() throw a NullVecExc.
Packit 8dc392
    // v.normalizeNonNull() and v.normalizedNonNull() are slightly
Packit 8dc392
    // faster than the other normalization routines, but if v.length()
Packit 8dc392
    // is 0.0, the result is undefined.
Packit 8dc392
    //----------------------------------------------------------------
Packit 8dc392
Packit 8dc392
    T			length () const;
Packit 8dc392
    T			length2 () const;
Packit 8dc392
Packit 8dc392
    const Vec3 &	normalize ();           // modifies *this
Packit 8dc392
    const Vec3 &	normalizeExc () throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
    const Vec3 &	normalizeNonNull ();
Packit 8dc392
Packit 8dc392
    Vec3<T>		normalized () const;	// does not modify *this
Packit 8dc392
    Vec3<T>		normalizedExc () const throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
    Vec3<T>		normalizedNonNull () const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //--------------------------------------------------------
Packit 8dc392
    // Number of dimensions, i.e. number of elements in a Vec3
Packit 8dc392
    //--------------------------------------------------------
Packit 8dc392
Packit 8dc392
    static unsigned int	dimensions() {return 3;}
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //-------------------------------------------------
Packit 8dc392
    // Limitations of type T (see also class limits<T>)
Packit 8dc392
    //-------------------------------------------------
Packit 8dc392
Packit 8dc392
    static T		baseTypeMin()		{return limits<T>::min();}
Packit 8dc392
    static T		baseTypeMax()		{return limits<T>::max();}
Packit 8dc392
    static T		baseTypeSmallest()	{return limits<T>::smallest();}
Packit 8dc392
    static T		baseTypeEpsilon()	{return limits<T>::epsilon();}
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //--------------------------------------------------------------
Packit 8dc392
    // Base type -- in templates, which accept a parameter, V, which
Packit 8dc392
    // could be either a Vec2<T>, a Vec3<T>, or a Vec4<T> you can 
Packit 8dc392
    // refer to T as V::BaseType
Packit 8dc392
    //--------------------------------------------------------------
Packit 8dc392
Packit 8dc392
    typedef T		BaseType;
Packit 8dc392
Packit 8dc392
  private:
Packit 8dc392
Packit 8dc392
    T			lengthTiny () const;
Packit 8dc392
};
Packit 8dc392
Packit 8dc392
Packit 8dc392
Packit 8dc392
template <class T> class Vec4
Packit 8dc392
{
Packit 8dc392
  public:
Packit 8dc392
Packit 8dc392
    //-------------------
Packit 8dc392
    // Access to elements
Packit 8dc392
    //-------------------
Packit 8dc392
Packit 8dc392
    T               x, y, z, w; 
Packit 8dc392
Packit 8dc392
    T &             operator [] (int i);
Packit 8dc392
    const T &       operator [] (int i) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //-------------
Packit 8dc392
    // Constructors
Packit 8dc392
    //-------------
Packit 8dc392
Packit 8dc392
    Vec4 ();			   // no initialization
Packit 8dc392
    explicit Vec4 (T a);           // (a a a a)
Packit 8dc392
    Vec4 (T a, T b, T c, T d);	   // (a b c d)
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //---------------------------------
Packit 8dc392
    // Copy constructors and assignment
Packit 8dc392
    //---------------------------------
Packit 8dc392
Packit 8dc392
    Vec4 (const Vec4 &v);
Packit 8dc392
    template <class S> Vec4 (const Vec4<S> &v);
Packit 8dc392
Packit 8dc392
    const Vec4 &    operator = (const Vec4 &v);
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //-------------------------------------
Packit 8dc392
    // Vec3 to Vec4 conversion, sets w to 1
Packit 8dc392
    //-------------------------------------
Packit 8dc392
Packit 8dc392
    template <class S> explicit Vec4 (const Vec3<S> &v);
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //---------
Packit 8dc392
    // Equality
Packit 8dc392
    //---------
Packit 8dc392
Packit 8dc392
    template <class S>
Packit 8dc392
    bool            operator == (const Vec4<S> &v) const;
Packit 8dc392
Packit 8dc392
    template <class S>
Packit 8dc392
    bool            operator != (const Vec4<S> &v) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //-----------------------------------------------------------------------
Packit 8dc392
    // Compare two vectors and test if they are "approximately equal":
Packit 8dc392
    //
Packit 8dc392
    // equalWithAbsError (v, e)
Packit 8dc392
    //
Packit 8dc392
    //	    Returns true if the coefficients of this and v are the same with
Packit 8dc392
    //	    an absolute error of no more than e, i.e., for all i
Packit 8dc392
    //
Packit 8dc392
    //      abs (this[i] - v[i]) <= e
Packit 8dc392
    //
Packit 8dc392
    // equalWithRelError (v, e)
Packit 8dc392
    //
Packit 8dc392
    //	    Returns true if the coefficients of this and v are the same with
Packit 8dc392
    //	    a relative error of no more than e, i.e., for all i
Packit 8dc392
    //
Packit 8dc392
    //      abs (this[i] - v[i]) <= e * abs (this[i])
Packit 8dc392
    //-----------------------------------------------------------------------
Packit 8dc392
Packit 8dc392
    bool		equalWithAbsError (const Vec4<T> &v, T e) const;
Packit 8dc392
    bool		equalWithRelError (const Vec4<T> &v, T e) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //------------
Packit 8dc392
    // Dot product
Packit 8dc392
    //------------
Packit 8dc392
Packit 8dc392
    T			dot (const Vec4 &v) const;
Packit 8dc392
    T			operator ^ (const Vec4 &v) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //-----------------------------------
Packit 8dc392
    // Cross product is not defined in 4D
Packit 8dc392
    //-----------------------------------
Packit 8dc392
Packit 8dc392
    //------------------------
Packit 8dc392
    // Component-wise addition
Packit 8dc392
    //------------------------
Packit 8dc392
Packit 8dc392
    const Vec4 &    operator += (const Vec4 &v);
Packit 8dc392
    Vec4            operator + (const Vec4 &v) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //---------------------------
Packit 8dc392
    // Component-wise subtraction
Packit 8dc392
    //---------------------------
Packit 8dc392
Packit 8dc392
    const Vec4 &    operator -= (const Vec4 &v);
Packit 8dc392
    Vec4            operator - (const Vec4 &v) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //------------------------------------
Packit 8dc392
    // Component-wise multiplication by -1
Packit 8dc392
    //------------------------------------
Packit 8dc392
Packit 8dc392
    Vec4            operator - () const;
Packit 8dc392
    const Vec4 &    negate ();
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //------------------------------
Packit 8dc392
    // Component-wise multiplication
Packit 8dc392
    //------------------------------
Packit 8dc392
Packit 8dc392
    const Vec4 &    operator *= (const Vec4 &v);
Packit 8dc392
    const Vec4 &    operator *= (T a);
Packit 8dc392
    Vec4            operator * (const Vec4 &v) const;
Packit 8dc392
    Vec4            operator * (T a) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //------------------------
Packit 8dc392
    // Component-wise division
Packit 8dc392
    //------------------------
Packit 8dc392
Packit 8dc392
    const Vec4 &    operator /= (const Vec4 &v);
Packit 8dc392
    const Vec4 &    operator /= (T a);
Packit 8dc392
    Vec4            operator / (const Vec4 &v) const;
Packit 8dc392
    Vec4            operator / (T a) const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //----------------------------------------------------------------
Packit 8dc392
    // Length and normalization:  If v.length() is 0.0, v.normalize()
Packit 8dc392
    // and v.normalized() produce a null vector; v.normalizeExc() and
Packit 8dc392
    // v.normalizedExc() throw a NullVecExc.
Packit 8dc392
    // v.normalizeNonNull() and v.normalizedNonNull() are slightly
Packit 8dc392
    // faster than the other normalization routines, but if v.length()
Packit 8dc392
    // is 0.0, the result is undefined.
Packit 8dc392
    //----------------------------------------------------------------
Packit 8dc392
Packit 8dc392
    T               length () const;
Packit 8dc392
    T               length2 () const;
Packit 8dc392
Packit 8dc392
    const Vec4 &    normalize ();           // modifies *this
Packit 8dc392
    const Vec4 &    normalizeExc () throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
    const Vec4 &    normalizeNonNull ();
Packit 8dc392
Packit 8dc392
    Vec4<T>         normalized () const;	// does not modify *this
Packit 8dc392
    Vec4<T>         normalizedExc () const throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
    Vec4<T>         normalizedNonNull () const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //--------------------------------------------------------
Packit 8dc392
    // Number of dimensions, i.e. number of elements in a Vec4
Packit 8dc392
    //--------------------------------------------------------
Packit 8dc392
Packit 8dc392
    static unsigned int	dimensions() {return 4;}
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //-------------------------------------------------
Packit 8dc392
    // Limitations of type T (see also class limits<T>)
Packit 8dc392
    //-------------------------------------------------
Packit 8dc392
Packit 8dc392
    static T		baseTypeMin()		{return limits<T>::min();}
Packit 8dc392
    static T		baseTypeMax()		{return limits<T>::max();}
Packit 8dc392
    static T		baseTypeSmallest()	{return limits<T>::smallest();}
Packit 8dc392
    static T		baseTypeEpsilon()	{return limits<T>::epsilon();}
Packit 8dc392
Packit 8dc392
Packit 8dc392
    //--------------------------------------------------------------
Packit 8dc392
    // Base type -- in templates, which accept a parameter, V, which
Packit 8dc392
    // could be either a Vec2<T>, a Vec3<T>, or a Vec4<T> you can 
Packit 8dc392
    // refer to T as V::BaseType
Packit 8dc392
    //--------------------------------------------------------------
Packit 8dc392
Packit 8dc392
    typedef T		BaseType;
Packit 8dc392
Packit 8dc392
  private:
Packit 8dc392
Packit 8dc392
    T			lengthTiny () const;
Packit 8dc392
};
Packit 8dc392
Packit 8dc392
Packit 8dc392
//--------------
Packit 8dc392
// Stream output
Packit 8dc392
//--------------
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
std::ostream &	operator << (std::ostream &s, const Vec2<T> &v);
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
std::ostream &	operator << (std::ostream &s, const Vec3<T> &v);
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
std::ostream &	operator << (std::ostream &s, const Vec4<T> &v);
Packit 8dc392
Packit 8dc392
//----------------------------------------------------
Packit 8dc392
// Reverse multiplication: S * Vec2<T> and S * Vec3<T>
Packit 8dc392
//----------------------------------------------------
Packit 8dc392
Packit 8dc392
template <class T> Vec2<T>	operator * (T a, const Vec2<T> &v);
Packit 8dc392
template <class T> Vec3<T>	operator * (T a, const Vec3<T> &v);
Packit 8dc392
template <class T> Vec4<T>	operator * (T a, const Vec4<T> &v);
Packit 8dc392
Packit 8dc392
Packit 8dc392
//-------------------------
Packit 8dc392
// Typedefs for convenience
Packit 8dc392
//-------------------------
Packit 8dc392
Packit 8dc392
typedef Vec2 <short>  V2s;
Packit 8dc392
typedef Vec2 <int>    V2i;
Packit 8dc392
typedef Vec2 <float>  V2f;
Packit 8dc392
typedef Vec2 <double> V2d;
Packit 8dc392
typedef Vec3 <short>  V3s;
Packit 8dc392
typedef Vec3 <int>    V3i;
Packit 8dc392
typedef Vec3 <float>  V3f;
Packit 8dc392
typedef Vec3 <double> V3d;
Packit 8dc392
typedef Vec4 <short>  V4s;
Packit 8dc392
typedef Vec4 <int>    V4i;
Packit 8dc392
typedef Vec4 <float>  V4f;
Packit 8dc392
typedef Vec4 <double> V4d;
Packit 8dc392
Packit 8dc392
Packit 8dc392
//-------------------------------------------
Packit 8dc392
// Specializations for VecN<short>, VecN<int>
Packit 8dc392
//-------------------------------------------
Packit 8dc392
Packit 8dc392
// Vec2<short>
Packit 8dc392
Packit 8dc392
template <> short
Packit 8dc392
Vec2<short>::length () const;
Packit 8dc392
Packit 8dc392
template <> const Vec2<short> &
Packit 8dc392
Vec2<short>::normalize ();
Packit 8dc392
Packit 8dc392
template <> const Vec2<short> &
Packit 8dc392
Vec2<short>::normalizeExc () throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
Packit 8dc392
template <> const Vec2<short> &
Packit 8dc392
Vec2<short>::normalizeNonNull ();
Packit 8dc392
Packit 8dc392
template <> Vec2<short>
Packit 8dc392
Vec2<short>::normalized () const;
Packit 8dc392
Packit 8dc392
template <> Vec2<short>
Packit 8dc392
Vec2<short>::normalizedExc () const throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
Packit 8dc392
template <> Vec2<short>
Packit 8dc392
Vec2<short>::normalizedNonNull () const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
// Vec2<int>
Packit 8dc392
Packit 8dc392
template <> int
Packit 8dc392
Vec2<int>::length () const;
Packit 8dc392
Packit 8dc392
template <> const Vec2<int> &
Packit 8dc392
Vec2<int>::normalize ();
Packit 8dc392
Packit 8dc392
template <> const Vec2<int> &
Packit 8dc392
Vec2<int>::normalizeExc () throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
Packit 8dc392
template <> const Vec2<int> &
Packit 8dc392
Vec2<int>::normalizeNonNull ();
Packit 8dc392
Packit 8dc392
template <> Vec2<int>
Packit 8dc392
Vec2<int>::normalized () const;
Packit 8dc392
Packit 8dc392
template <> Vec2<int>
Packit 8dc392
Vec2<int>::normalizedExc () const throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
Packit 8dc392
template <> Vec2<int>
Packit 8dc392
Vec2<int>::normalizedNonNull () const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
// Vec3<short>
Packit 8dc392
Packit 8dc392
template <> short
Packit 8dc392
Vec3<short>::length () const;
Packit 8dc392
Packit 8dc392
template <> const Vec3<short> &
Packit 8dc392
Vec3<short>::normalize ();
Packit 8dc392
Packit 8dc392
template <> const Vec3<short> &
Packit 8dc392
Vec3<short>::normalizeExc () throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
Packit 8dc392
template <> const Vec3<short> &
Packit 8dc392
Vec3<short>::normalizeNonNull ();
Packit 8dc392
Packit 8dc392
template <> Vec3<short>
Packit 8dc392
Vec3<short>::normalized () const;
Packit 8dc392
Packit 8dc392
template <> Vec3<short>
Packit 8dc392
Vec3<short>::normalizedExc () const throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
Packit 8dc392
template <> Vec3<short>
Packit 8dc392
Vec3<short>::normalizedNonNull () const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
// Vec3<int>
Packit 8dc392
Packit 8dc392
template <> int
Packit 8dc392
Vec3<int>::length () const;
Packit 8dc392
Packit 8dc392
template <> const Vec3<int> &
Packit 8dc392
Vec3<int>::normalize ();
Packit 8dc392
Packit 8dc392
template <> const Vec3<int> &
Packit 8dc392
Vec3<int>::normalizeExc () throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
Packit 8dc392
template <> const Vec3<int> &
Packit 8dc392
Vec3<int>::normalizeNonNull ();
Packit 8dc392
Packit 8dc392
template <> Vec3<int>
Packit 8dc392
Vec3<int>::normalized () const;
Packit 8dc392
Packit 8dc392
template <> Vec3<int>
Packit 8dc392
Vec3<int>::normalizedExc () const throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
Packit 8dc392
template <> Vec3<int>
Packit 8dc392
Vec3<int>::normalizedNonNull () const;
Packit 8dc392
Packit 8dc392
// Vec4<short>
Packit 8dc392
Packit 8dc392
template <> short
Packit 8dc392
Vec4<short>::length () const;
Packit 8dc392
Packit 8dc392
template <> const Vec4<short> &
Packit 8dc392
Vec4<short>::normalize ();
Packit 8dc392
Packit 8dc392
template <> const Vec4<short> &
Packit 8dc392
Vec4<short>::normalizeExc () throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
Packit 8dc392
template <> const Vec4<short> &
Packit 8dc392
Vec4<short>::normalizeNonNull ();
Packit 8dc392
Packit 8dc392
template <> Vec4<short>
Packit 8dc392
Vec4<short>::normalized () const;
Packit 8dc392
Packit 8dc392
template <> Vec4<short>
Packit 8dc392
Vec4<short>::normalizedExc () const throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
Packit 8dc392
template <> Vec4<short>
Packit 8dc392
Vec4<short>::normalizedNonNull () const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
// Vec4<int>
Packit 8dc392
Packit 8dc392
template <> int
Packit 8dc392
Vec4<int>::length () const;
Packit 8dc392
Packit 8dc392
template <> const Vec4<int> &
Packit 8dc392
Vec4<int>::normalize ();
Packit 8dc392
Packit 8dc392
template <> const Vec4<int> &
Packit 8dc392
Vec4<int>::normalizeExc () throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
Packit 8dc392
template <> const Vec4<int> &
Packit 8dc392
Vec4<int>::normalizeNonNull ();
Packit 8dc392
Packit 8dc392
template <> Vec4<int>
Packit 8dc392
Vec4<int>::normalized () const;
Packit 8dc392
Packit 8dc392
template <> Vec4<int>
Packit 8dc392
Vec4<int>::normalizedExc () const throw (IEX_NAMESPACE::MathExc);
Packit 8dc392
Packit 8dc392
template <> Vec4<int>
Packit 8dc392
Vec4<int>::normalizedNonNull () const;
Packit 8dc392
Packit 8dc392
Packit 8dc392
//------------------------
Packit 8dc392
// Implementation of Vec2:
Packit 8dc392
//------------------------
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T &
Packit 8dc392
Vec2<T>::operator [] (int i)
Packit 8dc392
{
Packit 8dc392
    return (&x)[i];
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const T &
Packit 8dc392
Vec2<T>::operator [] (int i) const
Packit 8dc392
{
Packit 8dc392
    return (&x)[i];
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec2<T>::Vec2 ()
Packit 8dc392
{
Packit 8dc392
    // empty
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec2<T>::Vec2 (T a)
Packit 8dc392
{
Packit 8dc392
    x = y = a;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec2<T>::Vec2 (T a, T b)
Packit 8dc392
{
Packit 8dc392
    x = a;
Packit 8dc392
    y = b;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec2<T>::Vec2 (const Vec2 &v)
Packit 8dc392
{
Packit 8dc392
    x = v.x;
Packit 8dc392
    y = v.y;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline
Packit 8dc392
Vec2<T>::Vec2 (const Vec2<S> &v)
Packit 8dc392
{
Packit 8dc392
    x = T (v.x);
Packit 8dc392
    y = T (v.y);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec2<T> &
Packit 8dc392
Vec2<T>::operator = (const Vec2 &v)
Packit 8dc392
{
Packit 8dc392
    x = v.x;
Packit 8dc392
    y = v.y;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline void
Packit 8dc392
Vec2<T>::setValue (S a, S b)
Packit 8dc392
{
Packit 8dc392
    x = T (a);
Packit 8dc392
    y = T (b);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline void
Packit 8dc392
Vec2<T>::setValue (const Vec2<S> &v)
Packit 8dc392
{
Packit 8dc392
    x = T (v.x);
Packit 8dc392
    y = T (v.y);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline void
Packit 8dc392
Vec2<T>::getValue (S &a, S &b) const
Packit 8dc392
{
Packit 8dc392
    a = S (x);
Packit 8dc392
    b = S (y);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline void
Packit 8dc392
Vec2<T>::getValue (Vec2<S> &v) const
Packit 8dc392
{
Packit 8dc392
    v.x = S (x);
Packit 8dc392
    v.y = S (y);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T *
Packit 8dc392
Vec2<T>::getValue()
Packit 8dc392
{
Packit 8dc392
    return (T *) &x;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const T *
Packit 8dc392
Vec2<T>::getValue() const
Packit 8dc392
{
Packit 8dc392
    return (const T *) &x;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline bool
Packit 8dc392
Vec2<T>::operator == (const Vec2<S> &v) const
Packit 8dc392
{
Packit 8dc392
    return x == v.x && y == v.y;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline bool
Packit 8dc392
Vec2<T>::operator != (const Vec2<S> &v) const
Packit 8dc392
{
Packit 8dc392
    return x != v.x || y != v.y;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
bool
Packit 8dc392
Vec2<T>::equalWithAbsError (const Vec2<T> &v, T e) const
Packit 8dc392
{
Packit 8dc392
    for (int i = 0; i < 2; i++)
Packit 8dc392
	if (!IMATH_INTERNAL_NAMESPACE::equalWithAbsError ((*this)[i], v[i], e))
Packit 8dc392
	    return false;
Packit 8dc392
Packit 8dc392
    return true;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
bool
Packit 8dc392
Vec2<T>::equalWithRelError (const Vec2<T> &v, T e) const
Packit 8dc392
{
Packit 8dc392
    for (int i = 0; i < 2; i++)
Packit 8dc392
	if (!IMATH_INTERNAL_NAMESPACE::equalWithRelError ((*this)[i], v[i], e))
Packit 8dc392
	    return false;
Packit 8dc392
Packit 8dc392
    return true;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T
Packit 8dc392
Vec2<T>::dot (const Vec2 &v) const
Packit 8dc392
{
Packit 8dc392
    return x * v.x + y * v.y;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T
Packit 8dc392
Vec2<T>::operator ^ (const Vec2 &v) const
Packit 8dc392
{
Packit 8dc392
    return dot (v);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T
Packit 8dc392
Vec2<T>::cross (const Vec2 &v) const
Packit 8dc392
{
Packit 8dc392
    return x * v.y - y * v.x;
Packit 8dc392
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T
Packit 8dc392
Vec2<T>::operator % (const Vec2 &v) const
Packit 8dc392
{
Packit 8dc392
    return x * v.y - y * v.x;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec2<T> &
Packit 8dc392
Vec2<T>::operator += (const Vec2 &v)
Packit 8dc392
{
Packit 8dc392
    x += v.x;
Packit 8dc392
    y += v.y;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec2<T>
Packit 8dc392
Vec2<T>::operator + (const Vec2 &v) const
Packit 8dc392
{
Packit 8dc392
    return Vec2 (x + v.x, y + v.y);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec2<T> &
Packit 8dc392
Vec2<T>::operator -= (const Vec2 &v)
Packit 8dc392
{
Packit 8dc392
    x -= v.x;
Packit 8dc392
    y -= v.y;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec2<T>
Packit 8dc392
Vec2<T>::operator - (const Vec2 &v) const
Packit 8dc392
{
Packit 8dc392
    return Vec2 (x - v.x, y - v.y);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec2<T>
Packit 8dc392
Vec2<T>::operator - () const
Packit 8dc392
{
Packit 8dc392
    return Vec2 (-x, -y);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec2<T> &
Packit 8dc392
Vec2<T>::negate ()
Packit 8dc392
{
Packit 8dc392
    x = -x;
Packit 8dc392
    y = -y;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec2<T> &
Packit 8dc392
Vec2<T>::operator *= (const Vec2 &v)
Packit 8dc392
{
Packit 8dc392
    x *= v.x;
Packit 8dc392
    y *= v.y;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec2<T> &
Packit 8dc392
Vec2<T>::operator *= (T a)
Packit 8dc392
{
Packit 8dc392
    x *= a;
Packit 8dc392
    y *= a;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec2<T>
Packit 8dc392
Vec2<T>::operator * (const Vec2 &v) const
Packit 8dc392
{
Packit 8dc392
    return Vec2 (x * v.x, y * v.y);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec2<T>
Packit 8dc392
Vec2<T>::operator * (T a) const
Packit 8dc392
{
Packit 8dc392
    return Vec2 (x * a, y * a);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec2<T> &
Packit 8dc392
Vec2<T>::operator /= (const Vec2 &v)
Packit 8dc392
{
Packit 8dc392
    x /= v.x;
Packit 8dc392
    y /= v.y;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec2<T> &
Packit 8dc392
Vec2<T>::operator /= (T a)
Packit 8dc392
{
Packit 8dc392
    x /= a;
Packit 8dc392
    y /= a;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec2<T>
Packit 8dc392
Vec2<T>::operator / (const Vec2 &v) const
Packit 8dc392
{
Packit 8dc392
    return Vec2 (x / v.x, y / v.y);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec2<T>
Packit 8dc392
Vec2<T>::operator / (T a) const
Packit 8dc392
{
Packit 8dc392
    return Vec2 (x / a, y / a);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
T
Packit 8dc392
Vec2<T>::lengthTiny () const
Packit 8dc392
{
Packit 8dc392
    T absX = (x >= T (0))? x: -x;
Packit 8dc392
    T absY = (y >= T (0))? y: -y;
Packit 8dc392
    
Packit 8dc392
    T max = absX;
Packit 8dc392
Packit 8dc392
    if (max < absY)
Packit 8dc392
	max = absY;
Packit 8dc392
Packit 8dc392
    if (max == T (0))
Packit 8dc392
	return T (0);
Packit 8dc392
Packit 8dc392
    //
Packit 8dc392
    // Do not replace the divisions by max with multiplications by 1/max.
Packit 8dc392
    // Computing 1/max can overflow but the divisions below will always
Packit 8dc392
    // produce results less than or equal to 1.
Packit 8dc392
    //
Packit 8dc392
Packit 8dc392
    absX /= max;
Packit 8dc392
    absY /= max;
Packit 8dc392
Packit 8dc392
    return max * Math<T>::sqrt (absX * absX + absY * absY);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T
Packit 8dc392
Vec2<T>::length () const
Packit 8dc392
{
Packit 8dc392
    T length2 = dot (*this);
Packit 8dc392
Packit 8dc392
    if (length2 < T (2) * limits<T>::smallest())
Packit 8dc392
	return lengthTiny();
Packit 8dc392
Packit 8dc392
    return Math<T>::sqrt (length2);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T
Packit 8dc392
Vec2<T>::length2 () const
Packit 8dc392
{
Packit 8dc392
    return dot (*this);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
const Vec2<T> &
Packit 8dc392
Vec2<T>::normalize ()
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
Packit 8dc392
    if (l != T (0))
Packit 8dc392
    {
Packit 8dc392
        //
Packit 8dc392
        // Do not replace the divisions by l with multiplications by 1/l.
Packit 8dc392
        // Computing 1/l can overflow but the divisions below will always
Packit 8dc392
        // produce results less than or equal to 1.
Packit 8dc392
        //
Packit 8dc392
Packit 8dc392
	x /= l;
Packit 8dc392
	y /= l;
Packit 8dc392
    }
Packit 8dc392
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
const Vec2<T> &
Packit 8dc392
Vec2<T>::normalizeExc () throw (IEX_NAMESPACE::MathExc)
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
Packit 8dc392
    if (l == T (0))
Packit 8dc392
	throw NullVecExc ("Cannot normalize null vector.");
Packit 8dc392
Packit 8dc392
    x /= l;
Packit 8dc392
    y /= l;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
const Vec2<T> &
Packit 8dc392
Vec2<T>::normalizeNonNull ()
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
    x /= l;
Packit 8dc392
    y /= l;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
Vec2<T>
Packit 8dc392
Vec2<T>::normalized () const
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
Packit 8dc392
    if (l == T (0))
Packit 8dc392
	return Vec2 (T (0));
Packit 8dc392
Packit 8dc392
    return Vec2 (x / l, y / l);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
Vec2<T>
Packit 8dc392
Vec2<T>::normalizedExc () const throw (IEX_NAMESPACE::MathExc)
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
Packit 8dc392
    if (l == T (0))
Packit 8dc392
	throw NullVecExc ("Cannot normalize null vector.");
Packit 8dc392
Packit 8dc392
    return Vec2 (x / l, y / l);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec2<T>
Packit 8dc392
Vec2<T>::normalizedNonNull () const
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
    return Vec2 (x / l, y / l);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
Packit 8dc392
//-----------------------
Packit 8dc392
// Implementation of Vec3
Packit 8dc392
//-----------------------
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T &
Packit 8dc392
Vec3<T>::operator [] (int i)
Packit 8dc392
{
Packit 8dc392
    return (&x)[i];
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const T &
Packit 8dc392
Vec3<T>::operator [] (int i) const
Packit 8dc392
{
Packit 8dc392
    return (&x)[i];
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec3<T>::Vec3 ()
Packit 8dc392
{
Packit 8dc392
    // empty
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec3<T>::Vec3 (T a)
Packit 8dc392
{
Packit 8dc392
    x = y = z = a;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec3<T>::Vec3 (T a, T b, T c)
Packit 8dc392
{
Packit 8dc392
    x = a;
Packit 8dc392
    y = b;
Packit 8dc392
    z = c;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec3<T>::Vec3 (const Vec3 &v)
Packit 8dc392
{
Packit 8dc392
    x = v.x;
Packit 8dc392
    y = v.y;
Packit 8dc392
    z = v.z;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline
Packit 8dc392
Vec3<T>::Vec3 (const Vec3<S> &v)
Packit 8dc392
{
Packit 8dc392
    x = T (v.x);
Packit 8dc392
    y = T (v.y);
Packit 8dc392
    z = T (v.z);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec3<T> &
Packit 8dc392
Vec3<T>::operator = (const Vec3 &v)
Packit 8dc392
{
Packit 8dc392
    x = v.x;
Packit 8dc392
    y = v.y;
Packit 8dc392
    z = v.z;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline
Packit 8dc392
Vec3<T>::Vec3 (const Vec4<S> &v)
Packit 8dc392
{
Packit 8dc392
    x = T (v.x / v.w);
Packit 8dc392
    y = T (v.y / v.w);
Packit 8dc392
    z = T (v.z / v.w);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
Vec3<T>::Vec3 (const Vec4<S> &v, InfException)
Packit 8dc392
{
Packit 8dc392
    T vx = T (v.x);
Packit 8dc392
    T vy = T (v.y);
Packit 8dc392
    T vz = T (v.z);
Packit 8dc392
    T vw = T (v.w);
Packit 8dc392
Packit 8dc392
    T absW = (vw >= T (0))? vw: -vw;
Packit 8dc392
Packit 8dc392
    if (absW < 1)
Packit 8dc392
    {
Packit 8dc392
        T m = baseTypeMax() * absW;
Packit 8dc392
        
Packit 8dc392
        if (vx <= -m || vx >= m || vy <= -m || vy >= m || vz <= -m || vz >= m)
Packit 8dc392
            throw InfPointExc ("Cannot normalize point at infinity.");
Packit 8dc392
    }
Packit 8dc392
Packit 8dc392
    x = vx / vw;
Packit 8dc392
    y = vy / vw;
Packit 8dc392
    z = vz / vw;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline void
Packit 8dc392
Vec3<T>::setValue (S a, S b, S c)
Packit 8dc392
{
Packit 8dc392
    x = T (a);
Packit 8dc392
    y = T (b);
Packit 8dc392
    z = T (c);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline void
Packit 8dc392
Vec3<T>::setValue (const Vec3<S> &v)
Packit 8dc392
{
Packit 8dc392
    x = T (v.x);
Packit 8dc392
    y = T (v.y);
Packit 8dc392
    z = T (v.z);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline void
Packit 8dc392
Vec3<T>::getValue (S &a, S &b, S &c) const
Packit 8dc392
{
Packit 8dc392
    a = S (x);
Packit 8dc392
    b = S (y);
Packit 8dc392
    c = S (z);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline void
Packit 8dc392
Vec3<T>::getValue (Vec3<S> &v) const
Packit 8dc392
{
Packit 8dc392
    v.x = S (x);
Packit 8dc392
    v.y = S (y);
Packit 8dc392
    v.z = S (z);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T *
Packit 8dc392
Vec3<T>::getValue()
Packit 8dc392
{
Packit 8dc392
    return (T *) &x;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const T *
Packit 8dc392
Vec3<T>::getValue() const
Packit 8dc392
{
Packit 8dc392
    return (const T *) &x;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline bool
Packit 8dc392
Vec3<T>::operator == (const Vec3<S> &v) const
Packit 8dc392
{
Packit 8dc392
    return x == v.x && y == v.y && z == v.z;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline bool
Packit 8dc392
Vec3<T>::operator != (const Vec3<S> &v) const
Packit 8dc392
{
Packit 8dc392
    return x != v.x || y != v.y || z != v.z;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
bool
Packit 8dc392
Vec3<T>::equalWithAbsError (const Vec3<T> &v, T e) const
Packit 8dc392
{
Packit 8dc392
    for (int i = 0; i < 3; i++)
Packit 8dc392
	if (!IMATH_INTERNAL_NAMESPACE::equalWithAbsError ((*this)[i], v[i], e))
Packit 8dc392
	    return false;
Packit 8dc392
Packit 8dc392
    return true;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
bool
Packit 8dc392
Vec3<T>::equalWithRelError (const Vec3<T> &v, T e) const
Packit 8dc392
{
Packit 8dc392
    for (int i = 0; i < 3; i++)
Packit 8dc392
	if (!IMATH_INTERNAL_NAMESPACE::equalWithRelError ((*this)[i], v[i], e))
Packit 8dc392
	    return false;
Packit 8dc392
Packit 8dc392
    return true;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T
Packit 8dc392
Vec3<T>::dot (const Vec3 &v) const
Packit 8dc392
{
Packit 8dc392
    return x * v.x + y * v.y + z * v.z;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T
Packit 8dc392
Vec3<T>::operator ^ (const Vec3 &v) const
Packit 8dc392
{
Packit 8dc392
    return dot (v);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec3<T>
Packit 8dc392
Vec3<T>::cross (const Vec3 &v) const
Packit 8dc392
{
Packit 8dc392
    return Vec3 (y * v.z - z * v.y,
Packit 8dc392
		 z * v.x - x * v.z,
Packit 8dc392
		 x * v.y - y * v.x);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec3<T> &
Packit 8dc392
Vec3<T>::operator %= (const Vec3 &v)
Packit 8dc392
{
Packit 8dc392
    T a = y * v.z - z * v.y;
Packit 8dc392
    T b = z * v.x - x * v.z;
Packit 8dc392
    T c = x * v.y - y * v.x;
Packit 8dc392
    x = a;
Packit 8dc392
    y = b;
Packit 8dc392
    z = c;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec3<T>
Packit 8dc392
Vec3<T>::operator % (const Vec3 &v) const
Packit 8dc392
{
Packit 8dc392
    return Vec3 (y * v.z - z * v.y,
Packit 8dc392
		 z * v.x - x * v.z,
Packit 8dc392
		 x * v.y - y * v.x);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec3<T> &
Packit 8dc392
Vec3<T>::operator += (const Vec3 &v)
Packit 8dc392
{
Packit 8dc392
    x += v.x;
Packit 8dc392
    y += v.y;
Packit 8dc392
    z += v.z;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec3<T>
Packit 8dc392
Vec3<T>::operator + (const Vec3 &v) const
Packit 8dc392
{
Packit 8dc392
    return Vec3 (x + v.x, y + v.y, z + v.z);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec3<T> &
Packit 8dc392
Vec3<T>::operator -= (const Vec3 &v)
Packit 8dc392
{
Packit 8dc392
    x -= v.x;
Packit 8dc392
    y -= v.y;
Packit 8dc392
    z -= v.z;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec3<T>
Packit 8dc392
Vec3<T>::operator - (const Vec3 &v) const
Packit 8dc392
{
Packit 8dc392
    return Vec3 (x - v.x, y - v.y, z - v.z);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec3<T>
Packit 8dc392
Vec3<T>::operator - () const
Packit 8dc392
{
Packit 8dc392
    return Vec3 (-x, -y, -z);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec3<T> &
Packit 8dc392
Vec3<T>::negate ()
Packit 8dc392
{
Packit 8dc392
    x = -x;
Packit 8dc392
    y = -y;
Packit 8dc392
    z = -z;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec3<T> &
Packit 8dc392
Vec3<T>::operator *= (const Vec3 &v)
Packit 8dc392
{
Packit 8dc392
    x *= v.x;
Packit 8dc392
    y *= v.y;
Packit 8dc392
    z *= v.z;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec3<T> &
Packit 8dc392
Vec3<T>::operator *= (T a)
Packit 8dc392
{
Packit 8dc392
    x *= a;
Packit 8dc392
    y *= a;
Packit 8dc392
    z *= a;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec3<T>
Packit 8dc392
Vec3<T>::operator * (const Vec3 &v) const
Packit 8dc392
{
Packit 8dc392
    return Vec3 (x * v.x, y * v.y, z * v.z);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec3<T>
Packit 8dc392
Vec3<T>::operator * (T a) const
Packit 8dc392
{
Packit 8dc392
    return Vec3 (x * a, y * a, z * a);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec3<T> &
Packit 8dc392
Vec3<T>::operator /= (const Vec3 &v)
Packit 8dc392
{
Packit 8dc392
    x /= v.x;
Packit 8dc392
    y /= v.y;
Packit 8dc392
    z /= v.z;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec3<T> &
Packit 8dc392
Vec3<T>::operator /= (T a)
Packit 8dc392
{
Packit 8dc392
    x /= a;
Packit 8dc392
    y /= a;
Packit 8dc392
    z /= a;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec3<T>
Packit 8dc392
Vec3<T>::operator / (const Vec3 &v) const
Packit 8dc392
{
Packit 8dc392
    return Vec3 (x / v.x, y / v.y, z / v.z);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec3<T>
Packit 8dc392
Vec3<T>::operator / (T a) const
Packit 8dc392
{
Packit 8dc392
    return Vec3 (x / a, y / a, z / a);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
T
Packit 8dc392
Vec3<T>::lengthTiny () const
Packit 8dc392
{
Packit 8dc392
    T absX = (x >= T (0))? x: -x;
Packit 8dc392
    T absY = (y >= T (0))? y: -y;
Packit 8dc392
    T absZ = (z >= T (0))? z: -z;
Packit 8dc392
    
Packit 8dc392
    T max = absX;
Packit 8dc392
Packit 8dc392
    if (max < absY)
Packit 8dc392
	max = absY;
Packit 8dc392
Packit 8dc392
    if (max < absZ)
Packit 8dc392
	max = absZ;
Packit 8dc392
Packit 8dc392
    if (max == T (0))
Packit 8dc392
	return T (0);
Packit 8dc392
Packit 8dc392
    //
Packit 8dc392
    // Do not replace the divisions by max with multiplications by 1/max.
Packit 8dc392
    // Computing 1/max can overflow but the divisions below will always
Packit 8dc392
    // produce results less than or equal to 1.
Packit 8dc392
    //
Packit 8dc392
Packit 8dc392
    absX /= max;
Packit 8dc392
    absY /= max;
Packit 8dc392
    absZ /= max;
Packit 8dc392
Packit 8dc392
    return max * Math<T>::sqrt (absX * absX + absY * absY + absZ * absZ);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T
Packit 8dc392
Vec3<T>::length () const
Packit 8dc392
{
Packit 8dc392
    T length2 = dot (*this);
Packit 8dc392
Packit 8dc392
    if (length2 < T (2) * limits<T>::smallest())
Packit 8dc392
	return lengthTiny();
Packit 8dc392
Packit 8dc392
    return Math<T>::sqrt (length2);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T
Packit 8dc392
Vec3<T>::length2 () const
Packit 8dc392
{
Packit 8dc392
    return dot (*this);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
const Vec3<T> &
Packit 8dc392
Vec3<T>::normalize ()
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
Packit 8dc392
    if (l != T (0))
Packit 8dc392
    {
Packit 8dc392
        //
Packit 8dc392
        // Do not replace the divisions by l with multiplications by 1/l.
Packit 8dc392
        // Computing 1/l can overflow but the divisions below will always
Packit 8dc392
        // produce results less than or equal to 1.
Packit 8dc392
        //
Packit 8dc392
Packit 8dc392
	x /= l;
Packit 8dc392
	y /= l;
Packit 8dc392
	z /= l;
Packit 8dc392
    }
Packit 8dc392
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
const Vec3<T> &
Packit 8dc392
Vec3<T>::normalizeExc () throw (IEX_NAMESPACE::MathExc)
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
Packit 8dc392
    if (l == T (0))
Packit 8dc392
	throw NullVecExc ("Cannot normalize null vector.");
Packit 8dc392
Packit 8dc392
    x /= l;
Packit 8dc392
    y /= l;
Packit 8dc392
    z /= l;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
const Vec3<T> &
Packit 8dc392
Vec3<T>::normalizeNonNull ()
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
    x /= l;
Packit 8dc392
    y /= l;
Packit 8dc392
    z /= l;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
Vec3<T>
Packit 8dc392
Vec3<T>::normalized () const
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
Packit 8dc392
    if (l == T (0))
Packit 8dc392
	return Vec3 (T (0));
Packit 8dc392
Packit 8dc392
    return Vec3 (x / l, y / l, z / l);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
Vec3<T>
Packit 8dc392
Vec3<T>::normalizedExc () const throw (IEX_NAMESPACE::MathExc)
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
Packit 8dc392
    if (l == T (0))
Packit 8dc392
	throw NullVecExc ("Cannot normalize null vector.");
Packit 8dc392
Packit 8dc392
    return Vec3 (x / l, y / l, z / l);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec3<T>
Packit 8dc392
Vec3<T>::normalizedNonNull () const
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
    return Vec3 (x / l, y / l, z / l);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
Packit 8dc392
//-----------------------
Packit 8dc392
// Implementation of Vec4
Packit 8dc392
//-----------------------
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T &
Packit 8dc392
Vec4<T>::operator [] (int i)
Packit 8dc392
{
Packit 8dc392
    return (&x)[i];
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const T &
Packit 8dc392
Vec4<T>::operator [] (int i) const
Packit 8dc392
{
Packit 8dc392
    return (&x)[i];
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec4<T>::Vec4 ()
Packit 8dc392
{
Packit 8dc392
    // empty
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec4<T>::Vec4 (T a)
Packit 8dc392
{
Packit 8dc392
    x = y = z = w = a;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec4<T>::Vec4 (T a, T b, T c, T d)
Packit 8dc392
{
Packit 8dc392
    x = a;
Packit 8dc392
    y = b;
Packit 8dc392
    z = c;
Packit 8dc392
    w = d;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec4<T>::Vec4 (const Vec4 &v)
Packit 8dc392
{
Packit 8dc392
    x = v.x;
Packit 8dc392
    y = v.y;
Packit 8dc392
    z = v.z;
Packit 8dc392
    w = v.w;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline
Packit 8dc392
Vec4<T>::Vec4 (const Vec4<S> &v)
Packit 8dc392
{
Packit 8dc392
    x = T (v.x);
Packit 8dc392
    y = T (v.y);
Packit 8dc392
    z = T (v.z);
Packit 8dc392
    w = T (v.w);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec4<T> &
Packit 8dc392
Vec4<T>::operator = (const Vec4 &v)
Packit 8dc392
{
Packit 8dc392
    x = v.x;
Packit 8dc392
    y = v.y;
Packit 8dc392
    z = v.z;
Packit 8dc392
    w = v.w;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline
Packit 8dc392
Vec4<T>::Vec4 (const Vec3<S> &v)
Packit 8dc392
{
Packit 8dc392
    x = T (v.x);
Packit 8dc392
    y = T (v.y);
Packit 8dc392
    z = T (v.z);
Packit 8dc392
    w = T (1);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline bool
Packit 8dc392
Vec4<T>::operator == (const Vec4<S> &v) const
Packit 8dc392
{
Packit 8dc392
    return x == v.x && y == v.y && z == v.z && w == v.w;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
template <class S>
Packit 8dc392
inline bool
Packit 8dc392
Vec4<T>::operator != (const Vec4<S> &v) const
Packit 8dc392
{
Packit 8dc392
    return x != v.x || y != v.y || z != v.z || w != v.w;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
bool
Packit 8dc392
Vec4<T>::equalWithAbsError (const Vec4<T> &v, T e) const
Packit 8dc392
{
Packit 8dc392
    for (int i = 0; i < 4; i++)
Packit 8dc392
        if (!IMATH_INTERNAL_NAMESPACE::equalWithAbsError ((*this)[i], v[i], e))
Packit 8dc392
            return false;
Packit 8dc392
Packit 8dc392
    return true;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
bool
Packit 8dc392
Vec4<T>::equalWithRelError (const Vec4<T> &v, T e) const
Packit 8dc392
{
Packit 8dc392
    for (int i = 0; i < 4; i++)
Packit 8dc392
        if (!IMATH_INTERNAL_NAMESPACE::equalWithRelError ((*this)[i], v[i], e))
Packit 8dc392
            return false;
Packit 8dc392
Packit 8dc392
    return true;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T
Packit 8dc392
Vec4<T>::dot (const Vec4 &v) const
Packit 8dc392
{
Packit 8dc392
    return x * v.x + y * v.y + z * v.z + w * v.w;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T
Packit 8dc392
Vec4<T>::operator ^ (const Vec4 &v) const
Packit 8dc392
{
Packit 8dc392
    return dot (v);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec4<T> &
Packit 8dc392
Vec4<T>::operator += (const Vec4 &v)
Packit 8dc392
{
Packit 8dc392
    x += v.x;
Packit 8dc392
    y += v.y;
Packit 8dc392
    z += v.z;
Packit 8dc392
    w += v.w;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec4<T>
Packit 8dc392
Vec4<T>::operator + (const Vec4 &v) const
Packit 8dc392
{
Packit 8dc392
    return Vec4 (x + v.x, y + v.y, z + v.z, w + v.w);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec4<T> &
Packit 8dc392
Vec4<T>::operator -= (const Vec4 &v)
Packit 8dc392
{
Packit 8dc392
    x -= v.x;
Packit 8dc392
    y -= v.y;
Packit 8dc392
    z -= v.z;
Packit 8dc392
    w -= v.w;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec4<T>
Packit 8dc392
Vec4<T>::operator - (const Vec4 &v) const
Packit 8dc392
{
Packit 8dc392
    return Vec4 (x - v.x, y - v.y, z - v.z, w - v.w);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec4<T>
Packit 8dc392
Vec4<T>::operator - () const
Packit 8dc392
{
Packit 8dc392
    return Vec4 (-x, -y, -z, -w);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec4<T> &
Packit 8dc392
Vec4<T>::negate ()
Packit 8dc392
{
Packit 8dc392
    x = -x;
Packit 8dc392
    y = -y;
Packit 8dc392
    z = -z;
Packit 8dc392
    w = -w;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec4<T> &
Packit 8dc392
Vec4<T>::operator *= (const Vec4 &v)
Packit 8dc392
{
Packit 8dc392
    x *= v.x;
Packit 8dc392
    y *= v.y;
Packit 8dc392
    z *= v.z;
Packit 8dc392
    w *= v.w;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec4<T> &
Packit 8dc392
Vec4<T>::operator *= (T a)
Packit 8dc392
{
Packit 8dc392
    x *= a;
Packit 8dc392
    y *= a;
Packit 8dc392
    z *= a;
Packit 8dc392
    w *= a;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec4<T>
Packit 8dc392
Vec4<T>::operator * (const Vec4 &v) const
Packit 8dc392
{
Packit 8dc392
    return Vec4 (x * v.x, y * v.y, z * v.z, w * v.w);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec4<T>
Packit 8dc392
Vec4<T>::operator * (T a) const
Packit 8dc392
{
Packit 8dc392
    return Vec4 (x * a, y * a, z * a, w * a);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec4<T> &
Packit 8dc392
Vec4<T>::operator /= (const Vec4 &v)
Packit 8dc392
{
Packit 8dc392
    x /= v.x;
Packit 8dc392
    y /= v.y;
Packit 8dc392
    z /= v.z;
Packit 8dc392
    w /= v.w;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline const Vec4<T> &
Packit 8dc392
Vec4<T>::operator /= (T a)
Packit 8dc392
{
Packit 8dc392
    x /= a;
Packit 8dc392
    y /= a;
Packit 8dc392
    z /= a;
Packit 8dc392
    w /= a;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec4<T>
Packit 8dc392
Vec4<T>::operator / (const Vec4 &v) const
Packit 8dc392
{
Packit 8dc392
    return Vec4 (x / v.x, y / v.y, z / v.z, w / v.w);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec4<T>
Packit 8dc392
Vec4<T>::operator / (T a) const
Packit 8dc392
{
Packit 8dc392
    return Vec4 (x / a, y / a, z / a, w / a);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
T
Packit 8dc392
Vec4<T>::lengthTiny () const
Packit 8dc392
{
Packit 8dc392
    T absX = (x >= T (0))? x: -x;
Packit 8dc392
    T absY = (y >= T (0))? y: -y;
Packit 8dc392
    T absZ = (z >= T (0))? z: -z;
Packit 8dc392
    T absW = (w >= T (0))? w: -w;
Packit 8dc392
    
Packit 8dc392
    T max = absX;
Packit 8dc392
Packit 8dc392
    if (max < absY)
Packit 8dc392
        max = absY;
Packit 8dc392
Packit 8dc392
    if (max < absZ)
Packit 8dc392
        max = absZ;
Packit 8dc392
Packit 8dc392
    if (max < absW)
Packit 8dc392
        max = absW;
Packit 8dc392
Packit 8dc392
    if (max == T (0))
Packit 8dc392
        return T (0);
Packit 8dc392
Packit 8dc392
    //
Packit 8dc392
    // Do not replace the divisions by max with multiplications by 1/max.
Packit 8dc392
    // Computing 1/max can overflow but the divisions below will always
Packit 8dc392
    // produce results less than or equal to 1.
Packit 8dc392
    //
Packit 8dc392
Packit 8dc392
    absX /= max;
Packit 8dc392
    absY /= max;
Packit 8dc392
    absZ /= max;
Packit 8dc392
    absW /= max;
Packit 8dc392
Packit 8dc392
    return max *
Packit 8dc392
        Math<T>::sqrt (absX * absX + absY * absY + absZ * absZ + absW * absW);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T
Packit 8dc392
Vec4<T>::length () const
Packit 8dc392
{
Packit 8dc392
    T length2 = dot (*this);
Packit 8dc392
Packit 8dc392
    if (length2 < T (2) * limits<T>::smallest())
Packit 8dc392
        return lengthTiny();
Packit 8dc392
Packit 8dc392
    return Math<T>::sqrt (length2);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline T
Packit 8dc392
Vec4<T>::length2 () const
Packit 8dc392
{
Packit 8dc392
    return dot (*this);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
const Vec4<T> &
Packit 8dc392
Vec4<T>::normalize ()
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
Packit 8dc392
    if (l != T (0))
Packit 8dc392
    {
Packit 8dc392
        //
Packit 8dc392
        // Do not replace the divisions by l with multiplications by 1/l.
Packit 8dc392
        // Computing 1/l can overflow but the divisions below will always
Packit 8dc392
        // produce results less than or equal to 1.
Packit 8dc392
        //
Packit 8dc392
Packit 8dc392
        x /= l;
Packit 8dc392
        y /= l;
Packit 8dc392
        z /= l;
Packit 8dc392
        w /= l;
Packit 8dc392
    }
Packit 8dc392
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
const Vec4<T> &
Packit 8dc392
Vec4<T>::normalizeExc () throw (IEX_NAMESPACE::MathExc)
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
Packit 8dc392
    if (l == T (0))
Packit 8dc392
        throw NullVecExc ("Cannot normalize null vector.");
Packit 8dc392
Packit 8dc392
    x /= l;
Packit 8dc392
    y /= l;
Packit 8dc392
    z /= l;
Packit 8dc392
    w /= l;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
const Vec4<T> &
Packit 8dc392
Vec4<T>::normalizeNonNull ()
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
    x /= l;
Packit 8dc392
    y /= l;
Packit 8dc392
    z /= l;
Packit 8dc392
    w /= l;
Packit 8dc392
    return *this;
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
Vec4<T>
Packit 8dc392
Vec4<T>::normalized () const
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
Packit 8dc392
    if (l == T (0))
Packit 8dc392
        return Vec4 (T (0));
Packit 8dc392
Packit 8dc392
    return Vec4 (x / l, y / l, z / l, w / l);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
Vec4<T>
Packit 8dc392
Vec4<T>::normalizedExc () const throw (IEX_NAMESPACE::MathExc)
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
Packit 8dc392
    if (l == T (0))
Packit 8dc392
        throw NullVecExc ("Cannot normalize null vector.");
Packit 8dc392
Packit 8dc392
    return Vec4 (x / l, y / l, z / l, w / l);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline
Packit 8dc392
Vec4<T>
Packit 8dc392
Vec4<T>::normalizedNonNull () const
Packit 8dc392
{
Packit 8dc392
    T l = length();
Packit 8dc392
    return Vec4 (x / l, y / l, z / l, w / l);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
//-----------------------------
Packit 8dc392
// Stream output implementation
Packit 8dc392
//-----------------------------
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
std::ostream &
Packit 8dc392
operator << (std::ostream &s, const Vec2<T> &v)
Packit 8dc392
{
Packit 8dc392
    return s << '(' << v.x << ' ' << v.y << ')';
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
std::ostream &
Packit 8dc392
operator << (std::ostream &s, const Vec3<T> &v)
Packit 8dc392
{
Packit 8dc392
    return s << '(' << v.x << ' ' << v.y << ' ' << v.z << ')';
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
std::ostream &
Packit 8dc392
operator << (std::ostream &s, const Vec4<T> &v)
Packit 8dc392
{
Packit 8dc392
    return s << '(' << v.x << ' ' << v.y << ' ' << v.z << ' ' << v.w << ')';
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
Packit 8dc392
//-----------------------------------------
Packit 8dc392
// Implementation of reverse multiplication
Packit 8dc392
//-----------------------------------------
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec2<T>
Packit 8dc392
operator * (T a, const Vec2<T> &v)
Packit 8dc392
{
Packit 8dc392
    return Vec2<T> (a * v.x, a * v.y);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec3<T>
Packit 8dc392
operator * (T a, const Vec3<T> &v)
Packit 8dc392
{
Packit 8dc392
    return Vec3<T> (a * v.x, a * v.y, a * v.z);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
template <class T>
Packit 8dc392
inline Vec4<T>
Packit 8dc392
operator * (T a, const Vec4<T> &v)
Packit 8dc392
{
Packit 8dc392
    return Vec4<T> (a * v.x, a * v.y, a * v.z, a * v.w);
Packit 8dc392
}
Packit 8dc392
Packit 8dc392
Packit 8dc392
#if (defined _WIN32 || defined _WIN64) && defined _MSC_VER
Packit 8dc392
#pragma warning(pop)
Packit 8dc392
#endif
Packit 8dc392
Packit 8dc392
IMATH_INTERNAL_NAMESPACE_HEADER_EXIT
Packit 8dc392
Packit 8dc392
#endif // INCLUDED_IMATHVEC_H