Isis 3 Programmer Reference
|
This class holds information about a control point that BundleAdjust needs to run correctly. More...
#include <BundleControlPoint.h>
Public Member Functions | |
BundleControlPoint (BundleSettingsQsp bundleSettings, ControlPoint *point) | |
Constructs a BundleControlPoint object from a ControlPoint. | |
BundleControlPoint (const BundleControlPoint &src) | |
Copy constructor. | |
virtual | ~BundleControlPoint () |
Destructor for BundleControlPoint. | |
BundleControlPoint & | operator= (const BundleControlPoint &src) |
void | copy (const BundleControlPoint &src) |
Copies given BundleControlPoint to this BundleControlPoint. | |
BundleMeasureQsp | addMeasure (ControlMeasure *controlMeasure) |
Creates a BundleMeasure from the given ControlMeasure and appends it to this BundleControlPoint's measure list. | |
void | computeResiduals () |
Computes the residuals for this BundleControlPoint. | |
void | setAdjustedSurfacePoint (SurfacePoint surfacePoint) |
Sets the adjusted surface point for this BundleControlPoint. | |
void | setNumberOfRejectedMeasures (int numRejected) |
Sets the number of rejected measures for this BundleControlPoint. | |
void | setRejected (bool reject) |
Sets this BundleControlPoint to rejected or not rejected. | |
void | setWeights (const BundleSettingsQsp settings) |
Sets the weights using the given BundleSettings QSharedPointer and a conversion value for meters to radians. | |
void | setSigmaWeightFromGlobals (double gSigma, int index) |
Sets the member sigmas and weights from a global sigma. | |
void | setSigmaWeightFromGlobals (double gSigma, int index, double cFactor) |
void | zeroNumberOfRejectedMeasures () |
Resets the number of rejected measures for this BundleControlPoint to zero. | |
void | productAlphaAV (double alpha, SparseBlockMatrix &sparseNormals, LinearAlgebra::Vector &v1) |
Perform the matrix multiplication v2 = alpha ( Q x v1 ). | |
virtual void | applyParameterCorrections (LinearAlgebra::Vector imageSolution, SparseBlockMatrix &sparseNormals, const BundleTargetBodyQsp target) |
Apply the parameter corrections to the bundle control point. | |
double | vtpv () |
Compute vtpv, the weighted sum of squares of constrained point residuals. | |
double | vtpvMeasures () |
Compute vtpv of image measures (weighted sum of squares of measure residuals). | |
ControlPoint * | rawControlPoint () const |
Accessor for the raw ControlPoint object used for this BundleControlPoint. | |
bool | isRejected () const |
Method used to determine whether this control point is rejected. | |
int | numberOfMeasures () const |
Accesses number of measures associated with this BundleControlPoint. | |
int | numberOfRejectedMeasures () const |
Accesses the number of rejected measures for this BundleControlPoint. | |
double | residualRms () const |
Gets the root-mean-square (rms) of the BundleControlPoint's residuals. | |
SurfacePoint | adjustedSurfacePoint () const |
Accesses the adjusted SurfacePoint associated with this BundleControlPoint. | |
QString | id () const |
Accesses the Point ID associated with this BundleControlPoint. | |
ControlPoint::PointType | type () const |
Accesses BundleControlPoint's type. | |
SurfacePoint::CoordinateType | coordTypeReports () const |
Accesses BundleControlPoint's coordinate type for reports. | |
SurfacePoint::CoordinateType | coordTypeBundle () const |
Accesses BundleControlPoint's control point coordinate type for the bundle adjustment. | |
boost::numeric::ublas::bounded_vector< double, 3 > & | corrections () |
Accesses the 3 dimensional ordered vector of correction values associated with coord1, coord2, and coord 3 (latitude, longitude, and radius or X, Y, and Z. | |
boost::numeric::ublas::bounded_vector< double, 3 > & | aprioriSigmas () |
Accesses the 3 dimensional ordered vector of apriori sigmas (apriori coordinate1, apriori coordinate2, apriori coordinate3). | |
boost::numeric::ublas::bounded_vector< double, 3 > & | adjustedSigmas () |
Accesses the 3 dimensional ordered vector of adjusted sigmas (adjusted coordinate1, adjusted coordinate2, adjusted coordinate3). | |
boost::numeric::ublas::bounded_vector< double, 3 > & | weights () |
Accesses the 3 dimensional ordered vector of weight values associated with coordinate1, coordinate2, and coordinate3. | |
boost::numeric::ublas::bounded_vector< double, 3 > & | nicVector () |
Accesses the 3 dimensional ordered NIC vector. | |
SparseBlockRowMatrix & | cholmodQMatrix () |
Accesses the CholMod matrix associated with this BundleControlPoint. | |
QString | formatBundleOutputSummaryString (bool errorPropagation) const |
Formats an output summary string for this BundleControlPoint. | |
QString | formatBundleOutputDetailString (bool errorPropagation, bool solveRadius=false) const |
Formats a detailed output string table for this BundleControlPoint. | |
QString | formatBundleLatitudinalOutputDetailString (bool errorPropagation, bool solveRadius=false) const |
Formats a detailed output string table for this Latitudinal BundleControlPoint. | |
QString | formatBundleRectangularOutputDetailString (bool errorPropagation) const |
Formats a detailed output string table for this Rectangular BundleControlPoint. | |
QString | formatValue (double value, int fieldWidth, int precision) const |
Formats the given double precision value using the specified field width and precision. | |
QString | formatAprioriSigmaString (SurfacePoint::CoordIndex index, int fieldWidth, int precision, bool solveRadius=false) const |
Formats the apriori sigma value indicated by the given type code. | |
QString | formatCoordAprioriSigmaString (SurfacePoint::CoordIndex index, int fieldWidth, int precision, bool solveRadius=false) const |
Formats the apriori coordinate 1 (latitude or X) sigma value. | |
QString | formatAdjustedSigmaString (SurfacePoint::CoordIndex, int fieldWidth, int precision, bool errorPropagation) const |
Formats the adjusted sigma value indicated by the given type code. | |
QString | formatCoordAdjustedSigmaString (SurfacePoint::CoordIndex, int fieldWidth, int precision, bool errorPropagation) const |
Formats the adjusted coordinate sigma value. | |
Protected Attributes | |
ControlPoint * | m_controlPoint |
< pointer to the control point object this represents | |
Private Member Functions | |
void | updateAdjustedSurfacePointLatitudinally (const BundleTargetBodyQsp target) |
Apply the parameter corrections to the bundle control point latitudinally. | |
void | updateAdjustedSurfacePointRectangularly () |
Apply the parameter corrections to the bundle control point rectangularly. | |
Private Attributes | |
boost::numeric::ublas::bounded_vector< double, 3 > | m_corrections |
corrections to point parameters | |
boost::numeric::ublas::bounded_vector< double, 3 > | m_aprioriSigmas |
apriori sigmas for point parameters | |
boost::numeric::ublas::bounded_vector< double, 3 > | m_adjustedSigmas |
adjusted sigmas for point parameters | |
boost::numeric::ublas::bounded_vector< double, 3 > | m_weights |
weights for point parameters | |
boost::numeric::ublas::bounded_vector< double, 3 > | m_nicVector |
array of NICs (see Brown, 1976) | |
SparseBlockRowMatrix | m_cholmodQMatrix |
The CholMod matrix associated with this point. | |
SurfacePoint::CoordinateType | m_coordTypeReports |
BundleControlPoint coordinate type. | |
SurfacePoint::CoordinateType | m_coordTypeBundle |
This class holds information about a control point that BundleAdjust needs to run correctly.
This class was created to extract functionality from BundleAdjust and wrap a ControlPoint with the extra necessary information to correctly perform a bundle adjustment.
Note that only non-ignored control points should be used to construct a BundleControlPoint. Similarly, a BundleControlPoint should only contain non-ignored control measures.
2014-05-22 Ken Edmundson - Original version.
2015-02-20 Jeannie Backer - Added unitTest. Reformatted output strings. Brought closer to ISIS coding standards.
2016-06-27 Jesse Mapel - Updated documentation and ISIS coding standards in preparation for merging IPCE into ISIS. Fixes #4075.
2016-08-15 Ian Humphrey - Added computeResiduals(), setNumberOfRejectedMeasures(), setRejected(), zeroNumberOfRejectedMeasures(), numberOfRejectedMeasures(), residualRms(), and type(). Modified numberMeasures() to return this->size(), since only non-ignored control measures will be added to this BundleControlPoint. Updated unit test for these methods (except computeResiduals). References #4173.
2016-08-15 Jesse Mapel - Changed contained member data type to a shared pointer. Added wrapper methods for several ControlPoint methods. Fixes #4159.
2016-10-27 Tyler Wilson - Modified formatRadiusAprioriSigmaString, formatAprioriSigmaString, and formatBundleOutputDetailString to accept a third argument (bool solveRadius) with a default value = false. References #4317.
2017-07-26 Debbie A. Cook - Added BundleSettings and metersToRadians as arguments to constructor and moved setWeights call from BundleAdjust::init into constructor. Added m_bundleControlPointCoordinateType. This option determines how control point coordinates are entered into BundleControlPoint, interpreted throughout the adjustment, and output. The coordinate type needs to be in this class, because BundleControlPoints are created without a parent control net and added to a control net later. Made format methods generic in regards to coordinate type. Added utility method setSigmaWeightFromGlobals. Merged methods formatLatitudeAdjustedSigmaString, formatLongitudeAdjustedSigmaString, and formatRadiusAdjustedSigmaString into a single generic coordinate method with an additional argument for the coordinate index. Did a similar merge for the family of methods like formatLatitudeAprioriSigmaString. Moved some of the functionality from BundleAdjust to this class as a new method applyParameterCorrections. Also had to move BundleAdjust method productAlphaAV to this class to support applyParameterCorrections. References #4649 and #501.
2017-08-24 Debbie A. Cook - Revised output units to be compatible with output from previous versions, corrected units throughout in comments and code. Reference #4649 and #501.
2018-01-05 Debbie A. Cook - Added new members m_coordTypeReports and m_coordTypeBundle to copy method. Reference #4649 and #501.
2018-05-31 Debbie A. Cook - Moved code from BundleAdjust::applyParameterCorrections pertaining to updating the adjusted surface point and method productAlphaAv into new methods applyParameterCorrections, updateAdjustedSurfacePointLatitudinally, and updateAdjustedSurfacePointRectangularly in BundleControlPoint. Reference #4649 and #501.
2018-09-28 Debbie A. Cook - Removed the metersToRadians argument from the constructor and from the setWeights method since we are now using the local radius of the point to convert lat/lon sigmas from meters to radians. References #4649 and #501.
Definition at line 91 of file BundleControlPoint.h.
Isis::BundleControlPoint::BundleControlPoint | ( | BundleSettingsQsp | bundleSettings, |
ControlPoint * | controlPoint ) |
Constructs a BundleControlPoint object from a ControlPoint.
Only the non-ignored measures are added to the BundleControlPoint.
controlPoint | Pointer to a ControlPoint that will be used to construct this BundleControlPoint. |
Definition at line 33 of file BundleControlPoint.cpp.
References addMeasure(), Isis::ControlPoint::GetMeasure(), m_adjustedSigmas, m_aprioriSigmas, m_controlPoint, m_coordTypeReports, m_corrections, m_nicVector, m_weights, Isis::Null, and setWeights().
Isis::BundleControlPoint::BundleControlPoint | ( | const BundleControlPoint & | src | ) |
Copy constructor.
Constructs a BundleControlPoint object from an existing BundleControlPoint.
src | The BundleControlPoint to be copied. |
Definition at line 77 of file BundleControlPoint.cpp.
References copy().
|
virtual |
Destructor for BundleControlPoint.
Definition at line 85 of file BundleControlPoint.cpp.
BundleMeasureQsp Isis::BundleControlPoint::addMeasure | ( | ControlMeasure * | controlMeasure | ) |
Creates a BundleMeasure from the given ControlMeasure and appends it to this BundleControlPoint's measure list.
controlMeasure | The ControlMeasure to be converted. |
Definition at line 125 of file BundleControlPoint.cpp.
Referenced by BundleControlPoint().
boost::numeric::ublas::bounded_vector< double, 3 > & Isis::BundleControlPoint::adjustedSigmas | ( | ) |
Accesses the 3 dimensional ordered vector of adjusted sigmas (adjusted coordinate1, adjusted coordinate2, adjusted coordinate3).
Definition at line 571 of file BundleControlPoint.cpp.
References m_adjustedSigmas.
SurfacePoint Isis::BundleControlPoint::adjustedSurfacePoint | ( | ) | const |
Accesses the adjusted SurfacePoint associated with this BundleControlPoint.
Definition at line 484 of file BundleControlPoint.cpp.
References m_controlPoint.
Referenced by Isis::BundleAdjust::computePartials(), Isis::IsisBundleObservation::computePoint3DPartials(), Isis::IsisBundleObservation::computeRHSPartials(), Isis::CsmBundleObservation::computeRHSPartials(), Isis::IsisBundleObservation::computeTargetPartials(), formatAdjustedSigmaString(), updateAdjustedSurfacePointLatitudinally(), and updateAdjustedSurfacePointRectangularly().
|
virtual |
Apply the parameter corrections to the bundle control point.
imageSolution | Image vector. |
factor | The unit conversion factor to use on lat and lon rad or x/y/z km. |
target | The BundleTargetBody. |
Reimplemented in Isis::BundleLidarControlPoint.
Definition at line 395 of file BundleControlPoint.cpp.
References isRejected(), Isis::SurfacePoint::Latitudinal, m_corrections, m_nicVector, productAlphaAV(), Isis::IException::Programmer, Isis::SurfacePoint::Rectangular, Isis::toString(), updateAdjustedSurfacePointLatitudinally(), and updateAdjustedSurfacePointRectangularly().
Referenced by Isis::BundleLidarControlPoint::applyParameterCorrections().
boost::numeric::ublas::bounded_vector< double, 3 > & Isis::BundleControlPoint::aprioriSigmas | ( | ) |
Accesses the 3 dimensional ordered vector of apriori sigmas (apriori coordinate1, apriori coordinate2, apriori coordinate3).
Definition at line 557 of file BundleControlPoint.cpp.
References m_aprioriSigmas.
SparseBlockRowMatrix & Isis::BundleControlPoint::cholmodQMatrix | ( | ) |
Accesses the CholMod matrix associated with this BundleControlPoint.
Definition at line 602 of file BundleControlPoint.cpp.
References m_cholmodQMatrix.
void Isis::BundleControlPoint::computeResiduals | ( | ) |
Computes the residuals for this BundleControlPoint.
Definition at line 140 of file BundleControlPoint.cpp.
References Isis::ControlPoint::ComputeResiduals(), and m_controlPoint.
SurfacePoint::CoordinateType Isis::BundleControlPoint::coordTypeBundle | ( | ) | const |
Accesses BundleControlPoint's control point coordinate type for the bundle adjustment.
Definition at line 533 of file BundleControlPoint.cpp.
SurfacePoint::CoordinateType Isis::BundleControlPoint::coordTypeReports | ( | ) | const |
Accesses BundleControlPoint's coordinate type for reports.
Definition at line 520 of file BundleControlPoint.cpp.
References m_coordTypeReports.
void Isis::BundleControlPoint::copy | ( | const BundleControlPoint & | src | ) |
Copies given BundleControlPoint to this BundleControlPoint.
src | The BundleControlPoint to be copied. |
Definition at line 94 of file BundleControlPoint.cpp.
References m_adjustedSigmas, m_aprioriSigmas, m_controlPoint, m_coordTypeReports, m_corrections, m_nicVector, and m_weights.
Referenced by BundleControlPoint(), and Isis::BundleLidarControlPoint::copy().
boost::numeric::ublas::bounded_vector< double, 3 > & Isis::BundleControlPoint::corrections | ( | ) |
Accesses the 3 dimensional ordered vector of correction values associated with coord1, coord2, and coord 3 (latitude, longitude, and radius or X, Y, and Z.
A bounded vector is recommended because the size will always be 3.
Definition at line 546 of file BundleControlPoint.cpp.
References m_corrections.
QString Isis::BundleControlPoint::formatAdjustedSigmaString | ( | SurfacePoint::CoordIndex | index, |
int | fieldWidth, | ||
int | precision, | ||
bool | errorPropagation ) const |
Formats the adjusted sigma value indicated by the given type code.
If error propagation is false or the selected sigma type was set to Null, then only "N/A" will be returned.
index | CoordIndex Coordinate index One: Latitude or X, Two: Longitude or Y, or Three: Radius or Z |
fieldWidth | The return string's field width. |
precision | The precision of the double to be saved off. |
errorPropagation | Indicates whether error propagation was selected. |
Definition at line 1048 of file BundleControlPoint.cpp.
References adjustedSurfacePoint(), Isis::SurfacePoint::GetSigmaDistance(), Isis::IsSpecial(), m_coordTypeReports, Isis::Distance::meters(), and Isis::Null.
Referenced by formatCoordAdjustedSigmaString().
QString Isis::BundleControlPoint::formatAprioriSigmaString | ( | SurfacePoint::CoordIndex | index, |
int | fieldWidth, | ||
int | precision, | ||
bool | solveRadius = false ) const |
Formats the apriori sigma value indicated by the given type code.
If no sigma was set, then the string "N/A" will be returned.
index | CoordIndex Coordinate index One: Latitude or X, Two: Longitude or Y, or Three: Radius or Z |
fieldWidth | The return string's field width. |
precision | The precision of the double to be saved off. |
solveRadius | A flag indicating to solve for each points individual radius. When solveRadius is false, the point radius is heavily weighted |
Definition at line 998 of file BundleControlPoint.cpp.
References Isis::IsSpecial(), m_aprioriSigmas, Isis::ControlPoint::PointTypeToString(), and type().
Referenced by formatCoordAprioriSigmaString().
QString Isis::BundleControlPoint::formatBundleLatitudinalOutputDetailString | ( | bool | errorPropagation, |
bool | solveRadius = false ) const |
Formats a detailed output string table for this Latitudinal BundleControlPoint.
errorPropagation | Indicates whether error propagation was selected. |
RTM | Conversion factor from radians to meters. Used to convert the latitude and longitude corrections to meters. |
solveRadius | A flag indicating to solve for each points individual radius. When solveRadius is false, the point radius is heavily weighted |
Definition at line 707 of file BundleControlPoint.cpp.
References Isis::DEG2RAD, Isis::Angle::degrees(), formatCoordAdjustedSigmaString(), formatCoordAprioriSigmaString(), formatValue(), Isis::SurfacePoint::GetLatitude(), Isis::SurfacePoint::GetLocalRadius(), Isis::SurfacePoint::GetLongitude(), Isis::IsSpecial(), Isis::Displacement::Kilometers, Isis::Displacement::kilometers(), Isis::Distance::kilometers(), Isis::SurfacePoint::LatitudeToMeters(), Isis::SurfacePoint::Latitudinal, Isis::SurfacePoint::LongitudeToMeters(), m_controlPoint, m_corrections, Isis::Null, numberOfMeasures(), numberOfRejectedMeasures(), Isis::ControlPoint::PointTypeToString(), Isis::IException::Programmer, Isis::RAD2DEG, Isis::SurfacePoint::Rectangular, Isis::toString(), and type().
Referenced by formatBundleOutputDetailString().
QString Isis::BundleControlPoint::formatBundleOutputDetailString | ( | bool | errorPropagation, |
bool | solveRadius = false ) const |
Formats a detailed output string table for this BundleControlPoint.
errorPropagation | Indicates whether error propagation was selected. |
RTM | Conversion factor from radians to meters. Used to convert the latitude and longitude corrections to meters. |
solveRadius | A flag indicating to solve for each points individual radius. When solveRadius is false, the point radius is heavily weighted |
Definition at line 668 of file BundleControlPoint.cpp.
References formatBundleLatitudinalOutputDetailString(), formatBundleRectangularOutputDetailString(), Isis::SurfacePoint::Latitudinal, m_coordTypeReports, Isis::IException::Programmer, Isis::SurfacePoint::Rectangular, and Isis::toString().
QString Isis::BundleControlPoint::formatBundleOutputSummaryString | ( | bool | errorPropagation | ) | const |
Formats an output summary string for this BundleControlPoint.
This string includes ID, point type, number of rays from non-rejected measures, residual RMS, adjusted coordinate1, adjusted coordinate 2, and adjusted coordinate 3 followed by the adjusted sigmas. In the case of Latitudinal coordinates, the coordinates will be adjusted latitude and longitude (in degrees), the adjusted radius (in km), and the adjusted sigmas for latitude, longitude and radius all in meters. In the case of Rectangular coordinates, the coordinates will be X, Y, Z (in km), and the adjusted sigmas for X, Y, and Z all in meters.
errorPropagation | Indicates whether error propagation was selected. |
Definition at line 621 of file BundleControlPoint.cpp.
References formatCoordAdjustedSigmaString(), formatValue(), Isis::SurfacePoint::GetCoord(), m_controlPoint, m_coordTypeReports, numberOfMeasures(), numberOfRejectedMeasures(), Isis::ControlPoint::PointTypeToString(), Isis::SurfacePoint::Rectangular, residualRms(), and type().
QString Isis::BundleControlPoint::formatBundleRectangularOutputDetailString | ( | bool | errorPropagation | ) | const |
Formats a detailed output string table for this Rectangular BundleControlPoint.
errorPropagation | Indicates whether error propagation was selected. |
Definition at line 850 of file BundleControlPoint.cpp.
References Isis::Angle::Degrees, Isis::Angle::degrees(), formatCoordAdjustedSigmaString(), formatCoordAprioriSigmaString(), formatValue(), Isis::SurfacePoint::GetLatitude(), Isis::SurfacePoint::GetLocalRadius(), Isis::SurfacePoint::GetLongitude(), Isis::IsSpecial(), Isis::Displacement::kilometers(), Isis::Distance::Kilometers, Isis::Distance::kilometers(), Isis::SurfacePoint::Latitudinal, m_controlPoint, m_corrections, Isis::Null, numberOfMeasures(), numberOfRejectedMeasures(), Isis::ControlPoint::PointTypeToString(), Isis::IException::Programmer, Isis::RAD2DEG, Isis::SurfacePoint::Rectangular, Isis::toString(), and type().
Referenced by formatBundleOutputDetailString().
QString Isis::BundleControlPoint::formatCoordAdjustedSigmaString | ( | SurfacePoint::CoordIndex | index, |
int | fieldWidth, | ||
int | precision, | ||
bool | errorPropagation ) const |
Formats the adjusted coordinate sigma value.
index | The coordinate index of the sigma to return. |
fieldWidth | The return string's field width. |
precision | The precision of the double to be saved off. |
errorPropagation | Indicates whether error propagation was selected. |
Definition at line 1084 of file BundleControlPoint.cpp.
References formatAdjustedSigmaString().
Referenced by formatBundleLatitudinalOutputDetailString(), formatBundleOutputSummaryString(), and formatBundleRectangularOutputDetailString().
QString Isis::BundleControlPoint::formatCoordAprioriSigmaString | ( | SurfacePoint::CoordIndex | index, |
int | fieldWidth, | ||
int | precision, | ||
bool | solveRadius = false ) const |
Formats the apriori coordinate 1 (latitude or X) sigma value.
fieldWidth | The return string's field width. |
precision | The precision of the double to be saved off. |
Definition at line 1027 of file BundleControlPoint.cpp.
References formatAprioriSigmaString().
Referenced by formatBundleLatitudinalOutputDetailString(), and formatBundleRectangularOutputDetailString().
QString Isis::BundleControlPoint::formatValue | ( | double | value, |
int | fieldWidth, | ||
int | precision ) const |
Formats the given double precision value using the specified field width and precision.
If the given value is special, then "Null" is returned.
value | The double value to be formattted. |
fieldWidth | The return string's field width. |
precision | The precision of the given double value to be saved off. |
Definition at line 976 of file BundleControlPoint.cpp.
References Isis::IsSpecial().
Referenced by formatBundleLatitudinalOutputDetailString(), formatBundleOutputSummaryString(), and formatBundleRectangularOutputDetailString().
QString Isis::BundleControlPoint::id | ( | ) | const |
Accesses the Point ID associated with this BundleControlPoint.
Definition at line 494 of file BundleControlPoint.cpp.
References Isis::ControlPoint::GetId(), and m_controlPoint.
Referenced by Isis::BundleAdjust::computePartials(), Isis::IsisBundleObservation::computeRHSPartials(), and Isis::CsmBundleObservation::computeRHSPartials().
bool Isis::BundleControlPoint::isRejected | ( | ) | const |
Method used to determine whether this control point is rejected.
Definition at line 440 of file BundleControlPoint.cpp.
References m_controlPoint.
Referenced by applyParameterCorrections().
boost::numeric::ublas::bounded_vector< double, 3 > & Isis::BundleControlPoint::nicVector | ( | ) |
Accesses the 3 dimensional ordered NIC vector.
Definition at line 592 of file BundleControlPoint.cpp.
References m_nicVector.
int Isis::BundleControlPoint::numberOfMeasures | ( | ) | const |
Accesses number of measures associated with this BundleControlPoint.
Definition at line 450 of file BundleControlPoint.cpp.
Referenced by formatBundleLatitudinalOutputDetailString(), formatBundleOutputSummaryString(), and formatBundleRectangularOutputDetailString().
int Isis::BundleControlPoint::numberOfRejectedMeasures | ( | ) | const |
Accesses the number of rejected measures for this BundleControlPoint.
Definition at line 462 of file BundleControlPoint.cpp.
References Isis::ControlPoint::GetNumberOfRejectedMeasures(), and m_controlPoint.
Referenced by formatBundleLatitudinalOutputDetailString(), formatBundleOutputSummaryString(), and formatBundleRectangularOutputDetailString().
void Isis::BundleControlPoint::productAlphaAV | ( | double | alpha, |
SparseBlockMatrix & | sparseNormals, | ||
LinearAlgebra::Vector & | v1 ) |
Perform the matrix multiplication v2 = alpha ( Q x v1 ).
alpha | A constant multiplier. |
sparseNormals | The sparse block normal equations matrix. |
v2 | The output vector. |
Q | A sparse block matrix. |
v1 | A vector. |
Definition at line 367 of file BundleControlPoint.cpp.
References m_cholmodQMatrix, and m_nicVector.
Referenced by applyParameterCorrections().
ControlPoint * Isis::BundleControlPoint::rawControlPoint | ( | ) | const |
Accessor for the raw ControlPoint object used for this BundleControlPoint.
Definition at line 430 of file BundleControlPoint.cpp.
References m_controlPoint.
double Isis::BundleControlPoint::residualRms | ( | ) | const |
Gets the root-mean-square (rms) of the BundleControlPoint's residuals.
Definition at line 474 of file BundleControlPoint.cpp.
References Isis::ControlPoint::GetResidualRms(), and m_controlPoint.
Referenced by formatBundleOutputSummaryString().
void Isis::BundleControlPoint::setAdjustedSurfacePoint | ( | SurfacePoint | surfacePoint | ) |
Sets the adjusted surface point for this BundleControlPoint.
surfacePoint | The surface point to be set. |
Definition at line 155 of file BundleControlPoint.cpp.
References m_controlPoint, and Isis::ControlPoint::SetAdjustedSurfacePoint().
Referenced by updateAdjustedSurfacePointLatitudinally(), and updateAdjustedSurfacePointRectangularly().
void Isis::BundleControlPoint::setNumberOfRejectedMeasures | ( | int | numRejected | ) |
Sets the number of rejected measures for this BundleControlPoint.
numRejected | Number of rejected measures. |
Definition at line 167 of file BundleControlPoint.cpp.
References m_controlPoint, and Isis::ControlPoint::SetNumberOfRejectedMeasures().
void Isis::BundleControlPoint::setRejected | ( | bool | reject | ) |
Sets this BundleControlPoint to rejected or not rejected.
reject | True will set the BundleControlPoint to rejected. |
Definition at line 179 of file BundleControlPoint.cpp.
References m_controlPoint, and Isis::ControlPoint::SetRejected().
void Isis::BundleControlPoint::setSigmaWeightFromGlobals | ( | double | gSigma, |
int | index ) |
Sets the member sigmas and weights from a global sigma.
TODO *** Should index be SurfacePoint::CoordIndex?
gSigma | The global sigma to assign. |
index | The index of the point coordinate being set (0, 1, or 2). |
cFactor | The conversion factor applied to gSigma to match bundle variable units. |
Definition at line 288 of file BundleControlPoint.cpp.
References Isis::SurfacePoint::Latitudinal, m_aprioriSigmas, m_controlPoint, m_weights, Isis::SurfacePoint::MetersToLatitude(), Isis::SurfacePoint::MetersToLongitude(), Isis::IException::Programmer, Isis::SurfacePoint::Rectangular, and Isis::toString().
Referenced by setWeights().
void Isis::BundleControlPoint::setWeights | ( | const BundleSettingsQsp | settings | ) |
Sets the weights using the given BundleSettings QSharedPointer and a conversion value for meters to radians.
settings | A QSharedPointer to BundleSettings object. |
metersToRadians | A double precision conversion factor. |
Definition at line 191 of file BundleControlPoint.cpp.
References Isis::ControlPoint::Constrained, Isis::ControlPoint::Fixed, Isis::ControlPoint::Free, Isis::SurfacePoint::GetSigmaDistance(), Isis::ControlPoint::GetType(), Isis::SurfacePoint::GetWeight(), Isis::ControlPoint::IsCoord1Constrained(), Isis::ControlPoint::IsCoord2Constrained(), Isis::ControlPoint::IsCoord3Constrained(), Isis::IsSpecial(), Isis::SurfacePoint::Latitudinal, m_aprioriSigmas, m_controlPoint, m_coordTypeReports, m_weights, Isis::Distance::meters(), and setSigmaWeightFromGlobals().
Referenced by BundleControlPoint().
ControlPoint::PointType Isis::BundleControlPoint::type | ( | ) | const |
Accesses BundleControlPoint's type.
Definition at line 507 of file BundleControlPoint.cpp.
References Isis::ControlPoint::GetType(), and m_controlPoint.
Referenced by formatAprioriSigmaString(), formatBundleLatitudinalOutputDetailString(), formatBundleOutputSummaryString(), and formatBundleRectangularOutputDetailString().
|
private |
Apply the parameter corrections to the bundle control point latitudinally.
factor | The unit conversion factor to use on lat & lon. Radius is in km & converted to m |
target | The BundleTargetBody. |
Definition at line 1097 of file BundleControlPoint.cpp.
References adjustedSurfacePoint(), Isis::Angle::Degrees, m_nicVector, Isis::Distance::Meters, Isis::RAD2DEG, and setAdjustedSurfacePoint().
Referenced by applyParameterCorrections().
|
private |
Apply the parameter corrections to the bundle control point rectangularly.
factor | The unit conversion factor to use on the coordinates. |
Definition at line 1164 of file BundleControlPoint.cpp.
References adjustedSurfacePoint(), m_nicVector, Isis::Displacement::Meters, and setAdjustedSurfacePoint().
Referenced by applyParameterCorrections().
double Isis::BundleControlPoint::vtpv | ( | ) |
Compute vtpv, the weighted sum of squares of constrained point residuals.
Definition at line 1221 of file BundleControlPoint.cpp.
References m_corrections, m_weights, and vtpv().
Referenced by vtpv(), vtpvMeasures(), and Isis::BundleLidarControlPoint::vtpvRangeContribution().
double Isis::BundleControlPoint::vtpvMeasures | ( | ) |
Compute vtpv of image measures (weighted sum of squares of measure residuals).
Definition at line 1193 of file BundleControlPoint.cpp.
References vtpv().
boost::numeric::ublas::bounded_vector< double, 3 > & Isis::BundleControlPoint::weights | ( | ) |
Accesses the 3 dimensional ordered vector of weight values associated with coordinate1, coordinate2, and coordinate3.
Definition at line 582 of file BundleControlPoint.cpp.
References m_weights.
void Isis::BundleControlPoint::zeroNumberOfRejectedMeasures | ( | ) |
Resets the number of rejected measures for this BundleControlPoint to zero.
Definition at line 353 of file BundleControlPoint.cpp.
References m_controlPoint, and Isis::ControlPoint::ZeroNumberOfRejectedMeasures().
|
private |
adjusted sigmas for point parameters
Definition at line 178 of file BundleControlPoint.h.
Referenced by adjustedSigmas(), BundleControlPoint(), and copy().
|
private |
apriori sigmas for point parameters
Definition at line 176 of file BundleControlPoint.h.
Referenced by aprioriSigmas(), BundleControlPoint(), copy(), formatAprioriSigmaString(), setSigmaWeightFromGlobals(), and setWeights().
|
private |
The CholMod matrix associated with this point.
Definition at line 184 of file BundleControlPoint.h.
Referenced by cholmodQMatrix(), and productAlphaAV().
|
protected |
< pointer to the control point object this represents
Definition at line 166 of file BundleControlPoint.h.
Referenced by adjustedSurfacePoint(), BundleControlPoint(), computeResiduals(), copy(), formatBundleLatitudinalOutputDetailString(), formatBundleOutputSummaryString(), formatBundleRectangularOutputDetailString(), id(), isRejected(), numberOfRejectedMeasures(), rawControlPoint(), residualRms(), setAdjustedSurfacePoint(), setNumberOfRejectedMeasures(), setRejected(), setSigmaWeightFromGlobals(), setWeights(), type(), and zeroNumberOfRejectedMeasures().
|
private |
Definition at line 187 of file BundleControlPoint.h.
|
private |
BundleControlPoint coordinate type.
Definition at line 186 of file BundleControlPoint.h.
Referenced by BundleControlPoint(), coordTypeReports(), copy(), formatAdjustedSigmaString(), formatBundleOutputDetailString(), formatBundleOutputSummaryString(), and setWeights().
|
private |
corrections to point parameters
Definition at line 174 of file BundleControlPoint.h.
Referenced by applyParameterCorrections(), BundleControlPoint(), copy(), corrections(), formatBundleLatitudinalOutputDetailString(), formatBundleRectangularOutputDetailString(), and vtpv().
|
private |
array of NICs (see Brown, 1976)
Definition at line 182 of file BundleControlPoint.h.
Referenced by applyParameterCorrections(), BundleControlPoint(), copy(), nicVector(), productAlphaAV(), updateAdjustedSurfacePointLatitudinally(), and updateAdjustedSurfacePointRectangularly().
|
private |
weights for point parameters
Definition at line 180 of file BundleControlPoint.h.
Referenced by BundleControlPoint(), copy(), setSigmaWeightFromGlobals(), setWeights(), vtpv(), and weights().