
org.jpmml.evaluator.functions.PercentileFunction Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pmml-extension Show documentation
Show all versions of pmml-extension Show documentation
JPMML class model evaluator extensions
/*
* 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