|
|||||||||
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.meta.ParameterCloner
public class ParameterCloner
Sets a list of parameters using existing parameter values.
The operator is similar to ParameterSetter
, but differs from that in
not requiring a ParameterSet input. It simply reads a parameter value from a
source and uses it to set the parameter value of a target parameter. Both,
source and target, are given in the format 'operator'.'parameter'.
This operator is more general than ParameterSetter and could completely
replace it. It is most useful, if you need a parameter which is optimized
more than once within the optimization loop - ParameterSetter cannot be used
here.
These parameters can either be generated by a
ParameterOptimizationOperator
or read by a
ParameterSetLoader
. This operator is
useful, e.g. in the following scenario. If one wants to find the best
parameters for a certain learning scheme, one usually is also interested in
the model generated with this parameters. While the first is easily possible
using a ParameterOptimizationOperator
, the latter is not possible
because the ParameterOptimizationOperator
does not return the
IOObjects produced within, but only a parameter set. This is, because the
parameter optimization operator knows nothing about models, but only about
the performance vectors produced within. Producing performance vectors does
not necessarily require a model.
To solve this problem, one can use a
ParameterSetter
. Usually, an experiment with a
ParameterSetter
contains at least two operators of the same
type, typically a learner. One learner may be an inner operator of the
ParameterOptimizationOperator
and may be named "Learner",
whereas a second learner of the same type named "OptimalLearner"
follows the parameter optimization and should use the optimal parameter set
found by the optimization. In order to make the ParameterSetter
set the optimal parameters of the right operator, one must specify its name.
Therefore, the parameter list name_map was introduced. Each
parameter in this list maps the name of an operator that was used during
optimization (in our case this is "Learner") to an operator that
should now use these parameters (in our case this is
"OptimalLearner").
Field Summary | |
---|---|
private static java.lang.Class[] |
INPUT_CLASSES
|
private static java.lang.Class[] |
OUTPUT_CLASSES
|
Constructor Summary | |
---|---|
ParameterCloner(OperatorDescription description)
|
Method Summary | |
---|---|
IOObject[] |
apply()
Implement this method in subclasses. |
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. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Field Detail |
---|
private static final java.lang.Class[] INPUT_CLASSES
private static final java.lang.Class[] OUTPUT_CLASSES
Constructor Detail |
---|
public ParameterCloner(OperatorDescription description)
Method Detail |
---|
public IOObject[] apply() throws OperatorException
Operator
apply
in class Operator
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 |