Main Page   Groups   Namespace List   Class Hierarchy   Alphabetical List   Compound List   File List   Namespace Members   Compound Members   File Members   Concepts

itk::Math Namespace Reference

Functions

template<typename TReturn , typename TInput >
TReturn CastWithRangeCheck (TInput x)
int Ceil (float x)
int Ceil (double x)
template<TReturn , typename TInput >
 Ceil (TInput x)
int Floor (float x)
int Floor (double x)
template<TReturn , typename TInput >
 Floor (TInput x)
int Round (float x)
int Round (double x)
template<typename TReturn , typename TInput >
TReturn Round (TInput x)
template<TReturn , typename TInput >
 RoundHalfIntegerToEven (TInput x)
int RoundHalfIntegerUp (float x)
int RoundHalfIntegerUp (double x)
template<TReturn , typename TInput >
 RoundHalfIntegerUp (TInput x)



int RoundHalfIntegerToEven (float x)
int RoundHalfIntegerToEven (double x)

Variables

static const double ln10 = 2.30258509299404568402
static const double ln2 = 0.69314718055994530942
static const double log10e = 0.43429448190325182765
static const double log2e = 1.4426950408889634074
static const double one_over_pi = 0.31830988618379067154
static const double one_over_sqrt2pi = 0.39894228040143267794
static const double pi_over_2 = 1.57079632679489661923
static const double pi_over_4 = 0.78539816339744830962
static const double sqrt1_2 = 0.70710678118654752440
static const double sqrt2 = 1.41421356237309504880
static const double two_over_pi = 0.63661977236758134308
static const double two_over_sqrtpi = 1.12837916709551257390

Function Documentation

template<typename TReturn , typename TInput >
TReturn itk::Math::CastWithRangeCheck ( TInput  x  )  [inline]

Definition at line 228 of file itkMath.h.

References itkConceptMacro.

int itk::Math::Ceil ( float  x  )  [inline]

Definition at line 222 of file itkMath.h.

int itk::Math::Ceil ( double  x  )  [inline]

Definition at line 221 of file itkMath.h.

template<TReturn , typename TInput >
itk::Math::Ceil ( TInput  x  )  [inline]

Round towards plus infinity.

The behavior of overflow is undefined due to numerous implementations.

Warning:
argument absolute value must be less than INT_MAX/2 for vnl_math_ceil to be guaranteed to work.
We also assume that the rounding mode is not changed from the default one (or at least that it is always restored to the default one).
int itk::Math::Floor ( float  x  )  [inline]

Definition at line 219 of file itkMath.h.

int itk::Math::Floor ( double  x  )  [inline]

Definition at line 218 of file itkMath.h.

template<TReturn , typename TInput >
itk::Math::Floor ( TInput  x  )  [inline]

Round towards minus infinity.

The behavior of overflow is undefined due to numerous implementations.

Warning:
argument absolute value must be less than NumbericTraits<TReturn>::max()/2 for vnl_math_floor to be guaranteed to work.
We also assume that the rounding mode is not changed from the default one (or at least that it is always restored to the default one).
int itk::Math::Round ( float  x  )  [inline]

Definition at line 216 of file itkMath.h.

int itk::Math::Round ( double  x  )  [inline]

Definition at line 215 of file itkMath.h.

template<typename TReturn , typename TInput >
TReturn itk::Math::Round ( TInput  x  )  [inline]

Round towards nearest integer (This is a synonym for RoundHalfIntegerUp).

Template Parameters:
TReturn must be an interger type
TInput must be float or double
See also:
RoundHalfIntegerUp<TReturn, TInput>()

Definition at line 163 of file itkMath.h.

int itk::Math::RoundHalfIntegerToEven ( float  x  )  [inline]

A useful macro to generate a template floating point to integer conversion templated on the return type and using either the 32 bit, the 64 bit or the vanilla version

Definition at line 209 of file itkMath.h.

