|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectedu.udo.cs.yale.operator.Operator
edu.udo.cs.yale.operator.features.transformation.GHA
public class GHA
Generalized Hebbian Algorithm (GHA) is an iterative method to compute
principal components. From a computational point of view, it can be
advantageous to solve the eigenvalue problem by iterative methods which do
not need to compute the covariance matrix directly. This is useful when the
ExampleSet contains many Attributes (hundreds, thousands). The operator
outputs a GHAModel
. With the ModelApplier
you
can transform the features.
Field Summary | |
---|---|
private double[][] |
data
|
private double |
learning_rate
|
private double[] |
mean
|
private int |
nr_components
|
private int |
nr_iterations
|
private Jama.Matrix |
W
|
Constructor Summary | |
---|---|
GHA(OperatorDescription description)
|
Method Summary | |
---|---|
IOObject[] |
apply()
Implement this method in subclasses. |
private double |
getCovarianz(int dim1,
int dim2)
|
java.lang.Class[] |
getInputClasses()
Returns the classes that are needed as input. |
java.lang.Class[] |
getOutputClasses()
Returns the classes that are guaranteed to be returned by apply() as additional output. |
java.util.List<ParameterType> |
getParameterTypes()
Returns a list of ParameterTypes describing the parameters of this operator. |
private void |
train()
|
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Field Detail |
---|
private double learning_rate
private int nr_components
private int nr_iterations
private double[] mean
private double[][] data
private Jama.Matrix W
Constructor Detail |
---|
public GHA(OperatorDescription description)
description
- Method Detail |
---|
public IOObject[] apply() throws OperatorException
Operator
apply
in class Operator
OperatorException
private double getCovarianz(int dim1, int dim2)
private void train() throws OperatorException
OperatorException
public java.lang.Class[] getInputClasses()
Operator
Operator.getOutputClasses()
and
Operator.apply()
if this is necessary. This default behavior can be
changed by overriding Operator.getInputDescription(Class)
. Subclasses
which implement this method should not make use of parameters since this
method is invoked by getParameterTypes(). Therefore, parameters are not
fully available at this point of time and this might lead to exceptions.
Please use InputDescriptions instead.
getInputClasses
in class Operator
public java.lang.Class[] getOutputClasses()
Operator
Operator.getInputDescription(Class)
and can be changed by
overwriting this method. Objects which are not consumed must not be
defined as additional output in this method. May be null or an empy array
(no additional output is produced).
getOutputClasses
in class Operator
public java.util.List<ParameterType> getParameterTypes()
Operator
getParameterTypes
in class Operator
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |