Package opennlp.tools.ml.perceptron
Class PerceptronTrainer
- java.lang.Object
- 
- opennlp.tools.ml.AbstractTrainer
- 
- opennlp.tools.ml.AbstractEventTrainer
- 
- opennlp.tools.ml.perceptron.PerceptronTrainer
 
 
 
- 
- All Implemented Interfaces:
- Trainer,- EventTrainer
 
 public class PerceptronTrainer extends AbstractEventTrainer Trainsmodelsusing the perceptron algorithm.Each outcome is represented as a binary perceptron classifier. This supports standard (integer) weighting as well average weighting as described in: Discriminative Training Methods for Hidden Markov Models: Theory and Experiments with the Perceptron Algorithm. Michael Collins, EMNLP 2002. - See Also:
- PerceptronModel,- AbstractEventTrainer
 
- 
- 
Field SummaryFields Modifier and Type Field Description static StringPERCEPTRON_VALUEstatic doubleTOLERANCE_DEFAULT- 
Fields inherited from class opennlp.tools.ml.AbstractEventTrainerDATA_INDEXER_ONE_PASS_REAL_VALUE, DATA_INDEXER_ONE_PASS_VALUE, DATA_INDEXER_PARAM, DATA_INDEXER_TWO_PASS_VALUE
 - 
Fields inherited from class opennlp.tools.ml.AbstractTrainerALGORITHM_PARAM, CUTOFF_DEFAULT, CUTOFF_PARAM, ITERATIONS_DEFAULT, ITERATIONS_PARAM, TRAINER_TYPE_PARAM, VERBOSE_DEFAULT, VERBOSE_PARAM
 - 
Fields inherited from interface opennlp.tools.ml.EventTrainerEVENT_VALUE
 
- 
 - 
Constructor SummaryConstructors Constructor Description PerceptronTrainer()Instantiates aPerceptronTrainerwith default training parameters.PerceptronTrainer(TrainingParameters parameters)Instantiates aPerceptronTrainerwith specificTrainingParameters.
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description AbstractModeldoTrain(DataIndexer indexer)booleanisSortAndMerge()booleanisValid()Deprecated.Usevalidate()instead.voidsetSkippedAveraging(boolean averaging)Enables skipped averaging, this flag changes the standard averaging to special averaging instead.voidsetStepSizeDecrease(double decrease)Enables and sets step size decrease.voidsetTolerance(double tolerance)Specifies the tolerance.AbstractModeltrainModel(int iterations, DataIndexer di, int cutoff)Trains aPerceptronModelwith given parameters.AbstractModeltrainModel(int iterations, DataIndexer di, int cutoff, boolean useAverage)Trains aPerceptronModelwith given parameters.voidvalidate()Checks the configuredparameters.- 
Methods inherited from class opennlp.tools.ml.AbstractEventTrainergetDataIndexer, train, train
 - 
Methods inherited from class opennlp.tools.ml.AbstractTrainergetAlgorithm, getCutoff, getIterations, init, init
 
- 
 
- 
- 
- 
Field Detail- 
PERCEPTRON_VALUEpublic static final String PERCEPTRON_VALUE - See Also:
- Constant Field Values
 
 - 
TOLERANCE_DEFAULTpublic static final double TOLERANCE_DEFAULT - See Also:
- Constant Field Values
 
 
- 
 - 
Constructor Detail- 
PerceptronTrainerpublic PerceptronTrainer() Instantiates aPerceptronTrainerwith default training parameters.
 - 
PerceptronTrainerpublic PerceptronTrainer(TrainingParameters parameters) Instantiates aPerceptronTrainerwith specificTrainingParameters.- Parameters:
- parameters- The- parameterto use.
 
 
- 
 - 
Method Detail- 
validatepublic void validate() Checks the configuredparameters. If a subclass overrides this, it should callsuper.validate();.- Overrides:
- validatein class- AbstractEventTrainer
- Throws:
- IllegalArgumentException- Thrown if the algorithm name is not equal to {- PERCEPTRON_VALUE}.
 
 - 
isValid@Deprecated public boolean isValid() Deprecated.Usevalidate()instead.- Overrides:
- isValidin class- AbstractEventTrainer
- Returns:
- trueif the validation of the internal configuration succeeds,- falseotherwise.
 
 - 
isSortAndMergepublic boolean isSortAndMerge() - Specified by:
- isSortAndMergein class- AbstractEventTrainer
 
 - 
doTrainpublic AbstractModel doTrain(DataIndexer indexer) throws IOException - Specified by:
- doTrainin class- AbstractEventTrainer
- Throws:
- IOException
 
 - 
setTolerancepublic void setTolerance(double tolerance) Specifies the tolerance. If the change in training set accuracy is less than this, stop iterating.- Parameters:
- tolerance- The level of tolerance. Must not be negative.
- Throws:
- IllegalArgumentException- Thrown if parameters are invalid.
 
 - 
setStepSizeDecreasepublic void setStepSizeDecrease(double decrease) Enables and sets step size decrease. The step size is decreased every iteration by the specified value.- Parameters:
- decrease- The step size decrease in percent. Must not be negative.
- Throws:
- IllegalArgumentException- Thrown if parameters are invalid.
 
 - 
setSkippedAveragingpublic void setSkippedAveraging(boolean averaging) Enables skipped averaging, this flag changes the standard averaging to special averaging instead.If we are doing averaging, and the current iteration is one of the first 20, or if it is a perfect square, then updated the summed parameters. The reason we don't take all of them is that the parameters change less toward the end of training, so they drown out the contributions of the more volatile early iterations. The use of perfect squares allows us to sample from successively farther apart iterations. - Parameters:
- averaging- Whether to skip 'averaging', or not.
 
 - 
trainModelpublic AbstractModel trainModel(int iterations, DataIndexer di, int cutoff) Trains aPerceptronModelwith given parameters.- Parameters:
- iterations- The number of iterations to use for training.
- di- The- DataIndexerused as data input.
- cutoff- The {- AbstractTrainer.CUTOFF_PARAM} value to use for training.
- Returns:
- A valid, trained perceptron model.
 
 - 
trainModelpublic AbstractModel trainModel(int iterations, DataIndexer di, int cutoff, boolean useAverage) Trains aPerceptronModelwith given parameters.- Parameters:
- iterations- The number of iterations to use for training.
- di- The- DataIndexerused as data input.
- cutoff- The {- AbstractTrainer.CUTOFF_PARAM} value to use for training.
- useAverage- Whether to use 'averaging', or not. See {- setSkippedAveraging(boolean)} for details.
- Returns:
- A valid, trained perceptron model.
 
 
- 
 
-