Commit 8fdf08e5 authored by GoshaZotov's avatar GoshaZotov

add RANK formula

parent 5a1c014b
...@@ -2417,14 +2417,18 @@ parserHelp.setDigitSeparator(AscCommon.g_oDefaultCultureInfo.NumberDecimalSepara ...@@ -2417,14 +2417,18 @@ parserHelp.setDigitSeparator(AscCommon.g_oDefaultCultureInfo.NumberDecimalSepara
if(cElementType.string === inputArguments[i].type && !dNotCheckNumberType){ if(cElementType.string === inputArguments[i].type && !dNotCheckNumberType){
return new cError(cErrorType.wrong_value_type); return new cError(cErrorType.wrong_value_type);
}else{ }else{
if(inputArguments[i].getValue){
argsArray[i] = inputArguments[i].getValue(); argsArray[i] = inputArguments[i].getValue();
}else{
argsArray[i] = inputArguments[i];
}
} }
} }
} }
return calculateFunc(argsArray); return calculateFunc(argsArray);
}; };
cBaseFunction.prototype._prepareArguments = function (args, arg1, bAddFirstArrElem) { cBaseFunction.prototype._prepareArguments = function (args, arg1, bAddFirstArrElem, typeArray) {
var newArgs = []; var newArgs = [];
var indexArr = null; var indexArr = null;
...@@ -2432,10 +2436,21 @@ parserHelp.setDigitSeparator(AscCommon.g_oDefaultCultureInfo.NumberDecimalSepara ...@@ -2432,10 +2436,21 @@ parserHelp.setDigitSeparator(AscCommon.g_oDefaultCultureInfo.NumberDecimalSepara
var arg = args[i]; var arg = args[i];
if (cElementType.cellsRange === arg.type || cElementType.cellsRange3D === arg.type) { if (cElementType.cellsRange === arg.type || cElementType.cellsRange3D === arg.type) {
if(typeArray && cElementType.array === typeArray[i]){
newArgs[i] = arg;
}else{
newArgs[i] = arg.cross(arg1); newArgs[i] = arg.cross(arg1);
}
}else if(cElementType.array === arg.type){ }else if(cElementType.array === arg.type){
if(bAddFirstArrElem){ if(bAddFirstArrElem){
if(typeArray && cElementType.array === typeArray[i]){
newArgs[i] = [];
arg.foreach(function (elem) {
newArgs[i].push(elem);
});
}else{
newArgs[i] = arg.getElementRowCol(0,0); newArgs[i] = arg.getElementRowCol(0,0);
}
}else{ }else{
indexArr = i; indexArr = i;
newArgs[i] = arg; newArgs[i] = arg;
......
...@@ -903,6 +903,61 @@ ...@@ -903,6 +903,61 @@
return (u < 0 && w > 0) || (u > 0 && w < 0); return (u < 0 && w > 0) || (u > 0 && w < 0);
} }
function rank( fVal, aSortArray, bAscending, bAverage )
{
//sort array
aSortArray.sort (function sortArr(a, b) {
return a.value - b.value;
});
var nSize = aSortArray.length;
var res;
if ( nSize == 0 /*|| nGlobalError != FormulaError::NONE*/ ){
res = null;
} else {
if ( fVal < aSortArray[ 0 ].value || fVal > aSortArray[ nSize - 1 ].value ){
res = null;
}else{
var fLastPos = 0;
var fFirstPos = -1.0;
var bFinished = false;
var i;
for ( i = 0; i < nSize && !bFinished /*&& nGlobalError == FormulaError::NONE*/; i++ ){
if ( aSortArray[ i ].value === fVal ){
if ( fFirstPos < 0 ){
fFirstPos = i + 1.0;
}
}else{
if ( aSortArray[ i ].value > fVal ){
fLastPos = i;
bFinished = true;
}
}
}
if ( !bFinished ){
fLastPos = i;
}
if ( !bAverage ){
if ( bAscending ){
res = fFirstPos;
}else{
res = nSize + 1.0 - fLastPos;
}
}else {
if ( bAscending ){
res = ( fFirstPos + fLastPos ) / 2.0 ;
}else{
res = nSize + 1.0 - ( fFirstPos + fLastPos ) / 2.0;
}
}
}
}
return res;
}
function GAMMADISTFUNCTION(fp, fAlpha, fBeta){ function GAMMADISTFUNCTION(fp, fAlpha, fBeta){
this.fp = fp; this.fp = fp;
this.fAlpha = fAlpha; this.fAlpha = fAlpha;
...@@ -5504,6 +5559,42 @@ ...@@ -5504,6 +5559,42 @@
cRANK.prototype = Object.create(cBaseFunction.prototype); cRANK.prototype = Object.create(cBaseFunction.prototype);
cRANK.prototype.constructor = cRANK; cRANK.prototype.constructor = cRANK;
cRANK.prototype.argumentsMin = 2;
cRANK.prototype.argumentsMax = 3;
cRANK.prototype.Calculate = function (arg) {
var oArguments = this._prepareArguments(arg, arguments[1], true, [null, cElementType.array]);
var argClone = oArguments.args;
//1 argument - array
argClone[0] = argClone[0].tocNumber();
argClone[2] = undefined !== argClone[2] ? argClone[2].tocNumber() : new cNumber(0);
var argError;
if (argError = this._checkErrorArg(argClone)) {
return this.value = argError;
}
var calcTDist = function(argArray){
var number = argArray[0];
var ref = argArray[1];
var order = argArray[2];
if(!ref.length){
return new cError(cErrorType.wrong_value_type);
}
var changedRef = [];
for(var i = 0; i < ref.length; i++){
if(cElementType.number === ref[i].type){
changedRef.push(ref[i]);
}
}
var res = rank(number, changedRef, order);
return null !== res && !isNaN(res) ? new cNumber(res) : new cError(cErrorType.wrong_value_type);
};
return this.value = this._findArrayInNumberArguments(oArguments, calcTDist);
};
/** /**
* @constructor * @constructor
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment