Class MultiOperandNumericFunction
- java.lang.Object
- 
- org.apache.poi.ss.formula.functions.MultiOperandNumericFunction
 
- 
- All Implemented Interfaces:
- Function
 - Direct Known Subclasses:
- AggregateFunction,- MatrixFunction.MutableValueCollector,- MinaMaxa,- Mirr
 
 public abstract class MultiOperandNumericFunction extends Object implements Function This is the super class for all excel function evaluator classes that take variable number of operands, and where the order of operands does not matter
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description static classMultiOperandNumericFunction.Policy
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedMultiOperandNumericFunction(boolean isReferenceBoolCounted, boolean isBlankCounted, boolean isFilterCounted)
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description protected abstract doubleevaluate(double[] values)ValueEvalevaluate(ValueEval[] args, int srcCellRow, int srcCellCol)protected intgetMaxNumOperands()Maximum number of operands accepted by this function.protected double[]getNumberArray(ValueEval[] operands)Returns a double array that contains values for the numeric cells from among the list of operands.booleanisHiddenRowCounted()booleanisSubtotalCounted()Whether to count nested subtotals.voidsetBlankEvalPolicy(MultiOperandNumericFunction.Policy policy)voidsetMissingArgPolicy(MultiOperandNumericFunction.Policy policy)protected booleantreatStringsAsZero()Functions like AVERAGEA() differ from AVERAGE() in the way they handle non-numeric cells.
 
- 
- 
- 
Method Detail- 
setMissingArgPolicypublic void setMissingArgPolicy(MultiOperandNumericFunction.Policy policy) 
 - 
setBlankEvalPolicypublic void setBlankEvalPolicy(MultiOperandNumericFunction.Policy policy) 
 - 
treatStringsAsZeroprotected boolean treatStringsAsZero() Functions like AVERAGEA() differ from AVERAGE() in the way they handle non-numeric cells. AVERAGEA treats booleans as 1.0 (true) and 0.0 (false). String cells are treated as 0.0 (AVERAGE() ignores the cell altogether).- Returns:
- whether to parse non-numeric cells
 
 - 
evaluatepublic final ValueEval evaluate(ValueEval[] args, int srcCellRow, int srcCellCol) - Specified by:
- evaluatein interface- Function
- Parameters:
- args- the evaluated function arguments. Empty values are represented with- BlankEvalor- MissingArgEval, never- null.
- srcCellRow- row index of the cell containing the formula under evaluation
- srcCellCol- column index of the cell containing the formula under evaluation
- Returns:
- The evaluated result, possibly an ErrorEval, nevernull. Note - Excel uses the error code #NUM! instead of IEEE NaN, so when numeric functions evaluate toDouble.NaNbe sure to translate the result toErrorEval.NUM_ERROR.
 
 - 
evaluateprotected abstract double evaluate(double[] values) throws EvaluationException- Throws:
- EvaluationException
 
 - 
getMaxNumOperandsprotected int getMaxNumOperands() Maximum number of operands accepted by this function. Subclasses may override to change default value.
 - 
getNumberArrayprotected final double[] getNumberArray(ValueEval[] operands) throws EvaluationException Returns a double array that contains values for the numeric cells from among the list of operands. Blanks and Blank equivalent cells are ignored. Error operands or cells containing operands of type that are considered invalid and would result in #VALUE! error in excel cause this function to returnnull.- Returns:
- never null
- Throws:
- EvaluationException
 
 - 
isSubtotalCountedpublic boolean isSubtotalCounted() Whether to count nested subtotals.
 - 
isHiddenRowCountedpublic boolean isHiddenRowCounted() - Returns:
- true if values in hidden rows are counted
- See Also:
- Subtotal
 
 
- 
 
-