Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033 #ifndef __cmtkVoxelMatchingMetric_h_included_
00034 #define __cmtkVoxelMatchingMetric_h_included_
00035
00036 #include <cmtkconfig.h>
00037
00038 #include <Registration/cmtkVoxelMatchingMetric_Type.h>
00039
00040 #include <System/cmtkSmartPtr.h>
00041
00042 #include <Base/cmtkInterpolator.h>
00043 #include <Base/cmtkUniformVolume.h>
00044 #include <Base/cmtkTypes.h>
00045 #include <Base/cmtkFunctional.h>
00046
00047 #include <cassert>
00048
00049 namespace
00050 cmtk
00051 {
00052
00055
00058 template<class T, ScalarDataType DT, Interpolators::InterpolationEnum I=cmtk::Interpolators::LINEAR>
00059 class VoxelMatchingMetric :
00061 public VoxelMatchingMetric_Type<T,DT>
00062 {
00063 public:
00065 typedef VoxelMatchingMetric<T,DT,I> Self;
00066
00068 typedef SmartPointer<Self> SmartPtr;
00069
00071 typedef Functional::ReturnType ReturnType;
00072
00082 VoxelMatchingMetric( const UniformVolume* refVolume, const UniformVolume* fltVolume, const bool initData = true );
00083
00086 VoxelMatchingMetric() {};
00087
00089 T GetSampleX ( const size_t index ) const
00090 {
00091 return this->DataX.Data[index];
00092 }
00093
00095 T GetSampleY ( const size_t index ) const
00096 {
00097 return this->DataY.Data[index];
00098 }
00099
00101 T GetSampleY ( const size_t baseIndex, const Types::Coordinate* frac ) const;
00102 };
00103
00105 typedef VoxelMatchingMetric<short,TYPE_SHORT> VoxelMatchingMetricShort;
00106
00108 typedef VoxelMatchingMetric<byte,TYPE_BYTE> VoxelMatchingMetricByte;
00109
00111 typedef VoxelMatchingMetric<short,TYPE_SHORT,Interpolators::NEAREST_NEIGHBOR> VoxelMatchingMetricShort_NN;
00112
00114 typedef VoxelMatchingMetric<byte,TYPE_BYTE,Interpolators::NEAREST_NEIGHBOR> VoxelMatchingMetricByte_NN;
00115
00117
00118 }
00119
00120 #include "cmtkVoxelMatchingMetric.txx"
00121
00122 #endif // #ifndef __cmtkVoxelMatchingMetric_h_included_