Medical Imaging Interaction Toolkit
2023.12.00
Medical Imaging Interaction Toolkit
|
#include <mitkAbstractGlobalImageFeature.h>
Public Types | |
typedef std::vector< std::pair< FeatureID, double > > | FeatureListType |
using | ParametersType = FeatureID::ParametersType |
![]() | |
typedef BaseData | Self |
typedef itk::DataObject | Superclass |
typedef itk::SmartPointer< Self > | Pointer |
typedef itk::SmartPointer< const Self > | ConstPointer |
![]() | |
using | UIDType = std::string |
Public Member Functions | |
mitkClassMacro (AbstractGlobalImageFeature, BaseData) | |
FeatureListType | CalculateFeatures (const Image *image, const Image *mask) |
Calculates the feature of this abstact interface. Does not necessarily considers the parameter settings. More... | |
virtual FeatureListType | CalculateFeatures (const Image *image, const Image *mask, const Image *maskNoNAN)=0 |
FeatureListType | CalculateFeaturesSlicewise (const Image::Pointer &image, const Image::Pointer &mask, int sliceID) |
Calculates the given feature Slice-wise. Might not be availble for an individual filter! More... | |
virtual void | CalculateAndAppendFeaturesSliceWise (const Image::Pointer &image, const Image::Pointer &mask, int sliceID, FeatureListType &featureList, bool checkParameterActivation=true) |
Calculates the feature of this abstact interface. Does not necessarily considers the parameter settings. More... | |
void | CalculateAndAppendFeatures (const Image *image, const Image *mask, const Image *maskNoNaN, FeatureListType &featureList, bool checkParameterActivation=true) |
Calculates the feature of this abstact interface. Does not necessarily considers the parameter settings. More... | |
virtual void | SetPrefix (std::string _arg) |
virtual void | SetShortName (std::string _arg) |
virtual void | SetLongName (std::string _arg) |
virtual void | SetFeatureClassName (std::string _arg) |
virtual void | SetDirection (int _arg) |
void | SetParameters (ParametersType param) |
virtual std::string | GetPrefix () const |
virtual std::string | GetShortName () const |
virtual std::string | GetLongName () const |
virtual std::string | GetFeatureClassName () const |
virtual ParametersType | GetParameters () const |
virtual IntensityQuantifier::Pointer | GetQuantifier () |
virtual int | GetDirection () const |
virtual void | SetMinimumIntensity (double _arg) |
virtual void | SetUseMinimumIntensity (bool _arg) |
virtual void | SetMaximumIntensity (double _arg) |
virtual void | SetUseMaximumIntensity (bool _arg) |
virtual double | GetMinimumIntensity () const |
virtual bool | GetUseMinimumIntensity () const |
virtual double | GetMaximumIntensity () const |
virtual bool | GetUseMaximumIntensity () const |
virtual void | SetBinsize (double _arg) |
virtual void | SetUseBinsize (bool _arg) |
virtual double | GetBinsize () const |
virtual bool | GetUseBinsize () const |
virtual void | SetMorphMask (mitk::Image::Pointer _arg) |
virtual mitk::Image::Pointer | GetMorphMask () const |
virtual void | SetBins (int _arg) |
virtual void | SetUseBins (bool _arg) |
virtual bool | GetUseBins () const |
virtual int | GetBins () const |
virtual void | SetIgnoreMask (bool _arg) |
virtual bool | GetIgnoreMask () const |
virtual void | SetEncodeParametersInFeaturePrefix (bool _arg) |
virtual bool | GetEncodeParametersInFeaturePrefix () const |
virtual void | EncodeParametersInFeaturePrefixOn () |
virtual void | EncodeParametersInFeaturePrefixOff () |
std::string | GetOptionPrefix () const |
virtual void | AddArguments (mitkCommandLineParser &parser) const =0 |
void | SetRequestedRegionToLargestPossibleRegion () override |
Set the RequestedRegion to the LargestPossibleRegion. More... | |
bool | RequestedRegionIsOutsideOfTheBufferedRegion () override |
Determine whether the RequestedRegion is outside of the BufferedRegion. More... | |
bool | VerifyRequestedRegion () override |
Verify that the RequestedRegion is within the LargestPossibleRegion. More... | |
void | SetRequestedRegion (const itk::DataObject *) override |
Set the requested region from this data object to match the requested region of the data object passed in as a parameter. More... | |
bool | IsEmpty () const override |
Check whether object contains data (at least at one point in time), e.g., a set of points may be empty. More... | |
![]() | |
virtual std::vector< std::string > | GetClassHierarchy () const |
virtual const char * | GetClassName () const |
BaseProperty::ConstPointer | GetConstProperty (const std::string &propertyKey, const std::string &contextName="", bool fallBackOnDefaultContext=true) const override |
Get property by its key. More... | |
std::vector< std::string > | GetPropertyKeys (const std::string &contextName="", bool includeDefaultContext=false) const override |
Query keys of existing properties. More... | |
std::vector< std::string > | GetPropertyContextNames () const override |
Query names of existing contexts. More... | |
BaseProperty * | GetNonConstProperty (const std::string &propertyKey, const std::string &contextName="", bool fallBackOnDefaultContext=true) override |
Get property by its key. More... | |
void | SetProperty (const std::string &propertyKey, BaseProperty *property, const std::string &contextName="", bool fallBackOnDefaultContext=false) override |
Add new or change existent property. More... | |
void | RemoveProperty (const std::string &propertyKey, const std::string &contextName="", bool fallBackOnDefaultContext=false) override |
Removes a property. If the property does not exist, nothing will be done. More... | |
const mitk::TimeGeometry * | GetTimeGeometry () const |
Return the TimeGeometry of the data as const pointer. More... | |
mitk::TimeGeometry * | GetTimeGeometry () |
Return the TimeGeometry of the data as pointer. More... | |
const mitk::TimeGeometry * | GetUpdatedTimeGeometry () |
Return the TimeGeometry of the data. More... | |
virtual void | Expand (unsigned int timeSteps) |
Expands the TimeGeometry to a number of TimeSteps. More... | |
const mitk::BaseGeometry * | GetUpdatedGeometry (int t=0) |
Return the BaseGeometry of the data at time t. More... | |
mitk::BaseGeometry * | GetGeometry (int t=0) const |
Return the geometry, which is a TimeGeometry, of the data as non-const pointer. More... | |
void | UpdateOutputInformation () override |
Update the information for this BaseData (the geometry in particular) so that it can be used as an output of a BaseProcess. More... | |
void | CopyInformation (const itk::DataObject *data) override |
Copy information from the specified data set. More... | |
virtual bool | IsInitialized () const |
Check whether the data has been initialized, i.e., at least the Geometry and other header data has been set. More... | |
virtual void | Clear () |
Calls ClearData() and InitializeEmpty();. More... | |
virtual bool | IsEmptyTimeStep (unsigned int t) const |
Check whether object contains data (at a specified time), e.g., a set of points may be empty. More... | |
void | ExecuteOperation (Operation *operation) override |
overwrite if the Data can be called by an Interactor (StateMachine). More... | |
virtual void | SetGeometry (BaseGeometry *aGeometry3D) |
Set the BaseGeometry of the data, which will be referenced (not copied!). Assumes the data object has only 1 time step ( is a 3D object ) and creates a new TimeGeometry which saves the given BaseGeometry. If an TimeGeometry has already been set for the object, it will be replaced after calling this function. More... | |
virtual void | SetTimeGeometry (TimeGeometry *geometry) |
Set the TimeGeometry of the data, which will be referenced (not copied!). More... | |
virtual void | SetClonedGeometry (const BaseGeometry *aGeometry3D) |
Set a clone of the provided Geometry as Geometry of the data. Assumes the data object has only 1 time step ( is a 3D object ) and creates a new TimeGeometry. If an TimeGeometry has already been set for the object, it will be replaced after calling this function. More... | |
virtual void | SetClonedTimeGeometry (const TimeGeometry *geometry) |
Set a clone of the provided TimeGeometry as TimeGeometry of the data. More... | |
virtual void | SetClonedGeometry (const BaseGeometry *aGeometry3D, unsigned int time) |
Set a clone of the provided geometry as BaseGeometry of a given time step. More... | |
mitk::PropertyList::Pointer | GetPropertyList () const |
Get the data's property list. More... | |
void | SetPropertyList (PropertyList *propertyList) |
Set the data's property list. More... | |
mitk::BaseProperty::Pointer | GetProperty (const char *propertyKey) const |
Get the property (instance of BaseProperty) with key propertyKey from the PropertyList, and set it to this, respectively;. More... | |
void | SetProperty (const char *propertyKey, BaseProperty *property) |
virtual void | SetOrigin (const Point3D &origin) |
Convenience method for setting the origin of the BaseGeometry instances of all time steps. More... | |
itk::SmartPointer< mitk::BaseDataSource > | GetSource () const |
Get the process object that generated this data object. More... | |
unsigned int | GetTimeSteps () const |
Get the number of time steps from the TimeGeometry As the base data has not a data vector given by itself, the number of time steps is defined over the time sliced geometry. In sub classes, a better implementation could be over the length of the data vector. More... | |
itk::ModifiedTimeType | GetMTime () const override |
Get the modified time of the last change of the contents this data object or its geometry. More... | |
void | Graft (const DataObject *) override |
![]() | |
itkTypeMacroNoParent (OperationActor) virtual ~OperationActor() | |
![]() | |
Identifiable () | |
Identifiable (const UIDType &uid) | |
Identifiable (const Identifiable &)=delete | |
Identifiable (Identifiable &&) noexcept | |
virtual | ~Identifiable () |
Identifiable & | operator= (const Identifiable &)=delete |
Identifiable & | operator= (Identifiable &&other) noexcept |
virtual UIDType | GetUID () const |
Get unique ID of an object. More... | |
![]() | |
~IPropertyOwner () override | |
![]() | |
virtual | ~IPropertyProvider () |
Static Public Member Functions | |
static std::string | GenerateLegacyFeatureNameWOEncoding (const FeatureID &id) |
![]() | |
static const char * | GetStaticNameOfClass () |
Protected Member Functions | |
std::vector< double > | SplitDouble (std::string str, char delimiter) |
virtual FeatureListType | DoCalculateFeatures (const Image *image, const Image *mask)=0 |
void | AddQuantifierArguments (mitkCommandLineParser &parser) const |
void | ConfigureQuantifierSettingsByParameters () |
virtual void | ConfigureSettingsByParameters (const ParametersType ¶meters) |
void | InitializeQuantifier (const Image *image, const Image *mask, unsigned int defaultBins=256) |
std::string | QuantifierParameterString () const |
FeatureID | CreateTemplateFeatureID (std::string settingsSuffix="", FeatureID::ParametersType additionalParams={}) |
virtual std::string | GenerateLegacyFeatureName (const FeatureID &id) const |
virtual std::string | GenerateLegacyFeatureNamePart (const FeatureID &id) const |
virtual std::string | GenerateLegacyFeatureEncoding (const FeatureID &id) const |
![]() | |
BaseData () | |
BaseData (const BaseData &other) | |
~BaseData () override | |
virtual void | InitializeTimeGeometry (unsigned int timeSteps=1) |
Initialize the TimeGeometry for a number of time steps. The TimeGeometry is initialized empty and evenly timed. In many cases it will be necessary to overwrite this in sub-classes. More... | |
virtual void | ClearData () |
reset to non-initialized state, release memory More... | |
virtual void | InitializeEmpty () |
Pure virtual; Must be used in subclasses to get a data object to a valid state. Should at least create one empty object and call Superclass::InitializeTimeGeometry() to ensure an existing valid geometry. More... | |
void | PrintSelf (std::ostream &os, itk::Indent indent) const override |
![]() | |
virtual void | SetUID (const UIDType &uid) |
Additional Inherited Members | |
![]() | |
bool | m_LastRequestedRegionWasOutsideOfTheBufferedRegion |
unsigned int | m_SourceOutputIndexDuplicate |
bool | m_Initialized |
Most Feature Generation Classes that use histograms use the same parameters and initialization logic. In general, all information can be passed either by the corresponding Setter (which does not differenciate between global setting and feature specific setting) and a parameter object which can be obtained from the command line arguments, for example.
If the image values are used for the initializiation of the histogram, it can be defined whether the whole image is used or only the masked areas to find minima and maxima. This is done by the option SetIgnoreMask or the corrsponding options -NAME::ignore-mask-for-histogram and -ignore-mask-for-histogram. If these are true, the whole image is used for the calculation.
Depending on the passed arguments, different initialization methods are used. The initialization is in the following order:
There are generally two options to set a parameter via the command line. A global one that works for all filters that use histograms and a local one that set this parameter specific for this filter. The local parameters start with the filter name (Indiciated by NAME) followed by two colons, for example vol::min to set the minimum intensity for the volume filter. The global parameter is overwritten by the local parameter, if it is specified. Otherwise, it is still valid. If this prevents the specification of an histogram initialization method (for example, because the binsize is globally specified but the histogram should be initialized using a fixed numbe of bins), the parameter NAME::ignore-global-histogram can be passed. Then, all global histogram parameters are ignored and only local ones are used.
The maximum intensity can be set by different command line parameters: global for all filters that use histograms by -minimum-intensity and -minimum. Alternative it can be set only for this filter by -NAME::minimum and -NAME::min.
The minimum intensity can be set by different command line parameters: global for all filters that use histograms by -maximum-intensity and -maximum. Alternative it can be set only for this filter by -NAME::maximum and -NAME::max.
The binsize can be set by different command line parameters: global for all filters that use histograms by -binsize. Alternative it can be set only for this filter by -NAME::binsize.
The number of bins can be set by different command line parameters: global for all filters that use histograms by -bins. Alternative it can be set only for this filter by -NAME::bins.
All features are supposed to work the same way if a histogram is used somewhere in the code. For this, each derived class that makes use of a histogram should use the Quantifier object. In order to use this object correctly, the AddArguments-Function should contain the line AddQuantifierArguments(parser);, the CalculateFeaturesUsingParameters function should contain the line InitializeQuantifierFromParameters(feature, mask); and the CalculateFeatures function sould contain the line InitializeQuantifier(image, mask);. These function calls ensure that the necessary options are given to the configuration file, and that the initialization of the quantifier is done correctly. This ensures an consistend behavior over all FeatureGeneration Classes.
Definition at line 151 of file mitkAbstractGlobalImageFeature.h.
typedef std::vector< std::pair<FeatureID, double> > mitk::AbstractGlobalImageFeature::FeatureListType |
Definition at line 156 of file mitkAbstractGlobalImageFeature.h.
Definition at line 157 of file mitkAbstractGlobalImageFeature.h.
|
pure virtual |
Can be called to add all relevant argument for configuring the feature instance to the passed parser instance. Must be implemented be derived classes. For adding the quantifier arguments use AddQuantifierArguments(...) as helper function.
Implemented in mitk::GIFGreyLevelDistanceZone, mitk::GIFCooccurenceMatrix2, mitk::GIFFirstOrderNumericStatistics, mitk::GIFFirstOrderStatistics, mitk::GIFNeighbouringGreyLevelDependenceFeature, mitk::GIFVolumetricStatistics, mitk::GIFVolumetricDensityStatistics, mitk::GIFGreyLevelRunLength, mitk::GIFGreyLevelSizeZone, mitk::GIFFirstOrderHistogramStatistics, mitk::GIFCurvatureStatistic, mitk::GIFNeighbourhoodGreyToneDifferenceFeatures, mitk::GIFImageDescriptionFeatures, mitk::GIFIntensityVolumeHistogramFeatures, mitk::GIFLocalIntensity, mitk::GIFCooccurenceMatrix, and mitk::GIFNeighbourhoodGreyLevelDifference.
|
protected |
void mitk::AbstractGlobalImageFeature::CalculateAndAppendFeatures | ( | const Image * | image, |
const Image * | mask, | ||
const Image * | maskNoNaN, | ||
FeatureListType & | featureList, | ||
bool | checkParameterActivation = true |
||
) |
Calculates the feature of this abstact interface. Does not necessarily considers the parameter settings.
image | |
mask | |
maskNoNaN | |
featureList | |
checkParameterActivation | Indicates if the features should only be calculated and added if the FeatureClass is activated in the parameters. True: only append if activated in the parametes. False: always and append it. |
|
virtual |
Calculates the feature of this abstact interface. Does not necessarily considers the parameter settings.
FeatureListType mitk::AbstractGlobalImageFeature::CalculateFeatures | ( | const Image * | image, |
const Image * | mask | ||
) |
Calculates the feature of this abstact interface. Does not necessarily considers the parameter settings.
|
pure virtual |
Implemented in mitk::GIFGreyLevelDistanceZone, mitk::GIFCooccurenceMatrix2, mitk::GIFFirstOrderNumericStatistics, mitk::GIFFirstOrderStatistics, mitk::GIFNeighbouringGreyLevelDependenceFeature, mitk::GIFVolumetricStatistics, mitk::GIFVolumetricDensityStatistics, mitk::GIFGreyLevelRunLength, mitk::GIFGreyLevelSizeZone, mitk::GIFFirstOrderHistogramStatistics, mitk::GIFCurvatureStatistic, mitk::GIFNeighbourhoodGreyToneDifferenceFeatures, mitk::GIFImageDescriptionFeatures, mitk::GIFIntensityVolumeHistogramFeatures, mitk::GIFLocalIntensity, mitk::GIFCooccurenceMatrix, and mitk::GIFNeighbourhoodGreyLevelDifference.
FeatureListType mitk::AbstractGlobalImageFeature::CalculateFeaturesSlicewise | ( | const Image::Pointer & | image, |
const Image::Pointer & | mask, | ||
int | sliceID | ||
) |
Calculates the given feature Slice-wise. Might not be availble for an individual filter!
|
protected |
Ensures that all quantifier relevant variables of the instance are set correctly given the information in m_Parameters.
|
protectedvirtual |
Ensures that the instance is configured according to the information given in the passed parameters. This method will be called by SetParameters(...) after ConfigureQuantifierSettingsByParameters() was called.
Reimplemented in mitk::GIFCooccurenceMatrix2, mitk::GIFNeighbouringGreyLevelDependenceFeature, mitk::GIFNeighbourhoodGreyToneDifferenceFeatures, mitk::GIFLocalIntensity, mitk::GIFCooccurenceMatrix, and mitk::GIFNeighbourhoodGreyLevelDifference.
|
protected |
|
protectedpure virtual |
Implemented in mitk::GIFGreyLevelDistanceZone, mitk::GIFCooccurenceMatrix2, mitk::GIFFirstOrderNumericStatistics, mitk::GIFFirstOrderStatistics, mitk::GIFNeighbouringGreyLevelDependenceFeature, mitk::GIFVolumetricStatistics, mitk::GIFVolumetricDensityStatistics, mitk::GIFGreyLevelRunLength, mitk::GIFGreyLevelSizeZone, mitk::GIFFirstOrderHistogramStatistics, mitk::GIFCurvatureStatistic, mitk::GIFNeighbourhoodGreyToneDifferenceFeatures, mitk::GIFImageDescriptionFeatures, mitk::GIFIntensityVolumeHistogramFeatures, mitk::GIFLocalIntensity, mitk::GIFCooccurenceMatrix, and mitk::GIFNeighbourhoodGreyLevelDifference.
|
virtual |
|
virtual |
|
protectedvirtual |
|
protectedvirtual |
Helper that generates the legacy feature names for a passed FeatureID. Format of the legacy feature name is: <ClassName>::[<LegacyFeatureEncoding>::]<LegacyFeatureNamePart> Overwrite GenerateLegacyFeatureNamePart and GenerateLegacyFeatureEncoding to change behavior in derived classes.
Reimplemented in mitk::GIFNeighbourhoodGreyLevelDifference.
|
protectedvirtual |
Reimplemented in mitk::GIFCooccurenceMatrix.
|
static |
Helper function that generates the legacy feature name without encoding of parameters; as it is used e.g. in the unit tests.
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
inline |
Definition at line 240 of file mitkAbstractGlobalImageFeature.h.
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
protected |
Initializes the quantifier gigen the quantifier relevant variables and the passed arguments.
|
inlineoverridevirtual |
Check whether object contains data (at least at one point in time), e.g., a set of points may be empty.
Reimplemented from mitk::BaseData.
Definition at line 300 of file mitkAbstractGlobalImageFeature.h.
mitk::AbstractGlobalImageFeature::mitkClassMacro | ( | AbstractGlobalImageFeature | , |
BaseData | |||
) |
|
protected |
Helper that encodes the quantifier parameters in a string (e.g. used for the legacy feature name)
|
inlineoverridevirtual |
Determine whether the RequestedRegion is outside of the BufferedRegion.
This method returns true if the RequestedRegion is outside the BufferedRegion (true if at least one pixel is outside). This is used by the pipeline mechanism to determine whether a filter needs to re-execute in order to satisfy the current request. If the current RequestedRegion is already inside the BufferedRegion from the previous execution (and the current filter is up to date), then a given filter does not need to re-execute
Implements mitk::BaseData.
Definition at line 295 of file mitkAbstractGlobalImageFeature.h.
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
inline |
Definition at line 192 of file mitkAbstractGlobalImageFeature.h.
|
virtual |
|
inlineoverridevirtual |
Set the requested region from this data object to match the requested region of the data object passed in as a parameter.
This method is implemented in the concrete subclasses of BaseData.
Implements mitk::BaseData.
Definition at line 297 of file mitkAbstractGlobalImageFeature.h.
|
inlineoverridevirtual |
Set the RequestedRegion to the LargestPossibleRegion.
This forces a filter to produce all of the output in one execution (i.e. not streaming) on the next call to Update().
Implements mitk::BaseData.
Definition at line 294 of file mitkAbstractGlobalImageFeature.h.
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
virtual |
|
protected |
|
inlineoverridevirtual |
Verify that the RequestedRegion is within the LargestPossibleRegion.
If the RequestedRegion is not within the LargestPossibleRegion, then the filter cannot possibly satisfy the request. This method returns true if the request can be satisfied (even if it will be necessary to process the entire LargestPossibleRegion) and returns false otherwise. This method is used by PropagateRequestedRegion(). PropagateRequestedRegion() throws a InvalidRequestedRegionError exception if the requested region is not within the LargestPossibleRegion.
Implements mitk::BaseData.
Definition at line 296 of file mitkAbstractGlobalImageFeature.h.