/*
* RapidMiner
*
* Copyright (C) 2001-2011 by Rapid-I and the contributors
*
* Complete list of developers available at our web site:
*
* http://rapid-i.com
*
* This program 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.
*
* This program 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 this program. If not, see http://www.gnu.org/licenses/.
*/
package com.rapidminer.operator.annotation;
import com.rapidminer.operator.ports.InputPort;
import com.rapidminer.operator.ports.metadata.ExampleSetMetaData;
import com.rapidminer.operator.ports.metadata.MDInteger;
import com.rapidminer.operator.tools.AttributeSubsetSelector;
/** Evaluates resource consumption based on a simple polynomial function.
*
* @author Simon Fischer
*
*/
public class PolynomialExampleSetResourceConsumptionEstimator extends ExampleSetResourceConsumptionEstimator {
private final PolynomialFunction cpuFunction;
private final PolynomialFunction memoryFunction;
public PolynomialExampleSetResourceConsumptionEstimator(InputPort in, AttributeSubsetSelector selector,
PolynomialFunction cpuFunction, PolynomialFunction memoryFunction) {
super(in, selector);
this.cpuFunction = cpuFunction;
this.memoryFunction = memoryFunction;
}
protected int getNumberOfRelevantAttributes(ExampleSetMetaData emd) {
return emd.getNumberOfRegularAttributes();
}
@Override
public long estimateMemory(ExampleSetMetaData exampleSet) {
final MDInteger numEx = exampleSet.getNumberOfExamples();
if (numEx == null) {
return -1;
} else if (numEx.getNumber() == 0) {
return -1;
}
final int numAtt = getNumberOfRelevantAttributes(exampleSet);
return cpuFunction.evaluate(numEx.getNumber(), numAtt);
}
@Override
public long estimateRuntime(ExampleSetMetaData exampleSet) {
final MDInteger numEx = exampleSet.getNumberOfExamples();
if (numEx == null) {
return -1;
} else if (numEx.getNumber() == 0) {
return -1;
}
final int numAtt = exampleSet.getNumberOfRegularAttributes();
return memoryFunction.evaluate(numEx.getNumber(), numAtt);
}
@Override
public PolynomialFunction getCpuFunction() {
return cpuFunction;
}
@Override
public PolynomialFunction getMemoryFunction() {
return memoryFunction;
}
}