/usr/include/InsightToolkit/Numerics/itkCacheableScalarFunction.h is in libinsighttoolkit3-dev 3.20.1+git20120521-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 | /*=========================================================================
Program: Insight Segmentation & Registration Toolkit
Module: itkCacheableScalarFunction.h
Language: C++
Date: $Date$
Version: $Revision$
Copyright (c) Insight Software Consortium. All rights reserved.
See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notices for more information.
=========================================================================*/
#ifndef __itkCacheableScalarFunction_h
#define __itkCacheableScalarFunction_h
#include "itkArray.h"
#include "itkExceptionObject.h"
namespace itk {
/** \class CacheableScalarFunction
* \brief function cache implementation
*
* This is the base class for continuous scalar functions which
* needs cache for their pre-evaluated function returns.
*
* The internal cache is created using the upper- and lower-bound domain
* values of the functional form (f(x))of subclasses of this class. So the
* cache only stores pre-evaluated values between f(lower-bound) and
* f(upper-bound).
*
* To create a cache for continuous function, it uses sampling.
* With the given sample number , upper-bound, and lower-bound, it calculates
* interval within the ranges. It pre-evaluates and save f(x)
* where x = lower-bound + interval * [0 - sample number]
*
* If a subclass of this class want to use a cache, it should
* explicitly call CreateCache(...) member function. GetCachedValue(x) will
* return pre-evaluated f(x) value. However, the return value from
* GetCachedValue(x) might be different from the exact return value from f(x)
* which is Evaluate(x) member function of subclasses of this class, because
* The GetCachedValue(x) member function internally converts x to cache table
* index and the conversion involves with truncation. So, users can think the
* cached value as an approximate to exact function return.
*
* In some case, approximate values can be useful.
* For example, CompositeValleyFunction can be used as an M-estimator and
* it is currently used for MRIBiasFieldCorrectionFilter
* as an energy function. The bias field estimation requires calculation of
* energy values again and again for each iteration.
*/
class ITK_EXPORT CacheableScalarFunction
{
public:
/** Constructor. */
CacheableScalarFunction();
/** Destructor. */
virtual ~CacheableScalarFunction() {}
/** Function's input and output value type. */
typedef double MeasureType;
typedef Array<MeasureType> MeasureArrayType;
/** Get the number of samples between the lower-bound and upper-bound
* of the cache table. */
long GetNumberOfSamples() { return m_NumberOfSamples; }
/** Check if the internal cache table and its values are valid. */
bool IsCacheAvailable() { return m_CacheAvailable; }
/** Get the upper-bound of domain that is used for filling the cache table. */
double GetCacheUpperBound() { return m_CacheUpperBound; }
/** Get the lower-bound of domain that is used for filling the cache table. */
double GetCacheLowerBound() { return m_CacheLowerBound; }
/** y = f(x)
* Subclasses of this class should override this member function
* to provide their own functional operation . */
virtual MeasureType Evaluate(MeasureType x)
{ return x; }
/** Gets the interval of each cell between the upper and lower bound */
double GetInterval()
{ return m_TableInc; }
/** y = f(x) = (approximately) cache_table(index(x))
* Get the function return using the internal cache table
* NOTE: Since the index calculation needs conversion from double
* to int, truncation happens. As a result, the return values from
* Evaluate(x) and GetCachedValue(x) may not be same for the same x. */
inline MeasureType GetCachedValue(MeasureType x)
{
if (x > m_CacheUpperBound || x < m_CacheLowerBound)
{
throw ExceptionObject(__FILE__,__LINE__);
}
// access table
int index = (int) ((x - m_CacheLowerBound) / m_TableInc);
return m_CacheTable[index];
}
protected:
/** Create the internal cache table and fill it with
* pre-evaluated values. */
void CreateCache(double lowerBound, double upperBound, long sampleSize);
private:
/** The number of samples will be precalcualted and saved in the
* cache table. */
long m_NumberOfSamples;
/** Storage for the precalcualted function values. */
MeasureArrayType m_CacheTable;
/** The upper-bound of domain that is used for filling the cache table. */
double m_CacheUpperBound;
/** The lower-bound of domain that is used for filling the cache table. */
double m_CacheLowerBound;
/** Sampling interval for function evaluation. */
double m_TableInc;
/** Is the cache available? */
bool m_CacheAvailable;
}; // end of class
} // end of namespace itk
#endif
|