public abstract class Estimator extends Object implements Cloneable, Serializable, OptionHandler, CapabilitiesHandler, RevisionHandler
// create a histogram for estimation
EqualWidthEstimator est = new EqualWidthEstimator();
est.addValues(instances, attrIndex);
Example code for an incremental estimator (incremental
estimators must implement interface IncrementalEstimator)
// Create a discrete estimator that takes values 0 to 9
DiscreteEstimator newEst = new DiscreteEstimator(10, true);
// Create 50 random integers first predicting the probability of the
// value, then adding the value to the estimator
Random r = new Random(seed);
for(int i = 0; i < 50; i++) {
current = Math.abs(r.nextInt() % 10);
System.out.println(newEst);
System.out.println("Prediction for " + current
+ " = " + newEst.getProbability(current));
newEst.addValue(current, 1);
}
Example code for a main method for an estimator.
public static void main(String [] argv) {
try {
LoglikeliEstimator est = new LoglikeliEstimator();
Estimator.buildEstimator((Estimator) est, argv, false);
System.out.println(est.toString());
} catch (Exception ex) {
ex.printStackTrace();
System.out.println(ex.getMessage());
}
}
Constructor and Description |
---|
Estimator() |
Modifier and Type | Method and Description |
---|---|
void |
addValue(double data,
double weight)
Add a new data value to the current estimator.
|
void |
addValues(Instances data,
int attrIndex)
Initialize the estimator with a new dataset.
|
void |
addValues(Instances data,
int attrIndex,
double min,
double max,
double factor)
Initialize the estimator with all values of one attribute of a dataset.
|
void |
addValues(Instances data,
int attrIndex,
int classIndex,
int classValue)
Initialize the estimator using only the instance of one class.
|
void |
addValues(Instances data,
int attrIndex,
int classIndex,
int classValue,
double min,
double max)
Initialize the estimator using only the instance of one class.
|
static void |
buildEstimator(Estimator est,
Instances instances,
int attrIndex,
int classIndex,
int classValueIndex,
boolean isIncremental) |
static void |
buildEstimator(Estimator est,
String[] options,
boolean isIncremental)
Build an estimator using the options.
|
static Estimator |
clone(Estimator model)
Creates a deep copy of the given estimator using serialization.
|
String |
debugTipText()
Returns the tip text for this property
|
boolean |
equals(Object obj)
Tests whether the current estimation object is equal to another
estimation object
|
static Estimator |
forName(String name,
String[] options)
Creates a new instance of a estimatorr given it's class name and
(optional) arguments to pass to it's setOptions method.
|
Capabilities |
getCapabilities()
Returns the Capabilities of this Estimator.
|
boolean |
getDebug()
Get whether debugging is turned on.
|
String[] |
getOptions()
Gets the current settings of the Estimator.
|
abstract double |
getProbability(double data)
Get a probability estimate for a value.
|
String |
getRevision()
Returns the revision string.
|
Enumeration |
listOptions()
Returns an enumeration describing the available options.
|
static Estimator[] |
makeCopies(Estimator model,
int num)
Creates a given number of deep copies of the given estimator using serialization.
|
static Estimator |
makeCopy(Estimator model)
Creates a deep copy of the given estimator using serialization.
|
void |
setDebug(boolean debug)
Set debugging mode.
|
void |
setOptions(String[] options)
Parses a given list of options.
|
void |
testCapabilities(Instances data,
int attrIndex)
Test if the estimator can handle the data.
|
public void addValue(double data, double weight)
data
- the new data valueweight
- the weight assigned to the data valuepublic void addValues(Instances data, int attrIndex) throws Exception
data
- the dataset used to build this estimatorattrIndex
- attribute the estimator is forException
- if building of estimator goes wrongpublic void addValues(Instances data, int attrIndex, double min, double max, double factor) throws Exception
data
- the dataset used to build this estimatorattrIndex
- attribute the estimator is formin
- minimal border of rangemax
- maximal border of rangefactor
- number of instances has been reduced to that factorException
- if building of estimator goes wrongpublic void addValues(Instances data, int attrIndex, int classIndex, int classValue) throws Exception
data
- the dataset used to build this estimatorattrIndex
- attribute the estimator is forclassIndex
- index of the class attributeclassValue
- the class valueException
- if building of estimator goes wrongpublic void addValues(Instances data, int attrIndex, int classIndex, int classValue, double min, double max) throws Exception
data
- the dataset used to build this estimatorattrIndex
- attribute the estimator is forclassIndex
- index of the class attributeclassValue
- the class valuemin
- minimal value of this attributemax
- maximal value of this attributeException
- if building of estimator goes wrongpublic abstract double getProbability(double data)
data
- the value to estimate the probability ofpublic static void buildEstimator(Estimator est, String[] options, boolean isIncremental) throws Exception
est
- the estimator usedoptions
- the list of optionsisIncremental
- true if estimator is incrementalException
- if something goes wrong or the user requests help on
command optionspublic static void buildEstimator(Estimator est, Instances instances, int attrIndex, int classIndex, int classValueIndex, boolean isIncremental) throws Exception
Exception
public static Estimator clone(Estimator model) throws Exception
model
- the estimator to copyException
- if an error occurspublic static Estimator makeCopy(Estimator model) throws Exception
model
- the estimator to copyException
- if an error occurspublic static Estimator[] makeCopies(Estimator model, int num) throws Exception
model
- the estimator to copynum
- the number of estimator copies to create.Exception
- if an error occurspublic boolean equals(Object obj)
public Enumeration listOptions()
listOptions
in interface OptionHandler
public void setOptions(String[] options) throws Exception
-D
If set, estimator is run in debug mode and
may output additional info to the console.
setOptions
in interface OptionHandler
options
- the list of options as an array of stringsException
- if an option is not supportedpublic String[] getOptions()
getOptions
in interface OptionHandler
public static Estimator forName(String name, String[] options) throws Exception
name
- the fully qualified class name of the estimatorroptions
- an array of options suitable for passing to setOptions. May
be null.Exception
- if the classifier name is invalid, or the options
supplied are not acceptable to the classifierpublic void setDebug(boolean debug)
debug
- true if debug output should be printedpublic boolean getDebug()
public String debugTipText()
public Capabilities getCapabilities()
getCapabilities
in interface CapabilitiesHandler
Capabilities
public String getRevision()
getRevision
in interface RevisionHandler
public void testCapabilities(Instances data, int attrIndex) throws Exception
data
- the dataset the estimator takes an attribute fromattrIndex
- the index of the attributeException
Capabilities
Copyright © 2012 University of Waikato, Hamilton, NZ. All Rights Reserved.