00001 #ifndef Impala_Core_Array_InvWw_h
00002 #define Impala_Core_Array_InvWw_h
00003
00004 #include <vector>
00005 #include "Core/Array/Pattern/PatM9PixOp.h"
00006 #include "Core/Array/Trait/M9poWw.h"
00007
00008 namespace Impala
00009 {
00010 namespace Core
00011 {
00012 namespace Array
00013 {
00014
00015
00016
00017 template<class DstArrayT, class SrcArrayT>
00018 inline void
00019 InvWw(DstArrayT*& dst, SrcArrayT* s1, SrcArrayT* s2, SrcArrayT* s3,
00020 SrcArrayT* s4, SrcArrayT* s5, SrcArrayT* s6, SrcArrayT* s7,
00021 SrcArrayT* s8, SrcArrayT* s9, typename SrcArrayT::ArithType scale)
00022 {
00023 Trait::M9poWw<DstArrayT, SrcArrayT> mpo(scale);
00024 Pattern::PatM9PixOp(dst, s1, s2, s3, s4, s5, s6, s7, s8, s9, mpo);
00025 }
00026
00027
00028
00029 template<class ArrayT>
00030 inline void
00031 InvWw(ArrayT*& dst, const std::vector<ArrayT*>& eList,
00032 typename ArrayT::ArithType scale)
00033 {
00034 InvWw(dst,
00035 eList[0], eList[3], eList[6],
00036 eList[1], eList[4], eList[7],
00037 eList[2], eList[5], eList[8], scale);
00038 }
00039
00040 }
00041 }
00042 }
00043
00044 #endif