Spectral Angle Mapper classification strategy. More...
#include <ClassifierSAMStrategy.h>
Classes | |
| class | Parameters |
| Classifier Parameters. More... | |
Public Types | |
| typedef std::map< ClassIDT, SamplesT > | ClassesSamplesT |
| Classes samples container type definition. More... | |
| typedef boost::shared_ptr< ClassesSamplesT > | ClassesSamplesTPtr |
| A shared pointer to a multi classes samples container type definition. More... | |
| typedef unsigned int | ClassIDT |
| Class ID type definition (zero means invalid ID). More... | |
| typedef std::vector< SampleT > | SamplesT |
| Class samples container type definition. More... | |
| typedef std::vector< double > | SampleT |
| Class sample type definition. More... | |
Public Member Functions | |
| ClassifierSAMStrategy () | |
| void | enableMultiThread (const bool &enable) |
| Enable / disable the use of multiple threads. More... | |
| void | enableOutputPalette (const bool enabled) |
| Enable (true) or disable (false) the creation of a paletted output raster. More... | |
| void | enableProgressInterface (const bool &enable) |
| Enable / disable the progress interface. More... | |
| void | enableRasterCache (const bool &enable) |
| Enable / disable the use of raster data cache. More... | |
| bool | execute () throw (te::rp::Exception) |
| Executes the classification strategy. More... | |
| const std::string & | getErrorMessage () const |
| Return the current error message if there is any. More... | |
| void | getMetaData (std::map< std::string, std::string > &metadata) const |
| Returns strategy-dependent metadata. More... | |
| bool | initialize (ClassifierStrategyParameters const *const strategyParams) throw (te::rp::Exception) |
| Initialize the classification strategy. More... | |
| std::unique_ptr< te::rst::Raster > | releaseOutputRaster () |
| Returns a pointer to the output raster or a void pointer if there is none. More... | |
| void | setInputPolygons (const std::vector< te::gm::Polygon * > &polygonsPtrs) |
| Set the input polygons. More... | |
| void | setInputRaster (const te::rst::Raster &raster) |
| Set the input raster. More... | |
| void | setInputRasterBands (const std::vector< unsigned int > &rasterBands) |
| Set the input raste bandsr. More... | |
| void | setUserOutputPalette (std::vector< te::rst::BandProperty::ColorEntry > &userPalette) |
| Set the output user palette. More... | |
| ~ClassifierSAMStrategy () | |
Protected Member Functions | |
| bool | createOutputRaster (const std::vector< int > &bandsDataTypes, const std::vector< double > &noDataValues) |
| Create the output raster using the EXPANSIBLE driver. More... | |
| virtual void | reset () |
| Reset to an initial state. More... | |
| void | setErrorMessage (const std::string &newErrorMessage) |
| Set the current error message. More... | |
| bool | setOutputRasterPalette (const unsigned int size) |
| Create and set the output raster palette folowing the current internal settings. More... | |
Protected Attributes | |
| std::vector< ClassIDT > | m_classesIndex2ID |
| An class index ordered vector of classes IDs;. More... | |
| SamplesT | m_classesMeans |
| Classes means. More... | |
| bool | m_createRasterPalette |
| Enable (true) or disable (false) the creation of a paletted output raster. More... | |
| bool | m_enableMultiThread |
| Enable or disable the use multipe threads. More... | |
| bool | m_enableRasterCache |
| Enable or disable the use a raster data cache. More... | |
| ClassIDT | m_highestTrainClassID |
| ClassifierSAMStrategy::Parameters | m_initParams |
| Initialization parameters. More... | |
| std::vector< te::gm::Polygon * > const * | m_inputPolygonsPtr |
| Input polygons. More... | |
| std::vector< unsigned int > | m_inputRasterBands |
| Input raster bands. More... | |
| te::rst::Raster const * | m_inputRasterPtr |
| A pointer to the input raster. More... | |
| bool | m_isInitialized |
| Is this instance initialized? More... | |
| std::map< std::string, std::string > | m_metaData |
| Strategy-dependent metadata. More... | |
| std::unique_ptr< te::rst::Raster > | m_outputRasterPtr |
| A pointer to the output raster. More... | |
| bool | m_progressInterfaceEnabled |
| Progress interface status. More... | |
| std::vector< te::rst::BandProperty::ColorEntry > | m_userOutputPalette |
| User output raster palette (it must be large enough to accomodate all classifyier generated classes or an empty vector to automatically generate an random palette. More... | |
Spectral Angle Mapper classification strategy.
This algorithm maps the spectral similarity of input raster to the given reference spectra wich can be either laboratory of field spectra. This method assumes that the data have been reduced to apparent reflectance with all dark current and path radiance biases removed. Reference: The spectral image processing system (SIPS)- interactive visualization and analysis of imaging spectrometer data. Kruse, F. A.; Lefkoff, A. B.; Boardman, J. W.; Heidebrecht, K. B.; Shapiro, A. T.; Barloon, P. J.; Goetz, A. F. H. The earth and space science information system (ESSIS). AIP Conference Proceedings, Volume 283, pp. 192-201 (1993).
Definition at line 55 of file ClassifierSAMStrategy.h.
| typedef std::map< ClassIDT, SamplesT > te::rp::ClassifierSAMStrategy::ClassesSamplesT |
Classes samples container type definition.
Definition at line 65 of file ClassifierSAMStrategy.h.
| typedef boost::shared_ptr<ClassesSamplesT> te::rp::ClassifierSAMStrategy::ClassesSamplesTPtr |
A shared pointer to a multi classes samples container type definition.
Definition at line 67 of file ClassifierSAMStrategy.h.
| typedef unsigned int te::rp::ClassifierSAMStrategy::ClassIDT |
Class ID type definition (zero means invalid ID).
Definition at line 59 of file ClassifierSAMStrategy.h.
| typedef std::vector< SampleT > te::rp::ClassifierSAMStrategy::SamplesT |
Class samples container type definition.
Definition at line 63 of file ClassifierSAMStrategy.h.
| typedef std::vector< double > te::rp::ClassifierSAMStrategy::SampleT |
Class sample type definition.
Definition at line 61 of file ClassifierSAMStrategy.h.
| te::rp::ClassifierSAMStrategy::ClassifierSAMStrategy | ( | ) |
Definition at line 73 of file ClassifierSAMStrategy.cpp.
References m_highestTrainClassID, m_isInitialized, and ~ClassifierSAMStrategy().
|
default |
Referenced by ClassifierSAMStrategy().
|
protectedinherited |
Create the output raster using the EXPANSIBLE driver.
| bandsDataTypes | Bands data types. |
| noDataValues | A vector of no-data values for each band. |
Definition at line 105 of file ClassifierStrategy.cpp.
References te::rst::Raster::getBand(), te::rst::Raster::getGrid(), te::rst::Band::getProperty(), te::rst::GrayIdxCInt, te::sa::Grid, te::rst::BandProperty::m_colorInterp, te::rp::ClassifierStrategy::m_inputRasterBands, te::rp::ClassifierStrategy::m_inputRasterPtr, te::rst::BandProperty::m_noDataValue, te::rp::ClassifierStrategy::m_outputRasterPtr, te::rst::BandProperty::m_type, te::rst::RasterFactory::make(), and TERP_TRUE_OR_THROW.
Referenced by te::rp::ClassifierDummyStrategy::execute(), te::rp::ClassifierKMeansStrategy::execute(), te::rp::ClassifierEDStrategy::execute(), te::rp::ClassifierMAPStrategy::execute(), te::rp::ClassifierEMStrategy::execute(), execute(), and te::rp::ClassifierISOSegStrategy::execute().
|
inherited |
Enable / disable the use of multiple threads.
| enable | Enable (true) or disable (false) the use of multiple threads. |
Definition at line 80 of file ClassifierStrategy.cpp.
References te::rp::ClassifierStrategy::m_enableMultiThread.
|
inherited |
Enable (true) or disable (false) the creation of a paletted output raster.
| enabled | Enable (true) or disable (false) the creation of a paletted output raster. |
Definition at line 90 of file ClassifierStrategy.cpp.
References te::rp::ClassifierStrategy::m_createRasterPalette.
|
inherited |
Enable / disable the progress interface.
| enable | Enable (true) or disable (false) the progress interface. |
Definition at line 70 of file ClassifierStrategy.cpp.
References te::rp::ClassifierStrategy::m_progressInterfaceEnabled.
|
inherited |
Enable / disable the use of raster data cache.
| enable | Enable (true) or disable (false) the use of raster cache. |
Definition at line 75 of file ClassifierStrategy.cpp.
References te::rp::ClassifierStrategy::m_enableRasterCache.
|
virtual | |||||||||||||
Executes the classification strategy.
Implements te::rp::ClassifierStrategy.
Definition at line 181 of file ClassifierSAMStrategy.cpp.
References col, te::rp::ClassifierStrategy::createOutputRaster(), dt, te::rst::Raster::getBand(), te::rst::Raster::getNumberOfColumns(), te::rst::Raster::getNumberOfRows(), te::rst::Band::getProperty(), te::rst::Raster::getValue(), m_classesIndex2ID, m_classesMeans, m_highestTrainClassID, m_initParams, te::rp::ClassifierStrategy::m_inputRasterBands, te::rp::ClassifierStrategy::m_inputRasterPtr, m_isInitialized, te::rp::ClassifierSAMStrategy::Parameters::m_maxAngularDistances, te::rst::BandProperty::m_noDataValue, te::rp::ClassifierStrategy::m_outputRasterPtr, te::rp::ClassifierStrategy::m_progressInterfaceEnabled, nCols, te::rp::ClassifierStrategy::setOutputRasterPalette(), TERP_INSTANCE_TRUE_OR_RETURN_FALSE, and te::dt::UINT32_TYPE.
|
inherited |
Return the current error message if there is any.
Definition at line 100 of file ClassifierStrategy.cpp.
References te::rp::ClassifierStrategy::m_errorMessage.
|
inherited |
Returns strategy-dependent metadata.
| metadata | Strategy-dependent metadata. |
Definition at line 85 of file ClassifierStrategy.cpp.
References te::rp::ClassifierStrategy::m_metaData.
|
virtual | ||||||||||||||
Initialize the classification strategy.
| strategyParams | A pointer to the user given specific classification strategy parameters ou NULL if no parameters are present. |
Implements te::rp::ClassifierStrategy.
Definition at line 81 of file ClassifierSAMStrategy.cpp.
References m_classesIndex2ID, m_classesMeans, m_highestTrainClassID, m_initParams, m_isInitialized, te::rp::ClassifierSAMStrategy::Parameters::m_maxAngularDistances, te::rp::ClassifierSAMStrategy::Parameters::m_trainSamplesPtr, te::rp::ClassifierSAMStrategy::Parameters::reset(), and TERP_INSTANCE_TRUE_OR_RETURN_FALSE.
|
inherited |
Returns a pointer to the output raster or a void pointer if there is none.
Definition at line 60 of file ClassifierStrategy.cpp.
References te::rp::ClassifierStrategy::m_outputRasterPtr.
|
protectedvirtualinherited |
Reset to an initial state.
Definition at line 185 of file ClassifierStrategy.cpp.
References te::rp::ClassifierStrategy::m_createRasterPalette, te::rp::ClassifierStrategy::m_enableMultiThread, te::rp::ClassifierStrategy::m_enableRasterCache, te::rp::ClassifierStrategy::m_errorMessage, te::rp::ClassifierStrategy::m_inputPolygonsPtr, te::rp::ClassifierStrategy::m_inputRasterBands, te::rp::ClassifierStrategy::m_inputRasterPtr, te::rp::ClassifierStrategy::m_metaData, te::rp::ClassifierStrategy::m_outputRasterPtr, te::rp::ClassifierStrategy::m_progressInterfaceEnabled, and te::rp::ClassifierStrategy::m_userOutputPalette.
Referenced by te::rp::ClassifierStrategy::ClassifierStrategy(), and te::rp::ClassifierStrategy::operator=().
|
protectedinherited |
Set the current error message.
| newErrorMessage | New error message; |
Definition at line 180 of file ClassifierStrategy.cpp.
References te::rp::ClassifierStrategy::m_errorMessage.
|
inherited |
Set the input polygons.
| polygonsPtrs | Input polygons pointers. |
Definition at line 65 of file ClassifierStrategy.cpp.
References te::rp::ClassifierStrategy::m_inputPolygonsPtr.
|
inherited |
Set the input raster.
| raster | Input raster. |
Definition at line 50 of file ClassifierStrategy.cpp.
References te::rp::ClassifierStrategy::m_inputRasterPtr.
|
inherited |
Set the input raste bandsr.
| rasterBands | Input raster bands. |
Definition at line 55 of file ClassifierStrategy.cpp.
References te::rp::ClassifierStrategy::m_inputRasterBands.
|
protectedinherited |
Create and set the output raster palette folowing the current internal settings.
| size | Palette size. |
Definition at line 145 of file ClassifierStrategy.cpp.
References te::rp::CreateFixedStepPalette(), te::rp::ClassifierStrategy::m_createRasterPalette, te::rp::ClassifierStrategy::m_outputRasterPtr, te::rp::ClassifierStrategy::m_userOutputPalette, te::rst::PaletteIdxCInt, and te::rst::RGBPalInt.
Referenced by te::rp::ClassifierDummyStrategy::execute(), te::rp::ClassifierKMeansStrategy::execute(), te::rp::ClassifierEDStrategy::execute(), te::rp::ClassifierMAPStrategy::execute(), te::rp::ClassifierEMStrategy::execute(), execute(), and te::rp::ClassifierISOSegStrategy::execute().
|
inherited |
Set the output user palette.
| userPalette | User output raster palette (it must be large enough to accomodate all classifyier generated classes or an empty vector to automatically generate an random palette. |
Definition at line 95 of file ClassifierStrategy.cpp.
References te::rp::ClassifierStrategy::m_userOutputPalette.
|
protected |
An class index ordered vector of classes IDs;.
Definition at line 116 of file ClassifierSAMStrategy.h.
Referenced by execute(), and initialize().
|
protected |
Classes means.
Definition at line 114 of file ClassifierSAMStrategy.h.
Referenced by execute(), and initialize().
|
protectedinherited |
Enable (true) or disable (false) the creation of a paletted output raster.
Definition at line 164 of file ClassifierStrategy.h.
Referenced by te::rp::ClassifierStrategy::enableOutputPalette(), te::rp::ClassifierStrategy::reset(), and te::rp::ClassifierStrategy::setOutputRasterPalette().
|
protectedinherited |
Enable or disable the use multipe threads.
Definition at line 159 of file ClassifierStrategy.h.
Referenced by te::rp::ClassifierStrategy::enableMultiThread(), te::rp::ClassifierISOSegStrategy::execute(), and te::rp::ClassifierStrategy::reset().
|
protectedinherited |
Enable or disable the use a raster data cache.
Definition at line 154 of file ClassifierStrategy.h.
Referenced by te::rp::ClassifierStrategy::enableRasterCache(), te::rp::ClassifierISOSegStrategy::execute(), and te::rp::ClassifierStrategy::reset().
|
protected |
Definition at line 110 of file ClassifierSAMStrategy.h.
Referenced by ClassifierSAMStrategy(), execute(), and initialize().
|
protected |
Initialization parameters.
Definition at line 112 of file ClassifierSAMStrategy.h.
Referenced by execute(), and initialize().
|
protectedinherited |
Input polygons.
Definition at line 179 of file ClassifierStrategy.h.
Referenced by te::rp::ClassifierDummyStrategy::execute(), te::rp::ClassifierISOSegStrategy::execute(), te::rp::ClassifierStrategy::reset(), and te::rp::ClassifierStrategy::setInputPolygons().
|
protectedinherited |
Input raster bands.
Definition at line 174 of file ClassifierStrategy.h.
Referenced by te::rp::ClassifierStrategy::createOutputRaster(), te::rp::ClassifierKMeansStrategy::execute(), te::rp::ClassifierEDStrategy::execute(), te::rp::ClassifierEMStrategy::execute(), te::rp::ClassifierMAPStrategy::execute(), execute(), te::rp::ClassifierISOSegStrategy::execute(), te::rp::ClassifierStrategy::reset(), and te::rp::ClassifierStrategy::setInputRasterBands().
|
protectedinherited |
A pointer to the input raster.
Definition at line 144 of file ClassifierStrategy.h.
Referenced by te::rp::ClassifierStrategy::createOutputRaster(), te::rp::ClassifierKMeansStrategy::execute(), te::rp::ClassifierEDStrategy::execute(), te::rp::ClassifierEMStrategy::execute(), te::rp::ClassifierMAPStrategy::execute(), execute(), te::rp::ClassifierISOSegStrategy::execute(), te::rp::ClassifierStrategy::reset(), and te::rp::ClassifierStrategy::setInputRaster().
|
protected |
Is this instance initialized?
Definition at line 108 of file ClassifierSAMStrategy.h.
Referenced by ClassifierSAMStrategy(), execute(), and initialize().
|
protectedinherited |
Strategy-dependent metadata.
Definition at line 184 of file ClassifierStrategy.h.
Referenced by te::rp::ClassifierStrategy::getMetaData(), and te::rp::ClassifierStrategy::reset().
|
protectedinherited |
A pointer to the output raster.
Definition at line 169 of file ClassifierStrategy.h.
Referenced by te::rp::ClassifierStrategy::createOutputRaster(), te::rp::ClassifierDummyStrategy::execute(), te::rp::ClassifierKMeansStrategy::execute(), te::rp::ClassifierEDStrategy::execute(), te::rp::ClassifierEMStrategy::execute(), te::rp::ClassifierMAPStrategy::execute(), execute(), te::rp::ClassifierISOSegStrategy::execute(), te::rp::ClassifierStrategy::releaseOutputRaster(), te::rp::ClassifierStrategy::reset(), and te::rp::ClassifierStrategy::setOutputRasterPalette().
|
protectedinherited |
Progress interface status.
Definition at line 149 of file ClassifierStrategy.h.
Referenced by te::rp::ClassifierStrategy::enableProgressInterface(), te::rp::ClassifierEDStrategy::execute(), te::rp::ClassifierMAPStrategy::execute(), execute(), te::rp::ClassifierISOSegStrategy::execute(), and te::rp::ClassifierStrategy::reset().
|
protectedinherited |
User output raster palette (it must be large enough to accomodate all classifyier generated classes or an empty vector to automatically generate an random palette.
Definition at line 189 of file ClassifierStrategy.h.
Referenced by te::rp::ClassifierStrategy::reset(), te::rp::ClassifierStrategy::setOutputRasterPalette(), and te::rp::ClassifierStrategy::setUserOutputPalette().