int itk::Math::RoundHalfIntegerToEven ( double  x  )  [inline]
Deprecated:
These methods have been deprecated as of ITK 3.16. Please use the templated methods of the form itk::Math::XXX<TReturn,TINput(TInput x) instead.
See also:
RoundHalfIntegerUp<TReturn, TInput>()

Definition at line 208 of file itkMath.h.

template<TReturn , typename TInput >
itk::Math::RoundHalfIntegerToEven ( TInput  x  )  [inline]

Round towards nearest integer.

Template Parameters:
TReturn must be an interger type
TInput must be float or double

halfway cases are rounded towards the nearest even integer, e.g.

The behavior of overflow is undefined due to numerous implementations.

Warning:
We assume that the rounding mode is not changed from the default one (or at least that it is always restored to the default one).
int itk::Math::RoundHalfIntegerUp ( float  x  )  [inline]

Definition at line 213 of file itkMath.h.

int itk::Math::RoundHalfIntegerUp ( double  x  )  [inline]

Definition at line 212 of file itkMath.h.

template<TReturn , typename TInput >
itk::Math::RoundHalfIntegerUp ( TInput  x  )  [inline]

Round towards nearest integer.

Template Parameters:
TReturn must be an interger type
TInput must be float or double

halfway cases are rounded upward, e.g.

          RoundHalfIntegerUp( 1.5) ==  2
          RoundHalfIntegerUp(-1.5) == -1
          RoundHalfIntegerUp( 2.5) ==  3

The behavior of overflow is undefined due to numerous implementations.

Warning:
The argument absolute value must be less than NumbericTraits<TReturn>::max()/2 for RoundHalfIntegerUp to be guaranteed to work.
We also assume that the rounding mode is not changed from the default one (or at least that it is always restored to the default one).

Variable Documentation

const double itk::Math::ln10 = 2.30258509299404568402 [static]

\[ \log_e 10 \]

Definition at line 50 of file itkMath.h.

const double itk::Math::ln2 = 0.69314718055994530942 [static]

\[ \log_e 2 \]

Definition at line 48 of file itkMath.h.

const double itk::Math::log10e = 0.43429448190325182765 [static]

\[ \log_10 e \]

Definition at line 46 of file itkMath.h.

const double itk::Math::log2e = 1.4426950408889634074 [static]

\[e] The base of the natural logarithm or Euler's number */ static const double e = 2.7182818284590452354; /** \brief \f[ \log_2 e \]

Definition at line 44 of file itkMath.h.

const double itk::Math::one_over_pi = 0.31830988618379067154 [static]
const double itk::Math::one_over_sqrt2pi = 0.39894228040143267794 [static]

\[ \frac{2}{\sqrt{2\pi}} \]

Definition at line 64 of file itkMath.h.

const double itk::Math::pi_over_2 = 1.57079632679489661923 [static]

\[ \pi ] */ static const double pi = 3.14159265358979323846; /** \brief \f[ \frac{\pi}{2} \]

Definition at line 54 of file itkMath.h.

const double itk::Math::pi_over_4 = 0.78539816339744830962 [static]

\[ \frac{\pi}{4} \]

Definition at line 56 of file itkMath.h.

const double itk::Math::sqrt1_2 = 0.70710678118654752440 [static]

\[ \sqrt{ \frac{1}{2}} \]

Definition at line 68 of file itkMath.h.

const double itk::Math::sqrt2 = 1.41421356237309504880 [static]

\[ \sqrt{2} \]

Definition at line 66 of file itkMath.h.

const double itk::Math::two_over_pi = 0.63661977236758134308 [static]

\[ \frac{2}{\pi} \]

Definition at line 60 of file itkMath.h.

const double itk::Math::two_over_sqrtpi = 1.12837916709551257390 [static]

\[ \frac{2}{\sqrt{\pi}} \]

Definition at line 62 of file itkMath.h.


Generated at Sat Apr 17 01:59:26 2010 for ITK by doxygen 1.6.1 written by Dimitri van Heesch, © 1997-2000