Class SpectrumFilter
- java.lang.Object
-
- weka.filters.Filter
-
- weka.filters.SimpleFilter
-
- weka.filters.SimpleBatchFilter
-
- weka.filters.unsupervised.attribute.SpectrumFilter
-
- All Implemented Interfaces:
Serializable,weka.core.CapabilitiesHandler,weka.core.CapabilitiesIgnorer,weka.core.CommandlineRunnable,weka.core.OptionHandler,weka.core.RevisionHandler
public class SpectrumFilter extends weka.filters.SimpleBatchFilterA meta-filter that applies the base filter only to the spectral part of the dataset, i.e., attributes starting with 'amplitude-'. Valid options are:-output-debug-info If set, filter is run in debug mode and may output additional info to the console
-do-not-check-capabilities If set, filter capabilities are not checked before filter is built (use with caution).
-prefix-old <att. prefix> The old prefix to look for. (default: amplitude-)
-prefix-new <att. prefix> The new prefix to look use. (default: amplitude-)
-filter <classname + options> The base filter to apply to the spectral part. (default: weka.filters.AllFilter)
-keep-attribute-names Whether to keep the attribute names generated by the base filter. Only disambiguates them if necessary. (default: false)
- Version:
- $Revision: 2347 $
- Author:
- fracpete (fracpete at waikato dot ac dot nz)
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description protected weka.filters.Filterm_Filterthe base filter.protected booleanm_KeepAttributeNameswhether to keep the attribute names generated by the base filter.protected weka.filters.MultiFilterm_MultiFilterthe multi-filter that does the actual work.protected Stringm_PrefixNewthe new prefix.protected Stringm_PrefixOldthe old prefix.static StringPREFIX_AMPLITUDEthe prefix for a spectral attribute.
-
Constructor Summary
Constructors Constructor Description SpectrumFilter()
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description protected weka.core.InstancescreateHeader(weka.core.Instances original, weka.core.Instances transformed)Creates a new header based on the input data and the transformed spectral part.protected weka.core.InstancesdetermineOutputFormat(weka.core.Instances inputFormat)Determines the output format based on the input format and returns this.protected StringdisambiguateAttributeName(String current, HashSet<String> names)Disambiguates the attribute.StringfilterTipText()Returns the tip text for this property.weka.core.CapabilitiesgetCapabilities()Returns the Capabilities of this filter.weka.filters.FiltergetFilter()Returns the base filter.booleangetKeepAttributeNames()Returns whether to keep the attribute names generated by the base filter.String[]getOptions()Gets the current settings of the filter.StringgetPrefixNew()Returns the (new) attribute prefix to use.StringgetPrefixOld()Returns the (old) attribute prefix to look for.StringgetRevision()Returns the revision string.StringglobalInfo()Returns a string describing this classifier.StringkeepAttributeNamesTipText()Returns the tip text for this property.EnumerationlistOptions()Returns an enumeration describing the available options.static voidmain(String[] args)Main method for testing this class.StringprefixNewTipText()Returns the tip text for this property.StringprefixOldTipText()Returns the tip text for this property.protected weka.core.Instancesprocess(weka.core.Instances instances)processes the given instances (may change the provided instances) and returns the modified version.voidsetFilter(weka.filters.Filter value)Sets the base filter.voidsetKeepAttributeNames(boolean value)Sets whether to keep the attribute names generated by the base filter.voidsetOptions(String[] options)Parses a list of options for this object.voidsetPrefixNew(String value)Sets the (new) attribute prefix to use.voidsetPrefixOld(String value)Sets the (old) attribute prefix to look for.protected weka.core.InstancetransformInstance(weka.core.Instances header, weka.core.Instance inst)Transforms the instance (filters spectral part and adds all other data again).protected weka.core.InstancestransformSpectrum(weka.core.Instances instances)Transforms the spectral data.-
Methods inherited from class weka.filters.SimpleBatchFilter
allowAccessToFullInputFormat, batchFinished, hasImmediateOutputFormat, input
-
Methods inherited from class weka.filters.Filter
batchFilterFile, bufferInput, copyValues, copyValues, debugTipText, doNotCheckCapabilitiesTipText, filterFile, flushInput, getCapabilities, getDebug, getDoNotCheckCapabilities, getInputFormat, getOutputFormat, initInputLocators, initOutputLocators, inputFormatPeek, isFirstBatchDone, isNewBatch, isOutputFormatDefined, makeCopies, makeCopy, mayRemoveInstanceAfterFirstBatchDone, numPendingOutput, output, outputFormatPeek, outputPeek, postExecution, preExecution, push, push, resetQueue, run, runFilter, setDebug, setDoNotCheckCapabilities, setOutputFormat, testInputFormat, toString, useFilter, wekaStaticWrapper
-
-
-
-
Field Detail
-
PREFIX_AMPLITUDE
public static final String PREFIX_AMPLITUDE
the prefix for a spectral attribute.- See Also:
- Constant Field Values
-
m_Filter
protected weka.filters.Filter m_Filter
the base filter.
-
m_PrefixOld
protected String m_PrefixOld
the old prefix.
-
m_PrefixNew
protected String m_PrefixNew
the new prefix.
-
m_KeepAttributeNames
protected boolean m_KeepAttributeNames
whether to keep the attribute names generated by the base filter.
-
m_MultiFilter
protected weka.filters.MultiFilter m_MultiFilter
the multi-filter that does the actual work.
-
-
Method Detail
-
globalInfo
public String globalInfo()
Returns a string describing this classifier.- Specified by:
globalInfoin classweka.filters.SimpleFilter- Returns:
- a description of the classifier suitable for displaying in the explorer/experimenter gui
-
listOptions
public Enumeration listOptions()
Returns an enumeration describing the available options.- Specified by:
listOptionsin interfaceweka.core.OptionHandler- Overrides:
listOptionsin classweka.filters.Filter- Returns:
- an enumeration of all the available options.
-
setOptions
public void setOptions(String[] options) throws Exception
Parses a list of options for this object. Also resets the state of the filter (this reset doesn't affect the options).- Specified by:
setOptionsin interfaceweka.core.OptionHandler- Overrides:
setOptionsin classweka.filters.Filter- Parameters:
options- the list of options as an array of strings- Throws:
Exception- if an option is not supported- See Also:
SimpleFilter.reset()
-
getOptions
public String[] getOptions()
Gets the current settings of the filter.- Specified by:
getOptionsin interfaceweka.core.OptionHandler- Overrides:
getOptionsin classweka.filters.Filter- Returns:
- an array of strings suitable for passing to setOptions
-
setPrefixOld
public void setPrefixOld(String value)
Sets the (old) attribute prefix to look for.- Parameters:
value- the prefix
-
getPrefixOld
public String getPrefixOld()
Returns the (old) attribute prefix to look for.- Returns:
- the prefix
-
prefixOldTipText
public String prefixOldTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setPrefixNew
public void setPrefixNew(String value)
Sets the (new) attribute prefix to use.- Parameters:
value- the prefix
-
getPrefixNew
public String getPrefixNew()
Returns the (new) attribute prefix to use.- Returns:
- the prefix
-
prefixNewTipText
public String prefixNewTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setFilter
public void setFilter(weka.filters.Filter value)
Sets the base filter.- Parameters:
value- the base filter
-
getFilter
public weka.filters.Filter getFilter()
Returns the base filter.- Returns:
- the base filter
-
filterTipText
public String filterTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
setKeepAttributeNames
public void setKeepAttributeNames(boolean value)
Sets whether to keep the attribute names generated by the base filter.- Parameters:
value- true if to keep
-
getKeepAttributeNames
public boolean getKeepAttributeNames()
Returns whether to keep the attribute names generated by the base filter.- Returns:
- true if to keep
-
keepAttributeNamesTipText
public String keepAttributeNamesTipText()
Returns the tip text for this property.- Returns:
- tip text for this property suitable for displaying in the GUI or for listing the options.
-
getCapabilities
public weka.core.Capabilities getCapabilities()
Returns the Capabilities of this filter. Derived filters have to override this method to enable capabilities.- Specified by:
getCapabilitiesin interfaceweka.core.CapabilitiesHandler- Overrides:
getCapabilitiesin classweka.filters.Filter- Returns:
- the capabilities of this object
- See Also:
Capabilities
-
determineOutputFormat
protected weka.core.Instances determineOutputFormat(weka.core.Instances inputFormat) throws ExceptionDetermines the output format based on the input format and returns this. In case the output format cannot be returned immediately, i.e., hasImmediateOutputFormat() returns false, then this method will called from batchFinished() after the call of preprocess(Instances), in which, e.g., statistics for the actual processing step can be gathered.- Specified by:
determineOutputFormatin classweka.filters.SimpleFilter- Parameters:
inputFormat- the input format to base the output format on- Returns:
- the output format
- Throws:
Exception- in case the determination goes wrong
-
transformSpectrum
protected weka.core.Instances transformSpectrum(weka.core.Instances instances) throws ExceptionTransforms the spectral data. Also initializes the m_MultiFilter member.- Parameters:
instances- the data to transform- Returns:
- the transformed spectral part
- Throws:
Exception- in case transformation goes wrong
-
disambiguateAttributeName
protected String disambiguateAttributeName(String current, HashSet<String> names)
Disambiguates the attribute.- Parameters:
current- the current attribute to disambiguate, if necessarynames- the names collected so far
-
createHeader
protected weka.core.Instances createHeader(weka.core.Instances original, weka.core.Instances transformed)Creates a new header based on the input data and the transformed spectral part.- Parameters:
original- the original input datatransformed- the transformed spectral part of the data- Returns:
- the new header (without enough space reserved for all rows)
-
transformInstance
protected weka.core.Instance transformInstance(weka.core.Instances header, weka.core.Instance inst) throws ExceptionTransforms the instance (filters spectral part and adds all other data again).- Parameters:
header- the header to useinst- the instance to transform- Returns:
- the transformed instance
- Throws:
Exception
-
process
protected weka.core.Instances process(weka.core.Instances instances) throws Exceptionprocesses the given instances (may change the provided instances) and returns the modified version.- Specified by:
processin classweka.filters.SimpleFilter- Parameters:
instances- the instances to process- Returns:
- the modified data
- Throws:
Exception- in case the processing goes wrong
-
getRevision
public String getRevision()
Returns the revision string.- Specified by:
getRevisionin interfaceweka.core.RevisionHandler- Overrides:
getRevisionin classweka.filters.Filter- Returns:
- the revision
-
main
public static void main(String[] args)
Main method for testing this class.- Parameters:
args- should contain arguments to the filter: use -h for help
-
-