mirror of https://github.com/apache/poi.git
add COVARIANCE.S function
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1901687 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
f0b78f9e3b
commit
41dfbd67c5
|
@ -91,6 +91,7 @@ public final class AnalysisToolPak implements UDFFinder {
|
||||||
r(m, "COUPNUM", null);
|
r(m, "COUPNUM", null);
|
||||||
r(m, "COUPPCD", null);
|
r(m, "COUPPCD", null);
|
||||||
r(m, "COVARIANCE.P", Covar.instanceP);
|
r(m, "COVARIANCE.P", Covar.instanceP);
|
||||||
|
r(m, "COVARIANCE.S", Covar.instanceS);
|
||||||
r(m, "CUBEKPIMEMBER", null);
|
r(m, "CUBEKPIMEMBER", null);
|
||||||
r(m, "CUBEMEMBER", null);
|
r(m, "CUBEMEMBER", null);
|
||||||
r(m, "CUBEMEMBERPROPERTY", null);
|
r(m, "CUBEMEMBERPROPERTY", null);
|
||||||
|
|
|
@ -42,6 +42,8 @@ public class Correl extends TwoArrayFunction {
|
||||||
|
|
||||||
public static final Correl instance = new Correl();
|
public static final Correl instance = new Correl();
|
||||||
|
|
||||||
|
private Correl() {}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ValueEval evaluate(int srcRowIndex, int srcColumnIndex, ValueEval arg0, ValueEval arg1) {
|
public ValueEval evaluate(int srcRowIndex, int srcColumnIndex, ValueEval arg0, ValueEval arg1) {
|
||||||
try {
|
try {
|
||||||
|
|
|
@ -37,7 +37,14 @@ import java.util.List;
|
||||||
*/
|
*/
|
||||||
public class Covar extends TwoArrayFunction implements FreeRefFunction {
|
public class Covar extends TwoArrayFunction implements FreeRefFunction {
|
||||||
|
|
||||||
public static final Covar instanceP = new Covar();
|
public static final Covar instanceP = new Covar(false);
|
||||||
|
public static final Covar instanceS = new Covar(true);
|
||||||
|
|
||||||
|
private final boolean sampleBased;
|
||||||
|
|
||||||
|
private Covar(boolean sampleBased) {
|
||||||
|
this.sampleBased = sampleBased;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ValueEval evaluate(int srcRowIndex, int srcColumnIndex, ValueEval arg0, ValueEval arg1) {
|
public ValueEval evaluate(int srcRowIndex, int srcColumnIndex, ValueEval arg0, ValueEval arg1) {
|
||||||
|
@ -45,7 +52,7 @@ public class Covar extends TwoArrayFunction implements FreeRefFunction {
|
||||||
final List<DoubleList> arrays = getNumberArrays(arg0, arg1);
|
final List<DoubleList> arrays = getNumberArrays(arg0, arg1);
|
||||||
final Covariance covar = new Covariance();
|
final Covariance covar = new Covariance();
|
||||||
final double result = covar.covariance(
|
final double result = covar.covariance(
|
||||||
arrays.get(0).toArray(), arrays.get(1).toArray(), false);
|
arrays.get(0).toArray(), arrays.get(1).toArray(), sampleBased);
|
||||||
return new NumberEval(result);
|
return new NumberEval(result);
|
||||||
} catch (EvaluationException e) {
|
} catch (EvaluationException e) {
|
||||||
return e.getErrorEval();
|
return e.getErrorEval();
|
||||||
|
|
|
@ -46,6 +46,7 @@ final class TestCovar {
|
||||||
HSSFFormulaEvaluator fe = new HSSFFormulaEvaluator(wb);
|
HSSFFormulaEvaluator fe = new HSSFFormulaEvaluator(wb);
|
||||||
assertDouble(fe, cell, "COVAR(A2:A6,B2:B6)", 5.2, 0.0000000005);
|
assertDouble(fe, cell, "COVAR(A2:A6,B2:B6)", 5.2, 0.0000000005);
|
||||||
assertDouble(fe, cell, "COVARIANCE.P(A2:A6,B2:B6)", 5.2, 0.0000000005);
|
assertDouble(fe, cell, "COVARIANCE.P(A2:A6,B2:B6)", 5.2, 0.0000000005);
|
||||||
|
assertDouble(fe, cell, "COVARIANCE.S(A2:A6,B2:B6)", 6.5, 0.0000000005);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -58,6 +59,7 @@ final class TestCovar {
|
||||||
HSSFFormulaEvaluator fe = new HSSFFormulaEvaluator(wb);
|
HSSFFormulaEvaluator fe = new HSSFFormulaEvaluator(wb);
|
||||||
assertDouble(fe, cell, "COVAR(A2:A6,B2:B6)", 5.5625, 0.0000000005);
|
assertDouble(fe, cell, "COVAR(A2:A6,B2:B6)", 5.5625, 0.0000000005);
|
||||||
assertDouble(fe, cell, "COVARIANCE.P(A2:A6,B2:B6)", 5.5625, 0.0000000005);
|
assertDouble(fe, cell, "COVARIANCE.P(A2:A6,B2:B6)", 5.5625, 0.0000000005);
|
||||||
|
assertDouble(fe, cell, "COVARIANCE.S(A2:A6,B2:B6)", 7.416666666666666, 0.0000000005);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,6 +72,7 @@ final class TestCovar {
|
||||||
HSSFFormulaEvaluator fe = new HSSFFormulaEvaluator(wb);
|
HSSFFormulaEvaluator fe = new HSSFFormulaEvaluator(wb);
|
||||||
assertDouble(fe, cell, "COVAR(A2:A6,B2:B6)", 5.5625, 0.0000000005);
|
assertDouble(fe, cell, "COVAR(A2:A6,B2:B6)", 5.5625, 0.0000000005);
|
||||||
assertDouble(fe, cell, "COVARIANCE.P(A2:A6,B2:B6)", 5.5625, 0.0000000005);
|
assertDouble(fe, cell, "COVARIANCE.P(A2:A6,B2:B6)", 5.5625, 0.0000000005);
|
||||||
|
assertDouble(fe, cell, "COVARIANCE.S(A2:A6,B2:B6)", 7.416666666666666, 0.0000000005);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -82,8 +85,10 @@ final class TestCovar {
|
||||||
HSSFFormulaEvaluator fe = new HSSFFormulaEvaluator(wb);
|
HSSFFormulaEvaluator fe = new HSSFFormulaEvaluator(wb);
|
||||||
assertError(fe, cell, "COVAR(A2:A6,B2:B5)", FormulaError.NA);
|
assertError(fe, cell, "COVAR(A2:A6,B2:B5)", FormulaError.NA);
|
||||||
assertError(fe, cell, "COVARIANCE.P(A2:A6,B2:B5)", FormulaError.NA);
|
assertError(fe, cell, "COVARIANCE.P(A2:A6,B2:B5)", FormulaError.NA);
|
||||||
|
assertError(fe, cell, "COVARIANCE.S(A2:A6,B2:B5)", FormulaError.NA);
|
||||||
assertError(fe, cell, "COVAR(A2:B6,B2:B6)", FormulaError.NA);
|
assertError(fe, cell, "COVAR(A2:B6,B2:B6)", FormulaError.NA);
|
||||||
assertError(fe, cell, "COVARIANCE.P(A2:B6,B2:B6)", FormulaError.NA);
|
assertError(fe, cell, "COVARIANCE.P(A2:B6,B2:B6)", FormulaError.NA);
|
||||||
|
assertError(fe, cell, "COVARIANCE.S(A2:B6,B2:B6)", FormulaError.NA);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue