Package weka.classifiers.functions
Class LinearRegression
- java.lang.Object
-
- weka.classifiers.Classifier
-
- weka.classifiers.functions.LinearRegression
-
- All Implemented Interfaces:
java.io.Serializable,java.lang.Cloneable,CapabilitiesHandler,OptionHandler,RevisionHandler,WeightedInstancesHandler
public class LinearRegression extends Classifier implements OptionHandler, WeightedInstancesHandler
Class for using linear regression for prediction. Uses the Akaike criterion for model selection, and is able to deal with weighted instances. Valid options are:-D Produce debugging output. (default no debugging output)
-S <number of selection method> Set the attribute selection method to use. 1 = None, 2 = Greedy. (default 0 = M5' method)
-C Do not try to eliminate colinear attributes.
-R <double> Set ridge parameter (default 1.0e-8).
- Version:
- $Revision: 9770 $
- Author:
- Eibe Frank (eibe@cs.waikato.ac.nz), Len Trigg (trigg@cs.waikato.ac.nz)
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description static intSELECTION_GREEDYAttribute selection method: Greedy methodstatic intSELECTION_M5Attribute selection method: M5 methodstatic intSELECTION_NONEAttribute selection method: No attribute selectionstatic Tag[]TAGS_SELECTIONAttribute selection methods
-
Constructor Summary
Constructors Constructor Description LinearRegression()
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description java.lang.StringattributeSelectionMethodTipText()Returns the tip text for this propertyvoidbuildClassifier(Instances data)Builds a regression model for the given data.doubleclassifyInstance(Instance instance)Classifies the given instance using the linear regression function.double[]coefficients()Returns the coefficients for this linear model.java.lang.StringdebugTipText()Returns the tip text for this propertyjava.lang.StringeliminateColinearAttributesTipText()Returns the tip text for this propertySelectedTaggetAttributeSelectionMethod()Gets the method used to select attributes for use in the linear regression.CapabilitiesgetCapabilities()Returns default capabilities of the classifier.booleangetDebug()Controls whether debugging output will be printedbooleangetEliminateColinearAttributes()Get the value of EliminateColinearAttributes.java.lang.String[]getOptions()Gets the current settings of the classifier.java.lang.StringgetRevision()Returns the revision string.doublegetRidge()Get the value of Ridge.java.lang.StringglobalInfo()Returns a string describing this classifierjava.util.EnumerationlistOptions()Returns an enumeration describing the available options.static voidmain(java.lang.String[] argv)Generates a linear regression function predictor.intnumParameters()Get the number of coefficients used in the modeljava.lang.StringridgeTipText()Returns the tip text for this propertyvoidsetAttributeSelectionMethod(SelectedTag method)Sets the method used to select attributes for use in the linear regression.voidsetDebug(boolean debug)Controls whether debugging output will be printedvoidsetEliminateColinearAttributes(boolean newEliminateColinearAttributes)Set the value of EliminateColinearAttributes.voidsetOptions(java.lang.String[] options)Parses a given list of options.voidsetRidge(double newRidge)Set the value of Ridge.java.lang.StringtoString()Outputs the linear regression model as a string.voidturnChecksOff()Turns off checks for missing values, etc.voidturnChecksOn()Turns on checks for missing values, etc.-
Methods inherited from class weka.classifiers.Classifier
distributionForInstance, forName, makeCopies, makeCopy
-
-
-
-
Field Detail
-
SELECTION_M5
public static final int SELECTION_M5
Attribute selection method: M5 method- See Also:
- Constant Field Values
-
SELECTION_NONE
public static final int SELECTION_NONE
Attribute selection method: No attribute selection- See Also:
- Constant Field Values
-
SELECTION_GREEDY
public static final int SELECTION_GREEDY
Attribute selection method: Greedy method- See Also:
- Constant Field Values
-
TAGS_SELECTION
public static final Tag[] TAGS_SELECTION
Attribute selection methods
-
-
Method Detail
-
turnChecksOff
public void turnChecksOff()
Turns off checks for missing values, etc. Use with caution. Also turns off scaling.
-
turnChecksOn
public void turnChecksOn()
Turns on checks for missing values, etc. Also turns on scaling.
-
globalInfo
public java.lang.String globalInfo()
Returns a string describing this classifier- Returns:
- a description of the classifier suitable for displaying in the explorer/experimenter gui
-
getCapabilities
public Capabilities getCapabilities()
Returns default capabilities of the classifier.- Specified by:
getCapabilitiesin interfaceCapabilitiesHandler- Overrides:
getCapabilitiesin classClassifier- Returns:
- the capabilities of this classifier
- See Also:
Capabilities
-
buildClassifier
public void buildClassifier(Instances data) throws java.lang.Exception
Builds a regression model for the given data.- Specified by:
buildClassifierin classClassifier- Parameters:
data- the training data to be used for generating the linear regression function- Throws:
java.lang.Exception- if the classifier could not be built successfully
-
classifyInstance
public double classifyInstance(Instance instance) throws java.lang.Exception
Classifies the given instance using the linear regression function.- Overrides:
classifyInstancein classClassifier- Parameters:
instance- the test instance- Returns:
- the classification
- Throws:
java.lang.Exception- if classification can't be done successfully
-
toString
public java.lang.String toString()
Outputs the linear regression model as a string.- Overrides:
toStringin classjava.lang.Object- Returns:
- the model as string
-
listOptions
public java.util.Enumeration listOptions()
Returns an enumeration describing the available options.- Specified by:
listOptionsin interfaceOptionHandler- Overrides:
listOptionsin classClassifier- Returns:
- an enumeration of all the available options.
-
setOptions
public void setOptions(java.lang.String[] options) throws java.lang.ExceptionParses a given list of options. Valid options are:-D Produce debugging output. (default no debugging output)
-S <number of selection method> Set the attribute selection method to use. 1 = None, 2 = Greedy. (default 0 = M5' method)
-C Do not try to eliminate colinear attributes.
-R <double> Set ridge parameter (default 1.0e-8).
- Specified by:
setOptionsin interfaceOptionHandler- Overrides:
setOptionsin classClassifier- Parameters:
options- the list of options as an array of strings- Throws:
java.lang.Exception- if an option is not supported
-
coefficients
public double[] coefficients()
Returns the coefficients for this linear model.- Returns:
- the coefficients for this linear model
-
getOptions
public java.lang.String[] getOptions()
Gets the current settings of the classifier.- Specified by:
getOptionsin interfaceOptionHandler- Overrides:
getOptionsin classClassifier- Returns:
- an array of strings suitable for passing to setOptions
-
ridgeTipText
public java.lang.String ridgeTipText()
Returns the tip text for this property- Returns:
- tip text for this property suitable for displaying in the explorer/experimenter gui
-
getRidge
public double getRidge()
Get the value of Ridge.- Returns:
- Value of Ridge.
-
setRidge
public void setRidge(double newRidge)
Set the value of Ridge.- Parameters:
newRidge- Value to assign to Ridge.
-
eliminateColinearAttributesTipText
public java.lang.String eliminateColinearAttributesTipText()
Returns the tip text for this property- Returns:
- tip text for this property suitable for displaying in the explorer/experimenter gui
-
getEliminateColinearAttributes
public boolean getEliminateColinearAttributes()
Get the value of EliminateColinearAttributes.- Returns:
- Value of EliminateColinearAttributes.
-
setEliminateColinearAttributes
public void setEliminateColinearAttributes(boolean newEliminateColinearAttributes)
Set the value of EliminateColinearAttributes.- Parameters:
newEliminateColinearAttributes- Value to assign to EliminateColinearAttributes.
-
numParameters
public int numParameters()
Get the number of coefficients used in the model- Returns:
- the number of coefficients
-
attributeSelectionMethodTipText
public java.lang.String attributeSelectionMethodTipText()
Returns the tip text for this property- Returns:
- tip text for this property suitable for displaying in the explorer/experimenter gui
-
setAttributeSelectionMethod
public void setAttributeSelectionMethod(SelectedTag method)
Sets the method used to select attributes for use in the linear regression.- Parameters:
method- the attribute selection method to use.
-
getAttributeSelectionMethod
public SelectedTag getAttributeSelectionMethod()
Gets the method used to select attributes for use in the linear regression.- Returns:
- the method to use.
-
debugTipText
public java.lang.String debugTipText()
Returns the tip text for this property- Overrides:
debugTipTextin classClassifier- Returns:
- tip text for this property suitable for displaying in the explorer/experimenter gui
-
setDebug
public void setDebug(boolean debug)
Controls whether debugging output will be printed- Overrides:
setDebugin classClassifier- Parameters:
debug- true if debugging output should be printed
-
getDebug
public boolean getDebug()
Controls whether debugging output will be printed- Overrides:
getDebugin classClassifier- Returns:
- true if debugging output is printed
-
getRevision
public java.lang.String getRevision()
Returns the revision string.- Specified by:
getRevisionin interfaceRevisionHandler- Overrides:
getRevisionin classClassifier- Returns:
- the revision
-
main
public static void main(java.lang.String[] argv)
Generates a linear regression function predictor.- Parameters:
argv- the options
-
-