Class RandomRBF
- java.lang.Object
-
- weka.datagenerators.DataGenerator
-
- weka.datagenerators.ClassificationGenerator
-
- weka.datagenerators.classifiers.classification.RandomRBF
-
- All Implemented Interfaces:
java.io.Serializable,OptionHandler,Randomizable,RevisionHandler
public class RandomRBF extends ClassificationGenerator
RandomRBF data is generated by first creating a random set of centers for each class. Each center is randomly assigned a weight, a central point per attribute, and a standard deviation. To generate new instances, a center is chosen at random taking the weights of each center into consideration. Attribute values are randomly generated and offset from the center, where the overall vector has been scaled so that its length equals a value sampled randomly from the Gaussian distribution of the center. The particular center chosen determines the class of the instance.
RandomRBF data contains only numeric attributes as it is non-trivial to include nominal values. Valid options are:-h Prints this help.
-o <file> The name of the output file, otherwise the generated data is printed to stdout.
-r <name> The name of the relation.
-d Whether to print debug informations.
-S The seed for random function (default 1)
-n <num> The number of examples to generate (default 100)
-a <num> The number of attributes (default 10).
-c <num> The number of classes (default 2)
-C <num> The number of centroids to use. (default 50)
- Version:
- $Revision: 1.4 $
- Author:
- Richard Kirkby (rkirkby at cs dot waikato dot ac dot nz), FracPete (fracpete at waikato dot ac dot nz)
- See Also:
- Serialized Form
-
-
Constructor Summary
Constructors Constructor Description RandomRBF()initializes the generator with default values
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description InstancesdefineDataFormat()Initializes the format for the dataset produced.InstancegenerateExample()Generates one example of the dataset.InstancesgenerateExamples()Generates all examples of the dataset.java.lang.StringgenerateFinished()Generates a comment string that documentats the data generator.java.lang.StringgenerateStart()Generates a comment string that documentates the data generator.intgetNumAttributes()Gets the number of attributes that should be produced.intgetNumCentroids()Gets the number of centroids.intgetNumClasses()Gets the number of classes the dataset should have.java.lang.String[]getOptions()Gets the current settings of the datagenerator.java.lang.StringgetRevision()Returns the revision string.booleangetSingleModeFlag()Return if single mode is set for the given data generator mode depends on option setting and or generator type.java.lang.StringglobalInfo()Returns a string describing this data generator.java.util.EnumerationlistOptions()Returns an enumeration describing the available options.static voidmain(java.lang.String[] args)Main method for executing this class.java.lang.StringnumAttributesTipText()Returns the tip text for this propertyjava.lang.StringnumCentroidsTipText()Returns the tip text for this propertyjava.lang.StringnumClassesTipText()Returns the tip text for this propertyvoidsetNumAttributes(int numAttributes)Sets the number of attributes the dataset should have.voidsetNumCentroids(int value)Sets the number of centroids to use.voidsetNumClasses(int numClasses)Sets the number of classes the dataset should have.voidsetOptions(java.lang.String[] options)Parses a list of options for this object.-
Methods inherited from class weka.datagenerators.ClassificationGenerator
getNumExamples, numExamplesTipText, setNumExamples
-
Methods inherited from class weka.datagenerators.DataGenerator
debugTipText, defaultOutput, formatTipText, getDatasetFormat, getDebug, getNumExamplesAct, getOutput, getRandom, getRelationName, getSeed, makeData, outputTipText, randomTipText, relationNameTipText, seedTipText, setDatasetFormat, setDebug, setOutput, setRandom, setRelationName, setSeed
-
-
-
-
Method Detail
-
globalInfo
public java.lang.String globalInfo()
Returns a string describing this data generator.- Returns:
- a description of the data generator suitable for displaying in the explorer/experimenter gui
-
listOptions
public java.util.Enumeration listOptions()
Returns an enumeration describing the available options.- Specified by:
listOptionsin interfaceOptionHandler- Overrides:
listOptionsin classClassificationGenerator- Returns:
- an enumeration of all the available options
-
setOptions
public void setOptions(java.lang.String[] options) throws java.lang.ExceptionParses a list of options for this object. Valid options are:-h Prints this help.
-o <file> The name of the output file, otherwise the generated data is printed to stdout.
-r <name> The name of the relation.
-d Whether to print debug informations.
-S The seed for random function (default 1)
-n <num> The number of examples to generate (default 100)
-a <num> The number of attributes (default 10).
-c <num> The number of classes (default 2)
-C <num> The number of centroids to use. (default 50)
- Specified by:
setOptionsin interfaceOptionHandler- Overrides:
setOptionsin classClassificationGenerator- Parameters:
options- the list of options as an array of strings- Throws:
java.lang.Exception- if an option is not supported
-
getOptions
public java.lang.String[] getOptions()
Gets the current settings of the datagenerator.- Specified by:
getOptionsin interfaceOptionHandler- Overrides:
getOptionsin classClassificationGenerator- Returns:
- an array of strings suitable for passing to setOptions
- See Also:
DataGenerator.removeBlacklist(String[])
-
setNumAttributes
public void setNumAttributes(int numAttributes)
Sets the number of attributes the dataset should have.- Parameters:
numAttributes- the new number of attributes
-
getNumAttributes
public int getNumAttributes()
Gets the number of attributes that should be produced.- Returns:
- the number of attributes that should be produced
-
numAttributesTipText
public java.lang.String numAttributesTipText()
Returns the tip text for this property- Returns:
- tip text for this property suitable for displaying in the explorer/experimenter gui
-
setNumClasses
public void setNumClasses(int numClasses)
Sets the number of classes the dataset should have.- Parameters:
numClasses- the new number of classes
-
getNumClasses
public int getNumClasses()
Gets the number of classes the dataset should have.- Returns:
- the number of classes the dataset should have
-
numClassesTipText
public java.lang.String numClassesTipText()
Returns the tip text for this property- Returns:
- tip text for this property suitable for displaying in the explorer/experimenter gui
-
getNumCentroids
public int getNumCentroids()
Gets the number of centroids.- Returns:
- the number of centroids.
-
setNumCentroids
public void setNumCentroids(int value)
Sets the number of centroids to use.- Parameters:
value- the number of centroids to use.
-
numCentroidsTipText
public java.lang.String numCentroidsTipText()
Returns the tip text for this property- Returns:
- tip text for this property suitable for displaying in the explorer/experimenter gui
-
getSingleModeFlag
public boolean getSingleModeFlag() throws java.lang.ExceptionReturn if single mode is set for the given data generator mode depends on option setting and or generator type.- Specified by:
getSingleModeFlagin classDataGenerator- Returns:
- single mode flag
- Throws:
java.lang.Exception- if mode is not set yet
-
defineDataFormat
public Instances defineDataFormat() throws java.lang.Exception
Initializes the format for the dataset produced. Must be called before the generateExample or generateExamples methods are used. Re-initializes the random number generator with the given seed.- Overrides:
defineDataFormatin classDataGenerator- Returns:
- the format for the dataset
- Throws:
java.lang.Exception- if the generating of the format failed- See Also:
DataGenerator.getSeed()
-
generateExample
public Instance generateExample() throws java.lang.Exception
Generates one example of the dataset.- Specified by:
generateExamplein classDataGenerator- Returns:
- the generated example
- Throws:
java.lang.Exception- if the format of the dataset is not yet definedjava.lang.Exception- if the generator only works with generateExamples which means in non single mode
-
generateExamples
public Instances generateExamples() throws java.lang.Exception
Generates all examples of the dataset. Re-initializes the random number generator with the given seed, before generating instances.- Specified by:
generateExamplesin classDataGenerator- Returns:
- the generated dataset
- Throws:
java.lang.Exception- if the format of the dataset is not yet definedjava.lang.Exception- if the generator only works with generateExample, which means in single mode- See Also:
DataGenerator.getSeed()
-
generateStart
public java.lang.String generateStart()
Generates a comment string that documentates the data generator. By default this string is added at the beginning of the produced output as ARFF file type, next after the options.- Specified by:
generateStartin classDataGenerator- Returns:
- string contains info about the generated rules
-
generateFinished
public java.lang.String generateFinished() throws java.lang.ExceptionGenerates a comment string that documentats the data generator. By default this string is added at the end of theproduces output as ARFF file type.- Specified by:
generateFinishedin classDataGenerator- Returns:
- string contains info about the generated rules
- Throws:
java.lang.Exception- if the generating of the documentaion fails
-
getRevision
public java.lang.String getRevision()
Returns the revision string.- Returns:
- the revision
-
main
public static void main(java.lang.String[] args)
Main method for executing this class.- Parameters:
args- should contain arguments for the data producer:
-
-