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

ShLibMiscImpl.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 SHLIBMISCIMPL_HPP 00028 #define SHLIBMISCIMPL_HPP 00029 00030 #include "ShLibMisc.hpp" 00031 #include "ShInstructions.hpp" 00032 #include "ShProgram.hpp" 00033 00034 namespace SH { 00035 00036 template<int M, int N, typename T> 00037 inline 00038 ShGeneric<M, T> cast(const ShGeneric<N, T>& a) 00039 { 00040 int copySize = std::min(M, N); 00041 ShAttrib<M, SH_TEMP, T> result; 00042 00043 int* indices = new int[copySize]; 00044 for(int i = 0; i < copySize; ++i) indices[i] = i; 00045 if(M < N) { 00046 result = a.template swiz<M>(indices); 00047 } else if( M > N ) { 00048 result.template swiz<N>(indices) = a; 00049 } else { // M == N 00050 shASN(result, a); 00051 } 00052 delete [] indices; 00053 return result; 00054 } 00055 00056 template<int M> 00057 inline 00058 ShGeneric<M, float> cast(float a) 00059 { 00060 return cast<M>(ShAttrib<1, SH_CONST, float>(a)); 00061 } 00062 00063 template<int M, int N, typename T> 00064 inline 00065 ShGeneric<M, T> fillcast(const ShGeneric<N, T>& a) 00066 { 00067 if( M <= N ) return cast<M>(a); 00068 int indices[M]; 00069 for(int i = 0; i < M; ++i) indices[i] = i >= N ? N - 1 : i; 00070 return a.template swiz<M>(indices); 00071 } 00072 00073 template<int M> 00074 inline 00075 ShGeneric<M, float> fillcast(float a) 00076 { 00077 return fillcast<M>(ShAttrib<1, SH_CONST, float>(a)); 00078 } 00079 00080 template<int M, int N, typename T> 00081 inline 00082 ShGeneric<M+N, T> join(const ShGeneric<M, T>& a, const ShGeneric<N, T>& b) 00083 { 00084 int indices[M+N]; 00085 for(int i = 0; i < M+N; ++i) indices[i] = i; 00086 ShAttrib<M+N, SH_TEMP, T> result; 00087 result.template swiz<M>(indices) = a; 00088 result.template swiz<N>(indices + M) = b; 00089 return result; 00090 } 00091 00092 template<int N, typename T> 00093 inline 00094 void discard(const ShGeneric<N, T>& c) 00095 { 00096 shKIL(c); 00097 } 00098 00099 template<int N, typename T> 00100 inline 00101 void kill(const ShGeneric<N, T>& c) 00102 { 00103 discard(c); 00104 } 00105 00106 template<typename T> 00107 ShProgram freeze(const ShProgram& p, 00108 const T& uniform) 00109 { 00110 return (p >> uniform) << (typename T::ConstType)(uniform); 00111 } 00112 00113 } 00114 00115 #endif

Generated on Mon Oct 18 14:17:39 2004 for Sh by doxygen 1.3.7