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

ShInterp.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 SHINTERP_HPP
00028 #define SHINTERP_HPP
00029 
00030 namespace SH {
00031 
00038 template<int L, typename T>
00039 class ShInterp : public T {
00040 public:
00041   static int level() {
00042     if (L >= 2) return 3; else return L;
00043   }
00044   
00045   ShInterp()
00046     : T()
00047   {
00048     this->m_node->traits().interpolation(level());
00049   }
00050   ShInterp(int width)
00051     : T(width)
00052   {
00053     this->m_node->traits().interpolation(level());
00054   }
00055   ShInterp(int width, int height)
00056     : T(width, height)
00057   {
00058     this->m_node->traits().interpolation(level());
00059   }
00060   ShInterp(int width, int height, int depth)
00061     : T(width, height, depth)
00062   {
00063     this->m_node->traits().interpolation(level());
00064   }
00065 
00066   typedef typename T::return_type return_type;
00067   
00068 };
00069 
00070 }
00071 
00072 #endif

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