Package edu.hws.jcm.draw
Class ScatterPlot
- java.lang.Object
-
- edu.hws.jcm.draw.Drawable
-
- edu.hws.jcm.draw.ScatterPlot
-
- All Implemented Interfaces:
Computable
,java.io.Serializable
public class ScatterPlot extends Drawable implements Computable
A ScatterPlot graphs data taken from a DataTableInput. The data in the form of a small plus sign at each (x,y) in the data. The x and y values can be taken directly from two specified columns in the table. They can also be computed by expressions that can use column names from the table as well as the special variable rowNumber. For example, if column names are X and Y, then it could plot sqrt(X) versus rowNumber*(X+Y).Optionally, a ScatterPlot will also draw a regression line for the data. Certain statistical values about the data points are available as Value objects by calling the getValueObject() method.
- See Also:
- Serialized Form
-
-
Field Summary
Fields Modifier and Type Field Description static int
CORRELATION
A constant that can be used in the getValueObject() method to indicate which statistic the object should represent.static int
DATACT
A constant that can be used in the getValueObject() method to indicate which statistic the object should represent.static int
INTERCEPT
A constant that can be used in the getValueObject() method to indicate which statistic the object should represent.static int
MISSINGCT
A constant that can be used in the getValueObject() method to indicate which statistic the object should represent.static int
SLOPE
A constant that can be used in the getValueObject() method to indicate which statistic the object should represent.static int
STANDARDERROR
A constant that can be used in the getValueObject() method to indicate which statistic the object should represent.
-
Constructor Summary
Constructors Constructor Description ScatterPlot()
Default constructor.ScatterPlot(DataTableInput table)
Create a scatter plot to plot data from the specified table.ScatterPlot(DataTableInput table, int column1, int column2)
Create a scatter plot to plot data from two specified columns in a table.ScatterPlot(DataTableInput table, Expression exp1, Expression exp2)
Create scatter plot to plot specified expressions using data from a table.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description void
compute()
Recompute the data for the scatter plot.void
draw(java.awt.Graphics g, boolean coordsChanged)
Draw the data points and regression line.boolean
getAutoChangeLimits()
The return value indicates whether the limits on the CoordinateRect are automatically adjusted when the data is recomputed.java.awt.Color
getDataColor()
Get the color that is used to draw the points in the data.java.awt.Color
getLineColor()
Get the color that is used to draw the regression line.boolean
getMissingValueIsError()
The return value indicates whether missing data is considered to be an error.boolean
getShowRegressionLine()
The return value tells whether a regression line is drawn.DataTableInput
getTable()
Get the DataTableInput from which the plotted data is obtained.Value
getValueObject(int valueCode)
Get a Value that represents a statistic about the data that is shown in the scatter plot.void
setAutoChangeLimits(boolean set)
If the parameter is true, then the limits on the CoordinateRect that contains this ScatterPlot are automatically adjusted whenever the data is recomputed.void
setColumns(int c1, int c2)
Specify that the data to be plotted should be taken from the specified columns in the table.void
setDataColor(java.awt.Color color)
Set the color that is used to draw the points in the data.void
setExpressions(Expression exp1, Expression exp2)
Specify the data for the the plot is to be obtained by evaluating the two expressions that are given as parameters.void
setLineColor(java.awt.Color color)
Set the color that is used to draw the regression line.void
setMissingValueIsError(boolean isError)
If the parameter is true, then a missing data value (an empty cell or an undefined value for one of the expressions) is considered to be an error, and a JCMError is thrown when it is encountered.void
setShowRegressionLine(boolean line)
If the parameter is true, then a regression line for the data is drawn.void
setTable(DataTableInput table)
Specify the table from which the plotted data is to be taken.-
Methods inherited from class edu.hws.jcm.draw.Drawable
getVisible, needsRedraw, setOwnerData, setVisible
-
-
-
-
Field Detail
-
INTERCEPT
public static final int INTERCEPT
A constant that can be used in the getValueObject() method to indicate which statistic the object should represent.- See Also:
- Constant Field Values
-
SLOPE
public static final int SLOPE
A constant that can be used in the getValueObject() method to indicate which statistic the object should represent.- See Also:
- Constant Field Values
-
DATACT
public static final int DATACT
A constant that can be used in the getValueObject() method to indicate which statistic the object should represent.- See Also:
- Constant Field Values
-
MISSINGCT
public static final int MISSINGCT
A constant that can be used in the getValueObject() method to indicate which statistic the object should represent.- See Also:
- Constant Field Values
-
STANDARDERROR
public static final int STANDARDERROR
A constant that can be used in the getValueObject() method to indicate which statistic the object should represent.- See Also:
- Constant Field Values
-
CORRELATION
public static final int CORRELATION
A constant that can be used in the getValueObject() method to indicate which statistic the object should represent.- See Also:
- Constant Field Values
-
-
Constructor Detail
-
ScatterPlot
public ScatterPlot()
Default constructor. A data table, at least, must be specified before anything can be drawn. The first two columns of the table will be plotted (once a table is specified).
-
ScatterPlot
public ScatterPlot(DataTableInput table)
Create a scatter plot to plot data from the specified table. Initially, it is configured to plot data from the first two columns in the table.
-
ScatterPlot
public ScatterPlot(DataTableInput table, int column1, int column2)
Create a scatter plot to plot data from two specified columns in a table. Columns are numbered starting from zero.
-
ScatterPlot
public ScatterPlot(DataTableInput table, Expression exp1, Expression exp2)
Create scatter plot to plot specified expressions using data from a table. The expressions should include references to the column names from the table and can also refer to the special variable "rowNumber".
-
-
Method Detail
-
setTable
public void setTable(DataTableInput table)
Specify the table from which the plotted data is to be taken. The data from the first two columns of the table will be plotted, unless this is changed by calling setColumns() or setExpressions().
-
getTable
public DataTableInput getTable()
Get the DataTableInput from which the plotted data is obtained.
-
setColumns
public void setColumns(int c1, int c2)
Specify that the data to be plotted should be taken from the specified columns in the table. Note that columns are numbered starting from zero. The parameters must be within the range of column numbers in the table.
-
setExpressions
public void setExpressions(Expression exp1, Expression exp2)
Specify the data for the the plot is to be obtained by evaluating the two expressions that are given as parameters. Both expressions should be non-null. The expressions can only be created by a Parser to which the variables from the table have been added by calling the method DataTableInput.addVariablesToParser(). The expressions are evaluated once for each row in the table to obtain the data to be ploted. They can include references to the column names from the table and to the special variable "rowNumber", which represents the number of the current row.
-
setShowRegressionLine
public void setShowRegressionLine(boolean line)
If the parameter is true, then a regression line for the data is drawn. The default value is true.
-
getShowRegressionLine
public boolean getShowRegressionLine()
The return value tells whether a regression line is drawn.
-
setMissingValueIsError
public void setMissingValueIsError(boolean isError)
If the parameter is true, then a missing data value (an empty cell or an undefined value for one of the expressions) is considered to be an error, and a JCMError is thrown when it is encountered. If the value is false, missing data are ignored, and the value of MISSINGCT gives the number of points for which the data was missing. Note that invalid data (a cell that contains text that does not represent a number) is always considered to be an error. Also note that completely empty rows at the bottom of a DataTableInput are always ignored and are never considered to be an error. The default value of missingValueIsError is true, so that missing data is considered to be an error unless you turn off this option.
-
getMissingValueIsError
public boolean getMissingValueIsError()
The return value indicates whether missing data is considered to be an error.
-
setAutoChangeLimits
public void setAutoChangeLimits(boolean set)
If the parameter is true, then the limits on the CoordinateRect that contains this ScatterPlot are automatically adjusted whenever the data is recomputed. The default value is true.
-
getAutoChangeLimits
public boolean getAutoChangeLimits()
The return value indicates whether the limits on the CoordinateRect are automatically adjusted when the data is recomputed.
-
getDataColor
public java.awt.Color getDataColor()
Get the color that is used to draw the points in the data.
-
setDataColor
public void setDataColor(java.awt.Color color)
Set the color that is used to draw the points in the data. The default value is red.
-
getLineColor
public java.awt.Color getLineColor()
Get the color that is used to draw the regression line.
-
setLineColor
public void setLineColor(java.awt.Color color)
Set the color that is used to draw the regression line. The default value is black.
-
getValueObject
public Value getValueObject(int valueCode)
Get a Value that represents a statistic about the data that is shown in the scatter plot. The parameter specifies which statistic is represented. It can be one of the constants defined in this class: SLOPE (of regression line), INTERCEPT (y-intercept of regression line), DATACT (number of data points), MISSINGCT (number of missing data; alwasy zero if the missingValueIsError property is true), STANDARDERROR (standard error of regression line), and CORRELATION (correlation coefficient between first and second coordintes of data points).
-
compute
public void compute()
Recompute the data for the scatter plot. This is generally not called directly.- Specified by:
compute
in interfaceComputable
-
draw
public void draw(java.awt.Graphics g, boolean coordsChanged)
Draw the data points and regression line. Not meant to be called directly.- Specified by:
draw
in classDrawable
- Parameters:
g
- The graphics context in which the Drawble is to be drawn. (The drawing can change the color in g, but should not permanently change font, painting mode, etc. Thus, every drawable is responsible for setting the color it wants to use.)coordsChanged
- Indicates whether the CoordinateRect has changed.
-
-