org.jpmml.evaluator.Evaluator Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pmml-evaluator Show documentation
Show all versions of pmml-evaluator Show documentation
JPMML class model evaluator
/*
* Copyright (c) 2013 Villu Ruusmann
*
* This file is part of JPMML-Evaluator
*
* JPMML-Evaluator is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* JPMML-Evaluator is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with JPMML-Evaluator. If not, see .
*/
package org.jpmml.evaluator;
import java.util.Map;
import org.dmg.pmml.FieldName;
import org.dmg.pmml.Model;
/**
*
* Performs the evaluation of a {@link Model}.
*
*
* Obtaining and verifying an Evaluator instance
*
* PMML pmml = ...;
* ModelEvaluatorFactory modelEvaluatorFactory = ModelEvaluatorFactory.newInstance();
* Evaluator evaluator = (Evaluator)modelEvaluatorFactory.newModelManager(pmml);
* evaluator.verify();
*
*
* Preparing arguments
* Converting an user-supplied map of arguments to a prepared map of arguments:
*
* Map<FieldName, ?> userArguments = ...;
* Map<FieldName, FieldValue> arguments = new LinkedHashMap<FieldName, FieldValue>();
* List<FieldName> activeFields = evaluator.getActiveFields();
* for(FieldName activeField : activeFields){
* FieldValue activeValue = evaluator.prepare(activeField, userArguments.get(activeField));
* arguments.put(activeField, activeValue);
* }
*
*
* Performing the evaluation
*
* Map<FieldName, ?> result = evaluator.evaluate(arguments);
*
*
* Processing results
* Retrieving the value of the {@link #getTargetField() target field} (ie. the primary result):
*
* FieldName targetField = evaluator.getTargetField();
* Object targetValue = result.get(targetField);
*
*
* Decoding a {@link Computable complex value} to a Java primitive value:
*
* if(targetValue instanceof Computable){
* Computable computable = (Computable)targetValue;
*
* targetValue = computable.getResult();
* }
*
*
* Retrieving the values of {@link #getOutputFields() output fields} (ie. secondary results):
*
* List<FieldName> outputFields = evaluator.getOutputFields();
* for(FieldName outputField : outputFields){
* Object outputValue = result.get(outputField);
* }
*
*
* Handling exceptions
* A code block that does exception-prone work should be surrounded with two levels of try-catch statements.
* The inner try statement should catch {@link EvaluationException} instances that indicate "local" problems, which are related to individual data records.
* The outer try statement should catch {@link InvalidFeatureException} and {@link UnsupportedFeatureException} instances that indicate "global" problems, which are related to the class model object.
*
* try {
* List<Map<FieldName, ?>> records = ...;
* for(Map<FieldName, ?> record : records){
* try {
* // Do exception-prone work
* } catch(EvaluationException ee){
* // The work failed because of the data record.
* // Skip this data record and proceed as usual with the next one
* }
* }
* } catch(InvalidFeatureException | UnsupportedFeatureException fe){
* // The work failed because of the class model object.
* // This is a persistent problem that is very likely to affect all data records
* // Decommission the Evaluator instance
* }
*
*
* @see EvaluatorUtil
*/
public interface Evaluator extends Consumer {
/**
*
* Prepares the input value for a field.
*
*
*
* First, the value is converted from the user-supplied representation to internal representation.
* After that, the value is subjected to missing value treatment, invalid value treatment and outlier treatment.
*
*
* @param name The name of the field
* @param string The input value in user-supplied representation. Use null
to represent a missing input value.
*
* @throws EvaluationException If the input value preparation fails.
* @throws InvalidFeatureException
* @throws UnsupportedFeatureException
*
* @see #getDataField(FieldName)
* @see #getMiningField(FieldName)
*/
FieldValue prepare(FieldName name, Object value);
/**
*
* Verifies the model.
*
*
* @throws EvaluationException If the verification fails.
* @throws InvalidFeatureException
* @throws UnsupportedFeatureException
*/
void verify();
/**
*
* Evaluates the model with the specified arguments.
*
*
* @param arguments Map of {@link #getActiveFields() active field} values.
*
* @return Map of {@link #getTargetFields() target field} and {@link #getOutputFields() output field} values.
* Simple values are represented using the Java equivalents of PMML data types (eg. String, Integer, Float, Double etc.).
* Complex values are represented as instances of {@link Computable} that return simple values.
* A missing result is represented by null
.
*
* @throws EvaluationException If the evaluation fails.
* @throws InvalidFeatureException
* @throws UnsupportedFeatureException
*
* @see Computable
*/
Map evaluate(Map arguments);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy