ITK
4.6.0
Insight Segmentation and Registration Toolkit
|
#include <itkAzimuthElevationToCartesianTransform.h>
Transforms from an azimuth, elevation, radius coordinate system to a Cartesian coordinate system, or vice versa.
The three coordinate axis are azimuth, elevation, and range.
The azimuth elevation coordinate system is defined similarly to spherical coordinates but is slightly different in that the azimuth and elevation are measured in degrees between the r-axis (i.e z axis) and the projection on the x-z and y-z planes, respectively. Range, or r, is the distance from the origin.
The equations form performing the conversion from azimuth-elevation coordinates to cartesian coordinates are as follows: z = std::sqrt((r^2*(cos(azimuth))^2)/(1 + (cos(azimuth))^2 * (tan(elevation))^2); x = z * std::tan(azimuth) y = z * std::tan(elevation)
The reversed transforms are: azimuth = arctan(x/y) elevation = arctan(y/z) r = std::sqrt(x^2 + y^2 + z^2)
In this class, we can also set what a "forward" transform means. If we call SetForwardAzimuthElevationToCartesian(), a forward transform will return cartesian coordinates when passed azimuth,elevation,r coordinates. Calling SetForwardCartesianToAzimuthElevation() will cause the forward transform to return azimuth,elevation,r coordinates from cartesian coordinates.
Setting the FirstSampleDistance to a non-zero value means that a r value of 12 is actually (12 + FirstSampleDistance) distance from the origin.
There are two template parameters for this class:
ScalarT The type to be used for scalar numeric values. Either float or double.
NDimensions The number of dimensions of the vector space (must be >=3).
Definition at line 82 of file itkAzimuthElevationToCartesianTransform.h.
Public Types | |
typedef SmartPointer< const Self > | ConstPointer |
typedef Superclass::InputPointType | InputPointType |
typedef Superclass::JacobianType | JacobianType |
typedef Matrix< TScalar, itkGetStaticConstMacro(SpaceDimension), itkGetStaticConstMacro(SpaceDimension) > | MatrixType |
typedef Superclass::OutputPointType | OutputPointType |
typedef Superclass::ParametersType | ParametersType |
typedef SmartPointer< Self > | Pointer |
typedef Superclass::ScalarType | ScalarType |
typedef AzimuthElevationToCartesianTransform | Self |
typedef AffineTransform < TScalar, NDimensions > | Superclass |
Public Types inherited from itk::AffineTransform< TScalar, NDimensions > | |
typedef Superclass::CenterType | CenterType |
typedef SmartPointer< const Self > | ConstPointer |
typedef Superclass::InputCovariantVectorType | InputCovariantVectorType |
typedef Superclass::InputPointType | InputPointType |
typedef Superclass::InputVectorType | InputVectorType |
typedef Superclass::InputVnlVectorType | InputVnlVectorType |
typedef Superclass::InverseMatrixType | InverseMatrixType |
typedef InverseTransformBaseType::Pointer | InverseTransformBasePointer |
typedef Superclass::InverseTransformBaseType | InverseTransformBaseType |
typedef Superclass::JacobianType | JacobianType |
typedef Superclass::MatrixType | MatrixType |
typedef Superclass::OffsetType | OffsetType |
typedef Superclass::OutputCovariantVectorType | OutputCovariantVectorType |
typedef Superclass::OutputPointType | OutputPointType |
typedef Superclass::OutputVectorType | OutputVectorType |
typedef Superclass::OutputVnlVectorType | OutputVnlVectorType |
typedef Superclass::ParametersType | ParametersType |
typedef SmartPointer< Self > | Pointer |
typedef Superclass::ScalarType | ScalarType |
typedef AffineTransform | Self |
typedef MatrixOffsetTransformBase < TScalar, NDimensions, NDimensions > | Superclass |
typedef Superclass::TranslationType | TranslationType |
Public Types inherited from itk::MatrixOffsetTransformBase< TScalar, NDimensions, NDimensions > | |
typedef InputPointType | CenterType |
typedef SmartPointer< const Self > | ConstPointer |
typedef Superclass::InputDiffusionTensor3DType | InputDiffusionTensor3DType |
typedef Superclass::InputSymmetricSecondRankTensorType | InputSymmetricSecondRankTensorType |
typedef CovariantVector < TScalar, InputDiffusionTensor3DType::Dimension > | InputTensorEigenVectorType |
typedef Superclass::InputVectorPixelType | InputVectorPixelType |
typedef Matrix< TScalar, itkGetStaticConstMacro(InputSpaceDimension), itkGetStaticConstMacro(OutputSpaceDimension)> | InverseMatrixType |
typedef InverseTransformBaseType::Pointer | InverseTransformBasePointer |
typedef Superclass::InverseTransformBaseType | InverseTransformBaseType |
typedef Superclass::JacobianType | JacobianType |
typedef OutputVectorType | OffsetType |
typedef OffsetType::ValueType | OffsetValueType |
typedef Superclass::OutputDiffusionTensor3DType | OutputDiffusionTensor3DType |
typedef Superclass::OutputSymmetricSecondRankTensorType | OutputSymmetricSecondRankTensorType |
typedef Superclass::OutputVectorPixelType | OutputVectorPixelType |
typedef Superclass::ParametersType | ParametersType |
typedef Superclass::ParametersValueType | ParametersValueType |
typedef SmartPointer< Self > | Pointer |
typedef Superclass::ScalarType | ScalarType |
typedef MatrixOffsetTransformBase | Self |
typedef Transform< TScalar, NInputDimensions, NOutputDimensions > | Superclass |
typedef Superclass::TransformCategoryType | TransformCategoryType |
typedef OutputVectorType | TranslationType |
typedef TranslationType::ValueType | TranslationValueType |
typedef Vector< TScalar, itkGetStaticConstMacro(InputSpaceDimension)> | InputVectorType |
typedef Vector< TScalar, itkGetStaticConstMacro(OutputSpaceDimension)> | OutputVectorType |
typedef OutputVectorType::ValueType | OutputVectorValueType |
typedef CovariantVector < TScalar, itkGetStaticConstMacro(InputSpaceDimension)> | InputCovariantVectorType |
typedef CovariantVector < TScalar, itkGetStaticConstMacro(OutputSpaceDimension)> | OutputCovariantVectorType |
typedef vnl_vector_fixed < TScalar, itkGetStaticConstMacro(InputSpaceDimension)> | InputVnlVectorType |
typedef vnl_vector_fixed < TScalar, itkGetStaticConstMacro(OutputSpaceDimension)> | OutputVnlVectorType |
typedef Point< TScalar, itkGetStaticConstMacro(InputSpaceDimension)> | InputPointType |
typedef InputPointType::ValueType | InputPointValueType |
typedef Point< TScalar, itkGetStaticConstMacro(OutputSpaceDimension)> | OutputPointType |
typedef OutputPointType::ValueType | OutputPointValueType |
typedef Matrix< TScalar, itkGetStaticConstMacro(OutputSpaceDimension), itkGetStaticConstMacro(InputSpaceDimension)> | MatrixType |
typedef MatrixType::ValueType | MatrixValueType |
Public Types inherited from itk::Transform< TScalar, NInputDimensions, NOutputDimensions > | |
typedef SmartPointer< const Self > | ConstPointer |
typedef Array < ParametersValueType > | DerivativeType |
typedef Matrix< double, itkGetStaticConstMacro(OutputSpaceDimension), itkGetStaticConstMacro(InputSpaceDimension)> | DirectionChangeMatrix |
typedef CovariantVector < TScalar, NInputDimensions > | InputCovariantVectorType |
typedef DiffusionTensor3D < TScalar > | InputDiffusionTensor3DType |
typedef Matrix< double, itkGetStaticConstMacro(InputSpaceDimension), itkGetStaticConstMacro(InputSpaceDimension)> | InputDirectionMatrix |
typedef Point< TScalar, NInputDimensions > | InputPointType |
typedef SymmetricSecondRankTensor < TScalar, NInputDimensions > | InputSymmetricSecondRankTensorType |
typedef VariableLengthVector < TScalar > | InputVectorPixelType |
typedef Vector< TScalar, NInputDimensions > | InputVectorType |
typedef vnl_vector_fixed < TScalar, NInputDimensions > | InputVnlVectorType |
typedef InverseTransformBaseType::Pointer | InverseTransformBasePointer |
typedef Transform< TScalar, NOutputDimensions, NInputDimensions > | InverseTransformBaseType |
typedef Array2D < ParametersValueType > | JacobianType |
typedef Matrix< TScalar, itkGetStaticConstMacro(OutputSpaceDimension), itkGetStaticConstMacro(InputSpaceDimension)> | MatrixType |
typedef Superclass::NumberOfParametersType | NumberOfParametersType |
typedef CovariantVector < TScalar, NOutputDimensions > | OutputCovariantVectorType |
typedef DiffusionTensor3D < TScalar > | OutputDiffusionTensor3DType |
typedef Matrix< double, itkGetStaticConstMacro(OutputSpaceDimension), itkGetStaticConstMacro(OutputSpaceDimension)> | OutputDirectionMatrix |
typedef Point< TScalar, NOutputDimensions > | OutputPointType |
typedef SymmetricSecondRankTensor < TScalar, NOutputDimensions > | OutputSymmetricSecondRankTensorType |
typedef VariableLengthVector < TScalar > | OutputVectorPixelType |
typedef Vector< TScalar, NOutputDimensions > | OutputVectorType |
typedef vnl_vector_fixed < TScalar, NOutputDimensions > | OutputVnlVectorType |
typedef Superclass::ParametersType | ParametersType |
typedef Superclass::ParametersValueType | ParametersValueType |
typedef SmartPointer< Self > | Pointer |
typedef TScalar | ScalarType |
typedef Transform | Self |
typedef TransformBaseTemplate < TScalar > | Superclass |
typedef Superclass::TransformCategoryType | TransformCategoryType |
Public Types inherited from itk::TransformBaseTemplate< TScalar > | |
typedef SmartPointer< const Self > | ConstPointer |
typedef IdentifierType | NumberOfParametersType |
typedef OptimizerParameters < ParametersValueType > | ParametersType |
typedef TScalar | ParametersValueType |
typedef SmartPointer< Self > | Pointer |
typedef TransformBaseTemplate | Self |
typedef Object | Superclass |
enum | TransformCategoryType { UnknownTransformCategory =0, Linear =1, BSpline =2, Spline =3, DisplacementField =4, VelocityField =5 } |
Public Types inherited from itk::Object | |
typedef SmartPointer< const Self > | ConstPointer |
typedef SmartPointer< Self > | Pointer |
typedef Object | Self |
typedef LightObject | Superclass |
Public Types inherited from itk::LightObject | |
typedef SmartPointer< const Self > | ConstPointer |
typedef SmartPointer< Self > | Pointer |
typedef LightObject | Self |
Static Public Member Functions | |
static Pointer | New () |
Static Public Member Functions inherited from itk::AffineTransform< TScalar, NDimensions > | |
static Pointer | New () |
Static Public Member Functions inherited from itk::MatrixOffsetTransformBase< TScalar, NDimensions, NDimensions > | |
static Pointer | New () |
Static Public Member Functions inherited from itk::Object | |
static bool | GetGlobalWarningDisplay () |
static void | GlobalWarningDisplayOff () |
static void | GlobalWarningDisplayOn () |
static Pointer | New () |
static void | SetGlobalWarningDisplay (bool flag) |
Static Public Member Functions inherited from itk::LightObject | |
static void | BreakOnError () |
static Pointer | New () |
Static Public Attributes | |
static const unsigned int | SpaceDimension = NDimensions |
static const unsigned int | ParametersDimension = NDimensions * ( NDimensions + 1 ) |
Static Public Attributes inherited from itk::AffineTransform< TScalar, NDimensions > | |
static const unsigned int | InputSpaceDimension = NDimensions |
static const unsigned int | OutputSpaceDimension = NDimensions |
static const unsigned int | SpaceDimension = NDimensions |
static const unsigned int | ParametersDimension = NDimensions *( NDimensions + 1 ) |
Static Public Attributes inherited from itk::MatrixOffsetTransformBase< TScalar, NDimensions, NDimensions > | |
static const unsigned int | InputSpaceDimension |
static const unsigned int | OutputSpaceDimension |
static const unsigned int | ParametersDimension |
Static Public Attributes inherited from itk::Transform< TScalar, NInputDimensions, NOutputDimensions > | |
static const unsigned int | InputSpaceDimension = NInputDimensions |
static const unsigned int | OutputSpaceDimension = NOutputDimensions |
Private Member Functions | |
AzimuthElevationToCartesianTransform (const Self &) | |
void | operator= (const Self &) |
Private Attributes | |
double | m_AzimuthAngularSeparation |
double | m_ElevationAngularSeparation |
double | m_FirstSampleDistance |
bool | m_ForwardAzimuthElevationToPhysical |
long | m_MaxAzimuth |
long | m_MaxElevation |
double | m_RadiusSampleSize |
Additional Inherited Members | |
Protected Types inherited from itk::LightObject | |
typedef int | InternalReferenceCountType |
Protected Attributes inherited from itk::Transform< TScalar, NInputDimensions, NOutputDimensions > | |
DirectionChangeMatrix | m_DirectionChange |
ParametersType | m_FixedParameters |
ParametersType | m_Parameters |
Protected Attributes inherited from itk::LightObject | |
InternalReferenceCountType | m_ReferenceCount |
SimpleFastMutexLock | m_ReferenceCountLock |
typedef SmartPointer< const Self > itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::ConstPointer |
Definition at line 90 of file itkAzimuthElevationToCartesianTransform.h.
typedef Superclass::InputPointType itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::InputPointType |
Standard coordinate point type for this class
Definition at line 114 of file itkAzimuthElevationToCartesianTransform.h.
typedef Superclass::JacobianType itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::JacobianType |
Jacobian type.
Definition at line 108 of file itkAzimuthElevationToCartesianTransform.h.
typedef Matrix< TScalar, itkGetStaticConstMacro(SpaceDimension), itkGetStaticConstMacro(SpaceDimension) > itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::MatrixType |
Standard matrix type for this class.
Definition at line 119 of file itkAzimuthElevationToCartesianTransform.h.
typedef Superclass::OutputPointType itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::OutputPointType |
Definition at line 115 of file itkAzimuthElevationToCartesianTransform.h.
typedef Superclass::ParametersType itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::ParametersType |
Parameters type.
Definition at line 102 of file itkAzimuthElevationToCartesianTransform.h.
typedef SmartPointer< Self > itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::Pointer |
Definition at line 89 of file itkAzimuthElevationToCartesianTransform.h.
typedef Superclass::ScalarType itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::ScalarType |
Standard scalar type for this class.
Definition at line 111 of file itkAzimuthElevationToCartesianTransform.h.
typedef AzimuthElevationToCartesianTransform itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::Self |
Standard class typedefs.
Definition at line 87 of file itkAzimuthElevationToCartesianTransform.h.
typedef AffineTransform< TScalar, NDimensions > itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::Superclass |
Definition at line 88 of file itkAzimuthElevationToCartesianTransform.h.
|
protected |
Create an AzimuthElevationToCartesianTransform object.
|
protectedvirtual |
Destroy an AzimuthElevationToCartesianTransform object.
|
private |
|
inline |
Back transform from cartesian to azimuth-elevation.
Definition at line 139 of file itkAzimuthElevationToCartesianTransform.h.
References itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::m_ForwardAzimuthElevationToPhysical, itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::TransformAzElToCartesian(), and itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::TransformCartesianToAzEl().
Referenced by itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::BackTransformPoint().
|
inline |
Definition at line 154 of file itkAzimuthElevationToCartesianTransform.h.
References itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::BackTransform().
|
virtual |
Create an object from an instance, potentially deferring to a factory. This method allows you to create an instance of an object that is exactly the same type as the referring object. This is useful in cases where an object has been cast back to a base class.
Reimplemented from itk::AffineTransform< TScalar, NDimensions >.
|
virtual |
Set the number of degrees between each azimuth unit.
|
virtual |
Set the number of degrees between each elevation unit.
|
virtual |
Set the distance to add to the radius.
|
virtual |
Set the maximum azimuth. The maximum azimuth and elevation can be set so that the resulting cartesian space is symmetric about the z axis. Therefore, the line defined by azimuth/2,elevation/2 = z-axis.
|
virtual |
Set the maximum elevation The maximum azimuth and elevation can be set so that the resulting cartesian space is symmetric about the z axis. Therefore, the line defined by azimuth/2,elevation/2 = z-axis.
|
virtual |
Run-time type information (and related methods).
Reimplemented from itk::AffineTransform< TScalar, NDimensions >.
|
virtual |
Set the number of cartesian units between each unit along the R .
|
static |
New macro for creation of through a Smart Pointer.
|
private |
|
protectedvirtual |
Print contents of an AzimuthElevationTransform.
Reimplemented from itk::AffineTransform< TScalar, NDimensions >.
|
virtual |
Set the number of degrees between each azimuth unit.
void itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::SetAzimuthElevationToCartesianParameters | ( | const double | sampleSize, |
const double | blanking, | ||
const long | maxAzimuth, | ||
const long | maxElevation, | ||
const double | azimuthAngleSeparation, | ||
const double | elevationAngleSeparation | ||
) |
Set the transformation parameters.
void itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::SetAzimuthElevationToCartesianParameters | ( | const double | sampleSize, |
const double | blanking, | ||
const long | maxAzimuth, | ||
const long | maxElevation | ||
) |
|
virtual |
Set the number of degrees between each elevation unit.
|
virtual |
Set the distance to add to the radius.
void itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::SetForwardAzimuthElevationToCartesian | ( | ) |
Defines that the forward transform goes from azimuth,elevation to cartesian.
void itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::SetForwardCartesianToAzimuthElevation | ( | ) |
Defines that the forward transform goes from cartesian to azimuth, elevation.
|
virtual |
Set the maximum azimuth. The maximum azimuth and elevation can be set so that the resulting cartesian space is symmetric about the z axis. Therefore, the line defined by azimuth/2,elevation/2 = z-axis.
|
virtual |
Set the maximum elevation The maximum azimuth and elevation can be set so that the resulting cartesian space is symmetric about the z axis. Therefore, the line defined by azimuth/2,elevation/2 = z-axis.
|
virtual |
Set the number of cartesian units between each unit along the R .
OutputPointType itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::TransformAzElToCartesian | ( | const InputPointType & | point | ) | const |
Perform conversion from Azimuth Elevation coordinates to Cartesian Coordinates.
Referenced by itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::BackTransform().
OutputPointType itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::TransformCartesianToAzEl | ( | const OutputPointType & | point | ) | const |
Perform conversion from Cartesian Coordinates to Azimuth Elevation coordinates.
Referenced by itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::BackTransform().
OutputPointType itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::TransformPoint | ( | const InputPointType & | point | ) | const |
Transform from azimuth-elevation to cartesian.
|
private |
Definition at line 231 of file itkAzimuthElevationToCartesianTransform.h.
|
private |
Definition at line 232 of file itkAzimuthElevationToCartesianTransform.h.
|
private |
Definition at line 233 of file itkAzimuthElevationToCartesianTransform.h.
|
private |
Definition at line 234 of file itkAzimuthElevationToCartesianTransform.h.
Referenced by itk::AzimuthElevationToCartesianTransform< TScalar, NDimensions >::BackTransform().
|
private |
Definition at line 228 of file itkAzimuthElevationToCartesianTransform.h.
|
private |
Definition at line 229 of file itkAzimuthElevationToCartesianTransform.h.
|
private |
Definition at line 230 of file itkAzimuthElevationToCartesianTransform.h.
|
static |
Dimension of the domain space.
Definition at line 95 of file itkAzimuthElevationToCartesianTransform.h.
|
static |
Dimension of the domain space.
Definition at line 93 of file itkAzimuthElevationToCartesianTransform.h.