OSSIM - Open Source Software Image Map
Version 1.9.0 (20180803)
|
#include <ossimTopographicCorrectionFilter.h>
Public Types | |
enum | ossimTopoCorrectionType { TOPO_CORRECTION_COSINE = 0, TOPO_CORRECTION_COSINE_C = 1, TOPO_CORRECTION_MINNAERT = 2 } |
![]() | |
enum | ossimConnectableObjectDirectionType { CONNECTABLE_DIRECTION_NONE = 0, CONNECTABLE_DIRECTION_INPUT = 1, CONNECTABLE_DIRECTION_OUTPUT = 2 } |
typedef std::vector< ossimRefPtr< ossimConnectableObject > > | ConnectableObjectList |
Public Member Functions | |
ossimTopographicCorrectionFilter () | |
ossimTopographicCorrectionFilter (ossimImageSource *colorSource, ossimImageSource *elevSource) | |
ossimRefPtr< ossimImageData > | getTile (const ossimIrect &tileRect, ossim_uint32 resLevel=0) |
virtual ossim_uint32 | getNumberOfOutputBands () const |
Returns the number of bands in a tile returned from this TileSource. More... | |
virtual ossimScalarType | getOutputScalarType () const |
This will be used to query the output pixel type of the tile source. More... | |
virtual double | getNullPixelValue (ossim_uint32 band=0) const |
Each band has a null pixel associated with it. More... | |
virtual double | getMinPixelValue (ossim_uint32 band=0) const |
Returns the min pixel of the band. More... | |
virtual double | getMaxPixelValue (ossim_uint32 band=0) const |
Returns the max pixel of the band. More... | |
virtual ossimIrect | getBoundingRect (ossim_uint32 resLevel=0) const |
This will return the bounding rect of the source. More... | |
virtual void | getDecimationFactor (ossim_uint32 resLevel, ossimDpt &result) const |
Will return the decimation factor for the given resolution level. More... | |
virtual void | getDecimationFactors (vector< ossimDpt > &decimations) const |
virtual ossim_uint32 | getNumberOfDecimationLevels () const |
Will return the number of resolution levels. More... | |
virtual double | getAzimuthAngle () const |
virtual double | getElevationAngle () const |
virtual void | setAzimuthAngle (double angle) |
virtual void | setElevationAngle (double angle) |
virtual void | initialize () |
virtual bool | loadState (const ossimKeywordlist &kwl, const char *prefix=0) |
Method to the load (recreate) the state of an object from a keyword list. More... | |
virtual bool | saveState (ossimKeywordlist &kwl, const char *prefix=0) const |
Method to save the state of an object to a keyword list. More... | |
bool | canConnectMyInputTo (ossim_int32 inputIndex, const ossimConnectableObject *object) const |
required to be overriden by derived classes More... | |
virtual void | connectInputEvent (ossimConnectionEvent &event) |
virtual void | disconnectInputEvent (ossimConnectionEvent &event) |
virtual void | propertyEvent (ossimPropertyEvent &event) |
virtual void | refreshEvent (ossimRefreshEvent &event) |
virtual ossimTopoCorrectionType | getTopoCorrectionType () const |
virtual void | setTopoCorrectionType (ossimTopoCorrectionType topoType) |
const std::vector< double > & | getGainValues () const |
void | setGainValues (const std::vector< double > &gainValues) |
const vector< double > & | getBiasValues () const |
void | setBiasValues (const std::vector< double > &biasValues) |
const vector< double > & | getKValues () const |
double | getK (int idx) const |
void | setK (int idx, double value) |
void | setKValues (const vector< double > &kValues) |
double | getC (int idx) const |
void | setC (int idx, double value) |
void | setCValues (const vector< double > &cValues) |
void | computeLightDirection () |
![]() | |
ossimImageCombiner () | |
ossimImageCombiner (ossimObject *owner, int numberOfInputs, int numberOfOutputs, bool inputListIsFixedFlag, bool outputListIsFixedFlag) | |
ossimImageCombiner (ossimConnectableObject::ConnectableObjectList &inputSources) | |
virtual void | updateRects () |
This will go through and precompute the bounding rects of each input image. More... | |
virtual ossim_uint32 | getNumberOfInputBands () const |
Returns the number of bands available from the input. More... | |
virtual ossim_uint32 | getTileWidth () const |
Returns the default processing tile width. More... | |
virtual ossim_uint32 | getTileHeight () const |
Returns the default processing tile height. More... | |
virtual ossim_uint32 | getNumberOfOverlappingImages (const ossimIrect &rect, ossim_uint32 resLevel=0) const |
Used to retrieve the number of overlapping images withint the given rect. More... | |
virtual void | getOverlappingImages (std::vector< ossim_uint32 > &result, const ossimIrect &rect, ossim_uint32 resLevel=0) const |
Used to populate the result with the index of the overlapping images. More... | |
virtual ossimRefPtr< ossimImageData > | getNextTile (ossim_uint32 &returnedIdx, const ossim_uint32 startIdx, const ossimIrect &tileRect, ossim_uint32 resLevel=0) |
virtual ossimRefPtr< ossimImageData > | getNextTile (ossim_uint32 &returnedIdx, const ossimIrect &tileRect, ossim_uint32 resLevel=0) |
virtual bool | getNextTile (ossim_uint32 &returnedIdx, const ossim_uint32 startIdx, ossimImageData *tile, ossim_uint32 resLevel=0) |
virtual ossimRefPtr< ossimImageData > | getNextNormTile (ossim_uint32 &returnedIdx, const ossim_uint32 index, const ossimIrect &tileRect, ossim_uint32 resLevel=0) |
virtual ossimRefPtr< ossimImageData > | getNextNormTile (ossim_uint32 &returnedIdx, const ossimIrect &tileRect, ossim_uint32 resLevel=0) |
virtual bool | hasDifferentInputs () const |
![]() | |
ossimImageSource (ossimObject *owner=0) | |
ossimImageSource (ossimObject *owner, ossim_uint32 inputListSize, ossim_uint32 outputListSize, bool inputListIsFixedFlag=true, bool outputListIsFixedFlag=true) | |
virtual | ~ossimImageSource () |
virtual ossimRefPtr< ossimImageData > | getTile (const ossimIpt &origin, ossim_uint32 resLevel=0) |
virtual bool | getTile (ossimImageData *result, ossim_uint32 resLevel=0) |
Method to get a tile. More... | |
virtual ossimObject * | getObject () |
For RTTI support. More... | |
virtual const ossimObject * | getObject () const |
For RTTI support. More... | |
virtual void | getDecimationFactors (std::vector< ossimDpt > &decimations) const |
Will return an array of all decimations for each resolution level. More... | |
virtual void | getOutputBandList (std::vector< ossim_uint32 > &bandList) const |
Initializes bandList. More... | |
virtual void | getBoundingRect (ossimIrect &rect, ossim_uint32 resLevel=0) const |
Gets the bounding rectangle of the source. More... | |
virtual void | getValidImageVertices (std::vector< ossimIpt > &validVertices, ossimVertexOrdering ordering=OSSIM_CLOCKWISE_ORDER, ossim_uint32 resLevel=0) const |
ordering specifies how the vertices should be arranged. More... | |
virtual ossimRefPtr< ossimImageGeometry > | getImageGeometry () |
Returns the image geometry object associated with this tile source or NULL if not defined. More... | |
virtual void | setImageGeometry (const ossimImageGeometry *geom) |
Default implementation sets geometry of the first input to the geometry specified. More... | |
virtual void | saveImageGeometry () const |
Default method to call input's saveImageGeometry. More... | |
virtual void | saveImageGeometry (const ossimFilename &geometry_file) const |
Default method to call input's saveImageGeometry. More... | |
virtual ossimRefPtr< ossimProperty > | getProperty (const ossimString &name) const |
virtual void | setProperty (ossimRefPtr< ossimProperty > property) |
virtual void | getPropertyNames (std::vector< ossimString > &propertyNames) const |
virtual bool | isIndexedData () const |
![]() | |
ossimSource (ossimObject *owner=0) | |
ossimSource (ossimObject *owner, ossim_uint32 inputListSize, ossim_uint32 outputListSize, bool inputListIsFixedFlag=true, bool outputListIsFixedFlag=true) | |
virtual | ~ossimSource () |
virtual bool | isSourceEnabled () const |
virtual void | enableSource () |
virtual void | disableSource () |
virtual bool | getEnableFlag () const |
virtual void | setEnableFlag (bool flag) |
virtual bool | isInitialized () const |
virtual void | setInitializedFlag (bool flag) |
virtual std::ostream & | print (std::ostream &out) const |
Outputs theErrorStatus as an ossimErrorCode and an ossimString. More... | |
![]() | |
ossimConnectableObject (ossimObject *owner=0) | |
Base constructor of this object. More... | |
ossimConnectableObject (ossimObject *owner, ossim_int32 inputListSize, ossim_int32 outputListSize, bool inputListIsFixedFlag=true, bool outputListIsFixedFlag=true) | |
virtual | ~ossimConnectableObject () |
void | setId (const ossimId &id) |
All connectable objects will have id's. More... | |
const ossimId & | getId () const |
Will allow us to get this object's id. More... | |
const ossimObject * | getOwner () const |
Fetches the current owner, most likely a container but not limited to one. More... | |
virtual void | changeOwner (ossimObject *owner) |
Permits changing the object's owner. More... | |
virtual void | setDescription (const ossimString &description) |
virtual ossimString | getDescription () const |
virtual bool | isConnected (ossimConnectableObjectDirectionType direction=CONNECTABLE_DIRECTION_INPUT) const |
will check the direction specified to see if all slots are full. More... | |
OSSIM_DEPRECATE_METHOD (virtual ossimConnectableObject *findConnectableObject(const ossimId &id)) | |
OSSIM_DEPRECATE_METHOD (virtual ossimConnectableObject *findObjectOfType(RTTItypeid typeId, ossimConnectableObjectDirectionType directionType, bool recurse=true)) | |
OSSIM_DEPRECATE_METHOD (virtual ossimConnectableObject *findObjectOfType(const ossimString &obj, ossimConnectableObjectDirectionType directionType, bool recurse=true)) | |
OSSIM_DEPRECATE_METHOD (virtual ossimConnectableObject *findInputObjectOfType(const ossimString &className)) | |
virtual ossim_int32 | findInputIndex (const ossimConnectableObject *object) |
Return a valid index of the input list if the passed in object is found else return -1. More... | |
virtual ossim_int32 | findInputIndex (const ossimId &id) |
Return a valid index of the input list if the passed id is found else return -1. More... | |
virtual ossim_int32 | findOutputIndex (const ossimConnectableObject *object) |
Return a valid index of the output list if the passed in object is found else return -1. More... | |
virtual ossim_int32 | findOutputIndex (const ossimId &id) |
Return a valid index of the output list if the passed in object is found else return -1. More... | |
virtual ossim_int32 | getMyInputIndexToConnectTo (ossimConnectableObject *object) const |
Should return the first available index to connect to. More... | |
virtual ossim_int32 | getMyOutputIndexToConnectTo (ossimConnectableObject *object) const |
Should return the first available index to connect to. More... | |
virtual bool | canConnectMyOutputTo (ossim_int32 myOutputIndex, const ossimConnectableObject *object) const |
default implementation is to allow anyone to connect to us. More... | |
virtual void | disconnect (ossimConnectableObject *object=0) |
Will disconnect the object passed in. More... | |
virtual void | disconnect (const ossimId &id) |
Will disconnect the object passed in. More... | |
virtual ossimRefPtr< ossimConnectableObject > | disconnectMyInput (ossim_int32 inputIndex, bool disconnectOutputFlag=true, bool createEventFlag=true) |
Will disconnect the object at the given input index and generate a connection event. More... | |
virtual void | disconnectMyInput (ossimConnectableObject *input, bool disconnectOutputFlag=true, bool createEventFlag=true) |
Finds the index of the passed in input and calls disconnectMyInput(inputIndex, disconnectOutputFlag, createEventFlag);. More... | |
virtual void | disconnectMyInputs (ConnectableObjectList &inputList, bool disconnectOutputFlag=true, bool createEventFlag=true) |
virtual ossimRefPtr< ossimConnectableObject > | disconnectMyOutput (ossim_int32 outputIndex, bool disconnectInputFlag=true, bool createEventFlag=true) |
Will disconnect the object at the given output index and generate a connection event. More... | |
virtual void | disconnectMyOutput (ossimConnectableObject *output, bool disconnectInputFlag=true, bool createEventFlag=true) |
Will disconnect the output object. More... | |
virtual void | disconnectMyOutputs (ConnectableObjectList &outputList, bool disconnectOutputFlag=true, bool createEventFlag=true) |
virtual void | disconnectAllInputs () |
Will disconnect all of the input objects. More... | |
virtual void | disconnectAllOutputs () |
Will disconnect all of the output objects. More... | |
virtual ossim_int32 | connectMyInputTo (ossimConnectableObject *inputObject, bool makeOutputConnection=true, bool createEventFlag=true) |
Will try to connect this objects input to the passed in object. More... | |
virtual ossim_int32 | connectMyInputTo (ossim_int32 inputIndex, ossimConnectableObject *inputObject, bool makeOutputConnection=true, bool createEventFlag=true) |
Will connect the specified input to the passed in object. More... | |
virtual bool | connectMyInputTo (ConnectableObjectList &inputList, bool makeOutputConnection=true, bool createEventFlag=true) |
virtual ossim_int32 | connectMyOutputTo (ossimConnectableObject *outputObject, bool makeInputConnection=true, bool createEventFlag=true) |
Will try to connect this objects output to the passed in object. More... | |
virtual bool | connectMyOutputTo (ConnectableObjectList &outputList, bool makeInputConnection=true, bool createEventFlag=true) |
virtual bool | connectInputList (ConnectableObjectList &inputList) |
Will disconnect itself from all inputs and reset to the passed in input list. More... | |
virtual bool | connectOutputList (ConnectableObjectList &outputList) |
Will disconnect itself from all outputs and reset to the passed in output list. More... | |
virtual ossim_uint32 | getNumberOfInputs () const |
Returns the number of input objects. More... | |
virtual ossim_uint32 | getNumberOfOutputs () const |
Return the number of output objects. More... | |
ossimConnectableObject * | getInput (ossim_uint32 index=0) |
returns the object at the specified index. More... | |
const ossimConnectableObject * | getInput (ossim_uint32 index=0) const |
returns the object at the specified index. More... | |
ossimConnectableObject * | getOutput (ossim_uint32 index=0) |
returns the object at the specified index. More... | |
const ossimConnectableObject * | getOutput (ossim_uint32 index=0) const |
returns the object at the specified index. More... | |
virtual void | setNumberOfInputs (ossim_int32 numberOfInputs) |
Will set the number of inputs. More... | |
virtual bool | getInputListIsFixedFlag () const |
virtual bool | getOutputListIsFixedFlag () const |
virtual void | setNumberOfOutputs (ossim_int32 numberOfInputs) |
Will set the number of outputs. More... | |
const ConnectableObjectList & | getInputList () const |
const ConnectableObjectList & | getOutputList () const |
ConnectableObjectList & | getInputList () |
ConnectableObjectList & | getOutputList () |
OSSIM_DEPRECATE_METHOD (virtual void findAllObjectsOfType(ConnectableObjectList &result, const RTTItypeid &typeInfo, bool recurse=true)) | |
OSSIM_DEPRECATE_METHOD (virtual void findAllObjectsOfType(ConnectableObjectList &result, const ossimString &className, bool recurse=true)) | |
virtual void | propagateEventToOutputs (ossimEvent &event) |
virtual void | propagateEventToInputs (ossimEvent &event) |
virtual void | setProperty (const ossimString &name, const ossimString &value) |
virtual ossim_uint32 | saveStateOfAllInputs (ossimKeywordlist &kwl, bool saveThisStateFlag=true, ossim_uint32 objectIndex=1, const char *prefix=0) const |
Save the state of all inputs to a keyword list. More... | |
virtual bool | fillContainer (ossimConnectableContainer &container) |
Inserts this object and all of its children and inputs into the container provided. More... | |
bool | moveInputUp (const ossimId &id) |
Moves the input connection matching id up one in the connection list. More... | |
bool | moveInputDown (const ossimId &id) |
Moves the input connection matching id down one in the connection list. More... | |
bool | moveInputToTop (const ossimId &id) |
Moves the input connection matching id to the top of the connection list. More... | |
bool | moveInputToBottom (const ossimId &id) |
Moves the input connection matching id to the bottom of the connection list. More... | |
virtual void | accept (ossimVisitor &visitor) |
We will add a visitor interface for all connectable objects. More... | |
![]() | |
ossimObject () | |
virtual | ~ossimObject () |
virtual ossimObject * | dup () const |
virtual ossimString | getShortName () const |
virtual ossimString | getLongName () const |
virtual ossimString | getClassName () const |
virtual RTTItypeid | getType () const |
virtual bool | canCastTo (ossimObject *obj) const |
virtual bool | canCastTo (const RTTItypeid &id) const |
virtual bool | canCastTo (const ossimString &parentClassName) const |
virtual bool | isEqualTo (const ossimObject &obj, ossimCompareType compareType=OSSIM_COMPARE_FULL) const |
![]() | |
ossimReferenced () | |
ossimReferenced (const ossimReferenced &) | |
ossimReferenced & | operator= (const ossimReferenced &) |
void | ref () const |
increment the reference count by one, indicating that this object has another pointer which is referencing it. More... | |
void | unref () const |
decrement the reference count by one, indicating that a pointer to this object is referencing it. More... | |
void | unref_nodelete () const |
decrement the reference count by one, indicating that a pointer to this object is referencing it. More... | |
int | referenceCount () const |
![]() | |
ossimListenerManager () | |
virtual | ~ossimListenerManager () |
virtual void | fireEvent (ossimEvent &event) |
virtual bool | addListener (ossimListener *listener) |
virtual bool | removeListener (ossimListener *listener) |
virtual bool | findListener (ossimListener *listener) |
![]() | |
ossimPropertyInterface () | |
virtual | ~ossimPropertyInterface () |
virtual ossimString | getPropertyValueAsString (const ossimString &name) const |
void | getPropertyList (std::vector< ossimRefPtr< ossimProperty > > &propertyList) const |
void | setProperties (std::vector< ossimRefPtr< ossimProperty > > &propertyList) |
![]() | |
ossimErrorStatusInterface () | |
virtual | ~ossimErrorStatusInterface () |
virtual ossimErrorCode | getErrorStatus () const |
virtual ossimString | getErrorStatusString () const |
virtual void | setErrorStatus (ossimErrorCode error_status) const |
virtual void | setErrorStatus () const |
virtual void | clearErrorStatus () const |
bool | hasError () const |
![]() | |
ossimConnectableObjectListener () | |
virtual | ~ossimConnectableObjectListener () |
virtual void | processEvent (ossimEvent &event) |
ProcessEvent. More... | |
virtual void | objectDestructingEvent (ossimObjectDestructingEvent &) |
virtual void | connectionEvent (ossimConnectionEvent &) |
virtual void | disconnectOutputEvent (ossimConnectionEvent &) |
virtual void | connectOutputEvent (ossimConnectionEvent &) |
virtual void | addObjectEvent (ossimContainerEvent &) |
virtual void | removeObjectEvent (ossimContainerEvent &) |
virtual void | containerEvent (ossimContainerEvent &) |
![]() | |
ossimListener () | |
virtual | ~ossimListener () |
void | enableListener () |
void | disableListener () |
void | setListenerEnableFlag (bool flag) |
bool | isListenerEnabled () const |
bool | getListenerEnableFlag () const |
Protected Member Functions | |
virtual | ~ossimTopographicCorrectionFilter () |
virtual void | allocate () |
virtual void | executeTopographicCorrection (ossimRefPtr< ossimImageData > &outputData, ossimRefPtr< ossimImageData > &colorData, ossimRefPtr< ossimImageData > &normalData) |
template<class T > | |
void | executeTopographicCorrectionTemplate (T dummy, ossimRefPtr< ossimImageData > &outputData, ossimRefPtr< ossimImageData > &colorData, ossimRefPtr< ossimImageData > &normalData) |
template<class T > | |
void | executeTopographicCorrectionMinnaertTemplate (T dummy, ossimRefPtr< ossimImageData > &outputData, ossimRefPtr< ossimImageData > &colorData, ossimRefPtr< ossimImageData > &normalData) |
template<class T > | |
bool | computeNdvi (T dummy, ossim_float64 &result, ossim_uint32 offset, const std::vector< T *> &bands) const |
void | resizeArrays (ossim_uint32 newSize) |
bool | setCCmputedFlag () |
![]() | |
virtual | ~ossimImageCombiner () |
void | precomputeBounds () const |
![]() | |
ossimImageSource (const ossimImageSource &rhs) | |
const ossimImageSource & | operator= (const ossimImageSource &) |
![]() | |
ossimSource (const ossimSource &rhs) | |
const ossimSource & | operator= (const ossimSource &rhs) |
![]() | |
ossimConnectableObject * | findObjectOfType (ConnectableObjectList *connectableList, ossimVisitor &visitor) |
![]() | |
virtual | ~ossimReferenced () |
![]() | |
ossimListenerManager (const ossimListenerManager &rhs) | |
class ossimTopographicCorrectionFilter
This clas is used to execute terrain correction. I t requires 2 inputs where the first input is a multi band data source to correct and the second is elevation normals used in light incident calculations.
A sample chain might look like:
landsatHandler —> Cache —> renderer —> cache ------------------------------------— |–> Topo correction filter —> Output ortho mosaic of elevation data-—> imageToPlaneNormals –> Cache —> Renderer –>Cache –
the ossimImageToPlaneNormalsFilter is used to take a single band elevation source and compute normals at each post. I suggest that you set the renderer to use a higher order convolution than just nearest neighbor, maybe Cubic. This way you have smoother interpolation as you change zoom levels.
Correction Types:
Cosine correction: In order for this to run it does not need any additional informat but the multi band source and an normal calculation input.
Cosine-C correction: In order for this to run it will need theC array populated for each band. It defaults to 0 forcing a default Cosine correction to take place.
Minnaert correction: In order for this to run it will need theK array populated for each band. The defaults should work pretty good
Definition at line 55 of file ossimTopographicCorrectionFilter.h.
Enumerator | |
---|---|
TOPO_CORRECTION_COSINE | |
TOPO_CORRECTION_COSINE_C | |
TOPO_CORRECTION_MINNAERT |
Definition at line 58 of file ossimTopographicCorrectionFilter.h.
ossimTopographicCorrectionFilter::ossimTopographicCorrectionFilter | ( | ) |
Definition at line 29 of file ossimTopographicCorrectionFilter.cpp.
ossimTopographicCorrectionFilter::ossimTopographicCorrectionFilter | ( | ossimImageSource * | colorSource, |
ossimImageSource * | elevSource | ||
) |
Definition at line 47 of file ossimTopographicCorrectionFilter.cpp.
References ossimConnectableObject::connectMyInputTo().
|
protectedvirtual |
Definition at line 63 of file ossimTopographicCorrectionFilter.cpp.
|
protectedvirtual |
Definition at line 158 of file ossimTopographicCorrectionFilter.cpp.
References computeLightDirection(), ossimImageDataFactory::create(), ossimConnectableObject::getInput(), ossimImageData::getNumberOfBands(), ossimImageSource::getOutputBandList(), ossimImageData::initialize(), ossimImageDataFactory::instance(), ossimSource::isSourceEnabled(), PTR_CAST, resizeArrays(), theBandMapping, theBias, theGain, and theTile.
Referenced by getTile().
|
virtual |
required to be overriden by derived classes
Reimplemented from ossimImageCombiner.
Definition at line 1193 of file ossimTopographicCorrectionFilter.cpp.
References PTR_CAST.
void ossimTopographicCorrectionFilter::computeLightDirection | ( | ) |
Definition at line 203 of file ossimTopographicCorrectionFilter.cpp.
References ossimMatrix3x3::createRotationMatrix(), theLightDirection, theLightSourceAzimuthAngle, theLightSourceElevationAngle, and ossimColumnVector3d::unit().
Referenced by allocate(), and ossimLandsatTopoCorrectionFilter::setLandsatHeader().
|
protected |
Definition at line 831 of file ossimTopographicCorrectionFilter.cpp.
|
virtual |
Reimplemented from ossimImageCombiner.
Definition at line 1202 of file ossimTopographicCorrectionFilter.cpp.
References initialize().
|
virtual |
Reimplemented from ossimImageCombiner.
Definition at line 1207 of file ossimTopographicCorrectionFilter.cpp.
References initialize().
|
protectedvirtual |
Definition at line 222 of file ossimTopographicCorrectionFilter.cpp.
References executeTopographicCorrectionMinnaertTemplate(), executeTopographicCorrectionTemplate(), ossimRectilinearDataObject::getScalarType(), OSSIM_DOUBLE, OSSIM_FLOAT, OSSIM_NORMALIZED_DOUBLE, OSSIM_NORMALIZED_FLOAT, OSSIM_SSHORT16, OSSIM_UCHAR, OSSIM_USHORT11, OSSIM_USHORT12, OSSIM_USHORT13, OSSIM_USHORT14, OSSIM_USHORT15, OSSIM_USHORT16, ossimNotify(), ossimNotifyLevel_WARN, theTopoCorrectionType, and TOPO_CORRECTION_MINNAERT.
Referenced by getTile().
|
protected |
Definition at line 447 of file ossimTopographicCorrectionFilter.cpp.
References ossimImageData::getBuf(), ossimDataObject::getDataObjectStatus(), ossimImageData::getHeight(), ossimImageData::getMaxPix(), ossimImageData::getMinPix(), ossimImageData::getNullPix(), ossimImageData::getNumberOfBands(), ossimImageData::getWidth(), ossim::min(), OSSIM_EMPTY, theBandMapping, theBias, theGain, theK, theLightDirection, x, and y.
Referenced by executeTopographicCorrection().
|
protected |
Definition at line 336 of file ossimTopographicCorrectionFilter.cpp.
References ossim::cosd(), FLT_EPSILON, ossimImageData::getBuf(), ossimDataObject::getDataObjectStatus(), ossimImageData::getHeight(), ossimImageData::getMaxPix(), ossimImageData::getMinPix(), ossimImageData::getNullPix(), ossimImageData::getNumberOfBands(), ossimImageData::getWidth(), OSSIM_EMPTY, theBandMapping, theBias, theC, theGain, theLightDirection, theLightSourceElevationAngle, theTopoCorrectionType, TOPO_CORRECTION_COSINE_C, x, and y.
Referenced by executeTopographicCorrection().
|
virtual |
Definition at line 1174 of file ossimTopographicCorrectionFilter.cpp.
References theLightSourceAzimuthAngle.
const vector< double > & ossimTopographicCorrectionFilter::getBiasValues | ( | ) | const |
Definition at line 1242 of file ossimTopographicCorrectionFilter.cpp.
References theBias.
|
virtual |
This will return the bounding rect of the source.
We can have several sources which are in a chain to modify the bounding image rect. lets say you are next to an image handler then it will return the bounding rect for that image. If you are at the right side of a resampler then you will get a bounding rect along the image view plane. This is going to be a very import method for both image writers, mosaics or anything that needs to operate only within the bounds of an image.
Reimplemented from ossimImageCombiner.
Definition at line 1128 of file ossimTopographicCorrectionFilter.cpp.
References ossimImageSource::getBoundingRect(), ossimConnectableObject::getInput(), ossimIrect::makeNan(), and PTR_CAST.
double ossimTopographicCorrectionFilter::getC | ( | int | idx | ) | const |
Definition at line 1282 of file ossimTopographicCorrectionFilter.cpp.
References theC.
|
virtual |
Will return the decimation factor for the given resolution level.
the decimation is the scale from Resolution 0 or full res. Usually this is a power of 2 decimation where the decimation result is 1.0/2^resoltion.
Reimplemented from ossimImageSource.
Definition at line 1142 of file ossimTopographicCorrectionFilter.cpp.
References ossimImageSource::getDecimationFactor(), ossimConnectableObject::getInput(), ossimDpt::makeNan(), and PTR_CAST.
|
virtual |
Definition at line 1155 of file ossimTopographicCorrectionFilter.cpp.
References ossimImageSource::getDecimationFactors(), ossimConnectableObject::getInput(), and PTR_CAST.
|
virtual |
Definition at line 1179 of file ossimTopographicCorrectionFilter.cpp.
References theLightSourceElevationAngle.
const std::vector< double > & ossimTopographicCorrectionFilter::getGainValues | ( | ) | const |
Definition at line 1232 of file ossimTopographicCorrectionFilter.cpp.
References theGain.
double ossimTopographicCorrectionFilter::getK | ( | int | idx | ) | const |
Definition at line 1257 of file ossimTopographicCorrectionFilter.cpp.
References theK.
const vector< double > & ossimTopographicCorrectionFilter::getKValues | ( | ) | const |
Definition at line 1252 of file ossimTopographicCorrectionFilter.cpp.
References theK.
|
virtual |
Returns the max pixel of the band.
Reimplemented from ossimImageCombiner.
Definition at line 1118 of file ossimTopographicCorrectionFilter.cpp.
References ossimConnectableObject::getInput(), ossimImageCombiner::getMaxPixelValue(), ossimImageSource::getMaxPixelValue(), and PTR_CAST.
|
virtual |
Returns the min pixel of the band.
Reimplemented from ossimImageCombiner.
Definition at line 1108 of file ossimTopographicCorrectionFilter.cpp.
References ossimConnectableObject::getInput(), ossimImageCombiner::getMinPixelValue(), ossimImageSource::getMinPixelValue(), and PTR_CAST.
|
virtual |
Each band has a null pixel associated with it.
The null pixel represents an invalid value.
Reimplemented from ossimImageCombiner.
Definition at line 1098 of file ossimTopographicCorrectionFilter.cpp.
References ossimConnectableObject::getInput(), ossimImageCombiner::getNullPixelValue(), ossimImageSource::getNullPixelValue(), and PTR_CAST.
|
virtual |
Will return the number of resolution levels.
Note: resolution level 0 is included in the return count.
Reimplemented from ossimImageSource.
Definition at line 1164 of file ossimTopographicCorrectionFilter.cpp.
References ossimConnectableObject::getInput(), ossimImageSource::getNumberOfDecimationLevels(), and PTR_CAST.
|
virtual |
Returns the number of bands in a tile returned from this TileSource.
Reimplemented from ossimImageSource.
Definition at line 1078 of file ossimTopographicCorrectionFilter.cpp.
References ossimConnectableObject::getInput(), ossimImageSource::getNumberOfOutputBands(), and PTR_CAST.
|
virtual |
This will be used to query the output pixel type of the tile source.
Please ignore the argument. It will soon be removed.
Reimplemented from ossimImageCombiner.
Definition at line 1088 of file ossimTopographicCorrectionFilter.cpp.
References ossimConnectableObject::getInput(), ossimImageCombiner::getOutputScalarType(), ossimImageSource::getOutputScalarType(), and PTR_CAST.
|
virtual |
Reimplemented from ossimImageSource.
Definition at line 67 of file ossimTopographicCorrectionFilter.cpp.
References allocate(), executeTopographicCorrection(), ossimImageData::getBuf(), ossimDataObject::getDataObjectStatus(), ossimImageData::getHeight(), ossimConnectableObject::getInput(), ossimImageData::getNumberOfBands(), ossimRectilinearDataObject::getScalarType(), ossimImageSource::getTile(), ossimImageData::getWidth(), ossimIrect::height(), ossimImageData::initialize(), ossimSource::isSourceEnabled(), ossimImageData::makeBlank(), OSSIM_DOUBLE, OSSIM_EMPTY, PTR_CAST, ossimImageData::setHeight(), ossimImageData::setOrigin(), ossimImageData::setWidth(), theTile, ossimIrect::ul(), ossimRefPtr< T >::valid(), ossimImageData::validate(), and ossimIrect::width().
|
virtual |
Definition at line 1222 of file ossimTopographicCorrectionFilter.cpp.
References theTopoCorrectionType.
|
virtual |
Reimplemented from ossimImageCombiner.
Reimplemented in ossimLandsatTopoCorrectionFilter.
Definition at line 150 of file ossimTopographicCorrectionFilter.cpp.
References ossimImageCombiner::initialize(), and theTile.
Referenced by connectInputEvent(), disconnectInputEvent(), ossimLandsatTopoCorrectionFilter::initialize(), propertyEvent(), and refreshEvent().
|
virtual |
Method to the load (recreate) the state of an object from a keyword list.
Return true if ok or false on error.
Reimplemented from ossimImageCombiner.
Reimplemented in ossimLandsatTopoCorrectionFilter.
Definition at line 898 of file ossimTopographicCorrectionFilter.cpp.
References ossimKeywordNames::AZIMUTH_ANGLE_KW, ossimKeywordNames::ELEVATION_ANGLE_KW, ossimKeywordlist::find(), and ossimKeywordNames::NUMBER_BANDS_KW.
Referenced by ossimLandsatTopoCorrectionFilter::loadState().
|
virtual |
Reimplemented from ossimImageCombiner.
Definition at line 1212 of file ossimTopographicCorrectionFilter.cpp.
References initialize().
|
virtual |
Reimplemented from ossimImageCombiner.
Definition at line 1217 of file ossimTopographicCorrectionFilter.cpp.
References initialize().
|
protected |
Definition at line 847 of file ossimTopographicCorrectionFilter.cpp.
References ossimConnectableObject::getInput(), ossim::min(), theBias, theC, theGain, and theK.
Referenced by allocate().
|
virtual |
Method to save the state of an object to a keyword list.
Return true if ok or false on error.
Reimplemented from ossimImageCombiner.
Reimplemented in ossimLandsatTopoCorrectionFilter.
Definition at line 996 of file ossimTopographicCorrectionFilter.cpp.
References ossimKeywordlist::add(), ossimKeywordNames::AZIMUTH_ANGLE_KW, ossimKeywordNames::ELEVATION_ANGLE_KW, ossimKeywordNames::NUMBER_BANDS_KW, theC, theLightSourceAzimuthAngle, and theLightSourceElevationAngle.
Referenced by ossimLandsatTopoCorrectionFilter::saveState().
|
virtual |
Definition at line 1184 of file ossimTopographicCorrectionFilter.cpp.
References theLightSourceAzimuthAngle.
void ossimTopographicCorrectionFilter::setBiasValues | ( | const std::vector< double > & | biasValues | ) |
Definition at line 1247 of file ossimTopographicCorrectionFilter.cpp.
References theBias.
void ossimTopographicCorrectionFilter::setC | ( | int | idx, |
double | value | ||
) |
Definition at line 1294 of file ossimTopographicCorrectionFilter.cpp.
References theC.
|
protected |
void ossimTopographicCorrectionFilter::setCValues | ( | const vector< double > & | cValues | ) |
Definition at line 1302 of file ossimTopographicCorrectionFilter.cpp.
References theC.
|
virtual |
Definition at line 1189 of file ossimTopographicCorrectionFilter.cpp.
References theLightSourceElevationAngle.
void ossimTopographicCorrectionFilter::setGainValues | ( | const std::vector< double > & | gainValues | ) |
Definition at line 1237 of file ossimTopographicCorrectionFilter.cpp.
References theGain.
void ossimTopographicCorrectionFilter::setK | ( | int | idx, |
double | value | ||
) |
Definition at line 1269 of file ossimTopographicCorrectionFilter.cpp.
References theK.
void ossimTopographicCorrectionFilter::setKValues | ( | const vector< double > & | kValues | ) |
Definition at line 1277 of file ossimTopographicCorrectionFilter.cpp.
References theK.
|
virtual |
Definition at line 1227 of file ossimTopographicCorrectionFilter.cpp.
References theTopoCorrectionType.
|
protected |
Definition at line 156 of file ossimTopographicCorrectionFilter.h.
Referenced by allocate(), executeTopographicCorrectionMinnaertTemplate(), and executeTopographicCorrectionTemplate().
|
protected |
Definition at line 162 of file ossimTopographicCorrectionFilter.h.
Referenced by allocate(), executeTopographicCorrectionMinnaertTemplate(), executeTopographicCorrectionTemplate(), getBiasValues(), resizeArrays(), setBiasValues(), and ossimLandsatTopoCorrectionFilter::setLandsatHeader().
|
protected |
Definition at line 160 of file ossimTopographicCorrectionFilter.h.
Referenced by executeTopographicCorrectionTemplate(), getC(), resizeArrays(), saveState(), setC(), and setCValues().
|
mutableprotected |
Definition at line 182 of file ossimTopographicCorrectionFilter.h.
|
protected |
Definition at line 163 of file ossimTopographicCorrectionFilter.h.
Referenced by allocate(), executeTopographicCorrectionMinnaertTemplate(), executeTopographicCorrectionTemplate(), getGainValues(), resizeArrays(), setGainValues(), and ossimLandsatTopoCorrectionFilter::setLandsatHeader().
|
protected |
Definition at line 181 of file ossimTopographicCorrectionFilter.h.
Referenced by ossimLandsatTopoCorrectionFilter::setLandsatHeader().
|
protected |
Definition at line 161 of file ossimTopographicCorrectionFilter.h.
Referenced by executeTopographicCorrectionMinnaertTemplate(), getK(), getKValues(), resizeArrays(), setK(), and setKValues().
|
protected |
This is computed from the elevation and azimuth angles of the light source.
Definition at line 179 of file ossimTopographicCorrectionFilter.h.
Referenced by computeLightDirection(), executeTopographicCorrectionMinnaertTemplate(), and executeTopographicCorrectionTemplate().
|
protected |
Used for the light vector computation.
Definition at line 173 of file ossimTopographicCorrectionFilter.h.
Referenced by computeLightDirection(), getAzimuthAngle(), saveState(), setAzimuthAngle(), and ossimLandsatTopoCorrectionFilter::setLandsatHeader().
|
protected |
Used for the light vector computation.
Definition at line 168 of file ossimTopographicCorrectionFilter.h.
Referenced by computeLightDirection(), executeTopographicCorrectionTemplate(), getElevationAngle(), saveState(), setElevationAngle(), and ossimLandsatTopoCorrectionFilter::setLandsatHeader().
|
protected |
Definition at line 185 of file ossimTopographicCorrectionFilter.h.
|
protected |
Definition at line 184 of file ossimTopographicCorrectionFilter.h.
|
protected |
The result of the illumination equation is stored in here. This is populated on each call to getTile.
Definition at line 154 of file ossimTopographicCorrectionFilter.h.
Referenced by allocate(), getTile(), and initialize().
|
protected |
Definition at line 183 of file ossimTopographicCorrectionFilter.h.
Referenced by executeTopographicCorrection(), executeTopographicCorrectionTemplate(), getTopoCorrectionType(), and setTopoCorrectionType().