24 #ifndef CUBE_CALCULATOR_H_ 25 #define CUBE_CALCULATOR_H_ 31 template<
class T>
class QVector;
228 QVector<double> *radiusBuffer(
int currentLine,
int ns,
int currentBand);
238 void loadBuffers(
int currentLine,
int ns,
int currentBand);
The calculation requires input data.
Center phase camera data.
void enableEmalBuffer()
Enables the local emission angle buffer for use.
void enableEmaBuffer()
Enables the emission angle buffer for use.
QVector< double > * m_inaBuffer
Incidence angle buffer.
void enableResBuffer()
Enables the resolution buffer for use.
This class is used to define what kind of data is being pushed onto the cube calculator.
int m_lastLine
The number of the last line loaded into the enabled camera buffers.
void prepareCalculations(QString equation, QVector< Cube *> &inCubes, Cube *outCube)
This method builds a list of actions to perform based on the postfix expression.
DataValue()
Constructs a default DataValue.
void enableRadiusBuffer()
Enables the radius buffer for use.
int lastPushToCubeStats(QVector< Cube *> &inCubes)
Creates statistics internally for the last cube data pushed to the data definitions.
QVector< double > * m_emalBuffer
Local emission angle buffer.
This class is used to manage buffers for calculating camera related information, such as angles...
QVector< double > * m_latBuffer
Latitude buffer.
QVector< double > * m_resBuffer
Resolution buffer.
QVector< double > * m_phalBuffer
Local phase angle buffer.
QVector< double > * m_inalBuffer
Local incidence angle buffer.
int m_cubeIndex
The index of the associated cube.
Pixel resolution camera data.
int m_outputSamples
Number of samples in the output cube.
Local emission camera data.
QVector< Statistics * > * m_cubeStats
Stores the cube statistics for the input cubes.
Center incidence camera data.
QVector< CameraBuffers * > * m_cameraBuffers
Stores the camera buffers that are enabled for camera related calculations.
void enablePhaBuffer()
Enables the phase angle buffer for use.
QVector< void(Calculator::*)(void)> * m_methods
This stores the addresses to the methods RunCalculations(...) will call.
DataValueType type()
Accesses the type of the DataValue.
QVector< Calculations > * m_calculations
This is what RunCalculations(...) will loop over.
The calculation requires calling one of the methods.
DataValueType
This is used to tell what kind of data to push onto the RPN calculator.
void addMethodCall(void(Calculator::*method)(void))
This is a conveinience method for PrepareCalculations(...).
QVector< double > * m_emaBuffer
Emission angle buffer.
Calculations
This is used to define the overall action to perform in RunCalculations(..).
Camera * m_camera
Camera to obtain camera-related information from.
QVector< double > runCalculations(QVector< Buffer *> &cubeData, int line, int band)
This method will execute the calculations built up when PrepareCalculations was called.
void enableInaBuffer()
Enables the incidence angle buffer for use.
void enableInacBuffer()
Enables the center incidence angle buffer for use.
void enablePhalBuffer()
Enables the local phase angle buffer for use.
void enableEmacBuffer()
Enables the center emission angle buffer for use.
void enablePhacBuffer()
Enables the center phase angle buffer for use.
Local incidence camera data.
QVector< double > * m_phacBuffer
Center phase angle buffer.
int lastPushToCubeCameras(QVector< Cube *> &inCubes)
Creates internal camera for the last pushed cube data.
int cubeIndex()
Accesses the cube index of the DataValue.
QVector< double > * m_lonBuffer
Longitude buffer.
QVector< DataValue > * m_dataDefinitions
This defines what kind of data RunCalculations(...) will push onto the calculator.
Center emission camera data.
DataValueType m_type
Type of data stored.
CameraBuffers(Camera *camera)
Constructs a CameraBuffers object.
QVector< double > * m_radiusBuffer
Radius buffer.
void Clear()
This method completely resets the calculator.
~CubeCalculator()
Destroys the CubeCalculator object.
void enableLonBuffer()
Enables the longitude buffer for use.
Namespace for ISIS/Bullet specific routines.
double constant()
Accesses the constant value of the DataValue.
QVector< Camera * > * m_cubeCameras
Stores the cameras for the input cubes.
QVector< double > * m_emacBuffer
Center emission angle buffer.
QVector< double > * m_phaBuffer
Phase angle buffer.
void enableLatBuffer()
Enables the latitude buffer for use.
~CameraBuffers()
Destroys the CameraBuffers.
double m_constantValue
Stored constant value.
void enableInalBuffer()
Enables the local incidence angle buffer for use.
QVector< double > * m_inacBuffer
Center incidence angle buffer.
CubeCalculator()
Constructs a CubeCalculator.
IO Handler for Isis Cubes.