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

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

There is a newer version: 1.6.8
Show newest version
/*
 * Copyright (c) 2018 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.io.Serializable;
import java.util.Collections;
import java.util.EnumSet;
import java.util.List;
import java.util.Objects;
import java.util.Set;

import org.dmg.pmml.MiningSchema;
import org.dmg.pmml.Model;
import org.dmg.pmml.Output;
import org.dmg.pmml.PMML;
import org.dmg.pmml.ResultFeature;
import org.jpmml.model.InvalidElementException;
import org.jpmml.model.MissingElementException;

public class ModelEvaluatorBuilder implements EvaluatorBuilder, Serializable {

	private PMML pmml = null;

	private Model model = null;

	private ConfigurationBuilder configurationBuilder = new ConfigurationBuilder();

	private Set extraResultFeatures = EnumSet.noneOf(ResultFeature.class);

	private InputMapper inputMapper = null;

	private ResultMapper resultMapper = null;

	private boolean checkSchema = true;


	protected ModelEvaluatorBuilder(){
	}

	/**
	 * 

* Selects the first scorable model. *

* * @throws MissingElementException If the PMML does not contain any scorable models. */ public ModelEvaluatorBuilder(PMML pmml){ this(pmml, (String)null); } /** *

* Selects the named model. *

* * @throws MissingElementException If the PMML does not contain a model with the specified model name. * * @see Model#getModelName() */ public ModelEvaluatorBuilder(PMML pmml, String modelName){ Model model = (pmml != null ? PMMLUtil.findModel(pmml, modelName) : null); setPMML(pmml); setModel(model); } public ModelEvaluatorBuilder(PMML pmml, Model model){ setPMML(pmml); setModel(model); } @Override public ModelEvaluatorBuilder clone(){ ModelEvaluatorBuilder modelEvaluatorBuilder; try { modelEvaluatorBuilder = (ModelEvaluatorBuilder)super.clone(); } catch(CloneNotSupportedException cnse){ throw (InternalError)new InternalError() .initCause(cnse); } modelEvaluatorBuilder.configurationBuilder = modelEvaluatorBuilder.configurationBuilder.clone(); return modelEvaluatorBuilder; } @Override public ModelEvaluator build(){ PMML pmml = getPMML(); Model model = getModel(); if((pmml == null) || (model == null)){ throw new IllegalStateException(); } ConfigurationBuilder configurationBuilder = getConfigurationBuilder(); Configuration configuration = configurationBuilder.build(); ModelEvaluatorFactory modelEvaluatorFactory = configuration.getModelEvaluatorFactory(); Set extraResultFeatures = getExtraResultFeatures(); ModelEvaluator modelEvaluator = modelEvaluatorFactory.newModelEvaluator(pmml, model, extraResultFeatures); modelEvaluator.configure(configuration); InputMapper inputMapper = getInputMapper(); ResultMapper resultMapper = getResultMapper(); modelEvaluator.setInputMapper(inputMapper); modelEvaluator.setResultMapper(resultMapper); boolean checkSchema = getCheckSchema(); if(checkSchema){ checkSchema(modelEvaluator); } return modelEvaluator; } protected void checkSchema(ModelEvaluator modelEvaluator){ Model model = modelEvaluator.getModel(); MiningSchema miningSchema = model.requireMiningSchema(); List inputFields = modelEvaluator.getInputFields(); List groupFields = Collections.emptyList(); if(modelEvaluator instanceof HasGroupFields){ HasGroupFields hasGroupFields = (HasGroupFields)modelEvaluator; groupFields = hasGroupFields.getGroupFields(); } // End if if((inputFields.size() + groupFields.size()) > 1000){ throw new InvalidElementException("Model has too many input fields", miningSchema); } List targetFields = modelEvaluator.getTargetFields(); List outputFields = modelEvaluator.getOutputFields(); if((targetFields.size() + outputFields.size()) < 1){ throw new InvalidElementException("Model does not have any target or output fields", miningSchema); } } public PMML getPMML(){ return this.pmml; } protected ModelEvaluatorBuilder setPMML(PMML pmml){ this.pmml = Objects.requireNonNull(pmml); return this; } public Model getModel(){ return this.model; } protected ModelEvaluatorBuilder setModel(Model model){ this.model = Objects.requireNonNull(model); return this; } public ConfigurationBuilder getConfigurationBuilder(){ return this.configurationBuilder; } public ModelEvaluatorFactory getModelEvaluatorFactory(){ ConfigurationBuilder configurationBuilder = getConfigurationBuilder(); return configurationBuilder.getModelEvaluatorFactory(); } public ModelEvaluatorBuilder setModelEvaluatorFactory(ModelEvaluatorFactory modelEvaluatorFactory){ ConfigurationBuilder configurationBuilder = getConfigurationBuilder(); configurationBuilder.setModelEvaluatorFactory(modelEvaluatorFactory); return this; } public ValueFactoryFactory getValueFactoryFactory(){ ConfigurationBuilder configurationBuilder = getConfigurationBuilder(); return configurationBuilder.getValueFactoryFactory(); } public ModelEvaluatorBuilder setValueFactoryFactory(ValueFactoryFactory valueFactoryFactory){ ConfigurationBuilder configurationBuilder = getConfigurationBuilder(); configurationBuilder.setValueFactoryFactory(valueFactoryFactory); return this; } public OutputFilter getOutputFilter(){ ConfigurationBuilder configurationBuilder = getConfigurationBuilder(); return configurationBuilder.getOutputFilter(); } /** *

* Sets the filter for cleaning the model schema and model evaluation results from redundant output fields. *

* * @see OutputFilters#KEEP_ALL * @see OutputFilters#KEEP_FINAL_RESULTS */ public ModelEvaluatorBuilder setOutputFilter(OutputFilter outputFilter){ ConfigurationBuilder configurationBuilder = getConfigurationBuilder(); configurationBuilder.setOutputFilter(outputFilter); return this; } public SymbolTable getDerivedFieldGuard(){ ConfigurationBuilder configurationBuilder = getConfigurationBuilder(); return configurationBuilder.getDerivedFieldGuard(); } /** *

* Sets a guard against recursive field declarations. *

* * @see FieldNameSet */ public ModelEvaluatorBuilder setDerivedFieldGuard(SymbolTable derivedFieldGuard){ ConfigurationBuilder configurationBuilder = getConfigurationBuilder(); configurationBuilder.setDerivedFieldGuard(derivedFieldGuard); return this; } public SymbolTable getFunctionGuard(){ ConfigurationBuilder configurationBuilder = getConfigurationBuilder(); return configurationBuilder.getFunctionGuard(); } /** *

* Sets a guard against recursive function declarations. *

* * @see FunctionNameStack */ public ModelEvaluatorBuilder setFunctionGuard(SymbolTable functionGuard){ ConfigurationBuilder configurationBuilder = getConfigurationBuilder(); configurationBuilder.setFunctionGuard(functionGuard); return this; } public Set getExtraResultFeatures(){ return this.extraResultFeatures; } /** *

* Sets extra functional requirements. *

* * The final set of functional requirements is obtained by combining * default functional requirements (as declared by the {@link Output} element of the model) * with extra functional requirements. */ public ModelEvaluatorBuilder setExtraResultFeatures(Set extraResultFeatures){ this.extraResultFeatures = extraResultFeatures; return this; } public InputMapper getInputMapper(){ return this.inputMapper; } /** *

* Sets a mapper for translating input field names from user namespace to model namespace. *

* * @see Evaluator#getInputFields() */ public ModelEvaluatorBuilder setInputMapper(InputMapper inputMapper){ this.inputMapper = inputMapper; return this; } public ResultMapper getResultMapper(){ return this.resultMapper; } /** *

* Sets a mapper for translating result field names from model namespace to user namespace. *

* * @see Evaluator#getTargetFields() * @see Evaluator#getOutputFields() */ public ModelEvaluatorBuilder setResultMapper(ResultMapper resultMapper){ this.resultMapper = resultMapper; return this; } public boolean getCheckSchema(){ return this.checkSchema; } /** *

* Should the "data schema" of models be checked for the most common signs of insanity? *

*/ public ModelEvaluatorBuilder setCheckSchema(boolean checkSchema){ this.checkSchema = checkSchema; return this; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy