Main Page | Modules | Namespace List | Class Hierarchy | Alphabetical List | Class List | Directories | 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, double> cast(double a)
00059 {
00060   return cast<M>(ShAttrib<1, SH_CONST, double>(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, double> fillcast(double a)
00076 {
00077   return fillcast<M>(ShAttrib<1, SH_CONST, double>(a));
00078 }
00079 
00080 template<int M, int N, typename T1, typename T2> 
00081 inline
00082 ShGeneric<M+N, CT1T2> join(const ShGeneric<M, T1>& a, const ShGeneric<N, T2>& 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, CT1T2> 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) << (T::ConstType)(uniform);
00111 }
00112 
00113 }
00114 
00115 #endif

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