00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022 #ifndef __freDifferenceEnergyImageToImageMetric_txx
00023 #define __freDifferenceEnergyImageToImageMetric_txx
00024
00025 #include "freDifferenceEnergyImageToImageMetric.h"
00026
00027 namespace itk
00028 {
00029 template <class TFixedImage, class TMovingImage, class TDifImage>
00030 typename DifferenceEnergyImageToImageMetric<TFixedImage, TMovingImage, TDifImage>
00031 ::MeasureType
00032 DifferenceEnergyImageToImageMetric<TFixedImage, TMovingImage, TDifImage>
00033 ::EvaluateMeasure(HistogramType& histogram) const
00034 {
00035 MeasureType measure = NumericTraits<MeasureType>::Zero;
00036 HistogramIteratorType it = histogram.Begin();
00037 HistogramIteratorType end = histogram.End();
00038 HistogramFrequencyType totalFrequency = histogram.GetTotalFrequency();
00039
00040 while (it != end)
00041 {
00042 HistogramFrequencyType freq = it.GetFrequency();
00043 if (freq > 0)
00044 {
00045 MeasureType energy = freq/totalFrequency;
00046 energy *= energy;
00047 measure += energy;
00048 }
00049 ++it;
00050 }
00051
00052
00053 return -1*measure;
00054 }
00055 }
00056
00057
00058 #endif // __freDifferenceEnergyImageToImageMetric_txx