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

org.jpmml.evaluator.functions.PercentileFunction Maven / Gradle / Ivy

There is a newer version: 1.2.15
Show newest version
/*
 * Copyright (c) 2014 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.functions;

import java.util.Collection;
import java.util.List;

import org.apache.commons.math3.stat.descriptive.rank.Percentile;
import org.dmg.pmml.DataType;
import org.jpmml.evaluator.DoubleVector;
import org.jpmml.evaluator.FieldValue;
import org.jpmml.evaluator.FieldValueUtil;
import org.jpmml.evaluator.FunctionException;
import org.jpmml.evaluator.TypeUtil;

/**
 * 

* A Java UDF for calculating the n-th percentile of a collection of values. *

* * Pseudo-declaration of function: *
 *   <DefineFunction name="..." dataType="double">
 *     <ParameterField name="values" dataType="collection of numbers"/>
 *     <ParameterField name="percentile" dataType="integer"/> <-- 0 < percentile <= 100 -->
 *   </DefineFunction>
 * 
* * @see Percentile */ public class PercentileFunction extends AbstractFunction { public PercentileFunction(){ this(PercentileFunction.class.getName()); } public PercentileFunction(String name){ super(name); } @Override public FieldValue evaluate(List arguments){ checkArguments(arguments, 2); Collection values = FieldValueUtil.getValue(Collection.class, arguments.get(0)); int percentile = (arguments.get(1)).asInteger(); if(percentile < 1 || percentile > 100){ throw new FunctionException(this, "Invalid percentile value " + percentile + ". Must be greater than 0 and equal or less than 100"); } Double result = evaluate(values, percentile); return FieldValueUtil.create(result); } static private Double evaluate(Collection values, int percentile){ DoubleVector doubleValues = new DoubleVector(values.size()); for(Object value : values){ Double doubleValue = (Double)TypeUtil.parseOrCast(DataType.DOUBLE, value); doubleValues.add(doubleValue.doubleValue()); } return doubleValues.percentile(percentile); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy