Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Class List | Directories | File List | Namespace Members | Class Members | File Members | Related Pages

ShHalf.hpp

00001 // Sh: A GPU metaprogramming language.
00002 //
00003 // Copyright (c) 2003 University of Waterloo Computer Graphics Laboratory
00004 // Project administrator: Michael D. McCool
00005 // Authors: Zheng Qin, Stefanus Du Toit, Kevin Moule, Tiberiu S. Popa,
00006 //          Michael D. McCool
00007 // 
00008 // This software is provided 'as-is', without any express or implied
00009 // warranty. In no event will the authors be held liable for any damages
00010 // arising from the use of this software.
00011 // 
00012 // Permission is granted to anyone to use this software for any purpose,
00013 // including commercial applications, and to alter it and redistribute it
00014 // freely, subject to the following restrictions:
00015 // 
00016 // 1. The origin of this software must not be misrepresented; you must
00017 // not claim that you wrote the original software. If you use this
00018 // software in a product, an acknowledgment in the product documentation
00019 // would be appreciated but is not required.
00020 // 
00021 // 2. Altered source versions must be plainly marked as such, and must
00022 // not be misrepresented as being the original software.
00023 // 
00024 // 3. This notice may not be removed or altered from any source
00025 // distribution.
00027 #ifndef SHHALF_HPP
00028 #define SHHALF_HPP
00029 
00030 #include <limits>
00031 #include "ShUtility.hpp"
00032 
00033 namespace SH {
00034 
00035 struct ShHalf {
00036   typedef unsigned short T; 
00037 
00038   static const int S = 1 << 15; // sign bit
00039   static const int E = 1 << 10; // exponent 
00040 
00041   T m_val;
00042 
00044   ShHalf();
00045 
00047   ShHalf(double value); 
00048 
00049   operator double() const;
00050 
00052   ShHalf& operator=(double value);
00053   ShHalf& operator=(const ShHalf& other);
00054   ShHalf& operator+=(double value);
00055   ShHalf& operator+=(const ShHalf& other);
00056   ShHalf& operator-=(double value);
00057   ShHalf& operator-=(const ShHalf& other);
00058   ShHalf& operator*=(double value);
00059   ShHalf& operator*=(const ShHalf& other);
00060   ShHalf& operator/=(double value);
00061   ShHalf& operator/=(const ShHalf& other);
00062 
00065   ShHalf& operator%=(double value);
00066   ShHalf& operator%=(const ShHalf& other);
00067   // @}
00068 
00070   ShHalf operator-() const;
00071 
00073   friend std::ostream& operator<<(std::ostream& out, const ShHalf &value);
00074 
00075 
00077   friend std::istream& operator>>(std::istream& out, ShHalf &value);
00078 
00079   private:
00081     static ShHalf make_half(T value);
00082 
00083     static T to_val(double value);
00084     void set_val(double value);
00085     double get_double() const;
00086 };
00087 
00088 }
00089 
00090 #include "ShHalfImpl.hpp"
00091   
00092 #endif

Generated on Mon Jan 24 18:36:32 2005 for Sh by  doxygen 1.4.1