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

ShLibDerivImpl.hpp

00001 // Sh: A GPU metaprogramming language.
00002 //
00003 // Copyright 2003-2005 Serious Hack Inc.
00004 // 
00005 // This software is provided 'as-is', without any express or implied
00006 // warranty. In no event will the authors be held liable for any damages
00007 // arising from the use of this software.
00008 // 
00009 // Permission is granted to anyone to use this software for any purpose,
00010 // including commercial applications, and to alter it and redistribute it
00011 // freely, subject to the following restrictions:
00012 // 
00013 // 1. The origin of this software must not be misrepresented; you must
00014 // not claim that you wrote the original software. If you use this
00015 // software in a product, an acknowledgment in the product documentation
00016 // would be appreciated but is not required.
00017 // 
00018 // 2. Altered source versions must be plainly marked as such, and must
00019 // not be misrepresented as being the original software.
00020 // 
00021 // 3. This notice may not be removed or altered from any source
00022 // distribution.
00024 #ifndef SHLIBDERIVIMPL_HPP
00025 #define SHLIBDERIVIMPL_HPP
00026 
00027 #include "ShLibDeriv.hpp"
00028 
00029 namespace SH {
00030 
00031 template<int N, typename T>
00032 ShGeneric<N, T> dx(const ShGeneric<N, T>& var)
00033 {
00034   ShAttrib<N, SH_TEMP, T> t;
00035   shDX(t, var);
00036   return t;
00037 }
00038 
00039 template<int N, typename T>
00040 ShGeneric<N, T> dy(const ShGeneric<N, T>& var)
00041 {
00042   ShAttrib<N, SH_TEMP, T> t;
00043   shDY(t, var);
00044   return t;
00045 }
00046 
00047 template<int N, typename T>
00048 inline
00049 ShGeneric<N, T> fwidth(const ShGeneric<N, T>& var)
00050 {
00051   return max(abs(dx(var)), abs(dy(var)));
00052 }
00053 
00054 template<typename T>
00055 inline
00056 ShGeneric<2, T> gradient(const ShGeneric<1, T>& var)
00057 {
00058   return ShAttrib2f(dx(var), dy(var));
00059 }
00060 
00061 template<int N, typename T>
00062 ShMatrix<2, N, SH_TEMP, T> jacobian(const ShGeneric<N, T>& var)
00063 {
00064   ShMatrix<2, N, SH_TEMP, T> ret;
00065   ret[0] = dx(var);
00066   ret[1] = dy(var);
00067   return ret;
00068 }
00069 
00070 
00071 
00072 }
00073 
00074 #endif

Generated on Thu Apr 21 17:32:47 2005 for Sh by  doxygen 1.4.2