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 __cmtkVoxelMatchingNormMutInf_h_included_
00034 #define __cmtkVoxelMatchingNormMutInf_h_included_
00035
00036 #include <cmtkconfig.h>
00037
00038 #include <Registration/cmtkRegistrationJointHistogram.h>
00039 #include <Base/cmtkInterpolator.h>
00040 #include <System/cmtkSmartPtr.h>
00041
00042 namespace
00043 cmtk
00044 {
00045
00048
00052 template<Interpolators::InterpolationEnum I=Interpolators::LINEAR>
00053 class VoxelMatchingNormMutInf :
00055 public RegistrationJointHistogram<I>
00056 {
00057 public:
00059 typedef VoxelMatchingNormMutInf<I> Self;
00060
00062 typedef SmartPointer<Self> SmartPtr;
00063
00065 typedef RegistrationJointHistogram<I> Superclass;
00066
00078 VoxelMatchingNormMutInf ( const UniformVolume* refVolume, const UniformVolume* fltVolume,
00079 const unsigned int numRefBins = CMTK_HISTOGRAM_AUTOBINS, const unsigned int numFltBins = CMTK_HISTOGRAM_AUTOBINS )
00080 : RegistrationJointHistogram<I>( refVolume, fltVolume, numRefBins, numFltBins ) {};
00081
00089 VoxelMatchingNormMutInf ( const UniformVolume* refVolume, const UniformVolume* fltVolume, const Types::DataItemRange& rangeRef, const Types::DataItemRange& rangeFlt )
00090 : RegistrationJointHistogram<I>( refVolume, fltVolume, CMTK_HISTOGRAM_AUTOBINS, CMTK_HISTOGRAM_AUTOBINS, rangeRef, rangeFlt ) {};
00091
00093 typename Self::ReturnType Get () const
00094 {
00095 double HX, HY;
00096 this->GetMarginalEntropies(HX,HY);
00097 const double HXY = this->GetJointEntropy();
00098
00099 return static_cast<typename Self::ReturnType>( (HX + HY) / HXY );
00100 }
00101 };
00102
00104 typedef VoxelMatchingNormMutInf<Interpolators::LINEAR> VoxelMatchingNormMutInf_Trilinear;
00105
00107 typedef VoxelMatchingNormMutInf<Interpolators::NEAREST_NEIGHBOR> VoxelMatchingNormMutInf_NearestNeighbor;
00108
00110
00111 }
00112
00113 #endif // #ifndef __cmtkVoxelMatchingNormMutInf_h_included_