| 1234567891011121314151617 | /*! *  * Spread.Sheets Library 10.0.1 *  * Copyright(c) GrapeCity, Inc.  All rights reserved. *  * Licensed under the SpreadJS Commercial License. * spread.sales@grapecity.com * http://spread.grapecity.com/spreadjs/eula/ *  *  */var GC=GC||{};GC.Spread=GC.Spread||{},GC.Spread.CalcEngine=function(a){var b={};function c(d){if(b[d])return b[d].exports;var e=b[d]={exports:{},id:d,loaded:!1};return a[d].call(e.exports,e,e.exports,c),e.loaded=!0,e.exports}return c.m=a,c.c=b,c.p="/assets/",c(0)}([function(a,b,c){var d=c(1);c(3),c(4),c(5),d.SR={},d.SR.en=c(6),a.exports=d},function(a,b,c){var d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z,$,_,aa,ba,ca,da,ea,fa,ga,ha,ia,ja,ka,la=c(2),ma={},na=ma.Functions={},oa="number",pa="string",qa="boolean",ra="TRUE",sa="FALSE",ta="#NULL!",ua="#DIV/0!",va="#VALUE!",wa="#REF!",xa="#NAME?",ya="#N/A",za="#NUM!",Aa=[ta,ua,va,wa,xa,ya,za],Ba=[0,7,15,23,29,42,36];ma.ErrorList=Aa,d=la.j,e=d.Ca,f=d.Ia,g=ma.BAND_INDEX_CONST=-2147483648,h=ma.MAX_ROW_COUNT=1048576,i=ma.MAX_COLUMN_COUNT=16384,j=la.j.G,k=la.l,l=la.u;function Ca(a){return a&&a.toUpperCase()}m=function(){return la.C(ma.SR)()},n=["o","n","s","b","d"],o=ma.kf=function(a,b,c,d){return{row:a,col:b,rowCount:c,colCount:d}},p=null,q=void 0,r=Math.abs,s=Math.min,t=Math.max,ma.BangSource={},ma.RefErrorSource={},ma.supportRowColumnFormula=!1,u=la.A,v=la.B,w=function(){function a(b){var c=a.nf(b);if(!c)throw m().Exp_NotSupported;this._error=c.error,this._code=c.code}return a.prototype.toString=function(){return this._error},a.prototype.toJSON=function(){return{_calcError:this._error,_code:this._code}},a.parse=function(b){try{return new a(b)}catch(a){return q}},a.nf=function(a){var b,c;if(a)for(b=0;b<Aa.length;b++)if(c=Aa[b],c===a||c===Ca(a))return{error:c,code:Ba[b]};return q},a}(),ma.CalcError=w,x=ma.Errors={},x.Null=new w(ta,0),x.DivideByZero=new w(ua,7),y=x.Value=new w(va,15),z=x.Reference=new w(wa,23),A=x.Name=new w(xa,29),B=x.NotAvailable=new w(ya,42),C=x.Number=new w(za,36),D=ma.pf=function(a,b){return{row:a,col:b}},E=function(a){return a<=2},F=ma.qf=function(a,b,c,d){return{row:a,col:b,rowCount:c,colCount:d}},G=ma.rf=function(a,b,c,d,e,f){var g=new L(1);return g.row=c,g.column=d,g.rowRelative=e,g.columnRelative=f,g.sf=!0,a&&(g.source=a),b&&(g.endSource=b),g},H=ma.uf=function(a,b,c,d,e,f,h,i,j,k){var l=new L(1),m;return l.isFullRow=d===g,l.isFullColumn=c===g,c>e&&(m=c,c=e,e=m,m=h,h=j,j=m),d>f&&(m=d,d=f,f=m,m=i,i=k,k=m),l.row=c,l.column=d,l.endRow=e,l.endColumn=f,l.rowRelative=h,l.columnRelative=i,l.endRowRelative=j,l.endColumnRelative=k,a&&(l.source=a),b&&(l.endSource=b),l};function Da(a,b,c,d){return a===-1&&d>127||b===-1&&c>127||c*d>127}I=ma.CalcArray=function(a){this.array=a},I.prototype={getRowCount:function(){return this.array.length},getColumnCount:function(){return this.array[0].length},getValue:function(a,b){var c=this.array;return a.row!==q&&(a=a.row,b=a.column),a<0||b<0||a>=c.length||b>=c[0].length?y:this.array[a][b]},getValueByIndex:function(a){var b=this.getColumnCount(),c=Math.floor(a/b),d=a%b;return this.getValue(c,d)},toArray:function(a,b,c,d,e){var f,g,h,i,j=this,k=1,l=1,m=[],n=Ja.CalcConvertedError;for(b=b===q||b,k=j.getRowCount(),l=j.getColumnCount(),h=0;h<k;h++)for(b||(g=[],m.push(g)),i=0;i<l;i++){if(f=j.getValue(h,i),c&&Ja.vf(f))return m=[f],m.isError=!0,m;if(f=Ja.wf(f,a,!1,e),d&&f===n)return m=[f],m.isError=!0,m;b?m.push(f):g.push(f)}return m.rowCount=k,m.colCount=l,m.rangeCount=1,m}},J=ma.CalcReference=function(a,b){var c=this;c.xf=a,b?(c.yf=b,c.zf=b.length):c.zf=1},J.prototype={getRangeCount:function(){return this.zf},getRow:function(a){return this.yf?this.yf[a||0].row:0},getColumn:function(a){return this.yf?this.yf[a||0].col:0},getRowCount:function(a){return this.yf?this.yf[a||0].rowCount:this.xf.getRowCount()},getColumnCount:function(a){return this.yf?this.yf[a||0].colCount:this.xf.getColumnCount()},getValue:function(a,b){var c,d,e;if(a.row!==q?(c=a.row,d=a.col):(c=arguments[1],d=arguments[2],b=arguments[0]),b=b||0,c>=0||d>=0){if(e=this.yf,!e)return this.xf.getValue(c,d);if(b<e.length)return this.xf.getValue(c+e[b].row,d+e[b].col)}return z},getValueByIndex:function(a){var b=this.getColumnCount(),c=Math.floor(a/b),d=a%b;return this.getValue(c,d)},isHiddenRow:function(a,b,c){return this.xf.isHiddenRow(b+this.getRow(a),c)},isSubtotal:function(a,b,c){var d,e=this.xf;return 0===a&&b<e.getRowCount()&&c<e.getColumnCount()&&(d=e.getCalcSourceModel().getExpression(b,c),d&&7===d.type&&"SUBTOTAL"===d.functionName)},getSource:function(){return this.xf},create:function(a){return new J(this.xf,a)},toArray:function(a,b,c,d,e){return this.xf.referenceToArray(this,a,b,c,d,e)}},K=ma.ExpressionType={unknow:0,reference:1,number:2,string:3,boolean:4,error:5,array:6,function:7,name:8,operator:9,parentheses:10,missingArgument:11,expand:12,structReference:13},L=ma.Expression=function(){function a(a){var b=this;b.type=a,1===a&&(b.tf=function(){var a=this;return a.isFullRow&&a.isFullColumn?3:a.isFullRow?1:a.isFullColumn?2:0},b.getRange=function(a,c){return M(b,a,c)},b.offset=function(a,b,c){var d,e=this;return e.sf?G(e.source,e.endSource,e.row+(e.rowRelative||c?a:0),e.column+(e.columnRelative||c?b:0),e.rowRelative,e.columnRelative):(d=H(e.source,e.endSource,e.row+(e.rowRelative||c?a:0),e.column+(e.columnRelative||c?b:0),e.endRow+(e.isFullColumn||!e.endRowRelative&&!c?0:a),e.endColumn+(e.isFullRow||!e.endColumnRelative&&!c?0:b),e.rowRelative,e.columnRelative,e.endRowRelative,e.endColumnRelative),d.isFullRow=e.isFullRow,d.isFullColumn=e.isFullColumn,d)},b.offset2=function(a,b,c,d){var e=this,f=H(e.source,e.endSource,e.row+(e.isFullColumn?0:a),e.column+(e.isFullRow?0:b),e.endRow+(e.isFullColumn?0:c),e.endColumn+(e.isFullRow?0:d),e.rowRelative,e.columnRelative,e.endRowRelative,e.endColumnRelative);return f.isFullRow=e.isFullRow,f.isFullColumn=e.isFullColumn,f})}return a.prototype.offset=function(a,b,c){var d,e,f,g=this,h=g.type;if(10===h)return ea(g.value.offset(a,b,c));if(7===h){for(d=g.arguments,e=[],f=0;f<d.length;f++)e.push(d[f].offset(a,b,c));return ca(g.function,e)}return 9===h?da(g.operatorType,g.value.offset(a,b,c),g.value2&&g.value2.offset(a,b,c)):this},a}(),M=ma.getRangeForReference=function(a,b,c){var d={row:-1,col:-1,rowCount:-1,colCount:-1},e,f,g,j;return a.isFullRow?(d.col=-1,d.colCount=-1):(a.columnRelative?(g=a.column+c,g=g>=i?g%i:g):g=a.column,a.sf?(d.col=g,d.colCount=1):(a.endColumnRelative?(j=a.endColumn+c,j=j>=i?j%i:j):j=a.endColumn,d.col=g<=j?g:j,d.colCount=r(j-g)+1)),a.isFullColumn?(d.row=-1,d.rowCount=-1):(a.rowRelative?(e=a.row+b,e=e>=h?e%h:e):e=a.row,a.sf?(d.row=e,d.rowCount=1):(a.endRowRelative?(f=a.endRow+b,f=f>=h?f%h:f):f=a.endRow,d.row=e<=f?e:f,d.rowCount=r(f-e)+1)),d},N=ma.CalcSource=function(){function a(b){this.id=a.sourceId++,this.Af=b,this.Bf=null}return a.sourceId=1,a}(),N.prototype={getCalcService:function(){return this.Af},Cf:function(){return this.Af},setCalcService:function(a){this.Af=a},getCalcSourceModel:function(){return this.Bf},setCalcSourceModel:function(a){this.Bf=a},getValue:function(a,b){return p},getName:function(){return""},setValue:function(a,b){},getReference:function(a){return new J(this,a)},getSources:function(a){return[this]},referenceToArray:function(a,b,c,d,e,f){var g,h,i,j,k,l,m,n,o,r,s,t,u=this,v=1,w=1,x=[],z=a.getRangeCount();if(0===z)return x.isError=!0,[];for(m=u.getRowCount(),n=u.getColumnCount(),c=c===q||c,o=0;o<z;o++){if(c||(l=[],x.push(l)),v=a.getRowCount(o),0===v)return x.isError=!0,[];if(w=a.getColumnCount(o),0===w)return x.isError=!0,[];for(i=a.getRow(o),j=a.getColumn(o),v=Math.min(i+v,m)-i,w=Math.min(j+w,n)-j,s=0;s<v;s++)for(g=i+s,c||(r=[],l.push(r)),t=0;t<w;t++){if(h=j+t,k=u.getValue(g,h),d&&Ja.vf(k))return x=[k],x.isError=!0,x;if(k=Ja.convertValue(k,b,!0,f),e&&k===Ja.CalcConvertedError)return x=[y],x.isError=!0,x;k===p&&f||(c?x.push(k):r.push(k))}}return c||1!==z||(x=x[0]),x.rowCount=v,x.colCount=w,x.rangeCount=z,x},getSheetReference:function(){var a=this;return a.Df=a.Df||new J(a),a.Df},setFormula:function(a,b){},setArrayFormula:function(a,b){},getRowCount:function(){return 1e3},getColumnCount:function(){return 100},isHiddenRow:function(a,b){return!1},getParserContext:function(a,b,c){return new ma.ParserContext(this,a,b,c)},startCalculation:function(){},endCalculation:function(){},getEvaluatorContext:function(a,b,c){return new ma.EvaluateContext(this,a,b,c)},getCustomFunction:function(a){return p},getCustomName:function(a){return p},refresh:function(){},toJSON:function(a,b){}},O=ma.CalcSourceModel=function(){function a(a,b){var c=this;c.Ef=0,c.Ff=0,c.Gf=[],c.dataTable={},c.dataTableByName={},c.Hf=[],c.If=[],c.Jf=p,c.xf=b,c.Af=a,c.B5=0}return a}(),O.prototype={getNode:function(a,b,c){var d,e=this,f=p;return a>=0&&b>=0?(d=e.dataTable[a],c&&!d&&(d=e.dataTable[a]={},a>e.Ef&&(e.Ef=a)),d&&(f=d[b],c&&!f&&(f=d[b]={},b>e.Ff&&(e.Ff=b)))):a===-1&&b>=0?(f=e.If[b],c&&!f&&(f=e.If[b]={},b>e.Ff&&(e.Ff=b))):a>=0&&b===-1?(f=e.Hf[a],c&&!f&&(f=e.Hf[a]={},b>e.Ff&&(e.Ff=b))):a===-1&&b===-1&&(f=e.Jf,c&&!f&&(f=e.Jf={})),f},getNodeByName:function(a,b){var c=this,d=c.dataTableByName[a];return b&&!d&&(d=c.dataTableByName[a]={}),d},Kf:function(a,b){var c=this.getNode(a,b);return c&&c.Lf},Mf:function(a,b){var c=this.getNode(a,b);return c&&c.Nf},getExpr:function(a,b){return this.Kf(a,b)},getArray:function(a,b){return this.Of(a,b)},Of:function(a,b){var c=this.getNode(a,b);return c&&c.Pf},Qf:function(a,b){var c=this.getWorkingNode(a,b);return c&&c.Pf},getWorkingExpression:function(a,b){var c=this.getWorkingNode(a,b);return c&&c.Nf},getExpression:function(a,b){var c=this.getWorkingNode(a,b);return c&&c.Lf},getWorkingExpressionByName:function(a){var b=this.getNodeByName(a);return b&&b.Nf},getExpressionByName:function(a){var b=this.getNodeByName(a);return b&&b.Lf},clearAll:function(){var a=this;a.clear(-1,-1,-1,-1),a.dataTable={},a.dataTableByName={},a.Hf=[],a.If=[],a.Jf=p},clear:function(a,b,c,d){this.$b(a,b,c,d)},addRows:function(a,b){var c,d=this,e=d.rC();if(!(a<0||a>e||b<0))for(u(d.dataTable,e,a,b),u(d.Hf,e,a,b),c=0;c<b;c++)d.dataTable[a+c]&&(d.dataTable[a+c]={rs:"n"})},deleteRows:function(a,b){var c=this,d=c.rC();a<0||a>=d||b<=0||(a+b>d&&(b=d-a),v(c.dataTable,d,a,b),v(c.Hf,d,a,b))},addColumns:function(a,b){var c,d,e=this,f=e.rC(),g=e.cC();if(!(a<0||a>g||b<0)){for(c=0;c<f;c++)d=e.dataTable[c],d&&a<g&&u(d,g,a,b);u(this.If,g,a,b)}},deleteColumns:function(a,b){var c,d,e=this,f=e.rC(),g=e.cC();if(!(a<0||a>=g||b<0)){for(c=0;c<f;c++)d=this.dataTable[c],d&&a<g&&v(d,g,a,b);v(this.If,g,a,b)}},Rf:function(a,b,c){var d=this.getNode(a,b,!!c);d&&(d.Lf=c)},Sf:function(a,b){var c=this.getNode(a,b,!0);c&&(c.Lf=q,c.Nf&&(c.Nf=q),c.Pf&&(c.Pf=q),c.isVolatile&&this.Tf(c))},Uf:function(a,b,c,d,e){var f,g=this.getNode(b,c);g&&g.Lf&&(f=a.getNode(d,e,!0),g.Pf&&(f.Pf=o(d,e,g.Pf.rowCount-(b-g.Pf.row),g.Pf.colCount-(c-g.Pf.col))),f.Lf=g.Lf,g.Nf&&(f.Nf=g.Nf)),g&&g.isVolatile&&(f.isVolatile=!0)},ega:function(a,b){var c=this.dataTable[a];return c&&c[b]},Wf:function(a,b,c){var d=this.getNode(a,b,!!c);d&&(d.Nf=c)},Xf:function(a,b,c){var d=this.getNode(a,b,!!c);d&&(d.Pf=c)},Yf:function(a,b){var c=this.getNode(a,b);return c&&c.calc},Zf:function(a,b,c){var d=this.getNode(a,b,!0);d&&(d.calc&&d.calc.isVolatile&&this.Tf(d),d.calc=c,c&&(c.node=d))},Q3:function(a,b,c){var d=this.getNode(a,b,!0);d&&d.calc&&(d.calc.isVolatile&&this.Tf(d),this.Af.Bh(d.calc,c),d.calc=q)},$f:function(a,b,c,d,e){var f,g=this;c>=0&&d>=0?(f=g.dataTable[c],f||(f=g.dataTable[c]={}),f[d]=e,e&&e.calc&&delete e.calc):c>=0&&d===-1&&a>=0&&b===-1?g.Hf[c]=e:d>=0&&c===-1&&b>=0&&a===-1&&(g.If[d]=e)},_f:function(a,b,c,d){var e=this,f=e.getNode(a,b),g=e.getNode(c,d);f?e.$f(a,b,c,d,f):g&&e.$f(a,b,c,d,p),g?e.$f(c,d,a,b,g):f&&e.$f(c,d,a,b,p)},ag:function(){return this.Gf},bg:function(a){a.isVolatile||(a.isVolatile=!0,this.Gf.push(a))},Tf:function(a){var b,c,d,e;if(a.isVolatile=void 0,b=this,b.B5++,b.B5>100){for(b.B5=0,c=[],d=b.Gf,e=0;e<length;e++)d[e].isVolatile&&c.push(d[e]);b.Gf=c}},cg:function(a,b){var c,d;for(c=0;c<a.length;c++)d=a[c],d&&(1&b)>0&&(d.Pf&&(d.Pf=q),d.Lf&&(d.Lf=q),d.Nf&&(d.Nf=q))},getCalcService:function(){return this.Af},setCalcService:function(a){this.Af=a},Cf:function(){return this.Af},getSource:function(){return this.xf},hasFormula:function(a,b){return a=a!==q?a:-1,b=b!==q?b:-1,!!this.getExpression(a,b)},setFormula:function(a,b,c,d,e,f){var g,h,i,j=this;if(c&&0===c.length&&(c=p),!e&&j.dg(a,b,1,1)&&j.eg(),g=j.getFormula(a,b),f||g!==c&&(""!==g||c)&&(g||""!==c)){if(h=j.Cf(),i=p,h)try{i=d||(c?h.parse(j.xf,c,a>=0?a:0,b>=0?b:0,!1,e,e):p),j.fg(a,b,i,q,!1)}catch(a){if(!e)throw a}a>=0&&b>=0&&j.xf.setFormula(a,b,c)}},getFormula:function(a,b,c){var d,e,f=this.Cf();return f&&(d=this.getExpression(a,b))?(e=this.Qf(a,b),a=e?e.row:a,b=e?e.col:b,f.unparse(this.xf,d,a,b,c)):p},setFormulaByName:function(a,b,c){var d,e,f,g;if(a&&(a=Ca(a),d=this,b&&0===b.length&&(b=p),e=d.getFormulaByName(a),e!==b&&(""!==e||b)&&(e||""!==b))){if(f=d.Cf(),g=p,f)try{g=b?f.parse(d.xf,b,0,0,!1,c):p,d.gg(a,g,q,!1)}catch(a){if(!c)throw a}d.xf.setFormula({name:a},b)}},getFormulaByName:function(a){var b,c=this.Cf();return c&&a&&(b=this.getExpressionByName(Ca(a)))?c.unparse(this.xf,b,0,0):p},eg:function(){throw m().Exp_ArrayFromulaPart},rC:function(){return Math.min(this.xf.getRowCount())},cC:function(){return Math.min(this.xf.getColumnCount())},setArrayFormula:function(a,b,c,d,e,f){var g,h,i,j,k=this;if(e&&0===e.length&&(e=p),k.dg(a,b,c,d)&&k.eg(),a=a<0?0:a,b=b<0?0:b,g=k.Cf(),g&&(k.$b(a,b,c,d),e)){try{h=e?g.parse(k.xf,e,a,b,!1,f,f):p}catch(a){if(!f)throw a;return}for(i=a;i<a+c;i++)for(j=b;j<b+d;j++)k.fg(i,j,h,o(a,b,c,d),!1);a>=0&&b>=0&&k.xf.setArrayFormula(a,b,c,d,g.unparse(k.xf,h,a,b))}},getWorkingNode:function(a,b){var c,d=this,e=d.xf;return a>=e.getRowCount()||b>=e.getColumnCount()?c:(a>=0&&b>=0?(c=d.getNode(a,b),c||(c=d.getNode(a,-1)),c||(c=d.getNode(-1,b))):c=a>=0&&b===-1?d.getNode(a,-1):a===-1&&b>=0?d.getNode(-1,b):d.getNode(-1,-1),c)},fg:function(a,b,c,d,e){var f,g,h,i,j,k=this,l=k.Cf();l.lh.asyncManager.endCalcCell(),f=d!==q&&null!==d,g=new ma.EvaluateContext(k.xf,D(f?d.row:a,f?d.col:b),f),h=fa(g,c,f,f?a-d.row:0,f?b-d.col:0),h=h===c?q:h,d!==q&&(i=d),a>=0&&b>=0?((e===q||e)&&(j=c?l.unparse(k.xf,c,a>=0?a:0,b>=0?b:0):q,k.xf.setFormula(a,b,j)),k.ig(a,b,c,h,i)):a>=0&&b===-1?k.jg(a,c,h):a===-1&&b>=0&&k.kg(b,c,h),l.autoCalculation&&!l.IsSuspended()&&l.recalculateAll(!1)},gg:function(a,b,c,d){var e,f=this,g=f.Cf(),h=new ma.EvaluateContext(f.xf,D(0,0),(!1)),i=fa(h,b,!1,0,0);i=i===b?q:i,(d===q||d)&&(e=b?g.unparse(f.xf,b,0,0):q,f.xf.setFormulaByName(a,e)),f.lg(a,b,i),g.autoCalculation&&!g.IsSuspended()&&g.recalculateAll(!1)},getRowExpression:function(a){return this.getExpression(a,-1)},getColumnExpression:function(a){return this.getExpression(-1,a)},lg:function(a,b,c){var d,e=this,f=e.mg(a,!0);f&&(f.ng(),d=this.getNodeByName(a,!0),d.Lf=b,c=b&&c?c:void 0,d.Nf=c,f.og(),e.Af.pg(f,3))},ig:function(a,b,c,d,e){var f,g=this;f=e?g.qg(a,b,!0):g.qg(a,b,!0),f&&(f.ng(),g.Rf(a,b,c),c?((d||g.Mf(a,b))&&g.Wf(a,b,d),(e||g.Qf(a,b))&&g.Xf(a,b,e)):(g.Wf(a,b,q),g.Xf(a,b,q)),f.og(),g.Af.pg(f,0))},jg:function(a,b,c){var d=this,e=d.rg(a,!0);e&&(e.ng(),d.Rf(a,-1,b),(c||d.Mf(a,-1))&&d.Wf(a,-1,c),e.og(),d.Af.pg(e,1))},kg:function(a,b,c){var d=this,e=d.sg(a,!0);e&&(e.ng(),d.Rf(-1,a,b),(c||d.Mf(-1,a))&&d.Wf(-1,a,c),e.og(),d.Af.pg(e,2))},$b:function(a,b,c,d){var e,f,g,h,i,j=this,k=a<0?0:a,l=b<0?0:b,m=a<0?j.rC():c,n=b<0?j.cC():d,r=k+m-1,s=l+n-1,t=function(a,b){if(e=j.Mf(a,b),f=j.Kf(a,b),e||f){g=j.Of(a,b);var c=g?o(g.row,g.col,g.rowCount,g.colCount):q;j.fg(a,b,p,c,!0)}};for(h=k;h<=r&&h>=0;h++)for(b<0&&t(h,-1),i=l;i<=s&&i>=0;i++)h===k&&a<0&&t(-1,i),t(h,i);a<0&&b<0&&t(a,b)},dg:function(a,b,c,d){return this.tg(a,b,c,d,!0,!0)},tg:function(a,b,c,d,e,f){var g,h,i,j,k,l,m=this,n=a<0?0:a,p=b<0?0:b,q=a<0?m.rC():c,r=b<0?m.cC():d,s=n+(0===q?1:q)-1,t=p+(0===r?1:r)-1,u=!1,v=[],w=[],x=m.dataTable;for(i=n;i<=s&&i>=0&&!(i>m.Ef);i++)if(h=x[i])for(j=p;j<=t&&j>=0&&!(j>m.Ff);j++)if(g=h[j])if(k=g.Pf){if(k.row<n||k.row+k.rowCount-1>s||k.col<p||k.col+k.colCount-1>t){if(e)return!0;u=!0}if(i!==k.row&&i!==n)continue;v.push(o(k.row,k.col,k.rowCount,k.colCount)),l=g.Lf,w.push(l),j=k.col+k.colCount-1}else!f&&(l=g.Lf)&&(v.push({row:i,col:j}),w.push(l));return!e&&{hasPart:u,ranges:v,formulas:w}},mg:function(a,b){var c=this,d=p,e=c.getNodeByName(a,b);return e&&(d=e.calc,!d&&b&&(d=new Z(c,a),e.calc=d,d.node=e)),d},qg:function(a,b,c){var d,e,f,g=this,h=p;if(a>=0&&b>=0){if(d=g.dataTable,e=d[a],!e){if(!c)return h;e=d[a]={},a>g.Ef&&(g.Ef=a)}if(f=e[b],!f)return c&&(f=e[b]={},h=new V(g,a,b),f.calc=h,h.node=f,b>g.Ff&&(g.Ff=b)),h;h=f.calc,!h&&c&&(h=new V(g,a,b),f.calc=h,h.node=f,a>g.Ef&&(g.Ef=a),b>g.Ff&&(g.Ff=b))}return h},rg:function(a,b){var c=this,d=p;return a>=0&&(d=c.Yf(a,-1),!d&&b&&(d=new W(c,a),c.Zf(a,-1,d),a>c.Ef&&(c.Ef=a))),d},sg:function(a,b){var c=this,d=p;return a>=0&&(d=c.Yf(-1,a),!d&&b&&(d=new X(c,a),c.Zf(-1,a,d),a>c.Ff&&(c.Ff=a))),d},ug:function(a){var b=this;return!b.vg&&a&&(b.vg=new $(b)),b.vg},wg:function(a,b){var c=this,d=p;return c.xg||(c.xg={}),d=c.xg[a],!d&&b&&(d=c.xg[a]=new Y(c,a)),d},yg:function(a,b){var c,d,e=this,f=Math.min(e.Ff,a+b-1);for(c=a;c!==-1&&c<=f;c++)e.isDirty(-1,c)&&(d=e.sg(c,!0),e.Af.pg(d,2))},zg:function(a,b){var c,d,e=this,f=Math.min(e.Ef,a+b-1);for(c=a;c!==-1&&c<=f;c++)e.isDirty(c,-1)&&(d=e.rg(c,!0),e.Af.pg(d,1))},Ag:function(a,b,c,d){var e,f,g,h,i=this,j=Math.min(i.Ef,a+c-1),k=Math.min(i.Ff,b+d-1);for(e=a;e<=j;e++)for(f=b;f<=k;f++)i.ega(e,f)&&(g=i.qg(e,f,!0),i.Af.pg(g,0));i.zg(a,c),i.yg(b,d),h=i.ug(!1),h&&h.Bg(a,b,c,d)},Cg:function(){var a,b,c,d,e,f=this,g=f.ag();for(c=0;c<g.length;c++)d=g[c],d&&d.isVolatile&&d instanceof V&&!f.Af.Dg(d)&&(e=f.qg(d.row,d.column,!0),f.Af.pg(e,0),a=f.rg(d.row,!1),a&&!f.Af.Eg(a)&&f.zg(d.row,1),b=f.sg(d.column,!1),b&&!f.Af.Eg(b)&&f.yg(d.column,1))},Fg:function(){for(var a,b,c,d,e,f=this,g=f.ag(),h=!0,i=5;h&&i;){for(h=!1,i--,c=0;c<g.length;c++)d=g[c],d&&d.isVolatile&&d instanceof V&&!f.Af.Dg(d)&&f.recalculateCell(d.row,d.column)&&(h=!0,e=f.qg(d.row,d.column,!0),f.Af.pg(e,0),a=f.rg(d.row,!1),a&&!f.Af.Eg(a)&&f.zg(d.row,1),b=f.sg(d.column,!1),b&&!f.Af.Eg(b)&&f.yg(d.column,1));h&&f.Af.Gg(!0)}},isDirty:function(a,b){return!(!this.Yf(a,b)&&!this.Kf(a,b))},recalculateCell:function(a,b){var c,d,e,f,g,h,i,j,k,l=this,m=l.xf,n=l.getWorkingExpression(a,b)||l.getExpression(a,b);if(n){if(c=D(a,b),d=m.getValue(a,b),e=!1,j=l.Qf(a,b),j&&(e=!0,f=j.row,g=j.col,h=j.rowCount,i=j.colCount),this.Af.lh.asyncManager.startCalcCell(this.xf,c),k=l.Af.Hg(l.xf,n,c,e,!0,j&&F(f,g,h,i)),d===k)return;return!(d instanceof Date&&k instanceof Date&&d.valueOf()===k.valueOf())&&(m.setValue(a,b,k),this.Af.lh.asyncManager.endCalcCell(this.xf,c),!0)}return!1},recalculateNameID:function(a){var b,c,d=this,e=d.xf,f=d.getWorkingExpressionByName(a)||d.getExpressionByName(a);if(f){if(b=e.getValueByName(a),c=d.Af.Hg(d.xf,f,{name:a},!1,!0),b===c)return;if(b instanceof Date&&c instanceof Date&&b.valueOf()===c.valueOf())return;e.setValueByName(a,c)}},Ig:function(a,b,c,d,e,f){for(var g,h,i,j,k,l,m,n,o,q,r,s,t,u,v,w,x,y,z,A,B,C,D,E,F,I,J,K,L,N,O,P,Q=this;12===d.type;)d=d.value;for(;10===d.type;)d=d.value;for(;12===d.type;)d=d.value;if(13===d.type){if(g=d.getRange(b,c,!0),g===p)return;d=1===g.rowCount&&1===g.colCount?G(p,p,g.row,g.col,!1,!1):H(p,p,g.row,g.col,g.row+g.rowCount-1,g.col+g.colCount-1,!1,!1,!1,!1)}if(e&&e!==d&&8===e.type&&(x=Ca(e.value),v=e.source||Q.xf,y=v.getCustomName(x),y?w=v.getCalcSourceModel():(w=Q.Af.getGlobalSourceModel()||v.getCalcSourceModel(),y=w.getSource().getCustomName(x),y||(z=v.getCalcSourceModel().wg(x,!0),z.Jg(a,f))),A=w.wg(x,!0),A.Jg(a,f),e=null),1===d.type&&d.endSource)for(B=d,C=B.source.getSources(B.endSource),D=0;D<C.length;D++)E=H(C[D],p,B.row,B.column,B.endRow,B.endColumn,B.rowRelative,B.columnRelative,B.endRowRelative,B.endColumnRelative),E.isFullRow=B.isFullRow,E.isFullColumn=B.isFullColumn,Q.Ig(a,b,c,E,p,f);else if(1===d.type){if(v=d.source||Q.xf,w=v.getCalcSourceModel(),!w)return;if(F=d,I=F.tf(),J=M(d,b,c),j=J.row,l=J.col,n=J.rowCount,o=J.colCount,k=j+n-1,m=l+o-1,0===I){if(0<=b&&0<=c)if(Da(h,i,n,o))K=w.ug(!0),K.Jg(j,l,n,o,a,f);else for(t=j;t<=k;t++)for(u=l;u<=m;u++)q=w.qg(t,u,!0),q&&q.Jg(a,f);else if(0<=b&&c===-1){for(t=j;t<=k;t++)for(u=l;u<=m;u++)F.columnRelative||F.endColumnRelative?(r=w.rg(t,!0),r&&r.Kg(a,-u,f)):(q=w.qg(t,u,!0),q&&q.Lg(a,f));for(t=j;t<=k;t++)for(u=l;u<=m;u++)F.rowRelative||F.endRowRelative?(s=w.sg(u,!0),s&&s.Mg(a,-t,f)):(q=w.qg(t,u,!0),q&&q.Ng(a,f))}}else if(1===I){if(0<=b&&0<=c)for(t=j;t<=k;t++)r=w.rg(t,!0),r&&r.Jg(a,f);else if(0<=b&&c===-1);else if(b===-1&&0<=c)if(F.rowRelative||F.endRowRelative);else for(j=F.row,k=F.endRow,t=j;t<=k;t++)r=w.rg(t,!0),r&&r.Ng(a,f)}else if(2===I)if(0<=b&&0<=c)for(u=l;u<=m;u++)s=w.sg(u,!0),s&&s.Jg(a,f);else if(0<=b&&c===-1);else if(b===-1&&0<=c)for(u=l;u<=m;u++)s=w.sg(u,!0),s&&s.Ng(a,f)}else if(9===d.type)Q.Ig(a,b,c,d.value,e&&9===e.type&&e.value,f),d.value2&&Q.Ig(a,b,c,d.value2,e&&9===e.type&&e.value2,f);else if(8===d.type){if(v=d.source||Q.xf,x=Ca(d.value),y=v.getCustomName(x),y?w=v.getCalcSourceModel():(w=Q.Af.getGlobalSourceModel()||v.getCalcSourceModel(),y=w.getSource().getCustomName(x),y||(z=v.getCalcSourceModel().wg(x,!0),z.Jg(a,f))),A=w.wg(x,!0),!A)return;A.Jg(a,f),Q.Ig(a,b,c,y,p,f)}else if(7===d.type){if(L=d.function,L&&(L.isVolatile()&&(f?Q.bg(a):Q.Tf(a)),!L.precedentReference()))return;for(N=d.arguments.length,D=0;D<N;D++)Q.Ig(a,b,c,d.arguments[D],e&&7===e.type&&e.arguments[D],f)}else if(25===d.type||26===d.type){if(O=d,v=d.source||Q.xf,w=v.getCalcSourceModel(),P=w.mg(O.value,!0),!P)return;P.Jg(a,f)}},Og:function(a,b){var c=this.getNodeByName(a);c&&(c.Nf||c.Lf)&&this.Ig(this.mg(a),0,0,c.Nf||c.Lf,c.Lf,b)},Pg:function(a,b,c,d,e){var f,g,h,i,j,k=this,l=a+c,m=b+d;for(i=a;i<l;i++)for(j=b;j<m;j++)f=k.Mf(i,j),g=k.Kf(i,j),(f||g)&&(h=k.Of(i,j),h?k.Ig(k.qg(i,j),h.row,h.col,f||g,g,e):k.Ig(k.qg(i,j),i,j,f||g,g,e))},Qg:function(a,b,c){var d,e,f=a+b;for(d=a;d!==-1&&d<f;d++)e=this.getColumnExpression(d),e&&this.Ig(this.sg(d,!1),-1,d,e,e,c)},Rg:function(a,b,c,d){this.Pg(a,b,c,d,!0)},Sg:function(a,b,c,d){this.Pg(a,b,c,d,!1)},Tg:function(a,b){},Ug:function(a,b){},Vg:function(a,b){this.Qg(a,b,!0)},Wg:function(a,b){this.Qg(a,b,!1)},Xg:function(a,b,c,d,e,f){var g,h,i,j=a+c,k=b+d;for(g=a;g<j;g++)for(h=b;h<k;h++)i=this.qg(g,h,!1),i&&(e&&i.Yg(),f&&i.Bg())},Zg:function(a,b,c,d){var e,f,g,h=this.Hf;if(h)for(e=a;e!==-1&&e<a+b&&e<h.length;e++)f=h[e],f&&f.calc&&(g=f.calc,c&&g.Yg(),d&&g.Bg())},$g:function(a,b,c,d){var e,f,g,h=this.If;if(h)for(e=a;e!==-1&&e<a+b&&e<h.length;e++)f=h[e],f&&f.calc&&(g=f.calc,c&&g.Yg(),d&&g.Bg())},_g:function(a,b,c,d,e,f){var g,h,i;(e||f)&&(g=this,0<=a&&0<=b?(g.Xg(a,b,c,d,e,f),g.Zg(a,c,e,f),g.$g(b,d,e,f),g.vg&&(e&&g.vg.Yg(a,b,c,d),f&&g.vg.Bg(a,b,c,d))):0<=a&&b===-1?(g.Xg(a,0,c,g.cC(),e,f),g.Zg(a,c,e,f),g.vg&&(e&&g.vg.Yg(a,b,c,d),f&&g.vg.Bg(a,b,c,d))):a===-1&&0<=b?(g.Xg(0,b,g.rC(),d,e,f),g.$g(b,d,e,f),g.vg&&(e&&g.vg.Yg(a,b,c,d),f&&g.vg.Bg(a,b,c,d))):a===-1&&b===-1&&(h=g.rC(),i=g.cC(),g.Xg(0,0,h,i,e,f),g.Zg(0,h,e,f),g.$g(0,i,e,f),g.vg&&(e&&g.vg.Yg(a,b,c,d),f&&g.vg.Bg(a,b,c,d))))},getAllNodes:function(){var a,b,c,d=[],e=this.dataTable,f=this.Hf,g=this.If,h=this.Jf;h&&d.push(h);for(b in f)d.push(f[b]);for(b in g)d.push(g[b]);for(c in e){a=e[c];for(b in a)d.push(a[b])}return d},toJSON:function(a){this.xf.toJSON(a,this.dataTable,this.Ef,this.Ff)}},P="cellListeners",Q="rowListeners",R="columnListeners",S="rowSliceListeners",T="columnSliceListeners",U=ma.BaseCalc=function(){function a(a){this.cellListeners=[],this.rowListeners=[],this.columnListeners=[],this.ah=a}return a}(),U.prototype={hasListeners:function(){var a,b,c=this,d=c.Ze;for(a=0;a<d.length;a++)if(b=c[d[a]],b&&b.length>0)return!0;return!1},Jg:function(a,b){var c,d=this.cellListeners;if(b)d.push(a);else for(c=0;c<d.length;c++)if(d[c]===a)return void d.splice(c,1)},Lg:function(a,b){var c,d=this.rowListeners;if(b)d.push(a);else for(c=0;c<d.length;c++)if(d[c]===a)return void d.splice(c,1)},Ng:function(a,b){var c,d=this.columnListeners;if(b)d.push(a);else for(c=0;c<d.length;c++)if(d[c]===a)return void d.splice(c,1)},Yg:function(){var a,b,c,d,e,f=this.Ze;for(b=0;b<f.length;b++)if(c=this[f[b]])for(d=c.length,e=0;e<d;e++)a=c[e],a.bh()},Bg:function(){var a,b,c,d,e,f=this.Ze;for(b=0;b<f.length;b++)if(c=this[f[b]])for(d=c.length,e=0;e<d;e++)a=c[e],a.dh||a.eh||a.fh()},gh:function(a){var b,c,d,e,f,g=this.Ze,h=a?1:-1;for(c=0;c<g.length;c++)if(d=this[g[c]])for(e=d.length,f=0;f<e;f++)b=d[f],b.delay+=h},bh:function(){},fh:function(){},ng:function(){},og:function(){}},V=ma.CellCalc=function(a){j(b,a);function b(b,c,d){a.call(this,b);var e=this;e.row=c,e.column=d,e.delay=0,e.Ze=[P,Q,R]}return b}(U),f(V.prototype,{og:function(){var a=this;a.ah.Rg(a.row,a.column,1,1)},ng:function(){var a=this;a.ah.Sg(a.row,a.column,1,1)},bh:function(){this.ah.Cf().ih().hh(this,0)},fh:function(){this.ah.Cf().pg(this,0)}});function Ea(a,b,c){a[b]||(a[b]=[]),a[b].push(c)}function Fa(a,b,c){var d,e=a[b];if(e)for(d=0;d<e.length;d++)if(e[d]===c)return void e.splice(d,1)}W=ma.RowCalc=function(a){j(b,a);function b(b,c){a.call(this,b);var d=this;d.row=c,d.Ze=[P,Q,S,R]}return b}(U),f(W.prototype,{incrementDelay2:function(a,b){},decrementDelay2:function(a,b){},og:function(){this.ah.Tg(this.row,1)},ng:function(){this.ah.Ug(this.row,1)},Kg:function(a,b,c){c?Ea(this,S,{row:a,columnOffset:b,columnCount:1}):Fa(this,S,{row:a,columnOffset:b,columnCount:1})},bh:function(){this.ah.Cf().ih().hh(this,1)},fh:function(){this.ah.Cf().pg(this,1)}}),X=ma.ColumnCalc=function(a){j(b,a);function b(b,c){a.call(this,b);var d=this;d.column=c,d.Ze=[P,Q,R,T]}return b}(U),f(X.prototype,{incrementDelay2:function(a,b){},decrementDelay2:function(a,b){},og:function(){this.ah.Vg(this.column,1)},ng:function(){this.ah.Wg(this.column,1)},Mg:function(a,b,c){this.Ng(a,c)},bh:function(){this.ah.Cf().ih().hh(this,2)},fh:function(){this.ah.Cf().pg(this,2)}}),Y=ma.NameCalc=function(a){j(b,a);function b(b,c){a.call(this,b),this.name=c,this.Ze=[P,Q,R]}return b}(U),f(Y.prototype,{updateListening:function(a,b){var c,d,e,f,g,h,i,j=this,k=j.Ze;for(e=0;e<k.length;e++)if(f=j[k[e]])for(g=f.length,h=f.slice(),i=0;i<g;i++)c=h[i],d=c.node,c.ng(),d&&(!d.Pf||d.Pf.row===c.row&&d.Pf.col===c.column)&&c.ah.fg(c.row,c.column,d.Lf,d.Pf,!0)},updateListeningOnRemoved:function(){var a,b,c,d,e,f,g,h,i,j,k,l=this,m=l.Ze,n=l.ah,o=n.Cf();for(f=0;f<m.length;f++)if(g=l[m[f]])for(h=g.length,i=0;i<h;i++)a=g[i],b=a.ah,c=a.row,d=a.col,c=c===q?-1:c,d=d===q?-1:d,e=b.getExpr(c,d),j=b.Qf(c,d),e&&(k=o.ih().adjustFormulaOnRemoveName(n,e,l.name),k!==e&&b.fg(c,d,k,j,!0))},fh:function(){var a,b,c,d,e,f=this.Ze;for(b=0;b<f.length;b++)if(c=this[f[b]])for(d=c.length,e=0;e<d;e++)a=c[e],a.fh()}}),Z=ma.NameIDCalc=function(a){j(b,a);function b(b,c){a.call(this,b);var d=this;d.name=c,d.delay=0,d.Ze=[P,Q,R]}return b}(U),f(Z.prototype,{og:function(){var a=this;a.ah.Og(a.name,!0)},ng:function(){var a=this;a.ah.Og(a.name,!1)},bh:function(){this.ah.Cf().ih().hh(this,3)},fh:function(){this.ah.Cf().pg(this,3)}}),$=ma.RangeCalc=function(){function a(a){this.ah=a,this.Ze=[P,Q,R]}return a}(),f($.prototype,{processListener:function(a,b,c,d,e,f,g){var h,i,j=this,k=j[a],l=b+","+c+","+d+","+e;if(k||(j[a]=k={}),h=k[l],!h){if(!g)return;h=k[l]=[],h.row=b,h.column=c,h.rowCount=d,h.colCount=e}if(g){for(i=0;i<h.length;i++)if(h[i]===f)return;h.push(f)}else for(i=0;i<h.length;i++)h[i]===f&&h.splice(i,1)},Jg:function(a,b,c,d,e,f){this.processListener(P,a,b,c,d,e,f)},Lg:function(a,b,c,d,e,f,g,h,i){this.processListener(Q,a,b,c,d,e,i)},Ng:function(a,b,c,d,e,f,g,h,i){this.processListener(R,a,b,c,d,e,i)},Yg:function(a,b,c,d){this.visit(0,a,b,c,d)},visit:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,n,o,p,q=this.Ze;for(h=0;h<q.length;h++)if(i=this[q[h]])for(g in i)if(j=i[g],k=j.row,l=j.column,m=j.rowCount,n=j.colCount,(k===-1||b===-1||k<b+d&&b<k+m)&&(l===-1||c===-1||l<c+e&&c<l+n))for(o=j.length,p=0;p<o;p++)f=j[p],0===a?f.bh():f.fh()},Bg:function(a,b,c,d){this.visit(1,a,b,c,d)},gh:function(a,b,c){var d,e,f,g,h,i,j,k=this.Ze,l=c?1:-1;for(e=0;e<k.length;e++)if(f=this[k[e]])for(g in f)if(h=f[g],d=h,(d.row===-1||d.row<=a&&a<d.row+d.rowCount)&&(d.col===-1||d.col<=b&&b<d.col+d.colCount))for(i=h.length,j=0;j<i;j++)h[j].delay+=l},og:function(){},ng:function(){}}),_=ma.CalcService=function(){function a(){var a=this;a.jh={},a.autoCalculation=!0,a.maximumIterations=1e3,a.maximumChange=.01,a.kh=new ma.Parser,a.lh=new ma.Evaluator(a),a.useR1C1=!1,a.mh=0,a.nh=ma.CalcOperatorAdjustor&&new ma.CalcOperatorAdjustor}return a}(),_.prototype={dispose:function(){var a=this;a.jh={},a.oh=p},cloneFrom:function(a){var b=this;b.useR1C1=a.useR1C1,b.mh=a.mh,b.qh=a.qh},ih:function(){return this.nh},getSourceModel:function(a){var b=this.jh[a.id];return b||(b=this.jh[a.id]=new O(this,a),a.setCalcSourceModel(b),a.setCalcService(this)),b},getGlobalSourceModel:function(a){return!this.oh&&a&&(this.oh=new O(this,a)),this.oh},setSourceModel:function(a,b){this.jh[a.id]=b,b.setCalcService(this)},getAllSouceModels:function(){var a,b=[],c=this.jh;for(a in c)b.push(c[a]);return b},removeSource:function(a){var b=this.jh[a.id];b&&(this.nh.ph(a),delete this.jh[a.id])},clearSource:function(){this.jh={},this.clearDirties()},ignoreDirty:function(){return this.qh},suspend:function(a){this.mh++,this.qh=!!a||a},resume:function(a){var b=this;b.mh--,b.mh<0&&(b.mh=0),b.IsSuspended()||(b.rh=p,b.qh=!1,b.recalculateAll(a))},clearDirties:function(){var a,b,c,d=this,e=[d.sh,d.th,d.uh,d.vh];for(c=0;c<e.length;c++)for(a=e[c];a;)b=a.eh,b?(a.eh=b.dh=q,a=b):a=p;d.sh=d.wh=d.th=d.xh=d.uh=d.yh=d.vh=d.zh=p},resumeWithoutCalc:function(){this.mh=0,this.clearDirties()},IsSuspended:function(){return this.mh>0},recalculate:function(a,b,c,d){var e=this.getSourceModel(a);c===-1?e.Ag(b,0,1,e.cC()):b===-1?e.Ag(0,c,e.rC(),1):e.Ag(b,c,1,1),this.IsSuspended()||this.recalculateAll(!1,d)},recalculateByName:function(a,b){var c,d;b&&(c=this.getSourceModel(a),d=c.mg(Ca(b),!0),this.pg(d,3),this.IsSuspended()||this.recalculateAll(!1))},recalcRange:function(a,b,c,d,e){var f=this.getSourceModel(a);c===-1?f.Ag(b,0,d,f.cC()):b===-1?f.Ag(0,c,f.rC(),e):f.Ag(b,c,d,e),this.IsSuspended()||this.recalculateAll(!1)},recalculateAll:function(a,b){var c,d,e,f,g,h=this;if(!h.IsSuspended()){b||h.lh.startCache(),d=h.jh;for(e in d)c=d[e],c.getSource().startCalculation(),a!==!1?(f=c.cC(),g=c.rC(),c.yg(0,f),c.zg(0,g),c.Ag(0,0,g,f)):b||c.Cg();if(h.Gg(),!b)for(e in d)c=d[e],c.Fg();for(e in d)c=d[e],c.getSource().endCalculation();b||h.lh.endCache()}},Ah:function(a,b){for(var c=a.length,d=b;d;)a[c]=d,c++,d=d.eh},Gg:function(a){var b,c,d,e,f,g,h,i,j,k,l,m,n,o,r,s,t,u,v,w,x,y,z,A,B,C,E;if(void 0===a&&(a=!0),b=this,c=p,d=!1,a){for(r=[],b.uh&&b.Ah(r,b.uh);b.th;){for(e=b.th.ah,k=e.cC(),g=0;g<k;g++)b.pg(e.qg(b.th.row,g,!0),0);b.Bh(b.th,1)}for(;b.uh;){if(e=b.uh.ah,j=e.rC(),j>0)for(f=0;f<j;f++)b.pg(e.qg(f,b.uh.column,!0),0);else b.uh.Bg();b.Bh(b.uh,2)}for(l=b.sh;l;l=l.eh){for(e=l.ah,h=l.row,i=l.column,m=e.rg(h,!1),n=e.sg(i,!1),o=e.ug(!1),l.Bg(),m&&m.Bg(),n&&n.Bg(),o&&o.Bg(h,i,1,1);b.th;){for(e=b.th.ah,k=e.cC(),g=0;g<k;g++)b.pg(e.qg(b.th.row,g,!0),0);b.Bh(b.th,1)}for(;b.uh;){for(s=!1,t=0;t<r.length;t++)if(r[t]===b.uh){s=!0;break}if(s)b.Bh(b.uh,2);else{for(r[r.length]=b.uh,e=b.uh.ah,j=e.rC(),f=0;f<j;f++)b.pg(e.qg(f,b.uh.column,!0),0);b.Bh(b.uh,2)}}}for(u=b.vh;u;u=u.eh)e=u.ah,u.Bg()}for(l=b.sh;l;l=c)e=l.ah,v=e.rC(),w=e.cC(),c=l.eh,l.row<v&&l.column<w?(ma.supportRowColumnFormula&&(n=e.sg(l.column,!1),n&&(n.delay=0)),l.delay=0):b.Bh(l,0);for(u=b.vh;u;u=u.eh)u.delay=0;for(l=b.sh;l;l=l.eh)e=l.ah,f=l.row,g=l.column,m=e.rg(f,!1),n=e.sg(g,!1),o=e.ug(!1),l.gh(!0),m&&m.gh(!0),n&&n.gh(!0),o&&o.gh(f,g,!0);for(u=b.vh;u;u=u.eh)u.gh(!0);do{for(d=!1,l=b.sh;l;l=c)if(c=l.eh,0===l.delay){if(e=l.ah,f=l.row,g=l.column,m=e.rg(f,!1),n=e.sg(g,!1),n&&n.delay)continue;o=e.ug(!1),e.recalculateCell(f,g),b.Bh(l,0),l.gh(!1),m&&m.gh(!1),n&&n.gh(!1),o&&o.gh(f,g,!1),d=!0}for(u=b.vh;u;u=u.eh)0===u.delay&&(e=u.ah,e.recalculateNameID(u.name),b.Bh(u,3),u.gh(!1),d=!0)}while(d);if(b.sh){x=!0;for(y in b.sourceModeles)z=b.jh[y],z.getSource().endCalculation();for(t=0;x&&t<b.maximumIterations;t++)for(x=!1,l=b.sh;l;l=c)c=l.eh,A=l.ah,B=D(f,g),f=l.row,g=l.column,C=A.getSource().getValue(f,g),A.recalculateCell(f,g),E=A.getSource().getValue(f,g),b.Ch(C,E)>=b.maximumChange&&(x=!0);for(l=b.sh;l;l=c)c=l.nextDirty,l.eh=q,c&&(c.dh=q);b.sh=b.wh=q}},Ch:function(a,b){var c=parseFloat(a),d=parseFloat(b);return r(d-c)},initParserContext:function(a){var b=this.Dh;b||(this.Dh=b=a.getParserContext(this.useR1C1))},getParserContext:function(a){var b=this,c=b.Dh;return c||(a?b.Dh=c=a.getParserContext(b.useR1C1):c=new ma.ParserContext(p,b.useR1C1,D(0,0),p)),c.setSource(a),c},parse:function(a,b,c,d,e,f,g){var h,i,j=this,k=j.rh,l=j.getParserContext(a);return l.useR1C1=!g&&j.useR1C1,l.ignoreError=f,l.row=c,l.column=d,l.culture=e,k?(l.useR1C1||(l.useR1C1=!0,b=j.kh.a1ToR1C1(l,b)),(h=k[b])?h:(i=j.kh.parse(l,b),k[b]=i,i)):j.kh.parse(l,b)},unparse:function(a,b,c,d,e,f){var g,h=this.getParserContext(a);return h.useR1C1=this.useR1C1,h.row=c,h.column=d,h.culture=e,f&&(h.Eh=!0,h.useR1C1=!1),g=this.kh.unparse(h,b),h.Eh=!1,g},Dg:function(a){return!!a.dh||a===this.sh},pg:function(a,b){var c=this,d,e;if(0===b)d=c.sh,e=c.wh;else if(1===b)d=c.th,e=c.xh;else if(2===b)d=c.uh,e=c.yh;else{if(3!==b)return;d=c.vh,e=c.zh}a&&!a.dh&&a!==d&&(d?e.eh=a:0===b?c.sh=a:1===b?c.th=a:2===b?c.uh=a:c.vh=a,a.dh=e,a.eh=p,0===b?c.wh=a:1===b?c.xh=a:2===b?c.yh=a:c.zh=a)},Bh:function(a,b){var c,d,e,f=this;if(0===b)c=f.sh;else if(1===b)c=f.th;else if(2===b)c=f.uh;else{if(3!==b)return;c=f.vh}a&&(a.dh||a===c)&&(d=a.dh,e=a.eh,d?d.eh=e:0===b?f.sh=e:1===b?f.th=e:2===b?f.uh=e:f.vh=e,e?e.dh=d:0===b?f.wh=d:1===b?f.xh=d:2===b?f.yh=d:f.zh=d,a.dh=p,a.eh=p)},Eg:function(a){return a.dh||a===this.th},isDirtyColumn:function(a){return a.dh||a===this.uh},Hg:function(a,b,c,d,e,f){var g,h,i,j,k,l,m,n,o=c.row||0,r=c.col||0,s=f?f.row:o,t=f?f.col:r,u=a.getEvaluatorContext(c,d,f),v=this.lh.evaluateExpression(b,u,e,4===arguments.length&&d);if(d&&arguments.length<=5)return v;if(Ja.Fh(v)){if(g=v.getRowCount(0),h=v.getColumnCount(0),1!==v.getRangeCount())return y;try{if(i=d?o-s:o-v.getRow(0),j=d?r-t:r-v.getColumn(0),k=D(0,0),1===g&&1===h);else if(1===g&&h>1&&j>=0&&j<h)k.col=j;else if(g>1&&1===h&&i>=0&&i<g)k.row=i;else{if(!(d&&i<g&&j<h))return d?B:y;k.row=i,k.col=j}v=v.getValue(k,0)}catch(a){return y}}else if(Ja.Ca(v))if(d){if(l=v,m=l.getRowCount(),n=l.getColumnCount(),1!==m&&o-s>=m||1!==n&&r-t>=n)return B;v=v.getValue(1===m?0:o-s,1===n?0:r-t)}else v=v.getValueByIndex(0);return v===q||v===p?e===!1?v:0:v},Gh:function(a,b,c){var d=this,e=d.Dh;return e||(d.Dh=e=a.getParserContext(d.useR1C1)),e.useR1C1=d.useR1C1,e.row=b,e.column=c,e},evaluate:function(a,b,c,d){var e=this,f=e.parse(a,b,c,d);return e.lh.evaluateExpression(f,a.getEvaluatorContext(D(c,d),!1),!1)}},aa=ma.Hh=function(a,b,c){var d=new L(5);return b&&(d.source=b),c&&(d.endSource=c),d.value=a,d},ba=ma.Ih=aa(z),ca=ma.Jh=function(a,b){var c=new L(7);return c.function=a,c.arguments=b,c.functionName=a.name,c};function Ga(a,b){var c=new L(12);return c.value=a,c.needExpendIndexs=b,c}da=ma.Kh=function(a,b,c){var d=new L(9);return d.operatorType=a,d.value=b,d.value2=c,d},ea=ma.Lh=function(a){var b=new L(10);return b.value=a,b};function Ha(a){var b=new L(3);return b.value=a,b}function Ia(a){var b=new L(2);return b.value=a,b}fa=ma.Mh=function(a,b,c,d,e){var f,j,k,l,m,n,o,q,r,s,t,u,v,w,x,z,C,E,F,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z,$,_,ba,fa=function(a,b,c,d,e){return{expr:a,acceptsArray:b,acceptsRef:c,index:d,context:e}},ga=a.row,ha=a.column,ia=[],ja=0,ka=a.arrayIdentity?a.arrayIdentity.row:ga,la=a.arrayIdentity?a.arrayIdentity.col:ha;for(ia[ja]={expr:b,acceptsArray:!1,acceptsRef:!1,index:-1},f=0,j=0,k=!1,l=d,m=e,n=!1;ja>=0;){if(o=ia[ja--],q=o.acceptsArray,r=o.acceptsRef,b=o.expr,s=p,b){if(7===b.type){if(u=b,w=u.arguments.length,!u.function){if(!a){s=aa(A);continue}if(v=a.getFunction(u.functionName),!v){s=aa(A);continue}if(w<v.minArgs||w>v.maxArgs){s=aa(y);continue}u.function=v}if(v=u.function,x=o.index,z=o.neeedExpendindexs,x<0?(o.noExpendCatchValue=n,o.arrayFormulaCatchValue=c,2===v.arrayArgumentEvaluateMode&&(n=!0),1===v.arrayArgumentEvaluateMode&&(c=!0),o.args=[]):(v.acceptsArray(x)?f--:k&&(z||(z=[],o.neeedExpendindexs=z),u.arguments[x]!==t,z.push(x)),o.args.push(t)),x===w-1){if(n=o.noExpendCatchValue,c=o.arrayFormulaCatchValue,C=o.args,E=!1,C&&C.length>0)for(F=0;F<C.length;F++)if(C[F]!==u.arguments[F]){E=!0;break}s=E?ca(u.function,C):b,z&&z.length>0&&(s=Ga(s,z),k=!0)}else k=!1,x++,o.index=x,v.acceptsArray(x)&&f++,ia[++ja]=o,ia[++ja]={expr:u.arguments[x],acceptsArray:v.acceptsArray(x),acceptsRef:v.acceptsReference(x),index:-1}}else if(1===b.type&&b.sf)j&&(b.rowRelative||b.columnRelative)&&(I=b.source!==ma.BangSource&&b.source||a.source,J=I.getRowCount(),K=I.getColumnCount(),L=b.rowRelative?(b.row+ka)%h%J:b.row,M=b.columnRelative?(b.column+la)%i%K:b.column,L=L<0?L+J:L,M=M<0?M+K:M,b=G(b.source,p,L,M,!1,!1));else if(1===b.type||13===b.type){if(13===b.type){if(N=b,O=N.getRange(ga,ha),!O){s=b,t=b;continue}b=H(N.source()===a.source?p:N.source(),p,O.row,O.col,O.row+O.rowCount-1,O.col+O.colCount-1)}P=b.source!==ma.BangSource&&b.source,Q=b,j&&(Q.rowRelative||Q.columnRelative||Q.endRowRelative||Q.endColumnRelative)&&(I=P||a.source,J=I.getRowCount(),K=I.getColumnCount(),R=Q.rowRelative?(Q.row+ka)%J:Q.row,S=Q.columnRelative?(Q.column+la)%K:Q.column,T=Q.endRowRelative?(Q.endRow+ka)%J:Q.endRow,U=Q.endColumnRelative?(Q.endColumn+la)%K:Q.endColumn,R=R<0?R+J:R,S=S<0?S+K:S,T=T<0?T+J:T,U=U<0?U+K:U,R>T&&(V=R,R=T,T=V),S>U&&(V=S,S=U,U=V),b.row===g&&(R=T=g),b.column===g&&(S=U=g),b=H(P,b.endSource,R,S,T,U,!1,!1,!1,!1)),r&&(q||!c)||ga<0||ha<0||(f>0&&!c||0===f||n?(O=Q.getRange(ga,ha),c?!Q.isFullColumn&&1!==O.rowCount&&l>=O.rowCount||!Q.isFullRow&&1!==O.colCount&&m>=O.colCount?s=aa(B):(L=(Q.isFullColumn?0:O.row)+(1===O.rowCount?0:l),M=(Q.isFullRow?0:O.col)+(1===O.colCount?0:m),s=G(P,b.endSource,L,M,!1,!1)):O.rowCount>1&&O.colCount>1||O.rowCount>1&&!Q.isFullColumn&&(ga<O.row||ga>=O.row+O.rowCount)||O.colCount>1&&!Q.isFullRow&&(ha<O.col||ha>=O.col+O.colCount)?s=aa(y):(L=Q.isFullColumn||O.rowCount>1?ga:O.row,M=Q.isFullRow||O.colCount>1?ha:O.col,s=G(P,b.endSource,L,M,!1,!1))):k=!0)}else if(9===b.type)W=b.operatorType>=15,o.index===-1?(o.index=b.value2?0:1,ia[++ja]=o,ia[++ja]=fa(b.value,W,W,-1)):0===o.index?(t!==b.value&&(s=da(b.operatorType,t,b.value2),o.expr=s),k&&(z=[],z.push(0),o.neeedExpendindexs=z,k=!1),o.index=1,ia[++ja]=o,ia[++ja]=fa(b.value2,W,W,-1)):(s=b.value2&&t!==b.value2?da(b.operatorType,b.value,t):b,z=o.neeedExpendindexs,k&&(z||(z=[]),z.push(1)),z&&(s=Ga(s,z),k=!0));else if(10===b.type)o.index===-1?(o.index=0,ia[++ja]=o,ia[++ja]=fa(b.value,q,r,-1)):b.value!==t&&(s=ea(t));else if(8===b.type)1===o.index?(j--,s=t,o.context&&(a=o.context)):(j++,ia[++ja]=fa(b,!0,!0,1),Y=a,b.source?(Z=b.source===ma.BangSource?a.source:b.source,Y=new ma.EvaluateContext(Z),Y.cloneFrom(a),X=Z.getCustomName(b.value)):(X=a.getName(b.value),a.source.getCustomName(b.value)||(Y=new ma.GloableEvaluateContext(a.source),Y.cloneFrom(a))),X||(X=aa(A)),a=Y||a,ia[++ja]=fa(X,!0,!0,-1,a));else if(6===b.type)if($=b,!q&&(f>0||c))k=!0;else if(!q&&0===f)if(l>=$.value.RowCount&&$.value.RowCount>1||m>=$.value.colCount&&$.value.colCount>1)s=aa(B);else try{1===$.value.RowCount&&(l=0),1===$.value.colCount&&(m=0),_=$.value.getValue(l,m),"string"==typeof _?s=Ha(_):"number"==typeof _&&(s=Ia(_)),ba=new ma.Parser,s=ba.parse(a.source.getParserContext(a.useR1C1,D(0,0)),""+$.value.getValue(l,m))}catch(a){s=aa(B)}}else;s===p?s=b:s!==b&&(E=!0),t=s}return s};function Ja(){}function Ka(a,b){return typeof a===oa||a instanceof Date||!b&&(typeof a===qa||!isNaN(a)&&!isNaN(parseFloat(a)))}Ja.Na=Ka;function La(a){return a instanceof w}Ja.vf=La;function Ma(a){return a instanceof I}Ja.Ca=Ma;function Na(a){return a instanceof J}Ja.Fh=Na;function Oa(a){return isNaN(a)||!isFinite(a)?C:a}Ja.Nh=Oa;function Pa(a,b,c,d,f,g){var h,i,j;if(a&&a.length&&a.rowCount&&a.colCount)return a;if(Ma(a))h=a.toArray(b,c,d,f,g),h.isArray=!0;else if(Na(a))h=a.toArray(b,c,d,f,g),h.isReference=!0;else if(e(a)&&a.length>0){if(h=[],e(a[0]))return Ja.Oh(a,b,!0);for(i=0;i<a.length;i++)j=Qa(a[i],b,!1),j===Ja.CalcConvertedError&&(h.isConvertError=!0),h.push(j);h.rowCount=1,h.colCount=a.length,h.rangeCount=1}else Ma(a)?h=[]:(a=Qa(a,b,!0),d&&La(a)?(h=[y],h.isError=!0):a===Ja.CalcConvertedError?(h=[Ja.CalcConvertedError],h.isConvertError=!0):c?(h=[],h.push(a)):(h=[[]],h[0].push(a)),h.rowCount=1,h.colCount=1,h.rangeCount=1);return h}Ja.Ph=Pa;function Qa(a,b,c,d){var e,f,g;if(La(a))return a;if(e={value:p},f=Ja.CalcConvertedError,d&&0!==b&&(a===p||a===q))return f;switch(b){case 1:case 5:c&&5!==b?a=Wa(a,e)?e.value:f:typeof a===oa||(a=a instanceof Date?k.Ra(a):f);break;case 4:typeof a===pa?(g=la.l.Qa(a),a=g!==q&&g!==p?k.Ra(g):f):c?a=Wa(a,e)?e.value:f:typeof a===oa||a instanceof Date||(a=f);break;case 3:c?a=Wa(a,e)?e.value:f:typeof a!==qa&&(a=f);break;case 2:a=a===p||a===q?"":""+a}return a}Ja.wf=Qa;function Ra(a,b,c){var d,e,f,g,h,i,j,k,l,m,o,r,s;if(!a||!a.length||!a[0].length)return d=[],d.isError=!0,[[y]];if(0===b)return a;if(e=n[b],f=a.length,g=a[0].length,k={value:p},l=!1,m=!1,o=Ja.CalcConvertedError,d=a[e],!d)for(d=[],a[e]=d,r=0;r<f;r++)for(h=a[r],i=d[r]=[],s=0;s<g;s++)if(j=h[s],La(j))l||(d.isError=!0,l=!0),i.push(j);else{switch(b){case 1:case 5:c&&5!==b?Wa(j,k)?j=k.value:(m||(m=!0,d.isConvertError=!0),j=0):typeof j===oa||j instanceof Date||(m||(m=!0,d.isConvertError=!0),j=o);break;case 3:c?Xa(j,k)?j=k.value:(m||(m=!0,d.isConvertError=!0),j=!1):typeof j!==qa&&(m||(m=!0,d.isConvertError=!0),j=o);break;case 2:j=j===p||j===q?"":""+j}i.push(j)}return d}Ja.Oh=Ra;function Sa(a){return isNaN(a)||!isFinite(a)}Ja.Qh=Sa;function Ta(a){var b=Va(a);if(r(b)<1e21)return parseInt(b,10);throw m().Exp_InvalidCast}Ja.Rh=Ta;function Ua(a,b){var c=Wa(a,b);return!!c&&(r(b.value)<1e21&&(b.value=parseInt(b.value,10),!0))}Ja.Sh=Ua;function Va(a){var b={value:0};if(Wa(a,b))return b.value;throw m().Exp_InvalidCast}Ja.Pa=Va,ga={JAN:1,FEB:2,MAR:3,APR:4,MAY:5,JUN:6,JUL:7,AUG:8,SEP:9,OCT:10,NOV:11,DEC:12};function Wa(a,b){var c,d,e,f,g=p;if(!a)return b.value=0,!0;c=typeof a;try{if(c===oa)g=a;else if(c===pa){if(a=a.trim(),0===a.length)return b.value=0,!0;if(d=!1,"%"===a.charAt(a.length-1)&&(d=!0,a=a.substr(0,a.length-1)),a.length>=2&&"0"===a[0]&&"x"===a[1])return!1;if(g=new Number(a).valueOf(),Ja.Qh(g)){if(e=a.charCodeAt(0),e|=32,a.length>4&&e>=96&&e<=122&&(f=a[0]+a[1]+a[2],f=f.toUpperCase(),!ga[f]))return!1;if("/"===a[0]||"/"===a[a.length-1])return!1;if(g=new Date(a),Ja.Qh(g.valueOf()))return!1;g=k.Ra(g)}d&&(g/=100)}else if(c===qa)g=a?1:0;else{if(!(a instanceof Date))return!1;g=k.Ra(a)}}catch(a){return!1}return b.value=g,!0}Ja.Th=Wa;function Xa(a,b){try{if(a)if(typeof a===qa);else if(a instanceof Date)a=0!==k.Ra(a);else{if(!Ka(a))return!1;a=0!==a}else a=!1}catch(a){return!1}return b.value=a,!0}Ja.Uh=Xa;function Ya(a){if(!a)return!1;if(typeof a===qa)return a;if(a instanceof Date)return 0!==k.Ra(a);if(Ka(a))return 0!==a;if(La(a))return!1;throw m().Exp_InvalidCast}Ja.Vh=Ya;function Za(a){try{if(a===q||a===p)return"";if(typeof a===qa)return a?ra:sa;if(typeof a===pa)return a;if(a instanceof Date)return""+k.Ra(a);if(Ma(a))throw m().Exp_InvalidCast;return""+a}catch(a){throw m().Exp_InvalidCast}}Ja.bc=Za;function $a(a){var b={value:p};if(_a(a,b))return b.value;throw m().Exp_InvalidCast}Ja.Wh=$a;function _a(a,b){var c,d,e,f;if(a)if(a instanceof Date)b.value=new Date(a);else if(typeof a===pa){if(c=la.l.Qa(a),!c)if(isNaN(a)){if(c=new Date(a),isNaN(c.valueOf()))return!1;try{if(d=/^[-+=\s]*(\d+)\W+(\d+)\W+(\d+)$/,e=l.ib(l.Db(a.replace(/ |\n/g,"")," ")," "),f=d.exec(e),f&&4===f.length&&(f.indexOf(""+c.getYear())===-1||f.indexOf(""+c.getMonth())===-1||f.indexOf(""+c.getDate())===-1))return!1}catch(a){return!1}}else if(c=la.l.Xb(parseFloat(a)),!c)return!1;b.value=c}else{if(typeof a!==oa)return!1;b.value=la.l.Xb(a)}else b.value=la.l.Xb(0);return!0}Ja.Xh=_a,Ja.CalcConvertedError={},ma.Convert=Ja,ha=function(){function a(){}return a.Yh=function(a,b){var c=16777216;return a===b||r(a-b)<r(a)/(c*c)},a.getArrayValue=function(a,b,c){return a?b<a.getRowCount()&&c<a.getColumnCount()?a.getValue(b,c):c>=a.getColumnCount()&&1===a.getColumnCount()&&b<a.getRowCount()?a.getValue(b,0):b>=a.getRowCount()&&1===a.getColumnCount()&&c<a.getColumnCount()?a.getValue(0,c):y:y},a.tryExtractToSingleValue=function(a){var b,c=!0;return(Na(a)||Ma(a))&&(b=Pa(a,0,!1,!0),b.isError?a=b[0]:1===b.rowCount&&1===b.colCount?a=b[0][0]:(a=b,c=!1)),{value:a,success:c}},a}(),ma.Zh=ha,ia=function(){function a(){}return a.getLength=function(a,b){return Ma(a)?a.getRowCount()*a.getColumnCount():Na(a)?(b=b?b:0,a.getRowCount(b)*a.getColumnCount(b)):void 0},a.getRowCount=function(a,b){return Ma(a)?a.getRowCount():Na(a)?(b=b?b:0,a.getRowCount(b)):void 0},a.getColumnCount=function(a,b){return Ma(a)?a.getColumnCount():Na(a)?(b=b?b:0,a.getColumnCount(b)):void 0},a.getValueByIndex=function(a,b,c){if(Ma(a))return a.getValueByIndex(b);if(Na(a)){c=c?c:0;var d=a.getColumnCount(c);return a.getValue(c,parseInt(b/d,10),b%d)}},a.getValue=function(a,b,c,d){return Ma(a)?a.getValue(b,c):Na(a)?(d=d?d:0,a.getValue(d,b,c)):void 0},a}(),ma.CalcArrayHelper=ia,function(a){a[a.normal=0]="normal",a[a.allwaysExpand=1]="allwaysExpand",a[a.neverExpand=2]="neverExpand"}(na.ArrayArgumentEvaluateMode||(na.ArrayArgumentEvaluateMode={})),ja=function(){function a(a,b,c,d){var e=this,f=arguments.length;e.name=a,e.minArgs=f<2?0:b,e.maxArgs=f<3?0:c,e.$h=d,e.typeName=""}return a.prototype={description:function(){var a=this,b=m()._h;return a.$h?a.$h:b&&b[a.name]},acceptsArray:function(a){return!1},acceptsReference:function(a){return!1},acceptsError:function(a){return!1},acceptsMissingArgument:function(a){return!1},isVolatile:function(){return!1},isContextSensitive:function(){return!1},isBranch:function(){return!1},findTestArgument:function(){return-1},findBranchArgument:function(a){return-1},expandRows:function(){return!0},expandColumns:function(){return!0},precedentReference:function(){return!0},returnReference:function(){return!1},evaluate:function(a){},evaluateWithContext:function(a,b){var c=this,d=b;return c.isContextSensitive()&&(d=b.slice(),d.unshift(a)),c.evaluate.apply(c,d)},toJSON:function(){var a,b={};for(a in this)this.hasOwnProperty(a)&&(b[a]=this[a]);return b},fromJSON:function(a){if(a)for(var b in a)a[b]!==q&&(this[b]=a[b])}},a.ai=function(a,b,c){var d,e=new na.Function(a,0,255);if(b&&"function"==typeof b&&(e.evaluate=b),c)for(d in c)c.hasOwnProperty(d)&&"override"!==d&&(e[d]=c[d]);return e},a}(),na.Function=ja,ka=function(a){j(b,a);function b(b,c,d,e){a.call(this,b,c,d,e)}return b}(ja),f(ka.prototype,{isContextSensitive:function(){return!0},evaluate:function(a,b){return this.evaluateAsync.apply(self,arguments)},evaluateAsync:function(a,b){self.evaluate.apply(self,arguments)},defaultValue:function(){return 0},evaluateMode:function(){return 0},evaluateWhenArgumentsIsSame:function(){return!0},interval:function(){return 1e4}}),na.AsyncFunction=ka,na.AsyncFunctionEvaluateMode={onRecalculation:0,calculateOnce:1,onInterval:2},na.bi={},na.ci={};function ab(a,b){return na.ci[Ca(a)]=b,b}na.defineGlobalCustomFunction=ab;function bb(a){if(!a)return p;a=Ca(a);var b=na.bi,c=na.ci;return b&&b[a]||c&&c[a]}na.findGlobalFunction=bb,a.exports=ma},function(a,b){a.exports=GC.Spread.Common},function(a,b,c){var d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s=c(2),t=c(1),u=s.j.G,v=s.j.Ia,w=void 0,x=null,y="string",z="boolean",A="TRUE",B="FALSE",C="ARRAY",D=t.ErrorList,E=t.Expression,F=s.u,G=function(){return s.C(t.SR)()},H="Exp_FormulaInvalidChar",I="Exp_FormulaInvalid",J="Exp_NoSyntax";function K(){throw G()[I]}function L(a,b,c){throw F.Kb(G()[c||H],[a,b])}t.OperatorType={Plus:0,Negate:1,Percent:2,Add:3,Sub:4,Mul:5,Div:6,Exp:7,Concat:8,EqualTo:9,NotEqualTo:10,LessThan:11,LessThanOrEqualTo:12,GreaterThan:13,GreaterThanOrEqualTo:14,Range:15,Union:16,Intersect:17},d=t.di=["+","-","%","+","-","*","/","^","&","=","<>","<","<=",">",">=",":",","," "],e={":":1,"^":2," ":3,"*":4,"/":4,",":5,"+":6,"-":6,"&":7,"<":8,"=":8,">":8,">=":8,"<=":8,"<>":8},t.FormulaTokenType={Operand:0,Function:1,Subexpression:2,Argument:3,OperatorPrefix:4,OperatorInfix:5,OperatorPostfix:6,Whitespace:7},t.FormulaTokenSubtype={Nothing:0,Start:1,Stop:2,Text:3,Number:4,Logical:5,Error:6,RangeOrName:7,Concatenation:8,Intersection:9,Union:10,RangeOp:11,ExternalReference:12},f=".",g=",",h=";",i=",",j=[14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,11,24,24,24,26,24,24,24,20,21,24,25,24,19,24,24,8,8,8,8,8,8,8,8,8,8,24,24,25,25,25,24,24,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,20,24,21,27,18,27,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,20,25,21,25,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,14,11,24,26,26,26,26,28,28,27,28,1,22,25,19,28,27,28,25,10,10,27,1,28,24,27,10,1,23,10,10,10,24,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,25,0,0,0,0,0,0,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,25,1,1,1,1,1,1,1,1];function M(a){return a<=255}function N(a){return a<=127}k=t.isDigit=function(a){var b=a.charCodeAt(0);return b>=48&&b<=57},t.ei=function(a){var b=a.charCodeAt(0);return!M(b)||(N(b)?(b|=32,b>=96&&b<=122):0===j[b]||1===j[b])},l=t.fi=function(a){var b=a.charCodeAt(0);return!M(b)||(N(b)?b<=57?b>=48:(b|=32,b>=96&&b<=122):0===j[b]||1===j[b])};function O(a){var b=a.charCodeAt(0);return!!M(b)&&(25===j[b]||26===j[b]||27===j[b]||28===j[b])}t.isNumber=function(a){var b=a.charCodeAt(0);return N(b)?b>=48&&b<=57:8===j[b]||10===j[b]};function P(a,b,c,d,e,f){var g,h,i=a.length,j=c===d?0:1,k=[];for(g=b+1;g<i;g++)if(h=a[g],h===e&&(k.push(h),g++,h=a[g]),h===c&&j++,h===d)if(j--,c===d&&g+2<i&&a[g+1]===c)k.push(c),g++;else{if(0===j)return{result:k,endIndex:g};k.push(h)}else k.push(h);f&&L(d,c,J)}function Q(a,b,c){var d,e,f,g,h=a.length,i=h-b;for(d=0;d<D.length;d++)if(e=D[d],f=e.length,b+f<=h&&(g=a.slice(b,b+f),f<=i&&e===g.join("").toUpperCase()))return{result:g,endIndex:b+f-1};c&&L([a[b],b])}function R(a,b,c){var d,e,f=a.length,g=0,h=[];for(d=b;d<f;d++)if(e=a[d],k(e))0===g?g=2:3===g?g=4:1===g?g=2:5!==g&&6!==g||(g=7),h.push(e);else if(e===c){if(2===g)g=4;else{if(0!==g&&1!==g)return{};g=3}h.push(".")}else if("+"===e||"-"===e){if(0===g)g=1;else{if(5!==g)return{num:h,endIndex:d-1};g=6}h.push(e)}else if("E"===e||"e"===e){if(2!==g&&4!==g)return{};g=5,h.push(e)}else if(2===g||4===g||7===g)return{num:h,endIndex:d-1};return 2===g||4===g||7===g?{num:h,endIndex:f-1}:{}}t.Parser=function(){function a(){}return a.prototype={setParserOption:function(a){var b;!a||a===!0&&!s.CultureManager.q4()?b={}:a&&(b=a.NumberFormat?a.NumberFormat:s.CultureManager.q4().NumberFormat),g=b.listSeparator||",",f=b.numberDecimalSeparator||".",h=b.arrayGroupSeparator||";",i=b.arrayListSeparator||","},parse:function(a,b){var c,d,e;return this.setParserOption(a.culture),c=b.split(""),this.gi=c,d=this.parseToTokens(a,c,!a.ignoreError),e=this.buildExpressionTree(a,d,!a.ignoreError)},unparse:function(a,b,c){var d,e;for(this.setParserOption(a.culture),d=a.getResolvers(),c=c||[],e=0;e<d.length&&!d[e].unparse(a,this,b,c);e++);return c.join("")},parseToTokens:function(a,b,c){var d,e,j,l,o,p,r,s,t,u,v,w,x,y,z,A,B,D,E;for(void 0===c&&(c=!0),d=this,e=function(a,b,c){return b.length>0?(a.push(new n(b,0,c)),[]):b},j=b.length,l=[],o=[],p=-1,r=[],t=0,u=0;u<j&&" "===b[u];)u++;for("="===b[u]&&u++,t=u,w=u;w<j;w++)if(x=b[w],'"'===x)y=P(b,w,'"','"',"",c),y?(l.push(new n(y.result,0,w,w+y.result.length+2,3)),w=y.endIndex,t=w+1):(m(r,b.slice(w,j)),w=j-1);else if("'"===x)y=P(b,w,"'","'","",c),y?(r.push("'"),m(r,y.result),r.push("'"),w=y.endIndex):(r.push("'"),w=j-1);else if("["===x)if(y=P(b,w,"[","]","'",c))r.push("["),m(r,y.result),r.push("]"),w=y.endIndex;else{if(d.lda&&0===r.length&&("R"===r[0]||"r"===r[0]||"C"===r[0]||"c"===r[0]))continue;m(r,b.slice(w,j)),w=j-1}else{if("\r"===x||"\n"===x)continue;if("#"===x)z=Q(b,w),z?(l.push(new n(z.result,0,w,w+z.result.length-1,6)),t=w+1,w=z.endIndex):r.push(x);else if("!"===x)0===r.length,l.push(new n(r,0,t,w,12)),r=[],t=w+1;else if("+"===x||"-"===x)A=0===l.length?null:l[l.length-1],0!==r.length?(l.push(new n(r,0,t)),l.push(new n(x,5,w)),r=[],t=w+1):(A&&7===A.Nc&&l.pop(),!A||2!==A.hi&&6!==A.Nc&&0!==A.Nc?(l.push(new n(x,4,w)),t=w+1):(l.push(new n(x,5,w)),t=w+1));else if(x===f||k(x))r.length>0?r.push(x):(B=R(b,w,f)).num?(D=B.endIndex,E=B.num,l.push(new n(E,0,w,D,4)),w=D,t=w+1):r.push(x);else if("{"===x)r.length>0&&c&&L(x,w),s=new n(C,1,w,w,1),l.push(s),o[++p]=s,t=w+1;else if(x===h&&p>=0&&o[p].value===C)r=e(l,r,t),p<0&&c&&L(x,w),l.push(new n(h,3,w,w)),t=w+1;else if("}"===x)r=e(l,r,t),D<0&&c&&L(x,w),v=o[p--],v=new n(x,v.Nc,w,w,2),l.push(v),t=w+1;else if(" "===x)r=e(l,r,t),t=w+1;else if(x===g||x===i||x===h)r=e(l,r,t),p<0||1!==o[p].Nc?l.push(new n(g,5,w,w,10)):l.push(new n(x,3,w,w)),t=w+1;else if("%"===x)r=e(l,r,t),l.push(new n(b[w],6,w,w)),t=w+1;else if(w+2<=j&&q[x+b[w+1]])r=e(l,r,t),l.push(new n(b.slice(w,w+2),5,w,w+1,5)),w++,t=w+1;else if(q[x])r=e(l,r,t),l.push(new n(x,5,w,w)),t=w+1;else if("("===x)r.length>0?(s=new n(r,1,t,w,1),r=[]):s=new n(x,2,w,w,1),l.push(s),o[++p]=s,t=w+1;else if(")"===x){if(r=e(l,r,t),p<0){c&&L(x,w);continue}v=o[p--],v=new n(x,v.Nc,w,w,2),l.push(v),t=w+1}else":"===x?(r=e(l,r,t),l.push(new n(x,5,w,w,11)),t=w+1):r.push(x)}return e(l,r,t),l},buildExpressionTree:function(a,b,c){var d=this.ii(a,b,c),e=this.ji(a,d,c);return e},ji:function(a,b,c){var d,f,g,h,i,j,k=this.ki(a,b,c);for(h=3;h<k.length;)if(i=k[h],j=k[h-2],i&&9===i.type){for(;h>=3&&e[i.value]>=e[j.value];)f=k[h-3],g=k[h-1],d=t.Kh(j.operatorType,f,g),k.splice(h-3,3,d),h-=2,h>=3&&(j=k[h-2]);h+=2}else h++;if(1===k.length)return k[0];for(h=k.length-2;h>0;h-=2)f=k[h-1],g=k[h+1],d=t.Kh(k[h].operatorType,f,g),k.splice(h-1,3,d);return d},ki:function(a,b,c){var d,e,f,h,i,j,k,l,m,n,o,p,q;for(b=Array.isArray(b)?b:[b],d=[],e=b.length,f=0;f<e;f++){if(h=b[f],i=h,9===h.type){if(0===h.operatorType||1===h.operatorType)if(f===e-1)c&&K();else{for(j=f;9===b[j].type&&b[j].operatorType<=1;)j++;for(k=this.ji(a,b[j]),l=j-1;l>=f;l--)i=t.Kh(h.operatorType,k),k=i;i=k,f=j}else if(2===h.operatorType){if(0!==f){i=t.Kh(h.operatorType,this.ji(a,d[d.length-1])),d[d.length-1]=i;continue}c&&K()}}else if(10===h.type)h.value=this.ji(a,h.value),i=h;else if(7===h.type){if(m=0,n=h.arguments,o=[],n.length>0){for(p=0;p<=n.length;p++)q=n[p],(p===n.length||0===q.type&&q.value===g)&&(m===p?o.push(new E(11)):o.push(this.ji(a,n.slice(m,p))),m=p+1);h.arguments=o}i=h}d.push(i)}return d},ii:function(a,b,c){var d,e,f=[];for(d=0,e=b.length;d<e;)d=this.resolveToken(a,b,f,d,c);return f},resolveToken:function(a,b,c,d,e){var f,g,h,i,j,k,l=b[d],m=a.getResolvers();for(f=0;f<m.length;f++)if(g=m[f].resolveToken(a,this,b,d)){h=g.expr,i=d-1,h&&g.index!==w?d=g.index-1:h=g,j=c.length>0?c[c.length-1]:x,j&&0!==h.type&&7!==h.type&&h.type<9&&0!==j.type&&7!==j.type&&j.type<9&&(k=b[i].li,k<l.mi-1&&c.push(t.Kh(17," "))),c.push(h);break}return d+1},resolveSubTokens:function(a,b,c,d){for(var e=[];c<b.length&&2!==b[c].hi;)c=this.resolveToken(a,b,e,c,d);return{exprs:e,index:c+1}}},a}(),m=function(a,b){return a.push.apply(a,b),a},n=t.FormulaToken=function(){function a(a,b,c,d,e){var f,g,h;e=e||0,f=this,f.Qb=a,g=Array.isArray(a)?a.join(""):a,f.Nc=b,f.mi=c,f.li=d||c+a.length-1,0===b&&0===e&&a?(h=g.toUpperCase(),h!==A&&h!==B||(e=5,g=h)):1===b&&g!==C&&(g=g.toUpperCase()),f.ni=g,f.hi=e,f.oi=[]}return a}(),o=t.TokenResolver=function(){function a(a){this.priority=a||5e3}return a.prototype.resolveToken=function(a,b,c,d){},a.prototype.unparse=function(a,b,c,d){},a}(),t.ParserContext=function(){function a(a,b,c,d){var e=this;e.Eh=!1,e.ignoreError=!1,e.source=x,e.useR1C1=b,e.row=c.row||0,e.column=c.col||0,e.baseIdentity=c,e.option=d,e.source=a,e.pi=[],e.addResolver(new r)}return a.prototype={getExternalSource:function(a,b){var c,d=this.source.Cf(),e=d.getAllSouceModels();for(c=0;c<e.length;c++)if(F.Mb(e[c].getSource().getName(),b))return e[c].getSource();return x},getExternalSourceToken:function(a){return a.getName()},getTableByName:function(a){return x},getTableByIndex:function(a,b){return x},setSource:function(a){this.source=a},getResolvers:function(){return this.pi},addResolver:function(a){var b,c=this.pi;for(b=0;;b++)if(!c[b]||a.priority>c[b].priority){c.splice(b,0,a);break}},getFunction:function(a){return this.source&&this.source.getCustomFunction(a)||t.Functions.findGlobalFunction(a)}},a}(),p={"+":0,"-":1},q=t.operaterTypesMap={":":15,",":16,"+":3,"-":4,"*":5,"/":6,"^":7,"%":2,"&":8,"=":9,"<":11,"<>":10,"<=":12,">":13,">=":14},r=t.DefaultTokenResolver=function(){o.call(this)},u(r,o),v(r.prototype,{resolveToken:function(a,b,c,d){var e,f,g,i,j,k,l,m=c[d],n=m.ni;if(0===m.Nc&&0===m.hi)g=n.toUpperCase(),g===A||g===B?(m.hi=5,m.ni=g,e=new E(4),e.value=g===A):(e=new E(8),e.value=n);else if(1===m.Nc){if(n===C){for(e=new E(6),d++,g=[[]],f=0,i=0,j=0;d<c.length&&2!==c[d].hi;){if(m=c[d],3===m.Nc){if(m.Qb===h){if(i!==j)throw F.Kb(G().Exp_InvalidArrayColumns,[m.mi]);g.push([]),f++,j=0}}else{if(0!==m.Nc||4!==m.hi&&3!==m.hi&&5!==m.hi&&6!==m.hi)throw G().Exp_InvalidArray;k=m.ni,4===m.hi?k=parseFloat(k):5===m.hi?k="TRUE"===k.toUpperCase():6===m.hi&&(k=t.CalcError.parse(k)),g[f].push(k),0===f&&i++,j++}d++}if(i!==j)throw F.Kb(G().Exp_InvalidArrayColumns,[m.mi]);return d++,e.value=new t.CalcArray(g),{expr:e,index:d}}if(m.Qb.length>0)return"@"===m.Qb[0]&&(m.ni=m.Qb.slice(0,m.Qb.length-1).join("")),e=new E(7),e.functionName=m.ni,e.function=a.getFunction(e.functionName)||t.Functions.findGlobalFunction(e.functionName),(l=b.resolveSubTokens(a,c,d+1))?(e.arguments=l.exprs,{expr:e,index:l.index}):(e.arguments=[],e)}else if(4===m.Nc||6===m.Nc||5===m.Nc)e=t.Kh(4===m.Nc?p[n]:q[n],n);else if(2===m.Nc){if(e=new E(10),l=b.resolveSubTokens(a,c,d+1))return e.value=l.exprs,{expr:e,index:l.index};K()}else 0===m.Nc?4===m.hi?(e=new E(2),e.value=parseFloat(n),e.originalValue=n):3===m.hi?(e=new E(3),e.value=n):5===m.hi?(e=new E(4),e.value=n===A):6===m.hi?(e=new E(5),e.value=t.CalcError.parse(n)):7===m.hi&&(e=new E(8),e.value=n):3===m.Nc&&(e=new E(0),e.value=n);return e},unparse:function(a,b,c,d){var e,f=this;if(6===c.type||4===c.type||2===c.type||5===c.type||3===c.type)f.qi(a,c,d);else if(9===c.type)f.ri(a,b,c,d);else if(10===c.type)d.push("("),b.unparse(a,c.value,d),d.push(")");else{if(7!==c.type)return!1;for(m(d,(c.function&&c.function.name||c.functionName).split("")),d.push("("),e=0;e<c.arguments.length;e++)0!==e&&d.push(g),b.unparse(a,c.arguments[e],d);d.push(")")}return!0},ri:function(a,b,c,e){var f=c.operatorType;2===f?(b.unparse(a,c.value,e),e.push("%")):0===f||1===f?(e.push(d[f]),b.unparse(a,c.value,e)):(b.unparse(a,c.value,e),e.push(d[f]),b.unparse(a,c.value2,e))},qi:function(a,b,c){var d,e,g,j,k,l,m,n,o=this,p=G().Exp_InvalidArray;if(3===b.type)c.push('"'),c.push(b.value),c.push('"');else if(2===b.type)d=b.originalValue||""+b.value,"."!==f&&(d=d.replace(".",f)),c.push(d);else if(4===b.type)c.push(b.value?A:B);else if(6===b.type){if(c.push("{"),e=b.value,e.getRowCount()<=0)throw p;for(g=0,j=e.getRowCount();g<j;g++)for(g>=1&&c.push(h),k=0,l=e.getColumnCount();k<l;k++){if(0!==k&&c.push(i),m=e.getValue(g,k),m===w||m===x)throw p;n=typeof m,m instanceof E?o.context(a,m,c):n===y?(c.push('"'),c.push(m),c.push('"')):n===z?c.push(m?A:B):"number"===n&&"."!==f?c.push((""+m).replace(".",f)):c.push(""+m)}c.push("}")}else 5===b.type?c.push(""+b.value):11===b.type}})},function(a,b,c){var d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w=c(1),x=w.Errors,y=c(2),z=y.j.G,A=null,B=void 0,C=Math.pow,D=Math.min,E=Math.max,F="string",G=function(){return y.C(w.SR)()},H=G().Exp_Format,I=w.Convert,J=I.Th,K=I.vf,L=I.Ph;function M(a,b,c,d){return{row:a,col:b,rowCount:c,colCount:d}}d=function(){function a(a,b,c,d){var e=this;e.si=0,e.ti=0,e.ui=0,e.source=a,e.arrayFormulaMode=!!c,e.identity=b||w.pf(0,0),e.arrayIdentity=d,e.row=d?d.row:e.identity.row,e.column=d?d.col:e.identity.col,e.rowOffset=d?e.identity.row-d.row:e.row,e.columnOffset=d?e.identity.col-d.col:e.column}return a}(),d.prototype={fga:function(a){return a===w.BangSource?this.source:a},getValue:function(a,b){return a?this.fga(a).getValue(b):e},getReference:function(a,b){return a?this.fga(a).getReference(b):e},getSheetRangeReference:function(a){return a&&a.source&&a.endSource?this.fga(a.source).getSheetRangeReference(a):e},getFunction:function(a){var b=this;return b.source?b.source.getCustomFunction(a):A},getName:function(a){var b,c=this,d=c.source?c.source.getCustomName(a):A;return!d&&c.source&&(b=c.source.Cf().getGlobalSourceModel(),d=b&&b.getSource().getCustomName(a)),d},vi:function(){return this.ui>0},wi:function(){this.ui++},xi:function(){this.ui--},SetAsyncResult:function(a,b){this.source.Cf().lh.SetAsyncResult(a,b)},cloneFrom:function(a){var b=this;b.acceptsReference=a.acceptsReference,b.arrayFormulaMode=a.arrayFormulaMode}},e=x.Reference,f=x.Value,g=w.CalcArray,h=x.Name,i=x.NotAvailable,j=x.DivideByZero,w.EvaluateContext=d,k=function(){function a(a,b){this.id=a.si++,this.ctx=a,this.row=a.row+(a.arrayFormulaMode&&a.rowOffset||0),this.col=a.column+(a.arrayFormulaMode&&a.columnOffset||0),this.node=b}return a.prototype.setAsyncResult=function(a){this.node.Fi=a,this.node.v5=!0,this.ctx.SetAsyncResult(this,a),this.ctx.source.refresh()},a}(),w.AsyncEvaluateContext=k,l=function(a){z(b,a);function b(b,c,d,e,f,g,h,i){a.call(this,b,c,d,e,f,g,h,i),this.yi=b.Cf().getGlobalSourceModel().getSource()}return b.prototype.getName=function(a){var b=this,c=b.yi?b.yi.getCustomName(a):A;return c},b}(d),w.GloableEvaluateContext=l,w.Evaluator=function(){function a(a){this.zi={},this.Ai={},this.asyncManager=new n(this),this.service=a}return a}(),w.Evaluator.prototype={evaluateExpression:function(a,b,c,d,e){var f=this.evaluate(a,b,!!d,!!e);return f===B||f===A?c===!1?f:0:"number"==typeof f&&(""+f).length>=15?+f.toPrecision(15):f},evaluate:function(a,b,c,d){var e,f,g;if(!a)throw G().Exp_ExprIsNull;for(;10===a.type;)a=a.value;if(e=this,g=A,12===a.type&&(g=a.needExpendIndexs,a=a.value),a.type>=2&&a.type<=6)f=e.evaluateConst(a,b,c);else if(1===a.type||13===a.type)f=e.evaluateReference(a,b,d,c);else if(8===a.type)f=e.evaluateName(a,b,c,d);else if(9!==a.type||a.value2){if(9===a.type)f=e.evaluateBinaryOperation(a,b,c,d,g);else if(7===a.type)f=e.evaluateFunction(a,b,c,d,g);else if(11===a.type)f=B;else if(b.evaluate)return b.evaluate(a,c,d)}else f=e.evaluateUnaryOperation(a,b,c,d,g);return f},evaluateConst:function(a,b,c){var d=a.value;return I.Ca(d)?c||b&&(b.arrayFormulaMode||b.vi())?d:d.getValue(0,0):d},evaluateReference:function(a,b,c,d){var h,i,j,k,l,m,n,o,p,q,r,s,t;if(!b)return f;if(h=(13===a.type?a.source():a.source)||b.source,i=b.row,j=b.column,k=a.getRange&&a.getRange(i,j),!k)return e;if(l=k.row<0?0:k.row,m=k.col<0?0:k.col,n=k.rowCount,o=k.colCount,c||b.arrayFormulaMode)return a.endSource?b.getSheetRangeReference({source:a.source,endSource:a.endSource,row:l,col:m,rowCount:n,colCount:o}):b.getReference(h,k);if(d&&(n>1||o>1)){for(p=[],q=0;q<n;q++)for(p[q]=[],r=0;r<o;r++)p[q][r]=h.getValue(q+l,r+m);return new g(p)}if(n>1||o>1)if(s=i>=k.row&&i<k.row+n,t=j>=k.col&&j<k.col+o,s&&t)l=i,m=j;else{if(!s&&!t)return f;if(s&&1===o)l=i;else{if(!t||1!==n)return f;m=j}}else if(k.row===-1&&n===-1){if(1!==o)return f;l=i}else if(k.col===-1&&o===-1){if(1!==n)return f;m=j}return h.getValue(l,m)},evaluateName:function(a,b,c,d){var e,f;return b?(a.source&&(e=a.source,b=e.getEvaluatorContext(b.identity,b.arrayFormulaMode,b.arrayIdentity)),f=b.getName(a.value),f?this.evaluate(f,b,c,d):h):h},evaluateUnaryOperation:function(a,b,c,d,e){var f,g=!1;return e&&e.length>0&&(c=!0,g=!0),f=this.evaluate(a.value,b,c,g),I.vf(f)?f:f===w.missingArgument?i:this.evaluateWithArgs(a,function(b){return p(a.operatorType,b[0])},b,e,[f],c,d)},evaluateBinaryOperation:function(a,b,c,d,e){var f,g,h,j,k=[c,c],l=a.operatorType>=15,m=[l,l];if(e&&e.length>0)for(f=0;f<e.length;f++)k[e[f]]=!0,m[e[f]]=!0;for(g=[a.value,a.value2],h=[],f=0;f<2;f++){if(j=this.evaluate(g[f],b,k[f],m[f]),I.vf(j))return j;if(j===w.missingArgument)return i;h[f]=j}return this.evaluateWithArgs(a,function(b){return p(a.operatorType,b[0],b[1])},b,e,h,c,d)},startCache:function(){this.Bi={},this.asyncManager.startCalc()},endCache:function(){this.Bi=A},evaluateFunction:function(a,b,c,d,e){var f,g,i,j,k,l,m,n,o,p,q,r,s,t,u,x,y,z,B;if(!a||!a.function||"string"==typeof a.function)return h;if(f=a.arguments.length,g=this,i=b.ti,j=a.function,m=A,j instanceof v.AsyncFunction&&this.asyncManager.startCalcFunction(j,a.arguments,b),0===f)k=[];else{for(k=[],n=[],o=[],p=0;p<f;p++)n[p]=j.acceptsArray(p),o[p]=j.acceptsReference(p);if(e&&e.length>0){for(m=[],p=0;p<f;p++)m[p]=!0;for(p=0;p<e.length;p++)q=e[p],n[q]=!0,o[q]=!0,m[q]=!(j.acceptsReference(q)&&!j.acceptsArray(q))}for(j.isBranch()&&(b.arrayFormulaMode||b.vi())&&(n[j.findTestArgument()]=!0,o[j.findTestArgument()]=!0),s=-1,t=-1,j.isBranch()&&(s=j.findTestArgument(),j.acceptsArray(s)&&b.wi(),r=g.evaluate(a.arguments[s],b,n[s],o[s]),j.acceptsArray(s)&&b.xi(),I.Fh(r)||I.Ca(r)||(t=j.findBranchArgument(r))),p=0;p<f;p++){if(s===p)l=r;else{if(t>=0&&p!==t){k[p]=null;continue}j.acceptsArray(p)&&b.wi(),l=g.evaluate(a.arguments[p],b,n[p],o[p]),j.acceptsArray(p)&&b.xi()}if(!j.acceptsArray(p)&&I.Ca(l)||!j.acceptsReference(p)&&I.Fh(l))if(u=I.Ca(l)?l:A,x=I.Fh(l)?l:A,u&&1===u.getRowCount()&&1===u.getColumnCount())l=u.getValue(0,0);else if(x&&1===x.getRowCount(0)&&1===x.getColumnCount(0))l=x.getValue(0,0,0);else{if(y=[],z=!1,e)for(B=0;B<e.length;B++)y.push(e[B]),e[B]===p&&(z=!0);z||(y.push(p),e=y)}if(I.vf(l)&&!j.acceptsError(p))return l;l===w.missingArgument&&(j.acceptsMissingArgument(p)||(l=A)),k[p]=l}}return g.evaluateWithArgs(a,function(a,c){var e,f,h=Y(a,j.Ci);return a=h.Di,j.isContextSensitive()?(b.acceptsReference=d||b.vi(),j instanceof v.AsyncFunction?(g.T4=g.T4||{},j.evaluateWhenArgumentsIsSame()?g.evaluateAsyncFunction(b,c,j,i,a):g.evaluateWithCache(j,a,function(){return g.evaluateAsyncFunction(b,c,j,i,a)},g.T4)):j.evaluateWithContext(b,a)):(f=function(){return h.Ei?j.evaluate.apply(j,a):h.Fi},e=b.arrayFormulaMode?g.evaluateWithCache(j,a,f,g.Bi):f())},b,e,k,c,d,m)},evaluateAsyncFunction:function(a,b,c,d,e){var f,g,h=this.asyncManager.getNode();return h.v5?g=h.Fi:h.canEvaluate()?(f=new k(a,h),g=c.evaluateWithContext(f,e),g===B&&(g=h.Fi!==B?h.Fi:c.defaultValue())):g=h.Fi!==B?h.Fi:c.defaultValue(),h.Fi=g,this.asyncManager.endCalcFunction(),g},evaluateWithCache:function(a,b,c,d){var e,f,g,h,i,j,k,l,m,n,o,p;if(d)if(e=!1,f=d[a.name+b.length])for(p=0;p<f.length;p++){if(g=f[p],e=!1,g.args.length===b.length)for(e=!0,h=0;h<b.length;h++)if(i=g.args[h],j=b[h],i!==j){if(!(i instanceof w.CalcReference&&j instanceof w.CalcReference)){e=!1;break}if(k=i.zf,i.xf!==j.xf||k!==j.zf){e=!1;break}for(l=0;l<k;l++)if(i.getRow(l)!==j.getRow(l)||i.getColumn(l)!==j.getColumn(l)||i.getRowCount(l)!==j.getRowCount(l)||i.getColumnCount(l)!==j.getColumnCount(l)){e=!1;break}}if(e)return g.flag++,g.value}else f=d[a.name+b.length]=[];if(m=c(),d&&m!==B){if(n=f.length,n>=100){for(o=[],p=0;p<n;p++)f[p].flag>0&&o.push(f[p]);o.sort(function(a,b){return b.flag-a.flag}),n=Math.min(50,o.length),f=o.slice(0,n),d[a.name+b.length]=f}f.push({args:b,value:m,flag:0})}return m},SetAsyncResult:function(a){var b=a.ctx;b.source.Cf().recalculate(b.source,a.row,a.col,!0)},evaluateWithArgs:function(a,b,c,d,e,g,h,j){var k,l,m,n,o,p,q,r,s,t,u,v,x,y;if(d&&d.length>0){if(k=this.Gi(c,a,e,d,j),!k)return i;for(l=[],n=k[0].length,o=k[0][0].length,p=0;p<n;p++)for(l[p]=[],q=0;q<o;q++)try{for(r=[],s=0;s<e.length;s++)r[s]=k[s][p][q];if(m=b(r,a),I.Fh(m)){if(7===a.type&&(t=a.function,t.returnReference&&t.returnReference()))return m;m=this.getOneValue(c,m)}l[p][q]=m}catch(a){l[p][q]=f}return new w.CalcArray(l)}try{if(m=b(e,a),c.arrayFormulaMode&&c.vi())return m;if(I.Ca(m)&&!g)return this.getOneValue(c,m);if(I.Fh(m)&&!h){if(u=m,g&&1===u.getRangeCount()){for(v=[],x=0;x<u.getRowCount(0);x++)for(v[x]=[],y=0;y<u.getColumnCount(0);y++)v[x][y]=u.getValue(0,x,y);return new w.CalcArray(v,u.getColumnCount(0))}return this.getOneValue(c,m)}return m}catch(a){return f}},getOneValue:function(a,b){var c,d,e,g;return I.Fh(b)?(e=b,e.getRangeCount()>1?b=f:(a.rowOffset!==-1||a.columnOffset!==-1?(c=1===e.getRowCount(0)?0:a.rowOffset-e.getRow(0),d=1===e.getColumnCount(0)?0:a.columnOffset-e.getColumn(0)):(c=1===e.getRowCount(0)?0:a.row-e.getRow(0),d=1===e.getColumnCount(0)?0:a.column-e.getColumn(0)),b=c>=e.getRowCount(0)||d>=e.getColumnCount(0)?i:e.getValue(0,c,d))):I.Ca(b)&&(g=b,!a.arrayFormulaMode||a.rowOffset===-1&&a.columnOffset===-1?b=g.getValue(0,0):(c=1===g.getRowCount()?0:a.rowOffset,d=1===g.getColumnCount()?0:a.columnOffset,b=c>=g.getRowCount()||d>=g.getColumnCount()?i:g.getValue(c,d))),b},Gi:function(a,b,c,d,e){var f,g,h,j,k,l,m,n,o,p,q,r,s,t,u,v=1,w=1,x=-1,z=!0,C=!0,D=null,E=null,F=1,G=1,H=7===b.type?b:A;if(H&&!H.function.expandRows()&&(z=!1),H&&!H.function.expandColumns()&&(C=!1),H&&H.function.isBranch()&&(a.arrayFormulaMode||a.vi())){if(x=H.function.findTestArgument(),f=[],g=!1,d)for(h=0;h<d.length;h++)f.push(d[h]),d[h]===x&&(g=!0);if(g||I.Ca(c[x])||I.Fh(c[x])){for(j=0;j<H.arguments.length;j++)j!==x&&y.k.Cb(f,j)<0&&(I.Ca(c[j])||I.Fh(c[j]))&&f.push(j);d=f}}for(k=0;k<d.length;k++){if(l=c[d[k]],D=I.Ca(l)?l:null,E=I.Fh(l)?l:null,F=0,G=0,D)F=D.getRowCount(),G=D.getColumnCount();else if(E){if(E.getRangeCount()>1)return A;F=z?E.getRowCount(0):1,G=C?E.getColumnCount(0):1}v=F>v?F:v,w=G>w?G:w}for(m=[],n=0,o=d[n],p=0;p<c.length;p++){if(m[p]=[],q=c[p],D=A,E=A,F=G=1,p===o){if(D=I.Ca(q)?q:A,E=I.Fh(q)?q:A,(D||E)&&(F=D&&D.getRowCount()||(z?E.getRowCount(0):1),G=D&&D.getColumnCount()||(C?E.getColumnCount(0):1),(1!==F&&F!==v||1!==G&&G!==w)&&(x===-1||p===x)&&!a.arrayFormulaMode))return A;n++,o=n<d.length?d[n]:-1}else if(e===B&&(D=I.Ca(q)?q:A,E=I.Fh(q)?q:A,(D||E)&&(F=D&&D.getRowCount()||(z?E.getRowCount(0):1),G=D&&D.getColumnCount()||(C?E.getColumnCount(0):1),(1!==F&&F!==v||1!==G&&G!==w)&&(x===-1||p===x)&&!a.arrayFormulaMode)))return A;for(E&&(r=E.getRow(0),s=E.getColumn(0),v=r+v-r,w=s+w-s),t=0;t<v;t++)for(m[p][t]=[],u=0;u<w;u++)1!==F&&t>=F||1!==G&&u>=G?m[p][t][u]=i:D?m[p][t][u]=D.getValue(1===F?0:t,1===G?0:u):E?!e||e[p]?m[p][t][u]=E.getValue(0,1===F?0:t,1===G?0:u):m[p][t][u]=E.create([M(E.getRow(0)+(1===F?0:t),E.getColumn(0)+(1===G?0:u),1,1)]):m[p][t][u]=q}return m}},m=function(){function a(a,b){this.id=a,this.Fi=B,this.v5=!1,this.oi=[],b!==B&&(this.evaluateMode=b)}return a}(),m.prototype={canEvaluate:function(){var a,b=this.oi;for(a=0;a<b.length;a++)if(!b[a].v5)return!1;return!0}},n=function(){function a(a){this.w5=[],this.x5=-1,this.y5={},this.z5=-1,this.lh=a}return a}(),n.prototype={startCalc:function(){var a,b,c,d,e;for(b in this.y5)if(c=this.y5[b],a=c.length,a>0)for(d=0;d<a;d++)e=c[d],0===e.evaluateMode&&(e.v5=!1)},startCalcCell:function(a,b){var c,d,e=this,f=a.getName()+"_"+b.row+"_"+b.col;return e.z5=-1,e.source=a,(c=e.y5[f])?void(e.cellNodes=c):(d=new m((-1)),c=e.y5[f]=[],e.x5=-1,e.cellNodes=c,e.row=b.row,e.col=b.col,c.root=d,e.w5[++e.x5]=d,void(e.evaluateMode=-1))},startCalcFunction:function(a,b,c){var d,e,f,g,h,i,j,k,l,n,o=this;if(o.z5++,o.isNewNode=!1,d=o.cellNodes[o.z5])return o.currentNode=d,d;if(o.isNewNode=!0,e=o.evaluateMode,f=a.evaluateMode(),"REFRESH"===a.name?(f=b[1]?o.lh.evaluate(b[1],c,!1,!1):0,o.evaluateMode=f):e!==-1&&(f=e),d=new m(o.z5,f),o.cellNodes[o.z5]=d,o.w5[o.x5].oi.push(d),d.parent=o.w5[o.x5],o.w5.push(d),o.x5++,o.currentNode=d,2===f&&e===-1){for(g=6e4,h=o.intervals,i=a.interval()||g,"REFRESH"===a.name&&(d.isRefresh=!0,i=b[2]?o.lh.evaluate(b[2],c,!1,!1):g),h||(o.intervals=h={}),j=h[i],j||(j=h[i]=[],j.intervalObj=window.setInterval(function(){var a,b,c;for(a=0;a<j.length;a++)b=j[a],c=b.node,c.v5=!1,c.isRefresh&&N(c),o.lh.service.recalculate(b.source,b.row,b.col,!0),o.source.refresh()},i)),k=!1,l=0;l<j.length;l++)if(n=j[l],n.source===o.source&&n.node===d&&n.row===o.row&&n.col===o.col){k=!0;break}k||j.push({source:o.source,node:d,row:o.row,col:o.col})}return d},getNode:function(){return this.currentNode},endCalcFunction:function(){this.isNewNode&&(this.w5.pop(),this.x5--),this.currentNode=this.currentNode.parent},endCalcCell:function(){},clearCell:function(a,b){var c,d,e,f,g,h,i=a.getName()+"_"+b.row+"_"+b.col,j=self.y5[i];j&&delete self.y5[i],c=self.intervals;for(d in c){for(e=c[d],f=[],g=0;g<e.length;g++)h=e[g],h.source===a&&h.row===b.row&&h.col===b.col||f.push(h);f.length?f.length!==e.length&&(f.intervalObj=e.intervalObj,c[d]=f):window.clearInterval(e.intervalObj)}},setAsyncResult:function(a,b){a.Fi=b}};function N(a){var b,c;for(c=0;c<a.oi.length;c++)b=a.oi[c],b.v5=!1,b.oi.length>0&&N(b)}o=function(a){var b,c=!0;return a&&a.getValue&&(b=L(a,0,!1,!0),b.isError?a=b[0]:1===b.rowCount&&1===b.colCount?a=b[0][0]:(a=b,c=!1)),{value:a,success:c}},p=w.evaluateOperator=function(a,b,c){return K(b)?b:K(c)?c:a<=2?O(a,b):a<=14?P(a,b,c):T(a,b,c)};function O(a,b){if(!b)return 0;var c=o(b);return c.success?Q(a,c.value):void 0}function P(a,b,c){var d,e,f,g,h,j,k,l,m,n,p,q;if(d=a<=7?Q:8===a?R:S,e=o(b),f=o(c),e.success&&f.success)return d(a,e.value,f.value);if(b=e.value,c=f.value,g=e.success?-1:b.rowCount,h=e.success?-1:b.colCount,j=f.success?-1:c.rowCount,k=f.success?-1:c.colCount,l=-1,m=-1,e.success||f.success)e.success?(l=j,m=k):(l=g,m=h);else{if(1!==g&&1!==j&&g!==j||1!==h&&1!==k&&h!==k)return i;l=1===g?j:g,m=1===h?k:h}for(n=[],p=0;p<l;p++)for(n[p]=[],q=0;q<m;q++)!e.success&&(1!==g&&g<l||1!==h&&h<m)||!f.success&&(1!==j&&j<l||1!==k&&k<m)?n[p][q]=i:n[p][q]=d(a,e.success?b:b[1===g?0:p][1===h?0:q],f.success?c:c[1===j?0:p][1===k?0:q]);return new w.CalcArray(n)}function Q(a,b,c){var d,e,g={value:0};if(!J(b,g))return 0===a&&"string"==typeof b?b:f;if(d=g.value,c!==B){if(!J(c,g))return f;e=g.value}else e=0;return 0===a?d:1===a?-d:2===a?d/100:3===a?d+e:4===a?d-e:5===a?d*e:6===a?e?d/e:j:7===a?!d&&e<0?j:C(d,e):void 0}function R(a,b,c){if(8===a)return K(b)?b:K(c)?c:(b=b||"",c=c||"",I.bc(b)+I.bc(c))}function S(a,b,c){var d,e,g,h,i,j,k,l;if(K(b))return b;if(K(c))return c;if(d=typeof b===F,e=typeof c===F,g=d||e,h=g?"":0,b=b===A||b===B?h:b,c=c===A||c===B?h:c,i=function(){return b===c?0:d&&e?b.toUpperCase().localeCompare(c.toUpperCase()):d?1:e?-1:w.Zh.Yh(b,c)?0:b-c},!g){if(j={value:0},k={value:0},!J(b,j)||!J(c,k))return f;b=j.value,c=k.value}return l=i(),9===a&&0===l||10===a&&0!==l||11===a&&l<0||12===a&&l<=0||13===a&&l>0||14===a&&l>=0}function T(a,b,c){var d,e,g,h,i,j,k,l,m,n,o,p;return!b||!c||(1!==b.getRangeCount()||1!==c.getRangeCount())&&16!==a||b.endSource||c.endSource?f:(d=b.getSource(),d&&d===c.getSource()?(16===a?e=b.yf.concat(c.yf):(g=15===a?D:E,h=15===a?E:D,i=b.getRow(0),j=b.getColumn(0),k=c.getRow(0),l=c.getColumn(0),m=g(i,k),n=g(j,l),o=h(i+b.getRowCount(0),k+c.getRowCount(0))-m,p=h(j+b.getColumnCount(0),l+c.getColumnCount(0))-n,e=[M(m,n,o,p)]),new w.CalcReference(d,e)):f)}q=I.Pa,r=I.Rh,s=I.bc,t=I.Xh,u=I.Vh;function U(a,b){var c,d,e,g=!0;switch(b.Hi){case 0:c=q(a),d=!0;break;case 1:c=parseFloat(a),d=!0;break;case 2:c=r(a),d=!0;break;case 3:c=parseInt(a),d=!0;break;case 4:c=L(a,b.Ii,b.Ji||!1,b.Ki||!1,b.Li||!1,b.Mi),c.isError&&(c=c[0],g=!1),c.isConvertError&&(c=f,g=!1);break;case 5:c=s(a),b.Ni&&""===c&&(c=f,g=!1);break;case 6:e={value:A},t(a,e)?c=e.value:(c=f,g=!1);break;case 7:c=u(a);break;case 8:c=W(a),!c||b.Oi&&0===c.Pi()&&0===c.Qi()?(c=w.Errors.Number,g=!1):c={Ri:c.Pi(),Si:c.Qi()};break;default:c=a}return d&&isNaN(c)&&(c=f,g=!1),{Ti:c,Ei:g}}v=w.Functions;function V(a,b){this.Ri=a,this.Si=b}V.prototype={Pi:function(){return this.Ri},Qi:function(){return this.Si},bc:function(a){a=a||"i";var b=this,c=b.Ri,d=b.Si,e="";return 0===c&&0!==d||(e+=""+c),d===-1?e+="-":0!==c&&d>0&&(e+="+"),d!==-1&&0!==d&&1!==d&&(e+=""+d),0!==d&&(e+=a),e}},v.Ui=V;function W(a){function b(a){var b,c,d,e,f,g,h,i,j,k;function l(a,b){return a.charAt(b)}function m(a,b){for(var c=a.length,d=!1;b<c&&!isNaN(l(a,b));)b++,d=!0;for(b<c&&"."===l(a,b)&&b++;b<c&&!isNaN(l(a,b));)b++,d=!0;if(b<c&&("E"===l(a,b)||"e"===l(a,b)))for(b++,d=!1,b<c&&("+"===l(a,b)||"-"===l(a,b))&&b++;b<c&&!isNaN(l(a,b));)b++,d=!0;return{Vi:d,mi:b}}if(b=0,c=0,d=!1,g=0,h=0,i=0,j=a.length,!a)throw G().Exp_ArgumentNull;if(0===j)throw H;if(i<j&&("+"===l(a,i)||"-"===l(a,i))&&i++,k=m(a,i),i=k.mi,e=k.Vi,i<j&&("+"===l(a,i)||"-"===l(a,i))?(g=i,i++,k=m(a,i),i=k.mi,f=k.Vi,i<j&&("i"===l(a,i)||"j"===l(a,i))&&(i++,d=!0),h=i-g):i<j&&("i"===l(a,i)||"j"===l(a,i))?(i++,h=i,f=e,d=!0,e=!1):g=i,i<j)throw H;if(g>0){if(!e)throw H;b=parseInt(a.substr(0,g),10)}if(h>0){if(!d)throw H;if(1===h||2===h&&"+"===l(a,g))c=1;else if(2===h&&"-"===l(a,g))c=-1;else{if(!f)throw H;c=parseInt(a.substr(g,h-1),10)}}return new V(b,c)}try{return a?"number"==typeof a?new V(parseFloat(a),0):"string"==typeof a?b(a):null:new V(0,0)}catch(a){return null}}v.Wi=W;function X(a,b,c){var d,e,f,g,h;for(Array.isArray(b)||(b=[b]),d=a.Ti,e=0;e<b.length;e++)if(f=b[e].split(" "),g=f[0],h=parseInt(f[1]),"<"===g&&d<h||">"===g&&d>h||"<="===g&&d<=h||">="===g&&d>=h||"="===g&&d===h||"!="===g&&d!==h||"checkLength"===g&&d.length>h)return a.Ti=c===B?w.Errors.Number:c,void(a.Ei=!1)}function Y(a,b){var c,d,e,f,g,h=[];if(!b)return{Di:a,Ei:!0};if(b.Xi)for(e=0;e<a.length;e++)h.push(b);else h=Array.isArray(b)?b:[b];for(d=0;d<h.length;d++){if(f=h[d],f.Yi&&!a[d])throw G().Exp_ArgumentNull;if(g=a[d]!==B){if(c=U(a[d],f),f.aj&&X(c,f.aj,f.bj),!c.Ei)break;a[d]=f.Zi?{$i:g,Qb:c.Ti}:c.Ti}else a[d]=f.Zi?{$i:g,Qb:f._i}:f._i}return{Di:a,Ei:c.Ei,Fi:c.Ti}}},function(a,b,c){var d,e,f=c(2),g=c(1),h=f.l.Ra,i=f.k.ac,j=f.q,k=f.j,l=k.Ea,m=k.Fa,n=void 0,o=isNaN,p=Math.abs,q=Math.exp,r=Math.log,s=Math.pow,t=g.Errors,u=t.Value,v=t.Number,w=t.DivideByZero,x=g.Convert,y=x.CalcConvertedError,z=x.Th,A=x.Rh,B=x.Pa,C=x.Na,D=x.Ph,E=x.Nh,F=g.Functions,G=g.Zh,H=G.Yh,I=function(){return f.C(g.SR)()};function J(a){this.Di=a}J.prototype={$j:function(a){var b,c,d,e,f=this.Di;if(k.Ca(f)||(f=[f]),f[0]===-1)return!0;for(b=0;b<f.length;b++)if(c=f[b],L(c)){if(c=c.split(" "),d=c[0],e=parseInt(c[1]),"!="===d&&a!==e||">"===d&&a>e||">="===d&&a>=e||"%="===d&&a%2===e)return!0}else if(a===c)return!0;return!1},_j:function(){return this.Di}},F.ak=function(a,b,c,d,e,f,g,h){function i(a,b,c){if(m(a))throw I().Exp_InvalidFunctionName;if(a=a.toUpperCase(),F.bi[a])throw I().Exp_InvalidOverrideFunction;var d=F.bi[a];if(d){if(!c||!c.override)throw I().Exp_OverrideNotAllowed}else F.bi[a]=d=new F.Function(a,0,255);return b&&"function"==typeof b&&(d.evaluate=b),k.H(c,function(a,b){var e;l(a,["acceptsReference","acceptsArray","acceptsError","acceptsMissingArgument","precedentReference","expandColumns","expandRows"])>=0?(e=new J(b),d[a]=function(a){return e.$j(a)}):l(a,["isVolatile","isBranch","findTestArgument","returnReference","isContextSensitive"])>=0?(e=new J(b),d[a]=function(){return e._j()}):c.hasOwnProperty(a)&&"override"!==a&&(d[a]=b)}),d}return h||(h={}),c!==n&&(h.minArgs=c),d!==n&&(h.maxArgs=d),f!==n&&(h.acceptsReference=f),g!==n&&(h.acceptsArray=g),e!==n&&(h.Ci=e),h.bk!==n&&(h.acceptsMissingArgument=h.bk),h.ck!==n&&(h.isVolatile=h.ck),h.dk!==n&&(h.isContextSensitive=h.dk),h.ek!==n&&(h.precedentReference=h.ek),h.fk!==n&&(h.arrayArgumentEvaluateMode=h.fk),h.gk!==n&&(h.acceptsError=h.gk),i(a,b,h)},F.hk=1.79769e308;function K(a){return"boolean"==typeof a}F.ik=K;function L(a){return"string"==typeof a}F.jk=L;function M(a){return"number"==typeof a}F.Na=M;function N(a){return a%400===0||a%4===0&&a%100!==0||1900===a}F.kk=N;function O(a,b){switch(b){case 0:case 2:case 4:return 360;case 1:return N(a.getFullYear())?366:365;case 3:return 365;default:return-1}}F.lk=O;function P(a,b){return a-b}F.mk=P;function Q(a,b){return l(b,[0,2,4,6,7,9,11])>=0?31:l(b,[3,5,8,10])>=0?30:1===b?N(a)?29:28:void 0}F.nk=Q;function R(a,b,c,d){var e,f,g=c.getFullYear(),h=c.getMonth(),i=c.getDate(),j=d.getFullYear(),k=d.getMonth(),l=d.getDate();return a?(e=2===h&&Q(g,h)===i,f=2===k&&Q(j,k)===l,b?(e&&(i=30),f&&(l=30)):e&&f&&(i=30,l=30),31===l&&i>=30&&(l=30)):31===l&&(l=1,b&&k++),31===i&&(i=30),360*(j-g)+30*(k-h)+l-i}function S(a,b,c){var d=1,e;return P(a,b)>0&&(a=[b,b=a][0],d=-1),e=l(c,[1,2,3])>=0?d*A(h(b)-h(a)):l(c,[4,5])>=0?d*R(!1,5===c,a,b):d*R(!0,6===c,a,b)}F.pk=S;function T(a){var b,c,d;return 0===a?c=0:(d=.5*p(a),d>=3?c=1:d<1?(b=d*d,c=((((((((.000124818987*b-.001075204047)*b+.005198775019)*b-.019198292004)*b+.059054035642)*b-.151968751364)*b+.319152932694)*b-.5319230073)*b+.797884560593)*d*2):(d-=2,c=(((((((((((((-45255659e-12*d+.00015252929)*d-19538132e-12)*d-.000676904986)*d+.001390604284)*d-.00079462082)*d-.002034254874)*d+.006549791214)*d-.010557625006)*d+.011630447319)*d-.009279453341)*d+.005353579108)*d-.002141268741)*d+.000535310849)*d+.999936657524)),a>0?.5*(c+1):.5*(1-c)}F.qk=T;function U(a,b,c,d,e){var f,g,h,j,k,l,n,o,p,q,r,s,t,v=c<100,x=2===c||102===c,z=x||3===c||103===c,A=5===c||105===c,B=4===c||104===c||A,F=9===c||109===c,G=1===c||101===c||F||d,H=6===c||106===c,I=H?1:0,J=!1,K=0;for(f=0;f<i(a);f++){if(q=a[f],z?r=D(q,0,!1,!1,!1,x):B?r=D(q,5,!1,!0,!1,!0):G?r=D(q,5,!1,F,!1,!0):H&&(r=D(q,5,!1,!1,!1,!0)),r.isError)return r[0];if(r.isConvertError)return u;for(s=r.rangeCount,t=r.isReference,g=0;g<s;g++)for(h=s>1?r[g]:r,t&&(j=q.getRow(g),k=q.getColumn(g)),l=0;l<i(h);l++)if(b||!t||!q.isHiddenRow(g,l,v))for(o=h[l],n=0;n<i(o);n++)!b&&t&&q.isSubtotal(g,l+j,n+k)||(p=o[n],p!==y&&(z&&!m(p)&&(!x||""!==p&&C(p,!0))?I++:B&&(!J||A&&p<I||!A&&p>I)?I=p:G?d?(e.sumx+=p,e.sumx2+=p*p,e.n++):(I+=p,K++):H&&(I*=p,K++),J=!0))}return G?F?I:d?void 0:0===K?w:E(I/K):H?E(K>0?I:0):I}F.rk=U;function V(a,b,c){var d,e=c%100,f=7===e||8===e,g=7===e||10===e?1:0,h={sumx:0,sumx2:0,n:0};return U(a,b,c,!0,h),h.n<=g?w:(d=Math.max(0,(h.n*h.sumx2-h.sumx*h.sumx)/(h.n*(h.n-g))),E(f?Math.sqrt(d):d))}F.sk=V;function W(a){var b=1,c;for(c=a;c>1;c--)b*=c;return b}F.tk=W;function X(a,b,c){var d=a.getDate(),e=b.getDate(),f=a.getMonth(),g=b.getMonth(),h=a.getFullYear(),i=b.getFullYear();return d=31===d?30:d,c?e=31===e?30:e:31===e&&(d<30?(e=1,g++,g>12&&(g=1,i++)):e=30),30*(12*(i-h)+g-f)+e-d}F.uk=X;function Y(a,b,c){function d(a,b,c){var d,e,f,g,i,j,k,l,m=S(a,b,c);return m<0&&(m=-m,a=[b,b=a][0]),1===c?(e=a.getFullYear(),f=b.getFullYear(),g=new Date(a),g.setFullYear(g.getFullYear()+1),P(b,g)>0?(k=f+1-e,g=new Date(e,0,1),i=new Date(f+1,0,1),j=A(h(i)-h(g))-365*(f+1-e)):(k=1,j=N(e)&&a.getMonth()<3||N(f)&&256*b.getMonth()+b.getDate()>=541?1:0),l=B(j)/B(k),d=365+l):d=O(new Date,c),m/d}return c<0||c>4?v:d(a,b,c)}F.vk=Y;function Z(a,b){var c,d,e,f,g;function h(a,b,c){var d;return 0===a?d=b<=c:1===a?d=b>=c:2===a?d=b!==c:3===a?d=b<c:4===a?d=b===c:5===a&&(d=b>c),d}return c=-1,d=!0,e={value:0},f=j.zb(b),4===a&&f&&(g=function(a){var b=j.sb(f);return b.lastIndex=0,b.test(a)}),m(b)?c=0:f?d=!1:z(""+b,e)?c=e.value:d=!1,function(e){m(e)&&(e="");var i={value:0};return d&&z(e,i)?h(a,i.value,c):(!f||!C(e,!0))&&(f&&g?g(""+e):h(a,(""+e).toUpperCase(),m(b)?"":(""+b).toUpperCase()))}}d={},e={wk:function(a){var b=Math.floor(a);return H(a,b+1)?b+1:b},xk:function(a){var b,c,e,f,g,h,j=a,k=d;if(k||(d=k={}),b=k[j])return b;if(C(a))return b=k[j]=Z(4,a);for(c="=><",e=m(a)?"":(""+a).toUpperCase(),f="\0",g=0;g<2&&g<i(e);g++){if(h=e[g],c.indexOf(h)===-1){if("<"===f)return k[j]=b=Z(3,e.substring(1)),b;if(">"===f)return k[j]=b=Z(5,e.substring(1)),b;break}if("="===h)return b="<"===f?Z(0,e.substring(2)):">"===f?Z(1,e.substring(2)):Z(4,"\0"===f?e.substring(1):a),k[j]=b,b;if("\0"===f)f=h;else{if("<"===f)return b=">"===h?Z(2,e.substring(2)):Z(3,e.substring(1)),k[j]=b,b;if(">"===f)return k[j]=b=Z(5,e.substring(1)),b}}return k[j]=b=Z(4,a),b},yk:function(a){var b=[1,10,100,1e3,1e4,1e5,1e6,1e7,1e8,1e9,1e10,1e11,1e12,1e13,1e14,1e15,1e16][a];return m(b)?s(10,parseFloat(a)):b},zk:function(a){var b=Math.ceil(a);return H(a,b-1)?b-1:b},Ak:function(a,b){var c=e.yk(p(b));return a=b<0?a/c:a*c,a=a<0?e.zk(a-.5):e.wk(a+.5),a=b<0?a*c:a/c,E(a)},Bk:function(a,b){if(a<0||b<0||a<b)return v;var c=1,d;for(b=Math.min(a-b,b),d=1;d<=b;d++)c*=a-d+1,c/=d;return E(c)},Ck:function(a,b){var c=p(a)>.5?s(1+a,b):q(b*r(1+a));return isFinite(c)?o(c)&&(c=5e-324):c===Number.POSITIVE_INFINITY?c=F.hk:c===Number.NEGATIVE_INFINITY&&(c=-F.hk),c},Dk:function(a,b){return(q(a)+(b?-1:1)*q(-a))/2},Ek:function(a,b){return o(a)?a:o(b)?b:1!==b&&1===a||0!==b&&b!==Number.POSITIVE_INFINITY?r(a)/r(b):NaN}},F.Fk=e,a.exports=F},function(a,b){function c(a,b){return{description:a,parameters:b}}function d(a,b){return{name:a,repeatable:b}}a.exports={Exp_InvalidCast:"InvalidCastException",Exp_FormulaInvalidChar:"The formula you typed contains an invalid char: '{0}' at index on {1}",Exp_FormulaInvalid:"The formula you typed is invlid",Exp_InvalidFunctionName:"Invalid function name",Exp_InvalidOverrideFunction:"Cannot override built-in function",Exp_InvalidArray:"Invalid array",Exp_OverrideNotAllowed:"Attempt to override function while override is not allowed",Exp_NoSyntax:"no syntax '{0}' to match the syntax '{1}'.",Exp_IsValid:"'{0}' is invalid.",Exp_InvalidParameters:"Invalid function parameters at {0}.",Exp_InvalidArrayColumns:"The length of array columns are unequal at {0}.",Exp_ExprIsNull:"The argument 'expr' is null",Exp_InvalidNull:"InvalidNullException",Exp_InvalidOperation:"InvalidOperationException",Exp_ArgumentNull:"ArgumentNullException",Exp_CriteriaIsNull:"criteria is null",Exp_Format:"Format",Exp_ArrayFromulaPart:"You cannot change part of an array.",Exp_NotSupported:"NotSupportException",_h:{ABS:c("This function calculates the absolute value of the specified value.",[d("value")]),ACCRINT:c("This function calculates the accrued interest for a security that pays periodic interest.",[d("issue"),d("first"),d("settle"),d("rate"),d("par"),d("frequency"),d("basis")]),ACCRINTM:c("This function calculates the accrued interest at maturity for a security that pays periodic interest.",[d("issue"),d("maturity"),d("rate"),d("par"),d("basis")]),ACOS:c("This function calculates the arccosine, that is, the angle whose cosine is the specified value.",[d("value")]),ACOSH:c("This function calculates the inverse hyperbolic cosine of the specified value.",[d("value")]),ADDRESS:c("This function uses the row and column numbers to create a cell address in text.",[d("row"),d("column"),d("absnum"),d("a1style"),d("sheettext")]),AMORDEGRC:c("This function returns the depreciation for an accounting period, taking into consideration prorated depreciation, and applies a depreciation coefficient in the calculation based on the life of the assets.",[d("cost"),d("datepurchased"),d("firstperiod"),d("salvage"),d("period"),d("drate"),d("basis")]),AMORLINC:c("This function calculates the depreciation for an accounting period, taking into account prorated depreciation.",[d("cost"),d("datepurchased"),d("firstperiod"),d("salvage"),d("period"),d("drate"),d("basis")]),AND:c("Check whether all arguments are True, and returns True if all arguments are True.",[d("logical1"),d("logical2")]),ASIN:c("This function calculates the arcsine, that is, the angle whose sine is the specified value.",[d("value")]),ASINH:c("This function calculates the inverse hyperbolic sine of a number.",[d("value")]),ATAN:c("This function calculates the arctangent, that is, the angle whose tangent is the specified value.",[d("value")]),ATAN2:c("This function calculates the arctangent of the specified x- and y-coordinates.",[d("x"),d("y")]),ATANH:c("This function calculates the inverse hyperbolic tangent of a number.",[d("value")]),AVEDEV:c("This function calculates the average of the absolute deviations of the specified values from their mean.",[d("value1"),d("value2",!0)]),AVERAGE:c("This function calculates the average of the specified numeric values.",[d("value1"),d("value2",!0)]),AVERAGEA:c("This function calculates the average of the specified values, including text or logical values as well as numeric values.",[d("value1"),d("value2",!0)]),AVERAGEIF:c("This function calculates the average of the specified numeric values provided that they meet the specified criteria.",[d("value1"),d("value2",!0),d("condition")]),AVERAGEIFS:c("This function calculates the average of all cells that meet multiple specified criteria.",[d("value1"),d("condition1"),d("value2",!0),d("condition2...")]),BESSELI:c("This function calculates the modified Bessel function of the first kind evaluated for purely imaginary arguments.",[d("value"),d("order")]),BESSELJ:c("This function calculates the Bessel function of the first kind.",[d("value"),d("order")]),BESSELK:c("This function calculates the modified Bessel function of the second kind evaluated for purely imaginary arguments.",[d("value"),d("order")]),BESSELY:c("This function calculates the Bessel function of the second kind.",[d("value"),d("order")]),BETADIST:c("This function calculates the cumulative beta distribution function.",[d("x"),d("alpha"),d("beta"),d("lower"),d("upper")]),BETAINV:c("This function calculates the inverse of the cumulative beta distribution function.",[d("prob"),d("alpha"),d("beta"),d("lower"),d("upper")]),BIN2DEC:c("This function converts a binary number to a decimal number",[d("number")]),BIN2HEX:c("This function converts a binary number to a hexadecimal number.",[d("number"),d("places")]),BIN2OCT:c("This function converts a binary number to an octal number.",[d("number"),d("places")]),BINOMDIST:c("This function calculates the individual term binomial distribution probability.",[d("x"),d("n"),d("p"),d("cumulative")]),CEILING:c("This function rounds a number up to the nearest multiple of a specified value.",[d("value"),d("signif")]),CHAR:c("This function returns the character specified by a number.",[d("value")]),CHIDIST:c("This function calculates the one-tailed probability of the chi-squared distribution.",[d("value"),d("deg")]),CHIINV:c("This function calculates the inverse of the one-tailed probability of the chi-squared distribution",[d("prob"),d("deg")]),CHITEST:c("This function calculates the test for independence from the chi-squared distribution.",[d("obs_array"),d("exp_array")]),CHOOSE:c("This function returns a value from a list of values.",[d("index"),d("value1"),d("value2",!0)]),CLEAN:c("This function removes all non-printable characters from text.",[d("text")]),CODE:c("This function returns a numeric code to represent the first character in a text string. The returned code corresponds to the Windows character set (ANSI).",[d("text")]),COLUMN:c("This function returns the column number of a reference.",[d("reference")]),COLUMNS:c("This function returns the number of columns in an array.",[d("array")]),COMBIN:c("This function calculates the number of possible combinations for a specified number of items.",[d("k"),d("n")]),COMPLEX:c("This function converts real and imaginary coefficients into a complex number.",[d("realcoeff"),d("imagcoeff"),d("suffix")]),CONCATENATE:c("This function combines multiple text strings or numbers into one text string.",[d("text1"),d("text2"),d("....")]),CONFIDENCE:c("This function returns confidence interval for a population mean.",[d("alpha"),d("stdev"),d("size")]),CONVERT:c("This function converts a number from one measurement system to its equivalent in another measurement system.",[d("number"),d("from-unit"),d("to-unit")]),CORREL:c("This function returns the correlation coefficient of the two sets of data.",[d("array1"),d("array2")]),COS:c("This function returns the cosine of the specified angle.",[d("angle")]),COSH:c("This function returns the hyperbolic cosine of the specified value.",[d("value")]),COUNT:c("This function returns the number of cells that contain numbers.",[d("value1"),d("value2",!0)]),COUNTA:c("This function returns the number of number of cells that contain numbers, text, or logical values.",[d("value1"),d("value2",!0)]),COUNTBLANK:c("This function returns the number of empty (or blank) cells in a range of cells on a sheet.",[d("cellrange")]),COUNTIF:c("This function returns the number of cells that meet a certain condition",[d("cellrange"),d("condition")]),COUNTIFS:c("This function returns the number of cells that meet multiple conditions.",[d("cellrange"),d("condition")]),COUPDAYBS:c("This function calculates the number of days from the beginning of the coupon period to the settlement date.",[d("settlement"),d("maturity"),d("frequency"),d("basis")]),COUPDAYS:c("This function returns the number of days in the coupon period that contains the settlement date.",[d("settlement"),d("maturity"),d("frequency"),d("basis")]),COUPDAYSNC:c("This function calculates the number of days from the settlement date to the next coupon date.",[d("settlement"),d("maturity"),d("frequency"),d("basis")]),COUPNCD:c("This function returns a date number of the next coupon date after the settlement date.",[d("settlement"),d("maturity"),d("frequency"),d("basi")]),COUPNUM:c("This function returns the number of coupons due between the settlement date and maturity date.",[d("settlement"),d("maturity"),d("frequency"),d("basis")]),COUPPCD:c("This function returns a date number of the previous coupon date before the settlement date.",[d("settlement"),d("maturity"),d("frequency"),d("basis")]),COVAR:c("This function returns the covariance, which is the average of the products of deviations for each data point pair in two sets of numbers.",[d("array1"),d("array2")]),CRITBINOM:c("This function returns the criterion binomial, the smallest value for which the cumulative binomial distribution is greater than or equal to a criterion value.",[d("n"),d("p"),d("alpha")]),CUMIPMT:c("This function returns the cumulative interest paid on a loan between the starting and ending periods.",[d("rate"),d("nper"),d("pval"),d("startperiod"),d("endperiod"),d("paytype")]),CUMPRINC:c("This function returns the cumulative principal paid on a loan between the start and end periods.",[d("rate"),d("nper"),d("pval"),d("startperiod"),d("endperiod"),d("paytype")]),DATE:c("This function returns the DateTime object for a particular date, specified by the year, month, and day.",[d("year"),d("month"),d("day")]),DATEDIF:c("This function returns the number of days, months, or years between two dates.",[d("date1"),d("date2"),d("outputcode")]),DATEVALUE:c("This function returns a DateTime object of the specified date.",[d("date_string")]),DAVERAGE:c("This function calculates the average of values in a column of a list or database that match the specified conditions.",[d("database"),d(" field"),d(" criteria")]),DAY:c("This function returns the day number of the month (integer 1 to 31) that corresponds to the specified date.",[d("date")]),DAYS360:c("This function returns the number of days between two dates based on a 360-day year.",[d("startdate"),d("enddate"),d("method")]),DB:c("This function calculates the depreciation of an asset for a specified period using the fixed\u2011declining balance method",[d("cost"),d("salvage"),d("life"),d("period"),d("month")]),DCOUNT:c("This function counts the cells that contain numbers in a column of a list or database that match the specified conditions",[d("database"),d(" field"),d(" criteria")]),DCOUNTA:c("This function counts the non-blank cells in a column of a list or database that match the specified conditions",[d("database"),d(" field"),d(" criteria")]),DDB:c("This function calculates the depreciation of an asset for a specified period using the double-declining balance method or another method you specify.",[d("cost"),d("salvage"),d("life"),d("period"),d("factor")]),DEC2BIN:c("This function converts a decimal number to a binary number.",[d("number"),d("places")]),DEC2HEX:c("This function converts a decimal number to a hexadecimal number",[d("number"),d("places")]),DEC2OCT:c("This function converts a decimal number to an octal number",[d("number"),d("places")]),DEGREES:c("This function converts the specified value from radians to degrees",[d("angle")]),DELTA:c("This function identifies whether two values are equal. Returns 1 if they are equal; returns 0 otherwise.",[d("value1"),d("value2")]),DEVSQ:c("This function calculates the sum of the squares of deviations of data points (or of an array of data points) from their sample mean.",[d("value1"),d("value2",!0)]),DGET:c("This function extracts a single value from a column of a list or database that matches the specified conditions.",[d("database"),d(" field"),d(" criteria")]),DISC:c("This function calculates the discount rate for a security.",[d("settle"),d("mature"),d("pricep"),d("redeem"),d("basis")]),DMAX:c("This function returns the largest number in a column of a list or database that matches the specified conditions.",[d("database"),d(" field"),d(" criteria")]),DMIN:c("This function returns the smallest number in a column of a list or database that matches the specified conditions.",[d("database"),d(" field"),d(" criteria")]),DOLLAR:c("This function converts a number to text using currency format, with the decimals rounded to the specified place.",[d("value"),d("digits")]),DOLLARDE:c("This function converts a fraction dollar price to a decimal dollar price.",[d("fractionaldollar"),d("fraction")]),DOLLARFR:c("This function converts a decimal number dollar price to a fraction dollar price.",[d("decimaldollar"),d("fraction")]),DPRODUCT:c("This function multiplies the values in a column of a list or database that match the specified conditions.",[d("database"),d(" field"),d(" criteria")]),DSTDEV:c("This function estimates the standard deviation of a population based on a sample by using the numbers in a column of a list or database that match the specified conditions.",[d("database"),d(" field"),d(" criteria")]),DSTDEVP:c("This function calculates the standard deviation of a population based on the entire population using the numbers in a column of a list or database that match the specified conditions.",[d("database"),d(" field"),d(" criteria")]),DSUM:c("This function adds the numbers in a column of a list or database that match the specified conditions.",[d("database"),d(" field"),d(" criteria")]),DURATION:c("This function returns the Macaulay duration for an assumed par value of $100.",[d("settlement"),d("maturity"),d("coupon"),d("yield"),d("frequency"),d("basis")]),DVAR:c("This function estimates the variance of a population based on a sample by using the numbers in a column of a list or database that match the specified conditions.",[d("database"),d(" field"),d(" criteria")]),DVARP:c("This function calculates the variance of a population based on the entire population by using the numbers in a column of a list or database that match the specified conditions.",[d("database"),d(" field"),d(" criteria")]),EDATE:c("This function calculates the date that is the indicated number of months before or after a specified date.",[d("startdate"),d("months")]),EFFECT:c("This function calculates the effective annual interest rate for a given nominal annual interest rate and the number of compounding periods per year.",[d("nomrate"),d("comper")]),EOMONTH:c("This function calculates the date for the last day of the month (end of month) that is the indicated number of months before or after the starting date.",[d("startdate"),d("months")]),ERF:c("This function calculates the error function integrated between a lower and an upper limit.",[d("limit"),d("upperlimit")]),ERFC:c("This function calculates the complementary error function integrated between a lower limit and infinity.",[d("lowerlimit")]),"ERROR.TYPE":c("This function returns a number corresponding to one of the error values.",[d("errorvalue")]),EURO:c("This function returns the equivalent of one Euro based on the ISO currency code.",[d("code")]),EUROCONVERT:c("This function converts currency from a Euro member currency (including Euros) to another Euro member currency (including Euros).",[d("currency"),d("source"),d("target"),d("fullprecision"),d("triangulation")]),EVEN:c("This function rounds the specified value up to the nearest even integer.",[d("value")]),EXACT:c("This function returns true if two strings are the same; otherwise, false.",[d("text1"),d("text2")]),EXP:c("This function returns e raised to the power of the specified value.",[d("value")]),EXPONDIST:c("This function returns the exponential distribution or the probability density.",[d("value"),d("lambda"),d("cumulative")]),FACT:c("This function calculates the factorial of the specified number.",[d("number")]),FACTDOUBLE:c("This function calculates the double factorial of the specified number.",[d("number")]),FALSE:c("This function returns the value for logical FALSE.",[]),FDIST:c("This function calculates the F probability distribution, to see degrees of diversity between two sets of data.",[d("value"),d("degnum"),d("degden")]),FIND:c("This function finds one text value within another and returns the text value\u2019s position in the text you searched.",[d("findtext"),d("intext"),d("start")]),FINV:c("This function returns the inverse of the F probability distribution.",[d("p"),d("degnum"),d("degden")]),FISHER:c("This function returns the Fisher transformation for a specified value.",[d("value")]),FISHERINV:c("This function returns the inverse of the Fisher transformation for a specified value.",[d("value")]),FIXED:c("This function rounds a number to the specified number of decimal places, formats the number in decimal format using a period and commas (if so specified), and returns the result as text.",[d("num"),d("digits"),d("notcomma")]),FLOOR:c("This function rounds a number down to the nearest multiple of a specified value.",[d("value"),d("signif")]),FORECAST:c("This function calculates a future value using existing values.",[d("value"),d("Yarray"),d("Xarray")]),FREQUENCY:c("This function calculates how often values occur within a range of values. This function returns a vertical array of numbers.",[d("dataarray"),d("binarray")]),FTEST:c("This function returns the result of an F-test, which returns the one-tailed probability that the variances in two arrays are not significantly different.",[d("array1"),d("array2")]),FV:c("This function returns the future value of an investment based on a present value, periodic payments, and a specified interest rate.",[d("rate"),d("numper"),d("paymt"),d("pval"),d("type")]),FVSCHEDULE:c("This function returns the future value of an initial principal after applying a series of compound interest rates. Calculate future value of an investment with a variable or adjustable rate.",[d("principal"),d("schedule")]),GAMMADIST:c("This function returns the gamma distribution.",[d("x"),d("alpha"),d("beta"),d("cumulative")]),GAMMAINV:c("This function returns the inverse of the gamma cumulative distribution.",[d("p"),d("alpha"),d("beta")]),GAMMALN:c("This function returns the natural logarithm of the Gamma function, G(x).",[d("value")]),GCD:c("This function returns the greatest common divisor of two numbers.",[d("number1"),d("number2")]),GEOMEAN:c("This function returns the geometric mean of a set of positive data.",[d("value1"),d("value2",!0)]),GESTEP:c("This function, greater than or equal to step, returns an indication of whether a number is equal to a threshold.",[d("number"),d("step")]),GROWTH:c("This function calculates predicted exponential growth. This function returns the y values for a series of new x values that are specified by using existing x and y values.",[d("y"),d("x"),d("newx"),d("constant")]),HARMEAN:c("This function returns the harmonic mean of a data set.",[d("value1"),d("value2",!0)]),HEX2BIN:c("This function converts a hexadecimal number to a binary number.",[d("number"),d(" places")]),HEX2DEC:c("This function converts a hexadecimal number to a decimal number.",[d("number")]),HEX2OCT:c("This function converts a hexadecimal number to an octal number.",[d("number"),d(" places")]),HLOOKUP:c("This function searches for a value in the top row and then returns a value in the same column from a specified row.",[d("value"),d("array"),d("row"),d("approx")]),HOUR:c("This function returns the hour that corresponds to a specified time.",[d("time")]),HYPGEOMDIST:c("This function returns the hypergeometric distribution.",[d("x"),d("n"),d("M"),d("N")]),IF:c("This function performs a comparison and returns one of two provided values based on that comparison.",[d("valueTest"),d("valueTrue"),d("valueFalse")]),IFERROR:c("This function evaluates a formula and returns a value you provide if there is an error or the formula result.",[d("value"),d("error")]),IMABS:c("This function returns the absolute value or modulus of a complex number.",[d("complexnum")]),IMAGINARY:c("This function returns the imaginary coefficient of a complex number.",[d("complexnum")]),IMARGUMENT:c("This function returns the argument theta, which is an angle expressed in radians.",[d("complexnum")]),IMCONJUGATE:c("This function returns the complex conjugate of a complex number.",[d("complexnum")]),IMCOS:c("This function returns the cosine of a complex number.",[d("complexnum")]),IMDIV:c("This function returns the quotient of two complex numbers.",[d("complexnum"),d("complexdenom")]),IMEXP:c("This function returns the exponential of a complex number.",[d("complexnum")]),IMLN:c("This function returns the natural logarithm of a complex number.",[d("complexnum")]),IMLOG2:c("This function returns the base-2 logarithm of a complex number.",[d("complexnum")]),IMLOG10:c("This function returns the common logarithm of a complex number.",[d("complexnum")]),IMPOWER:c("This function returns a complex number raised to a power.",[d("complexnum"),d("powernum")]),IMPRODUCT:c("This function returns the product of up to 29 complex numbers in the x+yi or x+yj text format.",[d("complexnum1"),d("complexnum2",!0)]),IMREAL:c("This function returns the real coefficient of a complex number in the x+yi or x+yj text format.",[d("complexnum")]),IMSIN:c("This function returns the sine of a complex number in the x+yi or x+yj text format.",[d("complexnum")]),IMSQRT:c("This function returns the square root of a complex number in the x+yi or x+yj text format.",[d("complexnum")]),IMSUB:c("This function returns the difference of two complex numbers in the x+yi or x+yj text format.",[d("complexnum1"),d("complexnum2")]),IMSUM:c("This function returns the sum of two or more complex numbers in the x+yi or x+yj text format.",[d("complexnum1"),d("complexnum2",!0)]),INDEX:c("This function returns a value or the reference to a value from within an array or range.",[d("return"),d("row"),d("col"),d("area")]),INDIRECT:c("This function returns the reference specified by a text string. References are immediately evaluated to display their contents.",[d("ref_text"),d("a1_style")]),INT:c("This function rounds a specified number down to the nearest integer.",[d("value")]),INTERCEPT:c("This function returns the coordinates of a point at which a line intersects the y-axis, by using existing x values and y values.",[d("dependent"),d("independent")]),INTRATE:c("This function calculates the interest rate for a fully invested security.",[d("settle"),d("mature"),d("invest"),d("redeem"),d("basis")]),IPMT:c("This function calculates the payment of interest on a loan.",[d("rate"),d("per"),d("nper"),d("pval"),d("fval"),d("type")]),IRR:c("This function returns the internal rate of return for a series of cash flows represented by the numbers in an array.",[d("arrayvals"),d("estimate")]),ISBLANK:c("This function tests whether a value, an expression, or contents of a referenced cell is empty.",[d("cellreference")]),ISERR:c("This function, Is Error Other Than Not Available, tests whether a value, an expression, or contents of a referenced cell has an error other than not available (#N/A).",[d("cellreference")]),ISERROR:c("This function, Is Error of Any Kind, tests whether a value, an expression, or contents of a referenced cell has an error of any kind.",[d("cellreference")]),ISEVEN:c("This function, Is Number Even, tests whether a value, an expression, or contents of a referenced cell is even.",[d("cellreference")]),ISLOGICAL:c("This function tests whether a value, an expression, or contents of a referenced cell is a logical (Boolean) value.",[d("cellreference")]),ISNA:c("This function, Is Not Available, tests whether a value, an expression, or contents of a referenced cell has the not available (#N/A) error value.",[d("cellreference")]),ISNONTEXT:c("This function tests whether a value, an expression, or contents of a referenced cell has any data type other than text.",[d("cellreference")]),ISNUMBER:c("This function tests whether a value, an expression, or contents of a referenced cell has numeric data.",[d("cellreference")]),ISODD:c("This function, Is Number Odd, tests whether a value, an expression, or contents of a referenced cell has numeric data.",[d("cellreference")]),ISPMT:c("This function calculates the interest paid during a specific period of an investment.",[d("rate"),d("per"),d("nper"),d("pv")]),ISREF:c("This function, Is Reference, tests whether a value, an expression, or contents of a referenced cell is a reference to another cell.",[d("cellreference")]),ISTEXT:c("This function tests whether a value, an expression, or contents of a referenced cell has text data.",[d("cellreference")]),KURT:c("This function returns the kurtosis of a data set.",[d("value1"),d("value2"),d("value3"),d("value4",!0)]),LARGE:c("This function returns the nth largest value in a data set, where n is specified.",[d("array"),d("n")]),LCM:c("This function returns the least common multiple of two numbers.",[d("number1"),d("number2")]),LEFT:c("This function returns the specified leftmost characters from a text value.",[d("mytext"),d("num_chars")]),LEN:c("This function returns the length of, the number of characters in, a text string.",[d("value")]),LINEST:c("This function calculates the statistics for a line.",[d("y"),d("x"),d("constant"),d("stats")]),LN:c("This function returns the natural logarithm of the specified number.",[d("value")]),LOG:c("This function returns the logarithm base Y of a number X.",[d("number"),d("base")]),LOG10:c("This function returns the logarithm base 10 of the number given.",[d("value")]),LOGEST:c("This function calculates an exponential curve that fits the data and returns an array of values that describes the curve.",[d("y"),d("x"),d("constant"),d("stats")]),LOGINV:c("This function returns the inverse of the lognormal cumulative distribution function of x, where LN(x) is normally distributed with the specified mean and standard deviation.",[d("prob"),d("mean"),d("stdev")]),LOGNORMDIST:c("This function returns the cumulative natural log normal distribution of x, where LN(x) is normally distributed with the specified mean and standard deviation. Analyze data that has been logarithmically transformed with this function.",[d("x"),d("mean"),d("stdev")]),LOOKUP:c("This function searches for a value and returns a value from the same location in a second area.",[d("lookupvalue"),d("lookupvector"),d("resultvector")]),LOWER:c("This function converts text to lower case letters.",[d("string")]),MATCH:c("This function returns the relative position of a specified item in a range.",[d("value1"),d("array"),d("type")]),MAX:c("This function returns the maximum value, the greatest value, of all the values in the arguments.",[d("value1"),d("value2",!0)]),MAXA:c("This function returns the largest value in a list of arguments, including text and logical values.",[d("value1"),d("value2",!0)]),MDETERM:c("This function returns the matrix determinant of an array.",[d("array")]),MDURATION:c("This function calculates the modified Macaulay duration of a security with an assumed par value of $100.",[d("settlement"),d("maturity"),d("coupon"),d("yield"),d("frequency"),d("basis")]),MEDIAN:c("This function returns the median, the number in the middle of the provided set of numbers; that is, half the numbers have values that are greater than the median, and half have values that are less than the median.",[d("value1"),d("value2",!0)]),MID:c("This function returns the requested number of characters from a text string starting at the position you specify.",[d("text"),d("start_num"),d("num_chars")]),MIN:c("This function returns the minimum value, the least value, of all the values in the arguments.",[d("value1"),d("value2",!0)]),MINA:c("This function returns the minimum value in a list of arguments, including text and logical values.",[d("value1"),d("value2",!0)]),MINUTE:c("This function returns the minute corresponding to a specified time.",[d("time")]),MINVERSE:c("This function returns the inverse matrix for the matrix stored in an array.",[d("array")]),MIRR:c("This function returns the modified internal rate of return for a series of periodic cash flows.",[d("arrayvals"),d("payment_int"),d("income_int")]),MMULT:c("This function returns the matrix product for two arrays.",[d("array1"),d("array2")]),MOD:c("This function returns the remainder of a division operation.",[d("dividend"),d("divisor")]),MODE:c("This function returns the most frequently occurring value in a set of data.",[d("value1"),d("value2",!0)]),MONTH:c("This function returns the month corresponding to the specified date value.",[d("date")]),MROUND:c("This function returns a number rounded to the desired multiple.",[d("number"),d("multiple")]),MULTINOMIAL:c("This function calculates the ratio of the factorial of a sum of values to the product of factorials.",[d("value1"),d("value2",!0)]),N:c("This function returns a value converted to a number.",[d("value")]),NA:c("This function returns the error value #N/A that means not available.",[]),NEGBINOMDIST:c("This function returns the negative binomial distribution.",[d("x"),d("r"),d("p")]),NETWORKDAYS:c("This function returns the total number of complete working days between the start and end dates.",[d("startdate"),d("enddate"),d("holidays")]),NOMINAL:c("This function returns the nominal annual interest rate for a given effective rate and number of compounding periods per year.",[d("effrate"),d("comper")]),NORMDIST:c("This function returns the normal cumulative distribution for the specified mean and standard deviation.",[d("x"),d("mean"),d("stdev"),d("cumulative")]),NORMINV:c("This function returns the inverse of the normal cumulative distribution for the given mean and standard deviation.",[d("prob"),d("mean"),d("stdev")]),NORMSDIST:c("This function returns the standard normal cumulative distribution function.",[d("value")]),NORMSINV:c("This function returns the inverse of the standard normal cumulative distribution. The distribution has a mean of zero and a standard deviation of one.",[d("prob")]),NOT:c("This function reverses the logical value of its argument.",[d("value")]),NOW:c("This function returns the current date and time.",[]),NPER:c("This function returns the number of periods for an investment based on a present value, future value, periodic payments, and a specified interest rate.",[d("rate"),d("paymt"),d("pval"),d("fval"),d("type")]),NPV:c("This function calculates the net present value of an investment by using a discount rate and a series of future payments and income.",[d("discount"),d("value1"),d("value2",!0)]),OCT2BIN:c("This function converts an octal number to a binary number.",[d("number"),d("places")]),OCT2DEC:c("This function converts an octal number to a decimal number.",[d("number")]),OCT2HEX:c("This function converts an octal number to a hexadecimal number.",[d("number"),d("places")]),ODD:c("This function rounds the specified value up to the nearest odd integer.",[d("value")]),ODDFPRICE:c("This function calculates the price per $100 face value of a security with an odd first period.",[d("settle"),d("maturity"),d("issue"),d("first"),d("rate"),d("yield"),d("redeem"),d("freq"),d("basis")]),ODDFYIELD:c("This function calculates the yield of a security with an odd first period.",[d("settle"),d("maturity"),d("issue"),d("first"),d("rate"),d("price"),d("redeem"),d("freq"),d("basis")]),ODDLPRICE:c("This function calculates the price per $100 face value of a security with an odd last coupon period.",[d("settle"),d("maturity"),d("last"),d("rate"),d("yield"),d("redeem"),d("freq"),d("basis")]),ODDLYIELD:c("This function calculates the yield of a security with an odd last period.",[d("settle"),d("maturity"),d("last"),d("rate"),d("price"),d("redeem"),d("freq"),d("basis")]),OFFSET:c("This function returns a reference to a range. The range is a specified number of rows and columns from a cell or range of cells. The function returns a single cell or a range of cells.",[d("reference"),d("rows"),d("cols"),d("height"),d("width")]),OR:c("This function calculates logical OR. It returns TRUE if any of its arguments are true; otherwise, returns FALSE if all arguments are false.",[d("argument1"),d("argument2...")]),PEARSON:c("This function returns the Pearson product moment correlation coefficient, a dimensionless index between -1.0 to 1.0 inclusive indicative of the linear relationship of two data sets.",[d("array_ind"),d("array_dep")]),PERCENTILE:c("This function returns the nth percentile of values in a range.",[d("array"),d("n")]),PERCENTRANK:c("This function returns the rank of a value in a data set as a percentage of the data set.",[d("array"),d("n"),d("sigdig")]),PERMUT:c("This function returns the number of possible permutations for a specified number of items.",[d("k"),d("n")]),PI:c("This function returns PI as 3.1415926536.",[]),PMT:c("This function returns the payment amount for a loan given the present value, specified interest rate, and number of terms.",[d("rate"),d("nper"),d("pval"),d("fval"),d("type")]),POISSON:c("This function returns the Poisson distribution.",[d("nevents"),d("mean"),d("cumulative")]),POWER:c("This function raises the specified number to the specified power.",[d("number"),d("power")]),PPMT:c("This function returns the amount of payment of principal for a loan given the present value, specified interest rate, and number of terms.",[d("rate"),d("per"),d("nper"),d("pval"),d("fval"),d("type")]),PRICE:c("This function calculates the price per $100 face value of a periodic interest security",[d("settlement"),d("maturity"),d("rate"),d("yield"),d("redeem"),d("frequency"),d("basis")]),PRICEDISC:c("This function returns the price per $100 face value of a discounted security.",[d("settle"),d("mature"),d("discount"),d("redeem"),d("basis")]),PRICEMAT:c("This function returns the price at maturity per $100 face value of a security that pays interest.",[d("settle"),d("mature"),d("issue"),d("rate"),d("yield"),d("basis")]),PROB:c("This function returns the probability that values in a range are between two limits.",[d("array"),d("probs"),d("lower"),d("upper")]),PRODUCT:c("This function multiplies all the arguments and returns the product.",[d("value1"),d("value2",!0)]),PROPER:c("This function capitalizes the first letter in each word of a text string.",[d("text")]),PV:c("This function returns the present value of an investment based on the interest rate, number and amount of periodic payments, and future value. The present value is the total amount that a series of future payments is worth now.",[d("rate"),d("numper"),d("paymt"),d("fval"),d("type")]),QUARTILE:c("This function returns which quartile (which quarter or 25 percent) of a data set a value is.",[d("array"),d("quart")]),QUOTIENT:c("This function returns the integer portion of a division. Use this to ignore the remainder of a division.",[d("numerator"),d("denominator")]),RADIANS:c("This function converts the specified number from degrees to radians.",[d("value")]),RAND:c("This function returns an evenly distributed random number between 0 and 1.",[]),RANDBETWEEN:c("This function returns a random number between the numbers you specify.",[d("lower"),d("upper")]),RANK:c("This function returns the rank of a number in a set of numbers. If you were to sort the set, the rank of the number would be its position in the list.",[d("number"),d("array"),d("order")]),RATE:c("This function returns the interest rate per period of an annuity.",[d("nper"),d("pmt"),d("pval"),d("fval"),d("type"),d("guess")]),RECEIVED:c("This function returns the amount received at maturity for a fully invested security.",[d("settle"),d("mature"),d("invest"),d("discount"),d("basis")]),REPLACE:c("This function replaces part of a text string with a different text string.",[d("old_text"),d("start_char"),d("num_chars"),d("new_text")]),REPT:c("This function repeats text a specified number of times.",[d("text"),d("number")]),RIGHT:c("This function returns the specified rightmost characters from a text value.",[d("text"),d("num_chars")]),ROMAN:c("This function converts an Arabic numeral to a Roman numeral text equivalent.",[d("number"),d("style")]),ROUND:c("This function rounds the specified value to the nearest number, using the specified number of decimal places.",[d("value"),d("places")]),ROUNDDOWN:c("This function rounds the specified number down to the nearest number, using the specified number of decimal places.",[d("value"),d("places")]),ROUNDUP:c("This function rounds the specified number up to the nearest number, using the specified number of decimal places.",[d("value"),d("places")]),ROW:c("This function returns the number of a row from a reference.",[d("reference")]),ROWS:c("This function returns the number of rows in an array.",[d("array")]),RSQ:c("This function returns the square of the Pearson product moment correlation coefficient (R\u2011squared) through data points in known y\u2019s and known x\u2019s.",[d("array_dep"),d("array_ind")]),SEARCH:c("This function finds one text string in another text string and returns the index of the starting position of the found text.",[d("string1"),d("string2")]),SECOND:c("This function returns the seconds (0 to 59) value for a specified time.",[d("time")]),SERIESSUM:c("This function returns the sum of a power series.",[d("x"),d("n"),d("m"),d("coeff")]),SIGN:c("This function returns the sign of a number or expression.",[d("cellreference")]),SIN:c("This function returns the sine of the specified angle.",[d("angle")]),SINH:c("This function returns the hyperbolic sine of the specified number.",[d("value")]),SKEW:c("This function returns the skewness of a distribution.",[d("number1"),d("number2",!0)]),SLN:c("This function returns the straight-line depreciation of an asset for one period.",[d("cost"),d("salvage"),d("life")]),SLOPE:c("This function calculates the slope of a linear regression.",[d("array_dep"),d("array_ind")]),SMALL:c("This function returns the nth smallest value in a data set, where n is specified.",[d("array"),d("n")]),SQRT:c("This function returns the positive square root of the specified number.",[d("value")]),SQRTPI:c("This function returns the positive square root of a multiple of pi (p).",[d("multiple")]),STANDARDIZE:c("This function returns a normalized value from a distribution characterized by mean and standard deviation.",[d("x"),d("mean"),d("stdev")]),STDEVA:c("This function returns the standard deviation for a set of numbers, text, or logical values.",[d("value1"),d("value2",!0)]),STDEVP:c("This function returns the standard deviation for an entire specified population (of numeric values).",[d("value1"),d("value2",!0)]),STDEVPA:c("This function returns the standard deviation for an entire specified population, including text or logical values as well as numeric values.",[d("value1"),d("value2",!0)]),STEYX:c("This function returns the standard error of the predicted y value for each x. The standard error is a measure of the amount of error in the prediction of y for a value of x.",[d("array_dep"),d("array_ind")]),SUBSTITUTE:c("This function substitutes a new string for specified characters in an existing string.",[d("text"),d("old_piece"),d("new_piece"),d("instance")]),SUBTOTAL:c("This function calculates a subtotal of a list of numbers using a specified built-in function.",[d("functioncode"),d("value1"),d("value2",!0)]),SUM:c("This function returns the sum of cells or range of cells.",[d("value1"),d("value2",!0)]),SUMIF:c("This function adds the cells using a given criteria.",[d("array"),d("condition"),d("sumrange")]),SUMIFS:c("This function adds the cells in a range using multiple criteria.",[d("array"),d("conditionarray"),d("condition",!0)]),SUMPRODUCT:c("This function returns the sum of products of cells. Multiplies corresponding components in the given arrays, and returns the sum of those products.",[d("array1"),d("array2",!0)]),SUMSQ:c("This function returns the sum of the squares of the arguments.",[d("value1"),d("value2",!0)]),SUMX2MY2:c("This function returns the sum of the difference of the squares of corresponding values in two arrays.",[d("array_x"),d("array_y")]),SUMX2PY2:c("This function returns the sum of the sum of squares of corresponding values in two arrays.",[d("array_x"),d("array_y")]),SUMXMY2:c("This function returns the sum of the square of the differences of corresponding values in two arrays.",[d("array_x"),d("array_y")]),SYD:c("This function returns the sum-of-years\u2019 digits depreciation of an asset for a specified period.",[d("cost"),d("salvage"),d("life"),d("period")]),T:c("This function returns the text in a specified cell.",[d("value")]),TAN:c("This function returns the tangent of the specified angle.",[d("angle")]),TANH:c("This function returns the hyperbolic tangent of the specified number.",[d("value")]),TBILLEQ:c("This function returns the equivalent yield for a Treasury bill (or T-bill)",[d("settle"),d("mature"),d("discount")]),TBILLPRICE:c("This function returns the price per $100 face value for a Treasury bill (or T-bill).",[d("settle"),d("mature"),d("discount")]),TBILLYIELD:c("This function returns the yield for a Treasury bill (or T-bill).",[d("settle"),d("mature"),d("priceper")]),TDIST:c("This function returns the probability for the t-distribution.",[d("x"),d("deg"),d("tails")]),TEXT:c("This function formats a number and converts it to text.",[d("value"),d("text")]),TIME:c("This function returns the TimeSpan object for a specified time.",[d("hour"),d("minutes"),d("seconds")]),TIMEVALUE:c("This function returns the TimeSpan object of the time represented by a text string.",[d("time_string")]),TINV:c("This function returns the t-value of the student's t-distribution as a function of the probability and the degrees of freedom.",[d("prog"),d("deg")]),TODAY:c("This function returns the date and time of the current date.",[]),TRANSPOSE:c("This function returns a vertical range of cells as a horizontal range or a horizontal range of cells as a vertical range.",[d("array")]),TREND:c("This function returns values along a linear trend. This function fits a straight line to the arrays known x and y values. Trend returns the y values along that line for the array of specified new x values.",[d("y"),d("x"),d("newx"),d("constant")]),TRIM:c("This function removes extra spaces from a string and leaves single spaces between words.",[d("text")]),TRIMMEAN:c("This function returns the mean of a subset of data excluding the top and bottom data.",[d("array"),d("percent")]),TRUE:c("This function returns the value for logical TRUE.",[]),TRUNC:c("This function removes the specified fractional part of the specified number.",[d("value"),d("precision")]),TTEST:c("This function returns the probability associated with a t-test.",[d("array1"),d("array2"),d("tails"),d("type")]),TYPE:c("This function returns the type of value.",[d("value")]),UPPER:c("This function converts text to uppercase letters.",[d("string")]),VALUE:c("This function converts a text string that is a number to a numeric value.",[d("text")]),VAR:c("This function returns the variance based on a sample of a population, which uses only numeric values.",[d("value1"),d("value2",!0)]),VARA:c("This function returns the variance based on a sample of a population, which includes numeric, logical, or text values.",[d("value1"),d("value2",!0)]),VARP:c("This function returns variance based on the entire population, which uses only numeric values.",[d("value1"),d("value2",!0)]),VARPA:c("This function returns variance based on the entire population, which includes numeric, logical, or text values.",[d("value1"),d("value2",!0)]),VDB:c("This function returns the depreciation of an asset for any period you specify using the variable declining balance method.",[d("cost"),d("salvage"),d("life"),d("start"),d("end"),d("factor"),d("switchnot")]),VLOOKUP:c("This function searches for a value in the leftmost column and returns a value in the same row from a column you specify.",[d("value"),d("array"),d("colindex"),d("approx")]),WEEKDAY:c("This function returns the number corresponding to the day of the week for a specified date.",[d("date"),d("type")]),WEEKNUM:c("This function returns a number that indicates the week of the year numerically.",[d("date"),d("weektype")]),WEIBULL:c("This function returns the two-parameter Weibull distribution, often used in reliability analysis.",[d("x"),d("alpha"),d("beta"),d("cumulative")]),WORKDAY:c("This function returns the number of working days before or after the starting date.",[d("startdate"),d("numdays"),d("holidays")]),XIRR:c("This function calculates the internal rate of return for a schedule of cash flows that may not be periodic.",[d("values"),d("dates"),d("guess")]),XNPV:c("This function calculates the net present value for a schedule of cash flows that may not be periodic.",[d("rate"),d("values"),d("dates")]),YEAR:c("This function returns the year as an integer for a specified date.",[d("date")]),YEARFRAC:c("This function returns the fraction of the year represented by the number of whole days between the start and end dates.",[d("startdate"),d("enddate"),d("basis")]),YIELD:c("This function calculates the yield on a security that pays periodic interest.",[d("settle"),d("maturity"),d("rate"),d("price"),d("redeem"),d("frequency"),d("basis")]),YIELDDISC:c("This function calculates the annual yield for a discounted security.",[d("settle"),d("maturity"),d("price"),d("redeem"),d("basis")]),YIELDMAT:c("This function calculates the annual yield of a security that pays interest at maturity.",[d("settle"),d("maturity"),d("issue"),d("issrate"),d("price"),d("basis")]),ZTEST:c("This function returns the significance value of a z-test. The z-test generates a standard score for x with respect to the set of data and returns the two-tailed probability for the normal distribution.",[d("array"),d("x"),d("sigma")]),HBARSPARKLINE:c("This function returns a data set used for representing a Hbar sparkline",[d("value"),d("colorScheme")]),VBARSPARKLINE:c("This function returns a data set used for representing a Vbar sparkline",[d("value"),d("colorScheme")]),VARISPARKLINE:c("This function returns a data set used for representing a variance sparkline",[d("variance"),d("reference"),d("mini"),d("maxi"),d("mark"),d("tickunit"),d("legend"),d("colorPositive"),d("colorNegative"),d("vertical")]),PIESPARKLINE:c("This function returns a data set used for representing a pie sparkline",[d("range|percentage"),d("color",!0)]),AREASPARKLINE:c("This function returns a data set used for representing a area sparkline",[d("points"),d("mini"),d("maxi"),d("line1"),d("line2"),d("colorPositive"),d("colorNegative")]),SCATTERSPARKLINE:c("This function returns a data set used for representing a scatter sparkline",[d("points1"),d("points2"),d("minX"),d("maxX"),d("minY"),d("maxY"),d("hLine"),d("vLine"),d("xMinZone"),d("xMaxZone"),d("yMinZone"),d("yMaxZone"),d("tags"),d("drawSymbol"),d("drawLines"),d("color1"),d("color2"),d("dash")]),LINESPARKLINE:c("This function returns a data set used for representing a line sparkline",[d("data"),d("dataOrientation"),d("dateAxisData"),d("dateAxisOrientation"),d("setting")]),COLUMNSPARKLINE:c("This function returns a data set used for representing a column sparkline",[d("data"),d("dataOrientation"),d("dateAxisData"),d("dateAxisOrientation"),d("setting")]),WINLOSSSPARKLINE:c("This function returns a data set used for representing a win/loss sparkline",[d("data"),d("dataOrientation"),d("dateAxisData"),d("dateAxisOrientation"),d("setting")]),BULLETSPARKLINE:c("This function returns a data set used for representing a bullet sparkline",[d("measure"),d("target"),d("maxi"),d("good"),d("bad"),d("forecast"),d("tickunit"),d("colorScheme"),d("vertical")]),SPREADSPARKLINE:c("This function returns a data set used for representing a spread sparkline",[d("points"),d("showAverage"),d("scaleStart"),d("scaleEnd"),d("style"),d("colorScheme"),d("vertical")]),STACKEDSPARKLINE:c("This function returns a data set used for representing a stacked sparkline",[d("points"),d("colorRange"),d("labelRange"),d("maximum"),d("targetRed"),d("targetGreen"),d("targetBlue"),d("tragetYellow"),d("color"),d("highlightPosition"),d("vertical"),d("textOrientation"),d("textSize")]),BOXPLOTSPARKLINE:c("This function returns a data set used for representing a boxplot sparkline",[d("points"),d("boxPlotClass"),d("showAverage"),d("scaleStart"),d("scaleEnd"),d("acceptableStart"),d("acceptableEnd"),d("colorScheme"),d("style"),d("vertical")]),CASCADESPARKLINE:c("This function returns a data set used for representing a cascade sparkline",[d("pointsRange"),d("pointIndex"),d("labelsRange"),d("minimum"),d("maximum"),d("colorPositive"),d("colorNegative"),d("vertical")]),PARETOSPARKLINE:c("This function returns a data set used for representing a pareto sparkline",[d("points"),d("pointIndex"),d("colorRange"),d("target"),d("target2"),d("highlightPosition"),d("label"),d("vertical")]),MONTHSPARKLINE:c("This function returns a data set used for representing a month sparkline",[d("year"),d("month"),d("dataRange"),d("emptyColor"),d("startColor"),d("middleColor"),d("endColor")]),YEARSPARKLINE:c("This function returns a data set used for representing a year sparkline",[d("year"),d("dataRange"),d("emptyColor"),d("startColor"),d("middleColor"),d("endColor")]),"CEILING.PRECISE":c("This function rounds a number up to the nearest integer or to the nearest multiple of a specified value.",[d("number"),d("signif")]),"COVARIANCE.S":c("This function returns the sample covariance, which is the average of the products of deviations for each data point pair in two sets of numbers.",[d("array1"),d("array2")]),"FLOOR.PRECISE":c("This function rounds a number down to the nearest integer or to the nearest multiple of a specified value.",[d("number"),d("signif")]),"PERCENTILE.EXC":c("This function returns the nth percentile of values in a range.",[d("array"),d("n")]),"QUARTILE.EXC":c("This function returns which quartile (which quarter or 25 percent) of a data set a value is.",[d("array"),d("quart")]),"RANK.AVG":c("This function returns the rank of a number in a set of numbers. If some values have the same rank, it will return the average rank.",[d("number"),d("array"),d("order")]),"MODE.MULT":c("This function returns the most frequently occurring vertical array or the most frequently occurring value in a set of data.",[d("number1"),d("number2",!0)]),"STDEV.P":c("This function returns the standard deviation for an entire specified population (of numeric values).",[d("value1"),d("value2",!0)]),"VAR.P":c("This function returns variance based on the entire population, which uses only numeric values.",[d("value1"),d("value2",!0)]),"COVARIANCE.P":c("This function returns the covariance, which is the average of the products of deviations for each data point pair in two sets of numbers.",[d("array1"),d("array2")]),"MODE.SNGL":c("This function returns the most frequently occurring value in a set of data.",[d("value1"),d("value2",!0)]),"PERCENTILE.INC":c("This function returns the nth percentile of values in a range.",[d("array"),d("n")]),"QUARTILE.INC":c("This function returns which quartile (which quarter or 25 percent) of a data set a value is.",[d("array"),d("quart")]),"RANK.EQ":c("This function returns the rank of a number in a set of numbers. If you were to sort the set, the rank of the number would be its position in the list.",[d("number"),d("array"),d("order")]),STDEV:c("This function returns standard deviation is estimated based on a sample.",[d("number1"),d("number2",!0)]),"STDEV.S":c("This function returns standard deviation is estimated based on a sample.",[d("number1"),d("number2",!0)]),"VAR.S":c("This function returns the variance based on a sample of a population, which uses only numeric values.",[d("value1"),d("value2",!0)]),"BETA.INV":c("This function calculates the inverse of the cumulative beta distribution function.",[d("prob"),d("alpha"),d("beta"),d("lower"),d("upper")]),"BINOM.DIST":c("This function calculates the individual term binomial distribution probability.",[d("x"),d("n"),d("p"),d("cumulative")]),"BINOM.INV":c("This function returns the criterion binomial, the smallest value for which the cumulative binomial distribution is greater than or equal to a criterion value.",[d("n"),d("p"),d("alpha")]),"CHISQ.DIST.RT":c("This function calculates the one-tailed probability of the chi-squared distribution.",[d("value"),d("deg")]),"CHISQ.INV.RT":c("This function calculates the inverse of the one-tailed probability of the chi-squared distribution.",[d("prob"),d("deg")]),"CHISQ.TEST":c("This function calculates the test for independence from the chi-squared distribution.",[d("obs_array"),d("exp_array")]),"CONFIDENCE.NORM":c("This function returns confidence interval for a population mean.",[d("alpha"),d("stdev"),d("size")]),"EXPON.DIST":c("This function returns the exponential distribution or the probability density.",[d("value"),d("lambda"),d("cumulative")]),"F.DIST.RT":c("This function calculates the F probability distribution, to see degrees of diversity between two sets of data.",[d("value"),d("degnum"),d("degden")]),"F.INV.RT":c("This function returns the inverse of the F probability distribution.",[d("p"),d("degnum"),d("degden")]),"F.TEST":c("This function returns the result of an F-test, which returns the one-tailed probability that the variances in two arrays are not significantly different.",[d("array1"),d("array2")]),"GAMMA.DIST":c("This function returns the gamma distribution.",[d("x"),d("alpha"),d("beta"),d("cumulative")]),"GAMMA.INV":c("This function returns the inverse of the gamma cumulative distribution.",[d("p"),d("alpha"),d("beta")]),"LOGNORM.INV":c("This function returns the inverse of the lognormal cumulative distribution function of x, where LN(x) is normally distributed with the specified mean and standard deviation.",[d("prob"),d("mean"),d("stdev")]),"NORM.DIST":c("This function returns the normal cumulative distribution for the specified mean and standard deviation.",[d("x"),d("mean"),d("stdev"),d("cumulative")]),"NORM.INV":c("This function returns the inverse of the normal cumulative distribution for the given mean and standard deviation.",[d("prob"),d("mean"),d("stdev")]),"NORM.S.INV":c("This function returns the inverse of the standard normal cumulative distribution. The distribution has a mean of zero and a standard deviation of one.",[d("prob")]),"PERCENTRANK.INC":c("This function returns the rank of a value in a data set as a percentage of the data set.",[d("array"),d("n"),d("signif")]),"POISSON.DIST":c("This function returns the Poisson distribution.",[d("nevents"),d("mean"),d("cumulative")]),"T.INV.2T":c("This function returns the t-value of the student's t-distribution as a function of the probability and the degrees of freedom.",[d("prog"),d("deg")]),"T.TEST":c("This function returns the probability associated with a t-test.",[d("array1"),d("array2"),d("tails"),d("type")]),"WEIBULL.DIST":c("This function returns the two-parameter Weibull distribution, often used in reliability analysis.",[d("x"),d("alpha"),d("beta"),d("cumulative")]),"Z.TEST":c("This function returns the significance value of a z-test. The z-test generates a standard score for x with respect to the set of data and returns the two-tailed probability for the normal distribution.",[d("array"),d("x"),d("sigma")]),"T.DIST.RT":c("This function returns the right-tailed t-distribution.",[d("x"),d("deg")]),"T.DIST.2T":c("This function returns the two-tailed t-distribution.",[d("x"),d("deg")]),"ISO.CEILING":c("This function returns a number up to the nearest integer or to the nearest multiple of significance, regardless of sign of significance.",[d("number"),d("signif")]),"BETA.DIST":c("This function returns the beta distribution.",[d("x"),d("alpha"),d("beta"),d("cumulative"),d("lower"),d("upper")]),"GAMMALN.PRECISE":c("This function returns the natural logarithm of the gamma function.",[d("value")]),"ERF.PRECISE":c("This function returns the error function.",[d("lowerlimit")]),"ERFC.PRECISE":c("This function returns the complementary ERF function.",[d("lowerlimit")]),"PERCENTRANK.EXC":c("This function returns the percentage rank(0..1, exclusive) of a value in a data set.",[d("array"),d("n"),d("signif")]),"HYPGEOM.DIST":c("This function returns the hypergeometric distribution.",[d("x"),d("n"),d("M"),d("N"),d("cumulative")]),"LOGNORM.DIST":c("This function returns the log normal distribution of x.",[d("x"),d("mean"),d("stdev"),d("cumulative")]),"NEGBINOM.DIST":c("This function returns the negative binomial distribution.",[d("x"),d("r"),d("p"),d("cumulative")]),"NORM.S.DIST":c("This function returns the standard normal distribution.",[d("z"),d("cumulative")]),"T.DIST":c("This function returns the t-distribution.",[d("x"),d("deg"),d("cumulative")]),"F.DIST":c("This function returns the F probability distribution.",[d("x"),d("degnum"),d("degden"),d("cumulative")]),"CHISQ.DIST":c("This function returns the chi-squared distribution.",[d("x"),d("deg"),d("cumulative")]),"F.INV":c("This function returns the inverse of the F probability distribution.",[d("probability"),d("degnum"),d("degden")]),"T.INV":c("This function returns the left-tailed inverse of the t-distribution.",[d("probability"),d("deg")]),"CHISQ.INV":c("This function returns the inverse of left-tailed probability of the chi-squared distribution.",[d("probability"),d("deg")]),"CONFIDENCE.T":c("This function returns the confidence interval for a Student's t distribution.",[d("alpha"),d("stdev"),d("size")]),"NETWORKDAYS.INTL":c("This function returns the number of workdays between two dates using arguments to indicate holidays and weekend days.",[d("startdate"),d("enddate"),d("weekend"),d("holidays")]),"WORKDAY.INTL":c("This function returns the serial number of the date before or after a number of workdays with custom weekend parameters. These parameters indicate weekend days and holidays.",[d("startdate"),d("numdays"),d("weekend"),d("holidays")]),REFRESH:c("This function decides how to re-calculate the formula. Can use the evaluateMode argument to specific the formula re-calculate on the reference value changed, evaluate once or re-calculate on interval.",[d("formula"),d("evaluateMode"),d("interval")])}}}]);
 |