Package weka.clusterers
Class CheckClusterer
java.lang.Object
weka.core.Check
weka.core.CheckScheme
weka.clusterers.CheckClusterer
- All Implemented Interfaces:
OptionHandler
,RevisionHandler
Class for examining the capabilities and finding problems with clusterers. If
you implement a clusterer using the WEKA.libraries, you should run the checks
on it to ensure robustness and correct operation. Passing all the tests of
this object does not mean bugs in the clusterer don't exist, but this will
help find some common ones.
Typical usage:
java weka.clusterers.CheckClusterer -W clusterer_name
-- clusterer_options
CheckClusterer reports on the following:
- Clusterer abilities
- Possible command line options to the clusterer
- Whether the clusterer can predict nominal, numeric, string, date or relational class attributes.
- Whether the clusterer can handle numeric predictor attributes
- Whether the clusterer can handle nominal predictor attributes
- Whether the clusterer can handle string predictor attributes
- Whether the clusterer can handle date predictor attributes
- Whether the clusterer can handle relational predictor attributes
- Whether the clusterer can handle multi-instance data
- Whether the clusterer can handle missing predictor values
- Whether the clusterer can handle instance weights
- Correct functioning
- Correct initialisation during buildClusterer (i.e. no result changes when buildClusterer called repeatedly)
- Whether the clusterer alters the data pased to it (number of instances, instance order, instance weights, etc)
- Degenerate cases
- building clusterer with zero training instances
- all but one predictor attribute values missing
- all predictor attribute values missing
- all but one class values missing
- all class values missing
weka.clusterers.AbstractClustererTest
uses this class to
test all the clusterers. Any changes here, have to be checked in that
abstract test class, too.
Valid options are:
-D Turn on debugging output.
-S Silent mode - prints nothing to stdout.
-N <num> The number of instances in the datasets (default 20).
-nominal <num> The number of nominal attributes (default 2).
-nominal-values <num> The number of values for nominal attributes (default 1).
-numeric <num> The number of numeric attributes (default 1).
-string <num> The number of string attributes (default 1).
-date <num> The number of date attributes (default 1).
-relational <num> The number of relational attributes (default 1).
-num-instances-relational <num> The number of instances in relational/bag attributes (default 10).
-words <comma-separated-list> The words to use in string attributes.
-word-separators <chars> The word separators to use in string attributes.
-W Full name of the clusterer analyzed. eg: weka.clusterers.SimpleKMeans (default weka.clusterers.SimpleKMeans)
Options specific to clusterer weka.clusterers.SimpleKMeans:
-N <num> number of clusters. (default 2).
-V Display std. deviations for centroids.
-M Replace missing values with mean/mode.
-S <num> Random number seed. (default 10)Options after -- are passed to the designated clusterer.
- Version:
- $Revision: 11451 $
- Author:
- Len Trigg (trigg@cs.waikato.ac.nz), FracPete (fracpete at waikato dot ac dot nz)
- See Also:
-
Nested Class Summary
Nested classes/interfaces inherited from class weka.core.CheckScheme
CheckScheme.PostProcessor
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
doTests()
Begin the tests, reporting results to System.outGet the clusterer used as the clustererString[]
Gets the current settings of the CheckClusterer.Returns the revision string.Returns an enumeration describing the available options.static void
Test method for this classvoid
setClusterer
(Clusterer newClusterer) Set the clusterer for testing.void
setOptions
(String[] options) Parses a given list of options.Methods inherited from class weka.core.CheckScheme
attributeTypeToString, getNumDate, getNumInstances, getNumInstancesRelational, getNumNominal, getNumNumeric, getNumRelational, getNumString, getPostProcessor, getWords, getWordSeparators, hasClasspathProblems, setNumDate, setNumInstances, setNumInstancesRelational, setNumNominal, setNumNumeric, setNumRelational, setNumString, setPostProcessor, setWords, setWordSeparators
-
Constructor Details
-
CheckClusterer
public CheckClusterer()default constructor
-
-
Method Details
-
listOptions
Returns an enumeration describing the available options.- Specified by:
listOptions
in interfaceOptionHandler
- Overrides:
listOptions
in classCheckScheme
- Returns:
- an enumeration of all the available options.
-
setOptions
Parses a given list of options. Valid options are:-D Turn on debugging output.
-S Silent mode - prints nothing to stdout.
-N <num> The number of instances in the datasets (default 20).
-nominal <num> The number of nominal attributes (default 2).
-nominal-values <num> The number of values for nominal attributes (default 1).
-numeric <num> The number of numeric attributes (default 1).
-string <num> The number of string attributes (default 1).
-date <num> The number of date attributes (default 1).
-relational <num> The number of relational attributes (default 1).
-num-instances-relational <num> The number of instances in relational/bag attributes (default 10).
-words <comma-separated-list> The words to use in string attributes.
-word-separators <chars> The word separators to use in string attributes.
-W Full name of the clusterer analyzed. eg: weka.clusterers.SimpleKMeans (default weka.clusterers.SimpleKMeans)
Options specific to clusterer weka.clusterers.SimpleKMeans:
-N <num> number of clusters. (default 2).
-V Display std. deviations for centroids.
-M Replace missing values with mean/mode.
-S <num> Random number seed. (default 10)
- Specified by:
setOptions
in interfaceOptionHandler
- Overrides:
setOptions
in classCheckScheme
- Parameters:
options
- the list of options as an array of strings- Throws:
Exception
- if an option is not supported
-
getOptions
Gets the current settings of the CheckClusterer.- Specified by:
getOptions
in interfaceOptionHandler
- Overrides:
getOptions
in classCheckScheme
- Returns:
- an array of strings suitable for passing to setOptions
-
doTests
public void doTests()Begin the tests, reporting results to System.out- Specified by:
doTests
in classCheckScheme
-
setClusterer
Set the clusterer for testing.- Parameters:
newClusterer
- the Clusterer to use.
-
getClusterer
Get the clusterer used as the clusterer- Returns:
- the clusterer used as the clusterer
-
getRevision
Returns the revision string.- Returns:
- the revision
-
main
Test method for this class- Parameters:
args
- the commandline options
-