PCL
|
Astrometric metadata. More...
#include <AstrometricMetadata.h>
Classes | |
struct | DescriptionItems |
A collection of strings describing the properties and parameters of an astrometric solution. More... | |
Static Public Member Functions | |
static IsoString | ReferenceSystemFromMetadata (const PropertyArray &properties, const FITSKeywordArray &keywords) |
static void | RemoveKeywords (FITSKeywordArray &keywords, bool removeCenterKeywords=true, bool removeScaleKeywords=true) |
static void | RemoveObservationLocationProperties (ImageWindow &window) |
static void | RemoveObservationLocationProperties (PropertyArray &properties) |
static void | RemoveProperties (ImageWindow &window, bool removeCenterProperties=true, bool removeScaleProperties=true) |
static void | RemoveProperties (PropertyArray &properties, bool removeCenterProperties=true, bool removeScaleProperties=true) |
static void | RescalePixelSizeKeywords (FITSKeywordArray &keywords, double scalingFactor) |
static void | RescalePixelSizeProperties (ImageWindow &window, double scalingFactor) |
static void | RescalePixelSizeProperties (PropertyArray &properties, double scalingFactor) |
Definition at line 112 of file AstrometricMetadata.h.
|
default |
Default constructor. Constructs an uninitialized AstrometricMetadata object.
|
inline |
Copy constructor.
Definition at line 158 of file AstrometricMetadata.h.
|
default |
Move constructor.
pcl::AstrometricMetadata::AstrometricMetadata | ( | ProjectionBase * | projection, |
WorldTransformation * | worldTransformation, | ||
int | width, | ||
int | height | ||
) |
Constructor from minimal data.
projection | Pointer to a dynamically allocated projection system. |
worldTransformation | Pointer to a dynamically allocated world coordinate transformation. |
width | Width in pixels of the image associated with this astrometric solution. |
height | Height in pixels of the image associated with this astrometric solution. |
Ownership of the specified projection and worldTransformation objects will be transferred to this object, which will destroy and deallocate them when appropriate.
pcl::AstrometricMetadata::AstrometricMetadata | ( | const ImageWindow & | window | ) |
Constructs an AstrometricMetadata object from the existing keywords and properties of an image window.
pcl::AstrometricMetadata::AstrometricMetadata | ( | XISFReader & | reader | ) |
Constructs an AstrometricMetadata object from the existing keywords and properties of the currently selected image in an XISF reader.
|
inlinevirtual |
Virtual destructor.
Definition at line 227 of file AstrometricMetadata.h.
|
inline |
Returns the bounding rectangle in pixels of the image associated with this astrometric solution.
The returned rectangle is equivalent to:
Definition at line 488 of file AstrometricMetadata.h.
void pcl::AstrometricMetadata::Build | ( | const PropertyArray & | properties, |
const FITSKeywordArray & | keywords, | ||
int | width, | ||
int | height, | ||
bool | regenerate = false |
||
) |
Reconstructs the astrometric solution from standardized metadata.
properties | A list of XISF image properties describing critical astrometry-related metadata items. |
keywords | A list of FITS header keywords, which may contain a set of standard WCS keywords to define a linear world transformation from celestial to image coordinates. If the required metadata is available in the properties array, the corresponding keywords contained by this object will be ignored. |
width | Width in pixels of the image associated with this astrometric solution. |
height | Height in pixels of the image associated with this astrometric solution. |
regenerate | If true and the metadata defines a spline-based WCS transformation, the internal surface splines and other numerical devices will be recalculated, even if they can be reconstructed from existing serializations, and no grid interpolations will be loaded or calculated. This parameter is false by default. |
The following standard XISF properties will be extracted from the specified properties array, if available:
Instrument:Sensor:XPixelSize Instrument:Telescope:FocalLength Observation:CelestialReferenceSystem Observation:Center:Dec Observation:Center:RA Observation:Equinox Observation:Location:Elevation Observation:Location:Latitude Observation:Location:Longitude Observation:Time:End Observation:Time:Start
The following nonstandard XISF properties support our native astrometric solutions since core version 1.8.9-2:
PCL:AstrometricSolution:Catalog PCL:AstrometricSolution:CelestialPoleNativeCoordinates PCL:AstrometricSolution:CreationTime PCL:AstrometricSolution:CreatorApplication PCL:AstrometricSolution:CreatorModule PCL:AstrometricSolution:CreatorOS PCL:AstrometricSolution:Information PCL:AstrometricSolution:LinearTransformationMatrix PCL:AstrometricSolution:ProjectionSystem PCL:AstrometricSolution:ReferenceCelestialCoordinates PCL:AstrometricSolution:ReferenceImageCoordinates PCL:AstrometricSolution:ReferenceNativeCoordinates
Spline-based astrometric solutions use an additional set of properties with the 'PCL:AstrometricSolution:SplineWorldTransformation:' identifier prefix.
XISF properties will always take precedence over existing equivalent FITS keywords.
If the specified properties array contains a valid serialization of spline parameters and control points, the astrometric solution will use a high-precision world transformation based on two-dimensional surface splines, which is capable of modeling local image distortions that are intractable with WCS linear transformations.
If this object contains valid metadata before calling this function, it will be disposed as appropriate, and a completely new astrometric solution will be constructed.
This member function can throw exceptions (of the Error class) if the specified properties and/or keywords arrays contain wrong or invalid data, or if the generated coordinate transformations are invalid (in the numerical or geometric sense).
|
inline |
Returns the name of the star catalog used to generate this astrometric solution, or an empty string if the corresponding metadata item is not available.
Definition at line 789 of file AstrometricMetadata.h.
Transformation from celestial coordinates to image coordinates.
[out] | pI | Reference to a point where the output image coordinates will be stored. |
pRD | Input equatorial spherical coordinates expressed in degrees. pRD.x is the right ascension and pRD.y is declination. |
Returns true iff the specified celestial coordinates can be reprojected on the image coordinate system. Note that the output image coordinates can lie outside of the image bounds defined by [0,0]-[Width(),Height()].
The input coordinates specified in pRD are expected to be referred to the reference system of this astrometric solution, either ICRS or GCRS, as returned by the ReferenceSystem() member function.
Definition at line 950 of file AstrometricMetadata.h.
|
inline |
Copies the optional metadata items for observation time (start and end times) and geodetic coordinates (longitude, latitude, and height) from the specified source object.
This function is useful to ensure that image-specific observational properties are preserved when copying astrometric solutions among images.
Definition at line 1259 of file AstrometricMetadata.h.
|
inline |
Copies the optional metadata items for observation time (start and end times) and geodetic coordinates (longitude, latitude, and height) from the specified wcs object.
This function is useful to ensure that image-specific observational properties are preserved when copying astrometric solutions among images.
Definition at line 1276 of file AstrometricMetadata.h.
References pcl::WCSKeywords::dateobs, and pcl::Optional< T >::IsDefined().
Returns the time this astrometric solution was generated, if available. When defined, the returned value should be represented in the UTC timescale.
Definition at line 779 of file AstrometricMetadata.h.
|
inline |
Returns the name (typically with version numbers) of the software application used to generate this astrometric solution, or an empty string if the corresponding metadata item is not available.
Definition at line 799 of file AstrometricMetadata.h.
|
inline |
Returns the name (typically with version numbers) of the software module or subsystem (such as a process or script) used to generate this astrometric solution, or an empty string if the corresponding metadata item is not available.
Definition at line 810 of file AstrometricMetadata.h.
|
inline |
Returns the name of the operating system under which this astrometric solution was generated, or an empty string if the corresponding metadata item is not available. Currently this member function can return one of "FreeBSD", "Linux", "macOS", and "Windows".
Definition at line 821 of file AstrometricMetadata.h.
|
inline |
Returns a collection of strings describing the metadata properties and parameters defining this astrometric solution.
The returned object is a copy of an internal structure that is generated automatically as necessary and cached between successive function calls. This allows for efficient real-time representations of changing astrometric metadata and parameters.
Definition at line 1468 of file AstrometricMetadata.h.
bool pcl::AstrometricMetadata::EnsureSplineGridInterpolationsInitialized | ( | int | deltaI = 16 | ) |
Ensures that the spline-based world transformation has its grid interpolations properly intialized for the specified deltaI grid distance in pixel units.
Returns true if this astrometric solution uses a spline world transformation and its grid interpolation devices are correctly initialized for the specified deltaI grid distance. Returns false if this astrometric solution uses a linear transformation, or if the grid interpolations couldn't be initialized.
|
inline |
Returns the focal distance in millimeters, calculated from the specified image resolution expressed in seconds of arc per pixel.
Definition at line 531 of file AstrometricMetadata.h.
|
inline |
Returns true if this object uses a world transformation based on 2-D surface splines (thin plate splines and other interpolation/approximation devices based on radial basis functions). Returns false if a linear transformation is being used.
Definition at line 332 of file AstrometricMetadata.h.
|
inline |
Returns the height in pixels of the image associated with this astrometric solution.
Definition at line 473 of file AstrometricMetadata.h.
|
inline |
Celestial coordinates of the geometric center of the image.
[out] | pRD | Reference to a point where the output equatorial spherical coordinates will be stored, expressed in degrees. pRD.x will be the right ascension and pRD.y the declination, respectively, calculated for the geometric center of the image. Output right ascensions are constrained to the [0,360) range. Output declinations are in the range [-90,+90]. |
Returns true iff the center of the image can be projected on the celestial sphere using this astrometric solution. This function must always return true under normal conditions. A failure to calculate central celestial coordinates denotes a corrupted or invalid astrometric solution.
The output coordinates stored in pRD will be referred to the reference system of this astrometric solution, either ICRS or GCRS, as returned by the ReferenceSystem() member function.
Definition at line 925 of file AstrometricMetadata.h.
Transformation from image coordinates to celestial coordinates.
[out] | pRD | Reference to a point where the output equatorial spherical coordinates will be stored, expressed in degrees. pRD.x will be the right ascension and pRD.y the declination. Output right ascensions are constrained to the [0,360) range. Output declinations are in the range [-90,+90]. |
pI | Input image coordinates in pixels. The specified location can legally lie outside the image bounds defined by [0,0]-[Width(),Height()]. |
Returns true iff the specified point pI can be projected on the celestial sphere using this astrometric solution.
The output coordinates stored in pRD will be referred to the reference system of this astrometric solution, either ICRS or GCRS, as returned by the ReferenceSystem() member function.
Definition at line 849 of file AstrometricMetadata.h.
|
inline |
Returns true iff this object is valid. A valid AstrometricMetadata instance defines a projection system and a world transformation.
Definition at line 268 of file AstrometricMetadata.h.
|
inline |
Returns the geodetic height of the observation location in meters, if available.
Definition at line 728 of file AstrometricMetadata.h.
|
inline |
Returns the geodetic latitude of the observation location, if available. The returned value is expressed in degrees in the range [-90,+90], reckoned positive north of the equator.
Definition at line 704 of file AstrometricMetadata.h.
|
inline |
Returns the geodetic longitude of the observation location, if available. The returned value is expressed in degrees in the range (-180,+180], reckoned positive eastward of the reference meridian.
Definition at line 675 of file AstrometricMetadata.h.
Returns the observation end time, if available. When defined, the returned value should be represented in the UTC timescale.
Definition at line 641 of file AstrometricMetadata.h.
Returns an estimate of the observation middle time. If both the start and end times are defined, returns the time point between them. If only the start time is defined, it is returned. Otherwise an undefined object is returned.
Definition at line 661 of file AstrometricMetadata.h.
Returns the observation start time, if available. When defined, the returned value should be represented in the UTC timescale.
Definition at line 623 of file AstrometricMetadata.h.
|
default |
Move assignment operator. Returns a reference to this object.
|
inline |
Copy constructor. Returns a reference to this object.
Definition at line 234 of file AstrometricMetadata.h.
|
inline |
Returns the physical pixel size in micrometers, if available.
Definition at line 759 of file AstrometricMetadata.h.
|
inline |
Returns a pointer to the projection system of this astrometric solution. Returns nullptr
if this object is not valid.
Definition at line 497 of file AstrometricMetadata.h.
Transformation from image coordinates to celestial coordinates, without enforcing a valid range of right ascensions.
[out] | pRD | Reference to a point where the output equatorial spherical coordinates will be stored, expressed in degrees. pRD.x will be the right ascension and pRD.y the declination. Output right ascensions are not constrained to the [0,360) range. Output declinations are in the range [-90,+90]. |
pI | Input image coordinates in pixels. The specified location can legally lie outside the image bounds defined by [0,0]-[Width(),Height()]. |
Returns true iff the specified point pI can be projected on the celestial sphere using this astrometric solution.
The output coordinates stored in pRD will be referred to the reference system of this astrometric solution, either ICRS or GCRS, as returned by the ReferenceSystem() member function.
This function is useful for interpolation schemes where discontinuities caused by zero crossings in right ascension, i.e. abrupt changes from 360 to 0 degrees, are not admissible numerically. Right ascensions returned by this function can be larger than 360 degrees or less than zero, ensuring smooth transitions.
Definition at line 895 of file AstrometricMetadata.h.
|
inline |
Returns the name of the coordinate reference system to which this astrometric solution has been referred.
This corresponds to the reference system of the coordinates of the reference point sources (usually stars with data acquired from astrometric catalogs) used to compute the astrometric solution. The current implementation supports the following reference systems:
ICRS
Reference point source positions are astrometric: they include corrections for space motion (proper motions, annual parallax and radial velocity, when available) and gravitational deflection of light, but not annual aberration. This is the default reference system that is assumed when none is specified or acquired from existing metadata.
GCRS
Reference point source positions are proper: they include corrections for space motion (proper motions, annual parallax and radial velocity, when available), gravitational deflection of light, and annual aberration (rigorous relativistic model).
Other nonstandard values can be returned by this function, such as different values of the RADESYS FITS keyword. Such values will be preserved but won't be supported by standard platform implementations.
Definition at line 423 of file AstrometricMetadata.h.
References pcl::GenericString< T, R, A >::IsEmpty().
|
static |
Returns the name of the reference system of celestial coordinates derived from the specified image metadata.
properties | A list of XISF image properties. |
keywords | A list of FITS header keywords. |
The reference system will be inferred from the following metadata items:
In case of metadata duplicity, XISF properties always take precedence over FITS keywords.
Typical returned values are "ICRS" and "GCRS". If no valid reference system can be deduced from the specified metadata, this function returns an empty string.
|
static |
Removes astrometry-related FITS header keywords from the specified keywords array. This includes some basic instrumental and observational keywords, as well as the following keywords:
RADESYS EQUINOX EPOCH CTYPE1 CTYPE2 CRVAL1 CRVAL2 CRPIX1 CRPIX2 CD1_1 CD1_2 CD2_1 CD2_2 PC1_1 PC1_2 PC2_1 PC2_2 CDELT1 CDELT2 CROTA1 CROTA2 PV1_1 PV1_2 PV1_3 PV1_4 LONPOLE LATPOLE
If removeCenterKeywords is true, the following keywords will also be removed:
RA OBJCTRA DEC OBJCTDEC
If removeScaleKeywords is true, the following keywords will also be removed:
FOCALLEN XPIXSZ YPIXSZ PIXSIZE
|
static |
Removes all XISF properties in the 'Observation:Location' namespace for the specified window's main view.
This function is intended for privacy protection purposes. It removes all properties that could be used to identify the observation location through its geographic coordinates, and possibly the observer's address and other sensitive information.
|
static |
Removes all XISF properties in the 'Observation:Location' namespace from the specified properties array.
This function is intended for privacy protection purposes. It removes all properties that could be used to identify the observation location through its geographic coordinates, and possibly the observer's address and other sensitive information.
|
static |
Removes astrometry-related XISF properties from the specified window's main view.
See RemoveProperties( PropertyArray&, bool, bool ) for detailed information.
|
static |
Removes astrometry-related XISF properties from the specified properties array.
If removeCenterProperties is true, the following properties will also be removed:
Observation:Center:RA Observation:Center:Dec Observation:Center:X Observation:Center:Y Observation:CelestialReferenceSystem Observation:Equinox
If removeScaleProperties is true, the following properties will also be removed:
Instrument:Telescope:FocalLength Instrument:Sensor:XPixelSize Instrument:Sensor:YPixelSize
The following properties will always be removed:
Observation:CelestialReferenceSystem Observation:Equinox PCL:AstrometricSolution:Catalog PCL:AstrometricSolution:CelestialPoleNativeCoordinates PCL:AstrometricSolution:CreationTime PCL:AstrometricSolution:CreatorApplication PCL:AstrometricSolution:CreatorModule PCL:AstrometricSolution:CreatorOS PCL:AstrometricSolution:Information PCL:AstrometricSolution:LinearTransformationMatrix PCL:AstrometricSolution:ProjectionSystem PCL:AstrometricSolution:ReferenceCelestialCoordinates PCL:AstrometricSolution:ReferenceImageCoordinates PCL:AstrometricSolution:ReferenceNativeCoordinates
Finally, for spline-based astrometric solutions, all existing properties with the 'PCL:AstrometricSolution:SplineWorldTransformation:' identifier prefix will also be removed.
|
static |
Rescales the values of existing FITS header keywords defining physical pixel dimensions in the specified keywords array.
This function multiplies the values of the following keywords by the specified scalingFactor:
XPIXSZ YPIXSZ PIXSIZE
This is useful in cases where a geometric transformation has to be applied to an image to modify its scale, such as a resampling operation.
|
static |
Rescales the values of existing XISF properties defining physical pixel dimensions for the specified window's main view.
See RescalePixelSizeProperties( PropertyArray&, double ) for detailed information.
|
static |
Rescales the values of existing XISF properties defining physical pixel dimensions in the specified properties array.
This function multiplies the values of the following properties by the specified scalingFactor:
Instrument:Sensor:XPixelSize Instrument:Sensor:YPixelSize
This is useful in cases where a geometric transformation has to be applied to an image to modify its scale, such as a resampling operation.
|
inline |
Returns the image resolution in degrees per pixel.
The returned value is calculated using an approximate linear transformation. Hence, it is usually a rough estimate since the actual resolution changes across the image as a function of local distortions. This member function should only be used for informative purposes.
Definition at line 558 of file AstrometricMetadata.h.
|
inline |
Returns the image resolution at the specified image coordinates in degrees per pixel.
The value returned by this function is calculated using the complete astrometric solution, including spline-based distortion corrections when appropriate, as the mean of the estimated resolution in the horizontal and vertical directions. It is the actual resolution in degrees per pixel at the specified location in image coordinates, accurate at least at the centipixel level.
Definition at line 577 of file AstrometricMetadata.h.
|
inline |
Returns the image resolution in seconds of arc per pixel, calculated from the specified focal distance in millimeters.
Definition at line 522 of file AstrometricMetadata.h.
References pcl::Const< T >::pi().
double pcl::AstrometricMetadata::Rotation | ( | bool & | flipped | ) | const |
Returns the angle of rotation of the Y axis of the image with respect to the north direction, as represented on a flat projection of the celestial sphere. A rotation angle of zero aligns north along the positive Y axis. A positive rotation angle rotates the Y axis from north to east.
The returned value is the rotation angle of the projection in degrees. The flipped variable will be true iff the projection is mirrored on the east-west direction.
|
inline |
Returns the radius in degrees of a circular region of the sky circumscribed to the bounding rectangle of this astrometric solution.
The returned radius can be used to perform search operations with star catalogs and solar system ephemerides.
Definition at line 599 of file AstrometricMetadata.h.
|
inline |
Sets the geodetic height of the observation location in meters.
Definition at line 736 of file AstrometricMetadata.h.
|
inline |
Sets the geodetic latitude of the observation location. The specified latitude must be expressed in degrees and must be in the range [-90,+90], reckoned positive north of the equator.
If a value out of the valid range is specified, this function will throw an Error exception.
Definition at line 717 of file AstrometricMetadata.h.
|
inline |
Sets the geodetic longitude of the observation location. The specified longitude must be expressed in degrees and can be either in the range [0,360] or [-180,+180], reckoned positive eastward.
If a value out of the valid range is specified, this function will throw an Error exception.
Definition at line 688 of file AstrometricMetadata.h.
|
inline |
Sets the observation end time. The specified endTime value should be represented in the UTC timescale.
Definition at line 650 of file AstrometricMetadata.h.
|
inline |
Sets the observation start time. The specified startTime value should be represented in the UTC timescale.
Definition at line 632 of file AstrometricMetadata.h.
|
inline |
Redefines the physical pixel size in micrometers. Recalculates the focal distance as a function of the pixel size.
Definition at line 768 of file AstrometricMetadata.h.
|
inline |
Sets the coordinate reference system. See ReferenceSystem() for more information and supported values.
Definition at line 432 of file AstrometricMetadata.h.
String pcl::AstrometricMetadata::Summary | ( | ) | const |
Returns a printable textual representation of the metadata properties and parameters defining this astrometric solution.
PropertyArray pcl::AstrometricMetadata::ToProperties | ( | ) | const |
Returns a list of XISF image properties serializing this astrometric solution.
The returned list will include the following standard XISF properties if the corresponding metadata is available:
Instrument:Sensor:XPixelSize Instrument:Sensor:YPixelSize Instrument:Telescope:FocalLength Observation:CelestialReferenceSystem Observation:Center:Dec Observation:Center:RA Observation:Equinox Observation:Location:Elevation Observation:Location:Latitude Observation:Location:Longitude Observation:Time:End Observation:Time:Start
The following nonstandard properties, which support our native astrometric solutions since core version 1.8.9-2, will be included:
PCL:AstrometricSolution:Catalog PCL:AstrometricSolution:CelestialPoleNativeCoordinates PCL:AstrometricSolution:CreationTime PCL:AstrometricSolution:CreatorApplication PCL:AstrometricSolution:CreatorModule PCL:AstrometricSolution:CreatorOS PCL:AstrometricSolution:Information PCL:AstrometricSolution:LinearTransformationMatrix PCL:AstrometricSolution:ProjectionSystem PCL:AstrometricSolution:ReferenceCelestialCoordinates PCL:AstrometricSolution:ReferenceImageCoordinates PCL:AstrometricSolution:ReferenceNativeCoordinates
For spline-based astrometric solutions, an additional set of properties with the 'PCL:AstrometricSolution:SplineWorldTransformation:' identifier prefix will also be included.
If this astrometric solution is not valid, an empty list is returned.
|
inline |
Undefines observation location metadata.
This function is intended for privacy protection purposes. It removes all metadata items that could be used to identify the observation location through its geographic coordinates, and possibly the observer's address and other sensitive information.
Definition at line 749 of file AstrometricMetadata.h.
|
inline |
Undefines the optional metadata items for observation time (start and end times) and geodetic coordinates (longitude, latitude, and height).
This function is useful to propagate the astrometric solution to other images, for example during an image registration task, without altering image-specific observational properties.
Definition at line 1242 of file AstrometricMetadata.h.
AstrometricMetadata pcl::AstrometricMetadata::Undistorted | ( | ) | const |
Calculates a new linear astrometric solution suitable for undistortion of the associated image by astrometric reprojection (e.g., using the AstrometricReprojection class).
void pcl::AstrometricMetadata::UpdateBasicKeywords | ( | FITSKeywordArray & | keywords | ) | const |
Updates the specified keywords array with basic astrometric FITS header keywords. This includes a number of standard instrumental and observational keywords, as well as some customary nonstandard keywords, included for compatibility with third-party applications:
RA OBJCTRA DEC OBJCTDEC DATE-OBS DATE-END OBSGEO-L LONG-OBS OBSGEO-B LAT-OBS OBSGEO-H ALT-OBS FOCALLEN XPIXSZ YPIXSZ PIXSIZE
Keywords are updated when the corresponding metadata items are available.
void pcl::AstrometricMetadata::UpdateProperties | ( | PropertyArray & | properties | ) | const |
Updates the specified properties array with a restricted set of view properties to reflect the state of this astrometric solution.
The following standard XISF properties will be created or redefined:
Instrument:Sensor:XPixelSize Instrument:Sensor:YPixelSize Instrument:Telescope:FocalLength Observation:CelestialReferenceSystem Observation:Center:Dec Observation:Center:RA Observation:Equinox
The following properties can be removed if the transformation is valid, since the default coordinate reference point is the geometric center of the image, which is used to calculate the values of the standard Observation:Center:RA
and Observation:Center:Dec
properties:
Observation:Center:X Observation:Center:Y
The following properties will be created or redefined if the corresponding metadata items are available, or removed otherwise:
Observation:Location:Elevation Observation:Location:Latitude Observation:Location:Longitude Observation:Time:End Observation:Time:Start
The following nonstandard properties (which support our native astrometric solutions since core version 1.8.9-2) will be created, redefined, or removed as necessary:
PCL:AstrometricSolution:Catalog PCL:AstrometricSolution:CelestialPoleNativeCoordinates PCL:AstrometricSolution:CreationTime PCL:AstrometricSolution:CreatorApplication PCL:AstrometricSolution:CreatorModule PCL:AstrometricSolution:CreatorOS PCL:AstrometricSolution:Information PCL:AstrometricSolution:LinearTransformationMatrix PCL:AstrometricSolution:ProjectionSystem PCL:AstrometricSolution:ReferenceCelestialCoordinates PCL:AstrometricSolution:ReferenceImageCoordinates PCL:AstrometricSolution:ReferenceNativeCoordinates
For spline-based astrometric solutions, an additional set of properties with the 'PCL:AstrometricSolution:SplineWorldTransformation:' identifier prefix will also be created, redefined or removed as necessary.
void pcl::AstrometricMetadata::UpdateWCSKeywords | ( | FITSKeywordArray & | keywords, |
bool | generate = false |
||
) | const |
Updates or removes standard WCS FITS header keywords in the specified keywords array:
RADESYS EQUINOX EPOCH CTYPE1 CTYPE2 CRVAL1 CRVAL2 CRPIX1 CRPIX2 CD1_1 CD1_2 CD2_1 CD2_2 PC1_1 PC1_2 PC2_1 PC2_2 CDELT1 CDELT2 CROTA1 CROTA2 PV1_1 PV1_2 PV1_3 PV1_4 LONPOLE LATPOLE
if generate is true, a new set of WCS FITS keywords will be generated (by replacing existing ones or creating them as necessary) in the keywords array.
If generate is false, existing WCS FITS keywords will be removed and no new ones will be generated. This is the default behavior since PixInsight core version 1.8.9-2, when our native astrometric solutions no longer depend on FITS keywords.
void pcl::AstrometricMetadata::Validate | ( | double | tolerance = 0.01 | ) | const |
Checks that this astrometric solution is valid and can perform coherent coordinate transformations.
tolerance | Maximum difference in pixels allowed for validation. The default value is 0.01 pixels. |
This routine performs two successive coordinate transformations, from image to celestial and from celestial to image coordinates, computed for the geometric center of the image. If the absolute value of the difference between the initial and final image coordinates is greater than the specified tolerance in pixels, for one or both axes, an Error exception is thrown.
This function also throws an Error exception if the solution has not been initialized, or if it cannot perform valid coordinate transformations.
void pcl::AstrometricMetadata::Verify | ( | DPoint & | centerErrors, |
DPoint & | topLeftErrors, | ||
DPoint & | topRightErrors, | ||
DPoint & | bottomLeftErrors, | ||
DPoint & | bottomRightErrors | ||
) | const |
Checks that this astrometric solution is valid and can perform coherent coordinate transformations, and returns the reprojection errors measured at the center and the four corners of the image.
[out] | centerErrors | Reprojection errors at the geometric center of the image, or (Width()/2,Height()/2) image coordinates. |
[out] | topLeftErrors | Reprojection errors at (0,0) image coordinates. |
[out] | topRightErrors | Reprojection errors at (Width(),0) image coordinates. |
[out] | bottomLeftErrors | Reprojection errors at (0,Height()) image coordinates. |
[out] | bottomRightErrors | Reprojection errors at (Width(),Height()) image coordinates. |
This routine performs five successive coordinate transformations, from image to celestial and from celestial to image coordinates, computed for the four corners and the geometric center of the image. The reported values in the specified point variables are the differences between the initial and final image coordinates, on the X and Y axes, in pixels.
This function throws an Error exception if the solution has not been initialized, or if it cannot perform valid coordinate transformations.
|
inline |
Returns the width in pixels of the image associated with this astrometric solution.
Definition at line 464 of file AstrometricMetadata.h.
|
inline |
Returns a pointer to the world coordinate transformation of this astrometric solution. Returns nullptr
if this object is not valid.
Definition at line 506 of file AstrometricMetadata.h.
void pcl::AstrometricMetadata::Write | ( | ImageWindow & | window, |
bool | notify = true |
||
) | const |
Updates the keywords and properties of an image window to represent this astrometric solution.
The pixel dimensions of the image in the target window must be coherent with this astrometric solution. If that is not true, this member function will throw an Error exception. An Error exception will also be thrown if this object does not define a valid astrometric solution.
See the UpdateBasicKeywords(), UpdateWCSKeywords() and UpdateProperties() member functions for information on the metadata items modified by this function.
void pcl::AstrometricMetadata::Write | ( | XISFWriter & | writer | ) | const |
Updates the keywords and properties of the current image in an XISF writer to serialize this astrometric solution.
The caller must ensure that the pixel dimensions of the current image in the target XISF writer, that is, the width and height of the image being generated, are coherent with this astrometric solution. Currently this condition cannot be verified or enforced by this member function.
This function will throw an Error exception if this object does not define a valid astrometric solution.
See the UpdateBasicKeywords(), UpdateWCSKeywords() and UpdateProperties() member functions for information on the metadata items modified by this function.