All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jpmml.evaluator.Evaluator Maven / Gradle / Ivy

There is a newer version: 1.6.8
Show newest version
/*
 * 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