Isis 3 Programmer Reference
BundleObservationSolveSettings.h
1#ifndef BundleObservationSolveSettings_h
2#define BundleObservationSolveSettings_h
3
10/* SPDX-License-Identifier: CC0-1.0 */
11
12#include <QList>
13#include <QSet>
14#include <QString>
15#include <QStringList>
16#include <QXmlStreamReader>
17
18#include <csm.h>
19
20#include "SpicePosition.h"
21#include "SpiceRotation.h"
22
23class QDataStream;
24class QUuid;
25class QXmlStreamWriter;
26
27namespace Isis {
28 class FileName;
29 class Project; // TODO: does xml stuff need project???
30 class PvlObject;
82
83 public:
85 BundleObservationSolveSettings(QXmlStreamReader *xmlReader);
87 QXmlStreamReader *xmlReader);
89 BundleObservationSolveSettings(const PvlGroup &scParameterGroup);
92 void initialize();
93
94 void setInstrumentId(QString instrumentId);
95 QString instrumentId() const;
96 void addObservationNumber(QString observationNumber);
97 bool removeObservationNumber(QString observationNumber);
98 QSet<QString> observationNumbers() const;
99
103 Set = 1,
104 Type = 2,
105 List = 3
106 };
107
108 static CSMSolveOption stringToCSMSolveOption(QString option);
109 static QString csmSolveOptionToString(CSMSolveOption option);
110 static csm::param::Set stringToCSMSolveSet(QString set);
111 static QString csmSolveSetToString(csm::param::Set set);
112 static csm::param::Type stringToCSMSolveType(QString type);
113 static QString csmSolveTypeToString(csm::param::Type type);
114 void setCSMSolveSet(csm::param::Set set);
115 void setCSMSolveType(csm::param::Type type);
117 CSMSolveOption csmSolveOption() const;
118 csm::param::Set csmParameterSet() const;
119 csm::param::Type csmParameterType() const;
121
133
134 static InstrumentPointingSolveOption stringToInstrumentPointingSolveOption(QString option);
135 static QString instrumentPointingSolveOptionToString(InstrumentPointingSolveOption option);
136 void setInstrumentPointingSettings(InstrumentPointingSolveOption option,
137 bool solveTwist,
138 int ckDegree = 2,
139 int ckSolveDegree = 2,
140 bool solvePolynomialOverExisting = false,
141 double anglesAprioriSigma = -1.0,
142 double angularVelocityAprioriSigma = -1.0,
143 double angularAccelerationAprioriSigma = -1.0,
144 QList<double> * additionalPointingSigmas=nullptr);
145 InstrumentPointingSolveOption instrumentPointingSolveOption() const;
146 bool solveTwist() const;
147 int ckDegree() const;
148 int ckSolveDegree() const;
150 bool solvePolyOverPointing() const;
151 QList<double> aprioriPointingSigmas() const;
153
154
155
166
167 static InstrumentPositionSolveOption stringToInstrumentPositionSolveOption(QString option);
168 static QString instrumentPositionSolveOptionToString(InstrumentPositionSolveOption option);
169 void setInstrumentPositionSettings(InstrumentPositionSolveOption option,
170 int spkDegree = 2,
171 int spkSolveDegree = 2,
172 bool positionOverHermite = false,
173 double positionAprioriSigma = -1.0,
174 double velocityAprioriSigma = -1.0,
175 double accelerationAprioriSigma = -1.0,
176 QList<double> * additionalPositionSigmas=nullptr);
177 InstrumentPositionSolveOption instrumentPositionSolveOption() const;
178 int spkDegree() const;
179 int spkSolveDegree() const;
181 bool solvePositionOverHermite() const;
182 QList<double> aprioriPositionSigmas() const;
184
185 void save(QXmlStreamWriter &stream, const Project *project) const;
186 void readSolveSettings(QXmlStreamReader *xmlReader);
187
192 QUuid *m_id;
194 QSet<QString> m_observationNumbers;
195
196 // CSM related parameters
198 csm::param::Set m_csmSolveSet;
200 csm::param::Type m_csmSolveType;
205 // pointing related parameters
217 QList<double> m_anglesAprioriSigma;
231 // position related parameters
257 };
260 typedef QSharedPointer<BundleObservationSolveSettings> BundleObservationSolveSettingsQsp;
261};
262
263#endif // BundleObservationSolveSettings_h
This class is used to modify and manage solve settings for 1 to many BundleObservations.
CSMSolveOption
Options for how to solve for CSM parameters.
@ NoCSMParameters
Do not solve for CSM parameters.
@ List
Solve for an explicit list of CSM parameters.
static InstrumentPointingSolveOption stringToInstrumentPointingSolveOption(QString option)
Translates a QString InstrumentPointingSolveOption to its enumerated value.
InstrumentPositionSolveOption
Options for how to solve for instrument position.
@ PositionVelocity
Solve for instrument positions and velocities.
@ PositionVelocityAcceleration
Solve for instrument positions, velocities, and accelerations.
@ AllPositionCoefficients
Solve for all coefficients in the polynomials fit to the instrument positions.
@ PositionOnly
Solve for instrument positions only.
@ NoPositionFactors
Solve for none of the position factors.
static QString csmSolveTypeToString(csm::param::Type type)
Convert a CSM parameter type enumeration value to a string.
csm::param::Type m_csmSolveType
The CSM parameter type to solve for.
SpicePosition::Source m_positionInterpolationType
SpicePosition interpolation types.
CSMSolveOption csmSolveOption() const
Get how the CSM parameters to solve for are specified for this observation.
CSMSolveOption m_csmSolveOption
How the CSM solution is specified.
void addObservationNumber(QString observationNumber)
Associates an observation number with these solve settings.
InstrumentPositionSolveOption instrumentPositionSolveOption() const
Accesses the instrument position solve option.
int m_numberCamAngleCoefSolved
The number of camera angle coefficients in solution.
void initialize()
Initializes the default state of this BundleObservationSolveSettings.
bool solveTwist() const
Accesses the flag for solving for twist.
void setCSMSolveType(csm::param::Type type)
Set the type of CSM parameters to solve for.
static QString csmSolveOptionToString(CSMSolveOption option)
Convert a CSM solve option enumeration value to a string.
int m_numberCamPosCoefSolved
The number of camera position coefficients in the solution.
BundleObservationSolveSettings & operator=(const BundleObservationSolveSettings &src)
Assigns the state of another BundleObservationSolveSettings to this one.
static csm::param::Set stringToCSMSolveSet(QString set)
Convert a string to its CSM parameter set enumeration value.
csm::param::Set csmParameterSet() const
Get the set of CSM parameters to solve for.
bool m_solvePositionOverHermiteSpline
The polynomial will be fit over an existing Hermite spline.
void setCSMSolveSet(csm::param::Set set)
Set the set of CSM parameters to solve for.
SpiceRotation::Source m_pointingInterpolationType
SpiceRotation interpolation type.
QSet< QString > m_observationNumbers
Associated observation numbers for these settings.
bool solvePolyOverPointing() const
Whether or not the solve polynomial will be fit over the existing pointing polynomial.
void setInstrumentPositionSettings(InstrumentPositionSolveOption option, int spkDegree=2, int spkSolveDegree=2, bool positionOverHermite=false, double positionAprioriSigma=-1.0, double velocityAprioriSigma=-1.0, double accelerationAprioriSigma=-1.0, QList< double > *additionalPositionSigmas=nullptr)
Sets the instrument pointing settings.
int m_spkDegree
Degree of the polynomial fit to the original camera position.
int numberCameraPositionCoefficientsSolved() const
Accesses the number of camera position coefficients in the solution.
void setInstrumentId(QString instrumentId)
Sets the instrument id for this observation.
QString m_instrumentId
The spacecraft instrument id for this observation.
void save(QXmlStreamWriter &stream, const Project *project) const
Saves this BundleObservationSolveSettings to an xml stream.
BundleObservationSolveSettings()
Constructor with default parameter initializations.
int ckDegree() const
Accesses the degree of polynomial fit to original camera angles (ckDegree).
QString instrumentId() const
Accesses the instrument id for this observation.
csm::param::Type csmParameterType() const
Get the type of CSM parameters to solve for.
QList< double > aprioriPositionSigmas() const
Accesses the a priori position sigmas.
QList< double > m_anglesAprioriSigma
The image position a priori sigmas.The size of the list is equal to the number of coefficients in the...
InstrumentPointingSolveOption m_instrumentPointingSolveOption
Option for how to solve for instrument pointing.
int m_spkSolveDegree
Degree of the camera position polynomial being fit to in the bundle adjustment.
static QString instrumentPointingSolveOptionToString(InstrumentPointingSolveOption option)
Tranlsates an enumerated InstrumentPointingSolveOption value to its string representation.
QList< double > aprioriPointingSigmas() const
Accesses the a priori pointing sigmas.
static InstrumentPositionSolveOption stringToInstrumentPositionSolveOption(QString option)
Translates a QString InstrumentPositionSolveOption to its enumerated value.
SpiceRotation::Source pointingInterpolationType() const
Accesses the SpiceRotation interpolation type for the instrument pointing.
static QString csmSolveSetToString(csm::param::Set set)
Convert a CSM parameter set enumeration value to a string.
int ckSolveDegree() const
Accesses the degree of the camera angles polynomial being fit to in the bundle adjustment (ckSolveDeg...
bool m_solvePointingPolynomialOverExisting
The polynomial will be fit over the existing pointing polynomial.
static CSMSolveOption stringToCSMSolveOption(QString option)
Convert a string to a CSM solve option enumeration value.
csm::param::Set m_csmSolveSet
The CSM parameter set to solve for.
void setInstrumentPointingSettings(InstrumentPointingSolveOption option, bool solveTwist, int ckDegree=2, int ckSolveDegree=2, bool solvePolynomialOverExisting=false, double anglesAprioriSigma=-1.0, double angularVelocityAprioriSigma=-1.0, double angularAccelerationAprioriSigma=-1.0, QList< double > *additionalPointingSigmas=nullptr)
Sets the instrument pointing settings.
bool solvePositionOverHermite() const
Whether or not the polynomial for solving will be fit over an existing Hermite spline.
InstrumentPositionSolveOption m_instrumentPositionSolveOption
Option for how to solve for instrument position.
QList< double > m_positionAprioriSigma
The instrument pointing a priori sigmas.
QStringList csmParameterList() const
Get the list of CSM parameters to solve for.
int m_ckSolveDegree
Degree of the camera angles polynomial being fit to in the bundle adjustment.
SpicePosition::Source positionInterpolationType() const
Accesses the SpicePosition interpolation type for the spacecraft position.
QSet< QString > observationNumbers() const
Returns a list of observation numbers associated with these solve settings.
static QString instrumentPositionSolveOptionToString(InstrumentPositionSolveOption option)
Translates an enumerated InstrumentPositionSolveOption to its string representation.
int numberCameraAngleCoefficientsSolved() const
Accesses the number of camera angle coefficients in the solution.
bool removeObservationNumber(QString observationNumber)
Removes an observation number from this solve settings.
int spkSolveDegree() const
Accesses the degree of thecamera position polynomial being fit to in the bundle adjustment (spkSolveD...
QUuid * m_id
A unique ID for this object (useful for others to reference this object when saving to disk).
InstrumentPointingSolveOption instrumentPointingSolveOption() const
Accesses the instrument pointing solve option.
void setCSMSolveParameterList(QStringList list)
Set an explicit list of CSM parameters to solve for.
QStringList m_csmSolveList
The names of the CSM parameters to solve for.
int m_ckDegree
Degree of the polynomial fit to the original camera angles.
InstrumentPointingSolveOption
Options for how to solve for instrument pointing.
@ AnglesVelocity
Solve for pointing angles and their angular velocities.
@ AnglesVelocityAcceleration
Solve for pointing angles, their velocities and their accelerations.
@ AllPointingCoefficients
Solve for all coefficients in the polynomials fit to the pointing angles.
@ AnglesOnly
Solve for pointing angles: right ascension, declination and, optionally, twist.
@ NoPointingFactors
Solve for none of the pointing factors.
int spkDegree() const
Accesses the degree of the polynomial fit to the original camera position (spkDegree).
static csm::param::Type stringToCSMSolveType(QString type)
Convert a string to its CSM parameter type enumeration value.
File name manipulation and expansion.
Definition FileName.h:100
The main project for ipce.
Definition Project.h:287
Contains multiple PvlContainers.
Definition PvlGroup.h:41
Source
This enum indicates the status of the object.
Source
The rotation can come from one of 3 places for an Isis cube.
This is free and unencumbered software released into the public domain.
Definition Apollo.h:16
QSharedPointer< BundleObservationSolveSettings > BundleObservationSolveSettingsQsp
Definition for BundleObservationSolveSettingsQsp, a QSharedPointer to a BundleObservationSolveSetting...