From d9cf11d07cbfb61e65ab902a83e8a490ee157ba9 Mon Sep 17 00:00:00 2001 From: Krzysztof Budnik Date: Thu, 13 Jul 2017 09:27:31 +0200 Subject: [PATCH] 2.1.0 --- dist/formula-parser.js | 21442 +++++++++++++++++++---------------- dist/formula-parser.min.js | 211 +- package.json | 2 +- 3 files changed, 11765 insertions(+), 9890 deletions(-) diff --git a/dist/formula-parser.js b/dist/formula-parser.js index 57c15bc4..69f89488 100644 --- a/dist/formula-parser.js +++ b/dist/formula-parser.js @@ -16,9 +16,9 @@ return /******/ (function(modules) { // webpackBootstrap /******/ function __webpack_require__(moduleId) { /******/ /******/ // Check if module is in cache -/******/ if(installedModules[moduleId]) +/******/ if(installedModules[moduleId]) { /******/ return installedModules[moduleId].exports; -/******/ +/******/ } /******/ // Create a new module (and put it into the cache) /******/ var module = installedModules[moduleId] = { /******/ i: moduleId, @@ -43,9 +43,6 @@ return /******/ (function(modules) { // webpackBootstrap /******/ // expose the module cache /******/ __webpack_require__.c = installedModules; /******/ -/******/ // identity function for calling harmony imports with the correct context -/******/ __webpack_require__.i = function(value) { return value; }; -/******/ /******/ // define getter function for harmony exports /******/ __webpack_require__.d = function(exports, name, getter) { /******/ if(!__webpack_require__.o(exports, name)) { @@ -73,7 +70,7 @@ return /******/ (function(modules) { // webpackBootstrap /******/ __webpack_require__.p = ""; /******/ /******/ // Load entry module and return exports -/******/ return __webpack_require__(__webpack_require__.s = 81); +/******/ return __webpack_require__(__webpack_require__.s = 16); /******/ }) /************************************************************************/ /******/ ([ @@ -95,67 +92,6 @@ exports.data = new Error('#GETTING_DATA'); /* 1 */ /***/ (function(module, exports, __webpack_require__) { -"use strict"; - - -exports.__esModule = true; - -var _errors; - -exports['default'] = error; -exports.isValidStrict = isValidStrict; -var ERROR = exports.ERROR = 'ERROR'; -var ERROR_DIV_ZERO = exports.ERROR_DIV_ZERO = 'DIV/0'; -var ERROR_NAME = exports.ERROR_NAME = 'NAME'; -var ERROR_NOT_AVAILABLE = exports.ERROR_NOT_AVAILABLE = 'N/A'; -var ERROR_NULL = exports.ERROR_NULL = 'NULL'; -var ERROR_NUM = exports.ERROR_NUM = 'NUM'; -var ERROR_REF = exports.ERROR_REF = 'REF'; -var ERROR_VALUE = exports.ERROR_VALUE = 'VALUE'; - -var errors = (_errors = {}, _errors[ERROR] = '#ERROR!', _errors[ERROR_DIV_ZERO] = '#DIV/0!', _errors[ERROR_NAME] = '#NAME?', _errors[ERROR_NOT_AVAILABLE] = '#N/A', _errors[ERROR_NULL] = '#NULL!', _errors[ERROR_NUM] = '#NUM!', _errors[ERROR_REF] = '#REF!', _errors[ERROR_VALUE] = '#VALUE!', _errors); - -/** - * Return error type based on provided error id. - * - * @param {String} type Error type. - * @returns {String|null} Returns error id. - */ -function error(type) { - var result = void 0; - - type = (type + '').replace(/#|!|\?/g, ''); - - if (errors[type]) { - result = errors[type]; - } - - return result ? result : null; -} - -/** - * Check if error type is strict valid with knows errors. - * - * @param {String} Error type. - * @return {Boolean} - */ -function isValidStrict(type) { - var valid = false; - - for (var i in errors) { - if (Object.prototype.hasOwnProperty.call(errors, i) && errors[i] === type) { - valid = true; - break; - } - } - - return valid; -} - -/***/ }), -/* 2 */ -/***/ (function(module, exports, __webpack_require__) { - var error = __webpack_require__(0); exports.flattenShallow = function(array) { @@ -414,6 +350,79 @@ exports.arrayEach = function(array, iteratee) { return array; }; +exports.transpose = function(matrix) { + if(!matrix) { + return error.value; + } + + return matrix[0].map(function(col, i) { + return matrix.map(function(row) { + return row[i]; + }); + }); +}; + + +/***/ }), +/* 2 */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +exports.__esModule = true; + +var _errors; + +exports['default'] = error; +exports.isValidStrict = isValidStrict; +var ERROR = exports.ERROR = 'ERROR'; +var ERROR_DIV_ZERO = exports.ERROR_DIV_ZERO = 'DIV/0'; +var ERROR_NAME = exports.ERROR_NAME = 'NAME'; +var ERROR_NOT_AVAILABLE = exports.ERROR_NOT_AVAILABLE = 'N/A'; +var ERROR_NULL = exports.ERROR_NULL = 'NULL'; +var ERROR_NUM = exports.ERROR_NUM = 'NUM'; +var ERROR_REF = exports.ERROR_REF = 'REF'; +var ERROR_VALUE = exports.ERROR_VALUE = 'VALUE'; + +var errors = (_errors = {}, _errors[ERROR] = '#ERROR!', _errors[ERROR_DIV_ZERO] = '#DIV/0!', _errors[ERROR_NAME] = '#NAME?', _errors[ERROR_NOT_AVAILABLE] = '#N/A', _errors[ERROR_NULL] = '#NULL!', _errors[ERROR_NUM] = '#NUM!', _errors[ERROR_REF] = '#REF!', _errors[ERROR_VALUE] = '#VALUE!', _errors); + +/** + * Return error type based on provided error id. + * + * @param {String} type Error type. + * @returns {String|null} Returns error id. + */ +function error(type) { + var result = void 0; + + type = (type + '').replace(/#|!|\?/g, ''); + + if (errors[type]) { + result = errors[type]; + } + + return result ? result : null; +} + +/** + * Check if error type is strict valid with knows errors. + * + * @param {String} Error type. + * @return {Boolean} + */ +function isValidStrict(type) { + var valid = false; + + for (var i in errors) { + if (Object.prototype.hasOwnProperty.call(errors, i) && errors[i] === type) { + valid = true; + break; + } + } + + return valid; +} /***/ }), /* 3 */ @@ -457,7 +466,7 @@ function invertNumber(number) { /* 4 */ /***/ (function(module, exports, __webpack_require__) { -var utils = __webpack_require__(2); +var utils = __webpack_require__(1); var error = __webpack_require__(0); var statistical = __webpack_require__(5); var information = __webpack_require__(7); @@ -767,7 +776,6 @@ exports.DECIMAL = function(number, radix) { return error.value; } - return parseInt(number, radix); }; @@ -787,7 +795,18 @@ exports.EVEN = function(number) { return exports.CEILING(number, -2, -1); }; -exports.EXP = Math.exp; +exports.EXP = function(number) { + if (arguments.length < 1) { + return error.na; + } + if (typeof number !== 'number' || arguments.length > 1) { + return error.error; + } + + number = Math.exp(number); + + return number; +}; var MEMOIZED_FACT = []; exports.FACT = function(number) { @@ -1603,9 +1622,9 @@ exports.TRUNC = function(number, digits) { /***/ (function(module, exports, __webpack_require__) { var mathTrig = __webpack_require__(4); -var text = __webpack_require__(8); -var jStat = __webpack_require__(13).jStat; -var utils = __webpack_require__(2); +var text = __webpack_require__(6); +var jStat = __webpack_require__(11).jStat; +var utils = __webpack_require__(1); var error = __webpack_require__(0); var misc = __webpack_require__(12); @@ -3369,7 +3388,7 @@ exports.VARPA = function() { count++; } } - result = sigma / count;; + result = sigma / count; if (isNaN(result)) { result = error.num; @@ -3409,571 +3428,353 @@ exports.Z.TEST = function(range, x, sd) { /* 6 */ /***/ (function(module, exports, __webpack_require__) { +var utils = __webpack_require__(1); var error = __webpack_require__(0); -var utils = __webpack_require__(2); +var numbro = __webpack_require__(9); -var d1900 = new Date(1900, 0, 1); -var WEEK_STARTS = [ - undefined, - 0, - 1, - undefined, - undefined, - undefined, - undefined, - undefined, - undefined, - undefined, - undefined, - undefined, - 1, - 2, - 3, - 4, - 5, - 6, - 0 -]; -var WEEK_TYPES = [ - [], - [1, 2, 3, 4, 5, 6, 7], - [7, 1, 2, 3, 4, 5, 6], - [6, 0, 1, 2, 3, 4, 5], - [], - [], - [], - [], - [], - [], - [], - [7, 1, 2, 3, 4, 5, 6], - [6, 7, 1, 2, 3, 4, 5], - [5, 6, 7, 1, 2, 3, 4], - [4, 5, 6, 7, 1, 2, 3], - [3, 4, 5, 6, 7, 1, 2], - [2, 3, 4, 5, 6, 7, 1], - [1, 2, 3, 4, 5, 6, 7] -]; -var WEEKEND_TYPES = [ - [], - [6, 0], - [0, 1], - [1, 2], - [2, 3], - [3, 4], - [4, 5], - [5, 6], - undefined, - undefined, - undefined, [0, 0], - [1, 1], - [2, 2], - [3, 3], - [4, 4], - [5, 5], - [6, 6] -]; +//TODO +exports.ASC = function() { + throw new Error('ASC is not implemented'); +}; -exports.DATE = function(year, month, day) { - var result; +//TODO +exports.BAHTTEXT = function() { + throw new Error('BAHTTEXT is not implemented'); +}; - year = utils.parseNumber(year); - month = utils.parseNumber(month); - day = utils.parseNumber(day); +exports.CHAR = function(number) { + number = utils.parseNumber(number); + if (number instanceof Error) { + return number; + } + return String.fromCharCode(number); +}; - if (utils.anyIsError(year, month, day)) { - result = error.value; +exports.CLEAN = function(text) { + text = text || ''; + var re = /[\0-\x1F]/g; + return text.replace(re, ""); +}; - } else if (year < 0 || month < 0 || day < 0) { - result = error.num; +exports.CODE = function(text) { + text = text || ''; + var result = text.charCodeAt(0); - } else { - result = new Date(year, month - 1, day); + if (isNaN(result)) { + result = error.na; } - return result; }; -exports.DATEVALUE = function(date_text) { - if (typeof date_text !== 'string') { - return error.value; - } - var date = Date.parse(date_text); +exports.CONCATENATE = function() { + var args = utils.flatten(arguments); - if (isNaN(date)) { - return error.value; - } - if (date <= -2203891200000) { - return (date - d1900) / 86400000 + 1; + var trueFound = 0; + while ((trueFound = args.indexOf(true)) > -1) { + args[trueFound] = 'TRUE'; } - return (date - d1900) / 86400000 + 2; -}; - -exports.DAY = function(serial_number) { - var date = utils.parseDate(serial_number); - if (date instanceof Error) { - return date; + var falseFound = 0; + while ((falseFound = args.indexOf(false)) > -1) { + args[falseFound] = 'FALSE'; } - return date.getDate(); + return args.join(''); }; -exports.DAYS = function(end_date, start_date) { - end_date = utils.parseDate(end_date); - start_date = utils.parseDate(start_date); - - if (end_date instanceof Error) { - return end_date; - } - if (start_date instanceof Error) { - return start_date; - } - - return serial(end_date) - serial(start_date); +//TODO +exports.DBCS = function() { + throw new Error('DBCS is not implemented'); }; -exports.DAYS360 = function(start_date, end_date, method) { - method = utils.parseBool(method); - start_date = utils.parseDate(start_date); - end_date = utils.parseDate(end_date); +exports.DOLLAR = function(number, decimals) { + decimals = (decimals === undefined) ? 2 : decimals; - if (start_date instanceof Error) { - return start_date; - } - if (end_date instanceof Error) { - return end_date; + number = utils.parseNumber(number); + decimals = utils.parseNumber(decimals); + if (utils.anyIsError(number, decimals)) { + return error.value; } - if (method instanceof Error) { - return method; + var format = ''; + if (decimals <= 0) { + number = Math.round(number * Math.pow(10, decimals)) / Math.pow(10, decimals); + format = '($0,0)'; + } else if (decimals > 0) { + format = '($0,0.' + new Array(decimals + 1).join('0') + ')'; } - var sm = start_date.getMonth(); - var em = end_date.getMonth(); - var sd, ed; + return numbro(number).format(format); +}; - if (method) { - sd = start_date.getDate() === 31 ? 30 : start_date.getDate(); - ed = end_date.getDate() === 31 ? 30 : end_date.getDate(); - } else { - var smd = new Date(start_date.getFullYear(), sm + 1, 0).getDate(); - var emd = new Date(end_date.getFullYear(), em + 1, 0).getDate(); - sd = start_date.getDate() === smd ? 30 : start_date.getDate(); - if (end_date.getDate() === emd) { - if (sd < 30) { - em++; - ed = 1; - } else { - ed = 30; - } - } else { - ed = end_date.getDate(); - } +exports.EXACT = function(text1, text2) { + if (arguments.length !== 2) { + return error.na; } - - return 360 * (end_date.getFullYear() - start_date.getFullYear()) + - 30 * (em - sm) + (ed - sd); + return text1 === text2; }; -exports.EDATE = function(start_date, months) { - start_date = utils.parseDate(start_date); - - if (start_date instanceof Error) { - return start_date; - } - if (isNaN(months)) { - return error.value; +exports.FIND = function(find_text, within_text, position) { + if (arguments.length < 2) { + return error.na; } - months = parseInt(months, 10); - start_date.setMonth(start_date.getMonth() + months); - - return serial(start_date); + position = (position === undefined) ? 0 : position; + return within_text ? within_text.indexOf(find_text, position - 1) + 1 : null; }; -exports.EOMONTH = function(start_date, months) { - start_date = utils.parseDate(start_date); +exports.FIXED = function(number, decimals, no_commas) { + decimals = (decimals === undefined) ? 2 : decimals; + no_commas = (no_commas === undefined) ? false : no_commas; - if (start_date instanceof Error) { - return start_date; - } - if (isNaN(months)) { + number = utils.parseNumber(number); + decimals = utils.parseNumber(decimals); + if (utils.anyIsError(number, decimals)) { return error.value; } - months = parseInt(months, 10); - return serial(new Date(start_date.getFullYear(), start_date.getMonth() + months + 1, 0)); + var format = no_commas ? '0' : '0,0'; + if (decimals <= 0) { + number = Math.round(number * Math.pow(10, decimals)) / Math.pow(10, decimals); + } else if (decimals > 0) { + format += '.' + new Array(decimals + 1).join('0'); + } + return numbro(number).format(format); }; -exports.HOUR = function(serial_number) { - serial_number = utils.parseDate(serial_number); +exports.HTML2TEXT = function (value) { + var result = ''; - if (serial_number instanceof Error) { - return serial_number; + if (value) { + if (value instanceof Array) { + value.forEach(function (line) { + if (result !== '') { + result += '\n'; + } + result += (line.replace(/<(?:.|\n)*?>/gm, '')); + }); + } else { + result = value.replace(/<(?:.|\n)*?>/gm, ''); + } } - return serial_number.getHours(); + return result; }; -exports.INTERVAL = function (second) { - if (typeof second !== 'number' && typeof second !== 'string') { +exports.LEFT = function(text, number) { + number = (number === undefined) ? 1 : number; + number = utils.parseNumber(number); + if (number instanceof Error || typeof text !== 'string') { return error.value; - } else { - second = parseInt(second, 10); } - - var year = Math.floor(second/946080000); - second = second%946080000; - var month = Math.floor(second/2592000); - second = second%2592000; - var day = Math.floor(second/86400); - second = second%86400; - - var hour = Math.floor(second/3600); - second = second%3600; - var min = Math.floor(second/60); - second = second%60; - var sec = second; - - year = (year > 0) ? year + 'Y' : ''; - month = (month > 0) ? month + 'M' : ''; - day = (day > 0) ? day + 'D' : ''; - hour = (hour > 0) ? hour + 'H' : ''; - min = (min > 0) ? min + 'M' : ''; - sec = (sec > 0) ? sec + 'S' : ''; - - return 'P' + year + month + day + 'T' + hour + min + sec; + return text ? text.substring(0, number) : null; }; -exports.ISOWEEKNUM = function(date) { - date = utils.parseDate(date); +exports.LEN = function(text) { + if (arguments.length === 0) { + return error.error; + } - if (date instanceof Error) { - return date; + if (typeof text === 'string') { + return text ? text.length : 0; } - date.setHours(0, 0, 0); - date.setDate(date.getDate() + 4 - (date.getDay() || 7)); - var yearStart = new Date(date.getFullYear(), 0, 1); + if (text.length) { + return text.length; + } - return Math.ceil((((date - yearStart) / 86400000) + 1) / 7); + return error.value; }; -exports.MINUTE = function(serial_number) { - serial_number = utils.parseDate(serial_number); - - if (serial_number instanceof Error) { - return serial_number; +exports.LOWER = function(text) { + if (typeof text !== 'string') { + return error.value; } - - return serial_number.getMinutes(); + return text ? text.toLowerCase() : text; }; -exports.MONTH = function(serial_number) { - serial_number = utils.parseDate(serial_number); - - if (serial_number instanceof Error) { - return serial_number; +exports.MID = function(text, start, number) { + start = utils.parseNumber(start); + number = utils.parseNumber(number); + if (utils.anyIsError(start, number) || typeof text !== 'string') { + return number; } - return serial_number.getMonth() + 1; + var begin = start - 1; + var end = begin + number; + + return text.substring(begin, end); }; -exports.NETWORKDAYS = function(start_date, end_date, holidays) { - return this.NETWORKDAYS.INTL(start_date, end_date, 1, holidays); +// TODO +exports.NUMBERVALUE = function (text, decimal_separator, group_separator) { + decimal_separator = (typeof decimal_separator === 'undefined') ? '.' : decimal_separator; + group_separator = (typeof group_separator === 'undefined') ? ',' : group_separator; + return Number(text.replace(decimal_separator, '.').replace(group_separator, '')); }; -exports.NETWORKDAYS.INTL = function(start_date, end_date, weekend, holidays) { - start_date = utils.parseDate(start_date); +// TODO +exports.PRONETIC = function() { + throw new Error('PRONETIC is not implemented'); +}; - if (start_date instanceof Error) { - return start_date; +exports.PROPER = function(text) { + if (text === undefined || text.length === 0) { + return error.value; } - end_date = utils.parseDate(end_date); - - if (end_date instanceof Error) { - return end_date; + if (text === true) { + text = 'TRUE'; } - if (weekend === undefined) { - weekend = WEEKEND_TYPES[1]; - } else { - weekend = WEEKEND_TYPES[weekend]; + if (text === false) { + text = 'FALSE'; } - if (!(weekend instanceof Array)) { + if (isNaN(text) && typeof text === 'number') { return error.value; } - if (holidays === undefined) { - holidays = []; - } else if (!(holidays instanceof Array)) { - holidays = [holidays]; + if (typeof text === 'number') { + text = '' + text; } - for (var i = 0; i < holidays.length; i++) { - var h = utils.parseDate(holidays[i]); - if (h instanceof Error) { - return h; - } - holidays[i] = h; - } - var days = (end_date - start_date) / (1000 * 60 * 60 * 24) + 1; - var total = days; - var day = start_date; - for (i = 0; i < days; i++) { - var d = (new Date().getTimezoneOffset() > 0) ? day.getUTCDay() : day.getDay(); - var dec = false; - if (d === weekend[0] || d === weekend[1]) { - dec = true; - } - for (var j = 0; j < holidays.length; j++) { - var holiday = holidays[j]; - if (holiday.getDate() === day.getDate() && - holiday.getMonth() === day.getMonth() && - holiday.getFullYear() === day.getFullYear()) { - dec = true; - break; - } - } - if (dec) { - total--; - } - day.setDate(day.getDate() + 1); - } - - return total; + return text.replace(/\w\S*/g, function(txt) { + return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase(); + }); }; -exports.NOW = function() { - return new Date(); +exports.REGEXEXTRACT = function (text, regular_expression) { + if (arguments.length < 2) { + return error.na; + } + var match = text.match(new RegExp(regular_expression)); + return match ? (match[match.length > 1 ? match.length - 1 : 0]) : null; }; -exports.SECOND = function(serial_number) { - serial_number = utils.parseDate(serial_number); - if (serial_number instanceof Error) { - return serial_number; +exports.REGEXMATCH = function (text, regular_expression, full) { + if (arguments.length < 2) { + return error.na; } + var match = text.match(new RegExp(regular_expression)); + return full ? match : !!match; +}; - return serial_number.getSeconds(); +exports.REGEXREPLACE = function (text, regular_expression, replacement) { + if (arguments.length < 3) { + return error.na; + } + return text.replace(new RegExp(regular_expression), replacement); }; -exports.TIME = function(hour, minute, second) { - hour = utils.parseNumber(hour); - minute = utils.parseNumber(minute); - second = utils.parseNumber(second); - if (utils.anyIsError(hour, minute, second)) { +exports.REPLACE = function(text, position, length, new_text) { + position = utils.parseNumber(position); + length = utils.parseNumber(length); + if (utils.anyIsError(position, length) || + typeof text !== 'string' || + typeof new_text !== 'string') { return error.value; } - if (hour < 0 || minute < 0 || second < 0) { - return error.num; - } - - return (3600 * hour + 60 * minute + second) / 86400; + return text.substr(0, position - 1) + new_text + text.substr(position - 1 + length); }; -exports.TIMEVALUE = function(time_text) { - time_text = utils.parseDate(time_text); +exports.REPT = function(text, number) { + number = utils.parseNumber(number); + if (number instanceof Error) { + return number; + } + return new Array(number + 1).join(text); +}; - if (time_text instanceof Error) { - return time_text; +exports.RIGHT = function(text, number) { + number = (number === undefined) ? 1 : number; + number = utils.parseNumber(number); + if (number instanceof Error) { + return number; } + return text ? text.substring(text.length - number) : error.na; +}; - return (3600 * time_text.getHours() + 60 * time_text.getMinutes() + time_text.getSeconds()) / 86400; +exports.SEARCH = function(find_text, within_text, position) { + var foundAt; + if (typeof find_text !== 'string' || typeof within_text !== 'string') { + return error.value; + } + position = (position === undefined) ? 0 : position; + foundAt = within_text.toLowerCase().indexOf(find_text.toLowerCase(), position - 1)+1; + return (foundAt === 0)?error.value:foundAt; }; -exports.TODAY = function() { - return new Date(); +exports.SPLIT = function (text, separator) { + return text.split(separator); }; -exports.WEEKDAY = function(serial_number, return_type) { - serial_number = utils.parseDate(serial_number); - if (serial_number instanceof Error) { - return serial_number; +exports.SUBSTITUTE = function(text, old_text, new_text, occurrence) { + if (arguments.length < 2) { + return error.na; } - if (return_type === undefined) { - return_type = 1; + if (!text || !old_text || !new_text) { + return text; + } else if (occurrence === undefined) { + return text.replace(new RegExp(old_text, 'g'), new_text); + } else { + var index = 0; + var i = 0; + while (text.indexOf(old_text, index) > 0) { + index = text.indexOf(old_text, index + 1); + i++; + if (i === occurrence) { + return text.substring(0, index) + new_text + text.substring(index + old_text.length); + } + } } - var day = serial_number.getDay(); +}; - return WEEK_TYPES[return_type][day]; +exports.T = function(value) { + return (typeof value === "string") ? value : ''; }; -exports.WEEKNUM = function(serial_number, return_type) { - serial_number = utils.parseDate(serial_number); - if (serial_number instanceof Error) { - return serial_number; - } - if (return_type === undefined) { - return_type = 1; - } - if (return_type === 21) { - return this.ISOWEEKNUM(serial_number); +// TODO incomplete implementation +exports.TEXT = function(value, format) { + value = utils.parseNumber(value); + if (utils.anyIsError(value)) { + return error.na; } - var week_start = WEEK_STARTS[return_type]; - var jan = new Date(serial_number.getFullYear(), 0, 1); - var inc = jan.getDay() < week_start ? 1 : 0; - jan -= Math.abs(jan.getDay() - week_start) * 24 * 60 * 60 * 1000; - return Math.floor(((serial_number - jan) / (1000 * 60 * 60 * 24)) / 7 + 1) + inc; + return numbro(value).format(format); }; -exports.WORKDAY = function(start_date, days, holidays) { - return this.WORKDAY.INTL(start_date, days, 1, holidays); +exports.TRIM = function(text) { + if (typeof text !== 'string') { + return error.value; + } + return text.replace(/ +/g, ' ').trim(); }; -exports.WORKDAY.INTL = function(start_date, days, weekend, holidays) { - start_date = utils.parseDate(start_date); - if (start_date instanceof Error) { - return start_date; - } - days = utils.parseNumber(days); - if (days instanceof Error) { - return days; - } - if (days < 0) { - return error.num; - } - if (weekend === undefined) { - weekend = WEEKEND_TYPES[1]; - } else { - weekend = WEEKEND_TYPES[weekend]; - } - if (!(weekend instanceof Array)) { +exports.UNICHAR = exports.CHAR; + +exports.UNICODE = exports.CODE; + +exports.UPPER = function(text) { + if (typeof text !== 'string') { return error.value; } - if (holidays === undefined) { - holidays = []; - } else if (!(holidays instanceof Array)) { - holidays = [holidays]; - } - for (var i = 0; i < holidays.length; i++) { - var h = utils.parseDate(holidays[i]); - if (h instanceof Error) { - return h; - } - holidays[i] = h; - } - var d = 0; - while (d < days) { - start_date.setDate(start_date.getDate() + 1); - var day = start_date.getDay(); - if (day === weekend[0] || day === weekend[1]) { - continue; - } - for (var j = 0; j < holidays.length; j++) { - var holiday = holidays[j]; - if (holiday.getDate() === start_date.getDate() && - holiday.getMonth() === start_date.getMonth() && - holiday.getFullYear() === start_date.getFullYear()) { - d--; - break; - } - } - d++; - } - - return start_date; + return text.toUpperCase(); }; -exports.YEAR = function(serial_number) { - serial_number = utils.parseDate(serial_number); - - if (serial_number instanceof Error) { - return serial_number; +exports.VALUE = function(text) { + if (typeof text !== 'string') { + return error.value; } + var result = numbro().unformat(text); - return serial_number.getFullYear(); + return result === void 0 ? 0 : result; }; -function isLeapYear(year) { - return new Date(year, 1, 29).getMonth() === 1; -} -// TODO : Use DAYS ? -function daysBetween(start_date, end_date) { - return Math.ceil((end_date - start_date) / 1000 / 60 / 60 / 24); -} +/***/ }), +/* 7 */ +/***/ (function(module, exports, __webpack_require__) { -exports.YEARFRAC = function(start_date, end_date, basis) { - start_date = utils.parseDate(start_date); - if (start_date instanceof Error) { - return start_date; - } - end_date = utils.parseDate(end_date); - if (end_date instanceof Error) { - return end_date; - } +var error = __webpack_require__(0); - basis = basis || 0; - var sd = start_date.getDate(); - var sm = start_date.getMonth() + 1; - var sy = start_date.getFullYear(); - var ed = end_date.getDate(); - var em = end_date.getMonth() + 1; - var ey = end_date.getFullYear(); - - switch (basis) { - case 0: - // US (NASD) 30/360 - if (sd === 31 && ed === 31) { - sd = 30; - ed = 30; - } else if (sd === 31) { - sd = 30; - } else if (sd === 30 && ed === 31) { - ed = 30; - } - return ((ed + em * 30 + ey * 360) - (sd + sm * 30 + sy * 360)) / 360; - case 1: - // Actual/actual - var feb29Between = function(date1, date2) { - var year1 = date1.getFullYear(); - var mar1year1 = new Date(year1, 2, 1); - if (isLeapYear(year1) && date1 < mar1year1 && date2 >= mar1year1) { - return true; - } - var year2 = date2.getFullYear(); - var mar1year2 = new Date(year2, 2, 1); - return (isLeapYear(year2) && date2 >= mar1year2 && date1 < mar1year2); - }; - var ylength = 365; - if (sy === ey || ((sy + 1) === ey) && ((sm > em) || ((sm === em) && (sd >= ed)))) { - if ((sy === ey && isLeapYear(sy)) || - feb29Between(start_date, end_date) || - (em === 1 && ed === 29)) { - ylength = 366; - } - return daysBetween(start_date, end_date) / ylength; - } - var years = (ey - sy) + 1; - var days = (new Date(ey + 1, 0, 1) - new Date(sy, 0, 1)) / 1000 / 60 / 60 / 24; - var average = days / years; - return daysBetween(start_date, end_date) / average; - case 2: - // Actual/360 - return daysBetween(start_date, end_date) / 360; - case 3: - // Actual/365 - return daysBetween(start_date, end_date) / 365; - case 4: - // European 30/360 - return ((ed + em * 30 + ey * 360) - (sd + sm * 30 + sy * 360)) / 360; - } -}; - -function serial(date) { - var addOn = (date > -2203891200000) ? 2 : 1; - - return (date - d1900) / 86400000 + addOn; -} - - -/***/ }), -/* 7 */ -/***/ (function(module, exports, __webpack_require__) { - -var error = __webpack_require__(0); - -// TODO -exports.CELL = function() { - throw new Error('CELL is not implemented'); -}; +// TODO +exports.CELL = function() { + throw new Error('CELL is not implemented'); +}; exports.ERROR = {}; exports.ERROR.TYPE = function(error_val) { @@ -4107,4532 +3908,4857 @@ exports.TYPE = function(value) { /* 8 */ /***/ (function(module, exports, __webpack_require__) { -var utils = __webpack_require__(2); var error = __webpack_require__(0); -var numbro = __webpack_require__(14); +var utils = __webpack_require__(1); -//TODO -exports.ASC = function() { - throw new Error('ASC is not implemented'); -}; +var d1900 = new Date(1900, 0, 1); +var WEEK_STARTS = [ + undefined, + 0, + 1, + undefined, + undefined, + undefined, + undefined, + undefined, + undefined, + undefined, + undefined, + undefined, + 1, + 2, + 3, + 4, + 5, + 6, + 0 +]; +var WEEK_TYPES = [ + [], + [1, 2, 3, 4, 5, 6, 7], + [7, 1, 2, 3, 4, 5, 6], + [6, 0, 1, 2, 3, 4, 5], + [], + [], + [], + [], + [], + [], + [], + [7, 1, 2, 3, 4, 5, 6], + [6, 7, 1, 2, 3, 4, 5], + [5, 6, 7, 1, 2, 3, 4], + [4, 5, 6, 7, 1, 2, 3], + [3, 4, 5, 6, 7, 1, 2], + [2, 3, 4, 5, 6, 7, 1], + [1, 2, 3, 4, 5, 6, 7] +]; +var WEEKEND_TYPES = [ + [], + [6, 0], + [0, 1], + [1, 2], + [2, 3], + [3, 4], + [4, 5], + [5, 6], + undefined, + undefined, + undefined, [0, 0], + [1, 1], + [2, 2], + [3, 3], + [4, 4], + [5, 5], + [6, 6] +]; -//TODO -exports.BAHTTEXT = function() { - throw new Error('BAHTTEXT is not implemented'); -}; +exports.DATE = function(year, month, day) { + var result; -exports.CHAR = function(number) { - number = utils.parseNumber(number); - if (number instanceof Error) { - return number; - } - return String.fromCharCode(number); -}; + year = utils.parseNumber(year); + month = utils.parseNumber(month); + day = utils.parseNumber(day); -exports.CLEAN = function(text) { - text = text || ''; - var re = /[\0-\x1F]/g; - return text.replace(re, ""); -}; + if (utils.anyIsError(year, month, day)) { + result = error.value; -exports.CODE = function(text) { - text = text || ''; - var result = text.charCodeAt(0); + } else if (year < 0 || month < 0 || day < 0) { + result = error.num; - if (isNaN(result)) { - result = error.na; + } else { + result = new Date(year, month - 1, day); } + return result; }; -exports.CONCATENATE = function() { - var args = utils.flatten(arguments); - - var trueFound = 0; - while ((trueFound = args.indexOf(true)) > -1) { - args[trueFound] = 'TRUE'; +exports.DATEVALUE = function(date_text) { + if (typeof date_text !== 'string') { + return error.value; } + var date = Date.parse(date_text); - var falseFound = 0; - while ((falseFound = args.indexOf(false)) > -1) { - args[falseFound] = 'FALSE'; + if (isNaN(date)) { + return error.value; + } + if (date <= -2203891200000) { + return (date - d1900) / 86400000 + 1; } - return args.join(''); + return (date - d1900) / 86400000 + 2; }; -//TODO -exports.DBCS = function() { - throw new Error('DBCS is not implemented'); +exports.DAY = function(serial_number) { + var date = utils.parseDate(serial_number); + if (date instanceof Error) { + return date; + } + + return date.getDate(); }; -exports.DOLLAR = function(number, decimals) { - decimals = (decimals === undefined) ? 2 : decimals; +exports.DAYS = function(end_date, start_date) { + end_date = utils.parseDate(end_date); + start_date = utils.parseDate(start_date); - number = utils.parseNumber(number); - decimals = utils.parseNumber(decimals); - if (utils.anyIsError(number, decimals)) { - return error.value; - } - var format = ''; - if (decimals <= 0) { - number = Math.round(number * Math.pow(10, decimals)) / Math.pow(10, decimals); - format = '($0,0)'; - } else if (decimals > 0) { - format = '($0,0.' + new Array(decimals + 1).join('0') + ')'; + if (end_date instanceof Error) { + return end_date; } - return numbro(number).format(format); -}; - -exports.EXACT = function(text1, text2) { - if (arguments.length !== 2) { - return error.na; + if (start_date instanceof Error) { + return start_date; } - return text1 === text2; -}; -exports.FIND = function(find_text, within_text, position) { - if (arguments.length < 2) { - return error.na; - } - position = (position === undefined) ? 0 : position; - return within_text ? within_text.indexOf(find_text, position - 1) + 1 : null; + return serial(end_date) - serial(start_date); }; -exports.FIXED = function(number, decimals, no_commas) { - decimals = (decimals === undefined) ? 2 : decimals; - no_commas = (no_commas === undefined) ? false : no_commas; +exports.DAYS360 = function(start_date, end_date, method) { + method = utils.parseBool(method); + start_date = utils.parseDate(start_date); + end_date = utils.parseDate(end_date); - number = utils.parseNumber(number); - decimals = utils.parseNumber(decimals); - if (utils.anyIsError(number, decimals)) { - return error.value; + if (start_date instanceof Error) { + return start_date; } - - var format = no_commas ? '0' : '0,0'; - if (decimals <= 0) { - number = Math.round(number * Math.pow(10, decimals)) / Math.pow(10, decimals); - } else if (decimals > 0) { - format += '.' + new Array(decimals + 1).join('0'); + if (end_date instanceof Error) { + return end_date; } - return numbro(number).format(format); -}; + if (method instanceof Error) { + return method; + } + var sm = start_date.getMonth(); + var em = end_date.getMonth(); + var sd, ed; -exports.HTML2TEXT = function (value) { - var result = ''; - - if (value) { - if (value instanceof Array) { - value.forEach(function (line) { - if (result !== '') { - result += '\n'; - } - result += (line.replace(/<(?:.|\n)*?>/gm, '')); - }); + if (method) { + sd = start_date.getDate() === 31 ? 30 : start_date.getDate(); + ed = end_date.getDate() === 31 ? 30 : end_date.getDate(); + } else { + var smd = new Date(start_date.getFullYear(), sm + 1, 0).getDate(); + var emd = new Date(end_date.getFullYear(), em + 1, 0).getDate(); + sd = start_date.getDate() === smd ? 30 : start_date.getDate(); + if (end_date.getDate() === emd) { + if (sd < 30) { + em++; + ed = 1; + } else { + ed = 30; + } } else { - result = value.replace(/<(?:.|\n)*?>/gm, ''); + ed = end_date.getDate(); } } - return result; + return 360 * (end_date.getFullYear() - start_date.getFullYear()) + + 30 * (em - sm) + (ed - sd); }; -exports.LEFT = function(text, number) { - number = (number === undefined) ? 1 : number; - number = utils.parseNumber(number); - if (number instanceof Error || typeof text !== 'string') { +exports.EDATE = function(start_date, months) { + start_date = utils.parseDate(start_date); + + if (start_date instanceof Error) { + return start_date; + } + if (isNaN(months)) { return error.value; } - return text ? text.substring(0, number) : null; + months = parseInt(months, 10); + start_date.setMonth(start_date.getMonth() + months); + + return serial(start_date); }; -exports.LEN = function(text) { - if (arguments.length === 0) { - return error.error; - } +exports.EOMONTH = function(start_date, months) { + start_date = utils.parseDate(start_date); - if (typeof text === 'string') { - return text ? text.length : 0; + if (start_date instanceof Error) { + return start_date; } + if (isNaN(months)) { + return error.value; + } + months = parseInt(months, 10); - if (text.length) { - return text.length; + return serial(new Date(start_date.getFullYear(), start_date.getMonth() + months + 1, 0)); +}; + +exports.HOUR = function(serial_number) { + serial_number = utils.parseDate(serial_number); + + if (serial_number instanceof Error) { + return serial_number; } - return error.value; + return serial_number.getHours(); }; -exports.LOWER = function(text) { - if (typeof text !== 'string') { +exports.INTERVAL = function (second) { + if (typeof second !== 'number' && typeof second !== 'string') { return error.value; + } else { + second = parseInt(second, 10); } - return text ? text.toLowerCase() : text; + + var year = Math.floor(second/946080000); + second = second%946080000; + var month = Math.floor(second/2592000); + second = second%2592000; + var day = Math.floor(second/86400); + second = second%86400; + + var hour = Math.floor(second/3600); + second = second%3600; + var min = Math.floor(second/60); + second = second%60; + var sec = second; + + year = (year > 0) ? year + 'Y' : ''; + month = (month > 0) ? month + 'M' : ''; + day = (day > 0) ? day + 'D' : ''; + hour = (hour > 0) ? hour + 'H' : ''; + min = (min > 0) ? min + 'M' : ''; + sec = (sec > 0) ? sec + 'S' : ''; + + return 'P' + year + month + day + 'T' + hour + min + sec; }; -exports.MID = function(text, start, number) { - start = utils.parseNumber(start); - number = utils.parseNumber(number); - if (utils.anyIsError(start, number) || typeof text !== 'string') { - return number; +exports.ISOWEEKNUM = function(date) { + date = utils.parseDate(date); + + if (date instanceof Error) { + return date; } - var begin = start - 1; - var end = begin + number; + date.setHours(0, 0, 0); + date.setDate(date.getDate() + 4 - (date.getDay() || 7)); + var yearStart = new Date(date.getFullYear(), 0, 1); - return text.substring(begin, end); + return Math.ceil((((date - yearStart) / 86400000) + 1) / 7); }; -// TODO -exports.NUMBERVALUE = function (text, decimal_separator, group_separator) { - decimal_separator = (typeof decimal_separator === 'undefined') ? '.' : decimal_separator; - group_separator = (typeof group_separator === 'undefined') ? ',' : group_separator; - return Number(text.replace(decimal_separator, '.').replace(group_separator, '')); +exports.MINUTE = function(serial_number) { + serial_number = utils.parseDate(serial_number); + + if (serial_number instanceof Error) { + return serial_number; + } + + return serial_number.getMinutes(); }; -// TODO -exports.PRONETIC = function() { - throw new Error('PRONETIC is not implemented'); +exports.MONTH = function(serial_number) { + serial_number = utils.parseDate(serial_number); + + if (serial_number instanceof Error) { + return serial_number; + } + + return serial_number.getMonth() + 1; }; -exports.PROPER = function(text) { - if (text === undefined || text.length === 0) { - return error.value; +exports.NETWORKDAYS = function(start_date, end_date, holidays) { + return this.NETWORKDAYS.INTL(start_date, end_date, 1, holidays); +}; + +exports.NETWORKDAYS.INTL = function(start_date, end_date, weekend, holidays) { + start_date = utils.parseDate(start_date); + + if (start_date instanceof Error) { + return start_date; } - if (text === true) { - text = 'TRUE'; + end_date = utils.parseDate(end_date); + + if (end_date instanceof Error) { + return end_date; } - if (text === false) { - text = 'FALSE'; + if (weekend === undefined) { + weekend = WEEKEND_TYPES[1]; + } else { + weekend = WEEKEND_TYPES[weekend]; } - if (isNaN(text) && typeof text === 'number') { + if (!(weekend instanceof Array)) { return error.value; } - if (typeof text === 'number') { - text = '' + text; + if (holidays === undefined) { + holidays = []; + } else if (!(holidays instanceof Array)) { + holidays = [holidays]; } - return text.replace(/\w\S*/g, function(txt) { - return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase(); - }); -}; - -exports.REGEXEXTRACT = function (text, regular_expression) { - if (arguments.length < 2) { - return error.na; + for (var i = 0; i < holidays.length; i++) { + var h = utils.parseDate(holidays[i]); + if (h instanceof Error) { + return h; + } + holidays[i] = h; } - var match = text.match(new RegExp(regular_expression)); - return match ? (match[match.length > 1 ? match.length - 1 : 0]) : null; + var days = (end_date - start_date) / (1000 * 60 * 60 * 24) + 1; + var total = days; + var day = start_date; + for (i = 0; i < days; i++) { + var d = (new Date().getTimezoneOffset() > 0) ? day.getUTCDay() : day.getDay(); + var dec = false; + if (d === weekend[0] || d === weekend[1]) { + dec = true; + } + for (var j = 0; j < holidays.length; j++) { + var holiday = holidays[j]; + if (holiday.getDate() === day.getDate() && + holiday.getMonth() === day.getMonth() && + holiday.getFullYear() === day.getFullYear()) { + dec = true; + break; + } + } + if (dec) { + total--; + } + day.setDate(day.getDate() + 1); + } + + return total; }; -exports.REGEXMATCH = function (text, regular_expression, full) { - if (arguments.length < 2) { - return error.na; - } - var match = text.match(new RegExp(regular_expression)); - return full ? match : !!match; +exports.NOW = function() { + return new Date(); }; -exports.REGEXREPLACE = function (text, regular_expression, replacement) { - if (arguments.length < 3) { - return error.na; +exports.SECOND = function(serial_number) { + serial_number = utils.parseDate(serial_number); + if (serial_number instanceof Error) { + return serial_number; } - return text.replace(new RegExp(regular_expression), replacement); + + return serial_number.getSeconds(); }; -exports.REPLACE = function(text, position, length, new_text) { - position = utils.parseNumber(position); - length = utils.parseNumber(length); - if (utils.anyIsError(position, length) || - typeof text !== 'string' || - typeof new_text !== 'string') { +exports.TIME = function(hour, minute, second) { + hour = utils.parseNumber(hour); + minute = utils.parseNumber(minute); + second = utils.parseNumber(second); + if (utils.anyIsError(hour, minute, second)) { return error.value; } - return text.substr(0, position - 1) + new_text + text.substr(position - 1 + length); -}; - -exports.REPT = function(text, number) { - number = utils.parseNumber(number); - if (number instanceof Error) { - return number; + if (hour < 0 || minute < 0 || second < 0) { + return error.num; } - return new Array(number + 1).join(text); + + return (3600 * hour + 60 * minute + second) / 86400; }; -exports.RIGHT = function(text, number) { - number = (number === undefined) ? 1 : number; - number = utils.parseNumber(number); - if (number instanceof Error) { - return number; +exports.TIMEVALUE = function(time_text) { + time_text = utils.parseDate(time_text); + + if (time_text instanceof Error) { + return time_text; } - return text ? text.substring(text.length - number) : error.na; + + return (3600 * time_text.getHours() + 60 * time_text.getMinutes() + time_text.getSeconds()) / 86400; }; -exports.SEARCH = function(find_text, within_text, position) { - var foundAt; - if (typeof find_text !== 'string' || typeof within_text !== 'string') { - return error.value; +exports.TODAY = function() { + return new Date(); +}; + +exports.WEEKDAY = function(serial_number, return_type) { + serial_number = utils.parseDate(serial_number); + if (serial_number instanceof Error) { + return serial_number; } - position = (position === undefined) ? 0 : position; - foundAt = within_text.toLowerCase().indexOf(find_text.toLowerCase(), position - 1)+1; - return (foundAt === 0)?error.value:foundAt; + if (return_type === undefined) { + return_type = 1; + } + var day = serial_number.getDay(); + + return WEEK_TYPES[return_type][day]; }; -exports.SPLIT = function (text, separator) { - return text.split(separator); +exports.WEEKNUM = function(serial_number, return_type) { + serial_number = utils.parseDate(serial_number); + if (serial_number instanceof Error) { + return serial_number; + } + if (return_type === undefined) { + return_type = 1; + } + if (return_type === 21) { + return this.ISOWEEKNUM(serial_number); + } + var week_start = WEEK_STARTS[return_type]; + var jan = new Date(serial_number.getFullYear(), 0, 1); + var inc = jan.getDay() < week_start ? 1 : 0; + jan -= Math.abs(jan.getDay() - week_start) * 24 * 60 * 60 * 1000; + + return Math.floor(((serial_number - jan) / (1000 * 60 * 60 * 24)) / 7 + 1) + inc; }; -exports.SUBSTITUTE = function(text, old_text, new_text, occurrence) { - if (arguments.length < 2) { - return error.na; +exports.WORKDAY = function(start_date, days, holidays) { + return this.WORKDAY.INTL(start_date, days, 1, holidays); +}; + +exports.WORKDAY.INTL = function(start_date, days, weekend, holidays) { + start_date = utils.parseDate(start_date); + if (start_date instanceof Error) { + return start_date; } - if (!text || !old_text || !new_text) { - return text; - } else if (occurrence === undefined) { - return text.replace(new RegExp(old_text, 'g'), new_text); + days = utils.parseNumber(days); + if (days instanceof Error) { + return days; + } + if (days < 0) { + return error.num; + } + if (weekend === undefined) { + weekend = WEEKEND_TYPES[1]; } else { - var index = 0; - var i = 0; - while (text.indexOf(old_text, index) > 0) { - index = text.indexOf(old_text, index + 1); - i++; - if (i === occurrence) { - return text.substring(0, index) + new_text + text.substring(index + old_text.length); + weekend = WEEKEND_TYPES[weekend]; + } + if (!(weekend instanceof Array)) { + return error.value; + } + if (holidays === undefined) { + holidays = []; + } else if (!(holidays instanceof Array)) { + holidays = [holidays]; + } + for (var i = 0; i < holidays.length; i++) { + var h = utils.parseDate(holidays[i]); + if (h instanceof Error) { + return h; + } + holidays[i] = h; + } + var d = 0; + while (d < days) { + start_date.setDate(start_date.getDate() + 1); + var day = start_date.getDay(); + if (day === weekend[0] || day === weekend[1]) { + continue; + } + for (var j = 0; j < holidays.length; j++) { + var holiday = holidays[j]; + if (holiday.getDate() === start_date.getDate() && + holiday.getMonth() === start_date.getMonth() && + holiday.getFullYear() === start_date.getFullYear()) { + d--; + break; } } + d++; } -}; -exports.T = function(value) { - return (typeof value === "string") ? value : ''; + return start_date; }; -// TODO incomplete implementation -exports.TEXT = function(value, format) { - value = utils.parseNumber(value); - if (utils.anyIsError(value)) { - return error.na; +exports.YEAR = function(serial_number) { + serial_number = utils.parseDate(serial_number); + + if (serial_number instanceof Error) { + return serial_number; } - return numbro(value).format(format); + return serial_number.getFullYear(); }; -exports.TRIM = function(text) { - if (typeof text !== 'string') { - return error.value; - } - return text.replace(/ +/g, ' ').trim(); -}; +function isLeapYear(year) { + return new Date(year, 1, 29).getMonth() === 1; +} -exports.UNICHAR = exports.CHAR; +// TODO : Use DAYS ? +function daysBetween(start_date, end_date) { + return Math.ceil((end_date - start_date) / 1000 / 60 / 60 / 24); +} -exports.UNICODE = exports.CODE; +exports.YEARFRAC = function(start_date, end_date, basis) { + start_date = utils.parseDate(start_date); + if (start_date instanceof Error) { + return start_date; + } + end_date = utils.parseDate(end_date); + if (end_date instanceof Error) { + return end_date; + } -exports.UPPER = function(text) { - if (typeof text !== 'string') { - return error.value; + basis = basis || 0; + var sd = start_date.getDate(); + var sm = start_date.getMonth() + 1; + var sy = start_date.getFullYear(); + var ed = end_date.getDate(); + var em = end_date.getMonth() + 1; + var ey = end_date.getFullYear(); + + switch (basis) { + case 0: + // US (NASD) 30/360 + if (sd === 31 && ed === 31) { + sd = 30; + ed = 30; + } else if (sd === 31) { + sd = 30; + } else if (sd === 30 && ed === 31) { + ed = 30; + } + return ((ed + em * 30 + ey * 360) - (sd + sm * 30 + sy * 360)) / 360; + case 1: + // Actual/actual + var feb29Between = function(date1, date2) { + var year1 = date1.getFullYear(); + var mar1year1 = new Date(year1, 2, 1); + if (isLeapYear(year1) && date1 < mar1year1 && date2 >= mar1year1) { + return true; + } + var year2 = date2.getFullYear(); + var mar1year2 = new Date(year2, 2, 1); + return (isLeapYear(year2) && date2 >= mar1year2 && date1 < mar1year2); + }; + var ylength = 365; + if (sy === ey || ((sy + 1) === ey) && ((sm > em) || ((sm === em) && (sd >= ed)))) { + if ((sy === ey && isLeapYear(sy)) || + feb29Between(start_date, end_date) || + (em === 1 && ed === 29)) { + ylength = 366; + } + return daysBetween(start_date, end_date) / ylength; + } + var years = (ey - sy) + 1; + var days = (new Date(ey + 1, 0, 1) - new Date(sy, 0, 1)) / 1000 / 60 / 60 / 24; + var average = days / years; + return daysBetween(start_date, end_date) / average; + case 2: + // Actual/360 + return daysBetween(start_date, end_date) / 360; + case 3: + // Actual/365 + return daysBetween(start_date, end_date) / 365; + case 4: + // European 30/360 + return ((ed + em * 30 + ey * 360) - (sd + sm * 30 + sy * 360)) / 360; } - return text.toUpperCase(); }; -exports.VALUE = function(text) { - if (typeof text !== 'string') { - return error.value; - } - var result = numbro().unformat(text); +function serial(date) { + var addOn = (date > -2203891200000) ? 2 : 1; - return result === void 0 ? 0 : result; -}; + return (date - d1900) / 86400000 + addOn; +} /***/ }), /* 9 */ /***/ (function(module, exports, __webpack_require__) { -"use strict"; - - -exports.__esModule = true; -exports.rowLabelToIndex = rowLabelToIndex; -exports.rowIndexToLabel = rowIndexToLabel; -exports.columnLabelToIndex = columnLabelToIndex; -exports.columnIndexToLabel = columnIndexToLabel; -exports.extractLabel = extractLabel; -exports.toLabel = toLabel; -/** - * Convert row label to index. - * - * @param {String} label Row label (eq. '1', '5') - * @returns {Number} Returns -1 if label is not recognized otherwise proper row index. +/* WEBPACK VAR INJECTION */(function(process) {var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*! + * numbro.js + * version : 1.11.0 + * author : Företagsplatsen AB + * license : MIT + * http://www.foretagsplatsen.se */ -function rowLabelToIndex(label) { - var result = parseInt(label, 10); - if (isNaN(result)) { - result = -1; - } else { - result = Math.max(result - 1, -1); - } +(function () { + 'use strict'; - return result; -} - -/** - * Convert row index to label. - * - * @param {Number} row Row index. - * @returns {String} Returns row label (eq. '1', '7'). - */ -function rowIndexToLabel(row) { - var result = ''; - - if (row >= 0) { - result = '' + (row + 1); - } - - return result; -} + /************************************ + Constants + ************************************/ -var COLUMN_LABEL_BASE = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'; -var COLUMN_LABEL_BASE_LENGTH = COLUMN_LABEL_BASE.length; + var numbro, + VERSION = '1.11.0', + binarySuffixes = ['B', 'KiB', 'MiB', 'GiB', 'TiB', 'PiB', 'EiB', 'ZiB', 'YiB'], + decimalSuffixes = ['B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'], + bytes = { + general: { scale: 1024, suffixes: decimalSuffixes, marker: 'bd' }, + binary: { scale: 1024, suffixes: binarySuffixes, marker: 'b' }, + decimal: { scale: 1000, suffixes: decimalSuffixes, marker: 'd' } + }, + // general must be before the others because it reuses their characters! + byteFormatOrder = [ bytes.general, bytes.binary, bytes.decimal ], + // internal storage for culture config files + cultures = {}, + // Todo: Remove in 2.0.0 + languages = cultures, + currentCulture = 'en-US', + zeroFormat = null, + defaultFormat = '0,0', + defaultCurrencyFormat = '0$', + // check for nodeJS + hasModule = (typeof module !== 'undefined' && module.exports), + // default culture + enUS = { + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal: function(number) { + var b = number % 10; + return (~~(number % 100 / 10) === 1) ? 'th' : + (b === 1) ? 'st' : + (b === 2) ? 'nd' : + (b === 3) ? 'rd' : 'th'; + }, + currency: { + symbol: '$', + position: 'prefix' + }, + defaults: { + currencyFormat: ',0000 a' + }, + formats: { + fourDigits: '0000 a', + fullWithTwoDecimals: '$ ,0.00', + fullWithTwoDecimalsNoCurrency: ',0.00' + } + }; -/** - * Convert column label to index. - * - * @param {String} label Column label (eq. 'ABB', 'CNQ') - * @returns {Number} Returns -1 if label is not recognized otherwise proper column index. - */ -function columnLabelToIndex(label) { - var result = 0; + /************************************ + Constructors + ************************************/ - if (typeof label === 'string') { - label = label.toUpperCase(); - for (var i = 0, j = label.length - 1; i < label.length; i += 1, j -= 1) { - result += Math.pow(COLUMN_LABEL_BASE_LENGTH, j) * (COLUMN_LABEL_BASE.indexOf(label[i]) + 1); + // Numbro prototype object + function Numbro(number) { + this._value = number; } - } - --result; - return result; -} + function numberLength(number) { + if (number === 0) { return 1; } + return Math.floor(Math.log(Math.abs(number)) / Math.LN10) + 1; + } -/** - * Convert column index to label. - * - * @param {Number} column Column index. - * @returns {String} Returns column label (eq. 'ABB', 'CNQ'). - */ -function columnIndexToLabel(column) { - var result = ''; + function zeroes(count) { + var i, ret = ''; - while (column >= 0) { - result = String.fromCharCode(column % COLUMN_LABEL_BASE_LENGTH + 97) + result; - column = Math.floor(column / COLUMN_LABEL_BASE_LENGTH) - 1; - } + for (i = 0; i < count; i++) { + ret += '0'; + } - return result.toUpperCase(); -} + return ret; + } + /** + * Implementation of toFixed() for numbers with exponents + * This function may return negative representations for zero values e.g. "-0.0" + */ + function toFixedLargeSmall(value, precision) { + var mantissa, + beforeDec, + afterDec, + exponent, + prefix, + endStr, + zerosStr, + str; -var LABEL_EXTRACT_REGEXP = /^([$])?([A-Za-z]+)([$])?([0-9]+)$/; + str = value.toString(); -/** - * Extract cell coordinates. - * - * @param {String} label Cell coordinates (eq. 'A1', '$B6', '$N$98'). - * @returns {Array} Returns an array of objects. - */ -function extractLabel(label) { - if (typeof label !== 'string' || !LABEL_EXTRACT_REGEXP.test(label)) { - return []; - } + mantissa = str.split('e')[0]; + exponent = str.split('e')[1]; - var _label$toUpperCase$ma = label.toUpperCase().match(LABEL_EXTRACT_REGEXP), - columnAbs = _label$toUpperCase$ma[1], - column = _label$toUpperCase$ma[2], - rowAbs = _label$toUpperCase$ma[3], - row = _label$toUpperCase$ma[4]; + beforeDec = mantissa.split('.')[0]; + afterDec = mantissa.split('.')[1] || ''; - return [{ - index: rowLabelToIndex(row), - label: row, - isAbsolute: rowAbs === '$' - }, { - index: columnLabelToIndex(column), - label: column, - isAbsolute: columnAbs === '$' - }]; -} + if (+exponent > 0) { + // exponent is positive - add zeros after the numbers + str = beforeDec + afterDec + zeroes(exponent - afterDec.length); + } else { + // exponent is negative -/** - * Convert row and column indexes into cell label. - * - * @param {Object} row Object with `index` and `isAbsolute` properties. - * @param {Object} column Object with `index` and `isAbsolute` properties. - * @returns {String} Returns cell label. - */ -function toLabel(row, column) { - var rowLabel = (row.isAbsolute ? '$' : '') + rowIndexToLabel(row.index); - var columnLabel = (column.isAbsolute ? '$' : '') + columnIndexToLabel(column.index); + if (+beforeDec < 0) { + prefix = '-0'; + } else { + prefix = '0'; + } - return columnLabel + rowLabel; -} + // tack on the decimal point if needed + if (precision > 0) { + prefix += '.'; + } -/***/ }), -/* 10 */ -/***/ (function(module, exports, __webpack_require__) { + zerosStr = zeroes((-1 * exponent) - 1); + // substring off the end to satisfy the precision + endStr = (zerosStr + Math.abs(beforeDec) + afterDec).substr(0, precision); + str = prefix + endStr; + } -"use strict"; + // only add percision 0's if the exponent is positive + if (+exponent > 0 && precision > 0) { + str += '.' + zeroes(precision); + } + return str; + } -exports.__esModule = true; -var SUPPORTED_FORMULAS = ['ABS', 'ACCRINT', 'ACOS', 'ACOSH', 'ACOT', 'ACOTH', 'ADD', 'AGGREGATE', 'AND', 'ARABIC', 'ARGS2ARRAY', 'ASIN', 'ASINH', 'ATAN', 'ATAN2', 'ATANH', 'AVEDEV', 'AVERAGE', 'AVERAGEA', 'AVERAGEIF', 'AVERAGEIFS', 'BASE', 'BESSELI', 'BESSELJ', 'BESSELK', 'BESSELY', 'BETA.DIST', 'BETA.INV', 'BETADIST', 'BETAINV', 'BIN2DEC', 'BIN2HEX', 'BIN2OCT', 'BINOM.DIST', 'BINOM.DIST.RANGE', 'BINOM.INV', 'BINOMDIST', 'BITAND', 'BITLSHIFT', 'BITOR', 'BITRSHIFT', 'BITXOR', 'CEILING', 'CEILINGMATH', 'CEILINGPRECISE', 'CHAR', 'CHISQ.DIST', 'CHISQ.DIST.RT', 'CHISQ.INV', 'CHISQ.INV.RT', 'CHOOSE', 'CHOOSE', 'CLEAN', 'CODE', 'COLUMN', 'COLUMNS', 'COMBIN', 'COMBINA', 'COMPLEX', 'CONCATENATE', 'CONFIDENCE', 'CONFIDENCE.NORM', 'CONFIDENCE.T', 'CONVERT', 'CORREL', 'COS', 'COSH', 'COT', 'COTH', 'COUNT', 'COUNTA', 'COUNTBLANK', 'COUNTIF', 'COUNTIFS', 'COUNTIN', 'COUNTUNIQUE', 'COVARIANCE.P', 'COVARIANCE.S', 'CSC', 'CSCH', 'CUMIPMT', 'CUMPRINC', 'DATE', 'DATEVALUE', 'DAY', 'DAYS', 'DAYS360', 'DB', 'DDB', 'DEC2BIN', 'DEC2HEX', 'DEC2OCT', 'DECIMAL', 'DEGREES', 'DELTA', 'DEVSQ', 'DIVIDE', 'DOLLAR', 'DOLLARDE', 'DOLLARFR', 'E', 'EDATE', 'EFFECT', 'EOMONTH', 'EQ', 'ERF', 'ERFC', 'EVEN', 'EXACT', 'EXPON.DIST', 'EXPONDIST', 'F.DIST', 'F.DIST.RT', 'F.INV', 'F.INV.RT', 'FACT', 'FACTDOUBLE', 'FALSE', 'FDIST', 'FDISTRT', 'FIND', 'FINV', 'FINVRT', 'FISHER', 'FISHERINV', 'FIXED', 'FLATTEN', 'FLOOR', 'FORECAST', 'FREQUENCY', 'FV', 'FVSCHEDULE', 'GAMMA', 'GAMMA.DIST', 'GAMMA.INV', 'GAMMADIST', 'GAMMAINV', 'GAMMALN', 'GAMMALN.PRECISE', 'GAUSS', 'GCD', 'GEOMEAN', 'GESTEP', 'GROWTH', 'GTE', 'HARMEAN', 'HEX2BIN', 'HEX2DEC', 'HEX2OCT', 'HOUR', 'HTML2TEXT', 'HYPGEOM.DIST', 'HYPGEOMDIST', 'IF', 'IMABS', 'IMAGINARY', 'IMARGUMENT', 'IMCONJUGATE', 'IMCOS', 'IMCOSH', 'IMCOT', 'IMCSC', 'IMCSCH', 'IMDIV', 'IMEXP', 'IMLN', 'IMLOG10', 'IMLOG2', 'IMPOWER', 'IMPRODUCT', 'IMREAL', 'IMSEC', 'IMSECH', 'IMSIN', 'IMSINH', 'IMSQRT', 'IMSUB', 'IMSUM', 'IMTAN', 'INT', 'INTERCEPT', 'INTERVAL', 'IPMT', 'IRR', 'ISBINARY', 'ISBLANK', 'ISEVEN', 'ISLOGICAL', 'ISNONTEXT', 'ISNUMBER', 'ISODD', 'ISODD', 'ISOWEEKNUM', 'ISPMT', 'ISTEXT', 'JOIN', 'KURT', 'LARGE', 'LCM', 'LEFT', 'LEN', 'LINEST', 'LN', 'LOG', 'LOG10', 'LOGEST', 'LOGNORM.DIST', 'LOGNORM.INV', 'LOGNORMDIST', 'LOGNORMINV', 'LOWER', 'LT', 'LTE', 'MATCH', 'MAX', 'MAXA', 'MEDIAN', 'MID', 'MIN', 'MINA', 'MINUS', 'MINUTE', 'MIRR', 'MOD', 'MODE.MULT', 'MODE.SNGL', 'MODEMULT', 'MODESNGL', 'MONTH', 'MROUND', 'MULTINOMIAL', 'MULTIPLY', 'NE', 'NEGBINOM.DIST', 'NEGBINOMDIST', 'NETWORKDAYS', 'NOMINAL', 'NORM.DIST', 'NORM.INV', 'NORM.S.DIST', 'NORM.S.INV', 'NORMDIST', 'NORMINV', 'NORMSDIST', 'NORMSINV', 'NOT', 'NOW', 'NPER', 'NPV', 'NUMBERS', 'NUMERAL', 'OCT2BIN', 'OCT2DEC', 'OCT2HEX', 'ODD', 'OR', 'PDURATION', 'PEARSON', 'PERCENTILEEXC', 'PERCENTILEINC', 'PERCENTRANKEXC', 'PERCENTRANKINC', 'PERMUT', 'PERMUTATIONA', 'PHI', 'PI', 'PMT', 'POISSON.DIST', 'POISSONDIST', 'POW', 'POWER', 'PPMT', 'PROB', 'PRODUCT', 'PROPER', 'PV', 'QUARTILE.EXC', 'QUARTILE.INC', 'QUARTILEEXC', 'QUARTILEINC', 'QUOTIENT', 'RADIANS', 'RAND', 'RANDBETWEEN', 'RANK.AVG', 'RANK.EQ', 'RANKAVG', 'RANKEQ', 'RATE', 'REFERENCE', 'REGEXEXTRACT', 'REGEXMATCH', 'REGEXREPLACE', 'REPLACE', 'REPT', 'RIGHT', 'ROMAN', 'ROUND', 'ROUNDDOWN', 'ROUNDUP', 'ROW', 'ROWS', 'RRI', 'RSQ', 'SEARCH', 'SEC', 'SECH', 'SECOND', 'SERIESSUM', 'SIGN', 'SIN', 'SINH', 'SKEW', 'SKEW.P', 'SKEWP', 'SLN', 'SLOPE', 'SMALL', 'SPLIT', 'SPLIT', 'SQRT', 'SQRTPI', 'STANDARDIZE', 'STDEV.P', 'STDEV.S', 'STDEVA', 'STDEVP', 'STDEVPA', 'STDEVS', 'STEYX', 'SUBSTITUTE', 'SUBTOTAL', 'SUM', 'SUMIF', 'SUMIFS', 'SUMPRODUCT', 'SUMSQ', 'SUMX2MY2', 'SUMX2PY2', 'SUMXMY2', 'SWITCH', 'SYD', 'T', 'T.DIST', 'T.DIST.2T', 'T.DIST.RT', 'T.INV', 'T.INV.2T', 'TAN', 'TANH', 'TBILLEQ', 'TBILLPRICE', 'TBILLYIELD', 'TDIST', 'TDIST2T', 'TDISTRT', 'TEXT', 'TIME', 'TIMEVALUE', 'TINV', 'TINV2T', 'TODAY', 'TRANSPOSE', 'TREND', 'TRIM', 'TRIMMEAN', 'TRUE', 'TRUNC', 'UNICHAR', 'UNICODE', 'UNIQUE', 'UPPER', 'VALUE', 'VAR.P', 'VAR.S', 'VARA', 'VARP', 'VARPA', 'VARS', 'WEEKDAY', 'WEEKNUM', 'WEIBULL.DIST', 'WEIBULLDIST', 'WORKDAY', 'XIRR', 'XNPV', 'XOR', 'YEAR', 'YEARFRAC']; + /** + * Implementation of toFixed() that treats floats more like decimals + * + * Fixes binary rounding issues (eg. (0.615).toFixed(2) === '0.61') that present + * problems for accounting- and finance-related software. + * + * Also removes negative signs for zero-formatted numbers. e.g. -0.01 w/ precision 1 -> 0.0 + */ + function toFixed(value, precision, roundingFunction, optionals) { + var power = Math.pow(10, precision), + optionalsRegExp, + output; -exports['default'] = SUPPORTED_FORMULAS; + if (value.toString().indexOf('e') > -1) { + // toFixed returns scientific notation for numbers above 1e21 and below 1e-7 + output = toFixedLargeSmall(value, precision); + // remove the leading negative sign if it exists and should not be present (e.g. -0.00) + if (output.charAt(0) === '-' && +output >= 0) { + output = output.substr(1); // chop off the '-' + } + } + else { + // Multiply up by precision, round accurately, then divide and use native toFixed(): + output = (roundingFunction(value + 'e+' + precision) / power).toFixed(precision); + } -/***/ }), -/* 11 */ -/***/ (function(module, exports, __webpack_require__) { + if (optionals) { + optionalsRegExp = new RegExp('0{1,' + optionals + '}$'); + output = output.replace(optionalsRegExp, ''); + } -var error = __webpack_require__(0); -var jStat = __webpack_require__(13).jStat; -var text = __webpack_require__(8); -var utils = __webpack_require__(2); -var bessel = __webpack_require__(32); + return output; + } -function isValidBinaryNumber(number) { - return (/^[01]{1,10}$/).test(number); -} + /************************************ + Formatting + ************************************/ -exports.BESSELI = function(x, n) { - x = utils.parseNumber(x); - n = utils.parseNumber(n); - if (utils.anyIsError(x, n)) { - return error.value; - } + // determine what type of formatting we need to do + function formatNumbro(n, format, roundingFunction) { + var output, + escapedFormat = format.replace(/\{[^\{\}]*\}/g, ''); - return bessel.besseli(x, n); -}; + // figure out what kind of format we are dealing with + if (escapedFormat.indexOf('$') > -1) { // currency!!!!! + output = formatCurrency(n, cultures[currentCulture].currency.symbol, format, roundingFunction); + } else if (escapedFormat.indexOf('%') > -1) { // percentage + output = formatPercentage(n, format, roundingFunction); + } else if (escapedFormat.indexOf(':') > -1) { // time + output = formatTime(n, format); + } else { // plain ol' numbers or bytes + output = formatNumber(n._value, format, roundingFunction); + } -exports.BESSELJ = function(x, n) { - x = utils.parseNumber(x); - n = utils.parseNumber(n); - if (utils.anyIsError(x, n)) { - return error.value; - } + // return string + return output; + } - return bessel.besselj(x, n); -}; + // revert to number + function unformatNumbro(n, string) { + var stringOriginal = string, + thousandRegExp, + millionRegExp, + billionRegExp, + trillionRegExp, + bytesMultiplier = false, + power; -exports.BESSELK = function(x, n) { - x = utils.parseNumber(x); - n = utils.parseNumber(n); - if (utils.anyIsError(x, n)) { - return error.value; - } + if (string.indexOf(':') > -1) { + n._value = unformatTime(string); + } else { + if (string === zeroFormat) { + n._value = 0; + } else { + if (cultures[currentCulture].delimiters.decimal !== '.') { + string = string.replace(/\./g, '').replace(cultures[currentCulture].delimiters.decimal, '.'); + } - return bessel.besselk(x, n); -}; + // see if abbreviations are there so that we can multiply to the correct number + thousandRegExp = new RegExp('[^a-zA-Z]' + cultures[currentCulture].abbreviations.thousand + + '(?:\\)|(\\' + cultures[currentCulture].currency.symbol + ')?(?:\\))?)?$'); + millionRegExp = new RegExp('[^a-zA-Z]' + cultures[currentCulture].abbreviations.million + + '(?:\\)|(\\' + cultures[currentCulture].currency.symbol + ')?(?:\\))?)?$'); + billionRegExp = new RegExp('[^a-zA-Z]' + cultures[currentCulture].abbreviations.billion + + '(?:\\)|(\\' + cultures[currentCulture].currency.symbol + ')?(?:\\))?)?$'); + trillionRegExp = new RegExp('[^a-zA-Z]' + cultures[currentCulture].abbreviations.trillion + + '(?:\\)|(\\' + cultures[currentCulture].currency.symbol + ')?(?:\\))?)?$'); -exports.BESSELY = function(x, n) { - x = utils.parseNumber(x); - n = utils.parseNumber(n); - if (utils.anyIsError(x, n)) { - return error.value; - } + // see if bytes are there so that we can multiply to the correct number + for (power = 1; power < binarySuffixes.length && !bytesMultiplier; ++power) { + if (string.indexOf(binarySuffixes[power]) > -1) { + bytesMultiplier = Math.pow(1024, power); + } else if (string.indexOf(decimalSuffixes[power]) > -1) { + bytesMultiplier = Math.pow(1000, power); + } + } - return bessel.bessely(x, n); -}; + var str = string.replace(/[^0-9\.]+/g, ''); + if (str === '') { + // An empty string is not a number. + n._value = NaN; -exports.BIN2DEC = function(number) { - // Return error if number is not binary or contains more than 10 characters (10 digits) - if (!isValidBinaryNumber(number)) { - return error.num; - } + } else { + // do some math to create our number + n._value = ((bytesMultiplier) ? bytesMultiplier : 1) * + ((stringOriginal.match(thousandRegExp)) ? Math.pow(10, 3) : 1) * + ((stringOriginal.match(millionRegExp)) ? Math.pow(10, 6) : 1) * + ((stringOriginal.match(billionRegExp)) ? Math.pow(10, 9) : 1) * + ((stringOriginal.match(trillionRegExp)) ? Math.pow(10, 12) : 1) * + ((string.indexOf('%') > -1) ? 0.01 : 1) * + (((string.split('-').length + + Math.min(string.split('(').length - 1, string.split(')').length - 1)) % 2) ? 1 : -1) * + Number(str); - // Convert binary number to decimal - var result = parseInt(number, 2); + // round if we are talking about bytes + n._value = (bytesMultiplier) ? Math.ceil(n._value) : n._value; + } + } + } + return n._value; + } - // Handle negative numbers - var stringified = number.toString(); - if (stringified.length === 10 && stringified.substring(0, 1) === '1') { - return parseInt(stringified.substring(1), 2) - 512; - } else { - return result; - } -}; + function formatCurrency(n, currencySymbol, originalFormat, roundingFunction) { + var format = originalFormat, + symbolIndex = format.indexOf('$'), + openParenIndex = format.indexOf('('), + plusSignIndex = format.indexOf('+'), + minusSignIndex = format.indexOf('-'), + space = '', + decimalSeparator = '', + spliceIndex, + output; + if(format.indexOf('$') === -1){ + // Use defaults instead of the format provided + if (cultures[currentCulture].currency.position === 'infix') { + decimalSeparator = currencySymbol; + if (cultures[currentCulture].currency.spaceSeparated) { + decimalSeparator = ' ' + decimalSeparator + ' '; + } + } else if (cultures[currentCulture].currency.spaceSeparated) { + space = ' '; + } + } else { + // check for space before or after currency + if (format.indexOf(' $') > -1) { + space = ' '; + format = format.replace(' $', ''); + } else if (format.indexOf('$ ') > -1) { + space = ' '; + format = format.replace('$ ', ''); + } else { + format = format.replace('$', ''); + } + } -exports.BIN2HEX = function(number, places) { - // Return error if number is not binary or contains more than 10 characters (10 digits) - if (!isValidBinaryNumber(number)) { - return error.num; - } + // Format The Number + output = formatNumber(n._value, format, roundingFunction, decimalSeparator); - // Ignore places and return a 10-character hexadecimal number if number is negative - var stringified = number.toString(); - if (stringified.length === 10 && stringified.substring(0, 1) === '1') { - return (1099511627264 + parseInt(stringified.substring(1), 2)).toString(16); - } + if (originalFormat.indexOf('$') === -1) { + // Use defaults instead of the format provided + switch (cultures[currentCulture].currency.position) { + case 'postfix': + if (output.indexOf(')') > -1) { + output = output.split(''); + output.splice(-1, 0, space + currencySymbol); + output = output.join(''); + } else { + output = output + space + currencySymbol; + } + break; + case 'infix': + break; + case 'prefix': + if (output.indexOf('(') > -1 || output.indexOf('-') > -1) { + output = output.split(''); + spliceIndex = Math.max(openParenIndex, minusSignIndex) + 1; - // Convert binary number to hexadecimal - var result = parseInt(number, 2).toString(16); + output.splice(spliceIndex, 0, currencySymbol + space); + output = output.join(''); + } else { + output = currencySymbol + space + output; + } + break; + default: + throw Error('Currency position should be among ["prefix", "infix", "postfix"]'); + } + } else { + // position the symbol + if (symbolIndex <= 1) { + if (output.indexOf('(') > -1 || output.indexOf('+') > -1 || output.indexOf('-') > -1) { + output = output.split(''); + spliceIndex = 1; + if (symbolIndex < openParenIndex || symbolIndex < plusSignIndex || symbolIndex < minusSignIndex) { + // the symbol appears before the "(", "+" or "-" + spliceIndex = 0; + } + output.splice(spliceIndex, 0, currencySymbol + space); + output = output.join(''); + } else { + output = currencySymbol + space + output; + } + } else { + if (output.indexOf(')') > -1) { + output = output.split(''); + output.splice(-1, 0, space + currencySymbol); + output = output.join(''); + } else { + output = output + space + currencySymbol; + } + } + } - // Return hexadecimal number using the minimum number of characters necessary if places is undefined - if (places === undefined) { - return result; - } else { - // Return error if places is nonnumeric - if (isNaN(places)) { - return error.value; + return output; } - // Return error if places is negative - if (places < 0) { - return error.num; + function formatForeignCurrency(n, foreignCurrencySymbol, originalFormat, roundingFunction) { + return formatCurrency(n, foreignCurrencySymbol, originalFormat, roundingFunction); } - // Truncate places in case it is not an integer - places = Math.floor(places); + function formatPercentage(n, format, roundingFunction) { + var space = '', + output, + value = n._value * 100; - // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) - return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; - } -}; + // check for space before % + if (format.indexOf(' %') > -1) { + space = ' '; + format = format.replace(' %', ''); + } else { + format = format.replace('%', ''); + } -exports.BIN2OCT = function(number, places) { - // Return error if number is not binary or contains more than 10 characters (10 digits) - if (!isValidBinaryNumber(number)) { - return error.num; - } + output = formatNumber(value, format, roundingFunction); - // Ignore places and return a 10-character octal number if number is negative - var stringified = number.toString(); - if (stringified.length === 10 && stringified.substring(0, 1) === '1') { - return (1073741312 + parseInt(stringified.substring(1), 2)).toString(8); - } + if (output.indexOf(')') > -1) { + output = output.split(''); + output.splice(-1, 0, space + '%'); + output = output.join(''); + } else { + output = output + space + '%'; + } - // Convert binary number to octal - var result = parseInt(number, 2).toString(8); - - // Return octal number using the minimum number of characters necessary if places is undefined - if (places === undefined) { - return result; - } else { - // Return error if places is nonnumeric - if (isNaN(places)) { - return error.value; + return output; } - // Return error if places is negative - if (places < 0) { - return error.num; + function formatTime(n) { + var hours = Math.floor(n._value / 60 / 60), + minutes = Math.floor((n._value - (hours * 60 * 60)) / 60), + seconds = Math.round(n._value - (hours * 60 * 60) - (minutes * 60)); + return hours + ':' + + ((minutes < 10) ? '0' + minutes : minutes) + ':' + + ((seconds < 10) ? '0' + seconds : seconds); } - // Truncate places in case it is not an integer - places = Math.floor(places); - - // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) - return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; - } -}; - -exports.BITAND = function(number1, number2) { - // Return error if either number is a non-numeric value - number1 = utils.parseNumber(number1); - number2 = utils.parseNumber(number2); - if (utils.anyIsError(number1, number2)) { - return error.value; - } + function unformatTime(string) { + var timeArray = string.split(':'), + seconds = 0; + // turn hours and minutes into seconds and add them all up + if (timeArray.length === 3) { + // hours + seconds = seconds + (Number(timeArray[0]) * 60 * 60); + // minutes + seconds = seconds + (Number(timeArray[1]) * 60); + // seconds + seconds = seconds + Number(timeArray[2]); + } else if (timeArray.length === 2) { + // minutes + seconds = seconds + (Number(timeArray[0]) * 60); + // seconds + seconds = seconds + Number(timeArray[1]); + } + return Number(seconds); + } - // Return error if either number is less than 0 - if (number1 < 0 || number2 < 0) { - return error.num; - } + function formatByteUnits (value, suffixes, scale) { + var suffix = suffixes[0], + power, + min, + max, + abs = Math.abs(value); - // Return error if either number is a non-integer - if (Math.floor(number1) !== number1 || Math.floor(number2) !== number2) { - return error.num; - } + if (abs >= scale) { + for (power = 1; power < suffixes.length; ++power) { + min = Math.pow(scale, power); + max = Math.pow(scale, power + 1); - // Return error if either number is greater than (2^48)-1 - if (number1 > 281474976710655 || number2 > 281474976710655) { - return error.num; - } + if (abs >= min && abs < max) { + suffix = suffixes[power]; + value = value / min; + break; + } + } - // Return bitwise AND of two numbers - return number1 & number2; -}; + // values greater than or equal to [scale] YB never set the suffix + if (suffix === suffixes[0]) { + value = value / Math.pow(scale, suffixes.length - 1); + suffix = suffixes[suffixes.length - 1]; + } + } -exports.BITLSHIFT = function(number, shift) { - number = utils.parseNumber(number); - shift = utils.parseNumber(shift); - if (utils.anyIsError(number, shift)) { - return error.value; - } + return { value: value, suffix: suffix }; + } - // Return error if number is less than 0 - if (number < 0) { - return error.num; - } + function formatNumber (value, format, roundingFunction, sep) { + var negP = false, + signed = false, + optDec = false, + abbr = '', + abbrK = false, // force abbreviation to thousands + abbrM = false, // force abbreviation to millions + abbrB = false, // force abbreviation to billions + abbrT = false, // force abbreviation to trillions + abbrForce = false, // force abbreviation + bytes = '', + byteFormat, + units, + ord = '', + abs = Math.abs(value), + totalLength, + length, + minimumPrecision, + pow, + w, + intPrecision, + precision, + prefix, + postfix, + thousands, + d = '', + forcedNeg = false, + neg = false, + indexOpenP, + indexMinus, + paren = '', + minlen, + i; - // Return error if number is a non-integer - if (Math.floor(number) !== number) { - return error.num; - } + // check if number is zero and a custom zero format has been set + if (value === 0 && zeroFormat !== null) { + return zeroFormat; + } - // Return error if number is greater than (2^48)-1 - if (number > 281474976710655) { - return error.num; - } + if (!isFinite(value)) { + return '' + value; + } - // Return error if the absolute value of shift is greater than 53 - if (Math.abs(shift) > 53) { - return error.num; - } + if (format.indexOf('{') === 0) { + var end = format.indexOf('}'); + if (end === -1) { + throw Error('Format should also contain a "}"'); + } + prefix = format.slice(1, end); + format = format.slice(end + 1); + } else { + prefix = ''; + } - // Return number shifted by shift bits to the left or to the right if shift is negative - return (shift >= 0) ? number << shift : number >> -shift; -}; + if (format.indexOf('}') === format.length - 1 && format.length) { + var start = format.indexOf('{'); + if (start === -1) { + throw Error('Format should also contain a "{"'); + } + postfix = format.slice(start + 1, -1); + format = format.slice(0, start + 1); + } else { + postfix = ''; + } -exports.BITOR = function(number1, number2) { - number1 = utils.parseNumber(number1); - number2 = utils.parseNumber(number2); - if (utils.anyIsError(number1, number2)) { - return error.value; - } + // check for min length + var info; + if (format.indexOf('.') === -1) { + info = format.match(/([0-9]+).*/); + } else { + info = format.match(/([0-9]+)\..*/); + } + minlen = info === null ? -1 : info[1].length; - // Return error if either number is less than 0 - if (number1 < 0 || number2 < 0) { - return error.num; - } + // see if we should use parentheses for negative number or if we should prefix with a sign + // if both are present we default to parentheses + if (format.indexOf('-') !== -1) { + forcedNeg = true; + } + if (format.indexOf('(') > -1) { + negP = true; + format = format.slice(1, -1); + } else if (format.indexOf('+') > -1) { + signed = true; + format = format.replace(/\+/g, ''); + } - // Return error if either number is a non-integer - if (Math.floor(number1) !== number1 || Math.floor(number2) !== number2) { - return error.num; - } + // see if abbreviation is wanted + if (format.indexOf('a') > -1) { + intPrecision = format.split('.')[0].match(/[0-9]+/g) || ['0']; + intPrecision = parseInt(intPrecision[0], 10); - // Return error if either number is greater than (2^48)-1 - if (number1 > 281474976710655 || number2 > 281474976710655) { - return error.num; - } + // check if abbreviation is specified + abbrK = format.indexOf('aK') >= 0; + abbrM = format.indexOf('aM') >= 0; + abbrB = format.indexOf('aB') >= 0; + abbrT = format.indexOf('aT') >= 0; + abbrForce = abbrK || abbrM || abbrB || abbrT; - // Return bitwise OR of two numbers - return number1 | number2; -}; + // check for space before abbreviation + if (format.indexOf(' a') > -1) { + abbr = ' '; + format = format.replace(' a', ''); + } else { + format = format.replace('a', ''); + } -exports.BITRSHIFT = function(number, shift) { - number = utils.parseNumber(number); - shift = utils.parseNumber(shift); - if (utils.anyIsError(number, shift)) { - return error.value; - } + totalLength = numberLength(value); + minimumPrecision = totalLength % 3; + minimumPrecision = minimumPrecision === 0 ? 3 : minimumPrecision; - // Return error if number is less than 0 - if (number < 0) { - return error.num; - } + if (intPrecision && abs !== 0) { + pow = 3 * ~~((Math.min(intPrecision, totalLength) - minimumPrecision) / 3); + abs = abs / Math.pow(10, pow); + } - // Return error if number is a non-integer - if (Math.floor(number) !== number) { - return error.num; - } + if (totalLength !== intPrecision) { + if (abs >= Math.pow(10, 12) && !abbrForce || abbrT) { + // trillion + abbr = abbr + cultures[currentCulture].abbreviations.trillion; + value = value / Math.pow(10, 12); + } else if (abs < Math.pow(10, 12) && abs >= Math.pow(10, 9) && !abbrForce || abbrB) { + // billion + abbr = abbr + cultures[currentCulture].abbreviations.billion; + value = value / Math.pow(10, 9); + } else if (abs < Math.pow(10, 9) && abs >= Math.pow(10, 6) && !abbrForce || abbrM) { + // million + abbr = abbr + cultures[currentCulture].abbreviations.million; + value = value / Math.pow(10, 6); + } else if (abs < Math.pow(10, 6) && abs >= Math.pow(10, 3) && !abbrForce || abbrK) { + // thousand + abbr = abbr + cultures[currentCulture].abbreviations.thousand; + value = value / Math.pow(10, 3); + } + } - // Return error if number is greater than (2^48)-1 - if (number > 281474976710655) { - return error.num; - } + length = numberLength(value); + if (intPrecision && length < intPrecision && format.indexOf('.') === -1) { + format += '[.]'; + format += zeroes(intPrecision - length); + } + } - // Return error if the absolute value of shift is greater than 53 - if (Math.abs(shift) > 53) { - return error.num; - } + // see if we are formatting + // binary-decimal bytes (1024 MB), binary bytes (1024 MiB), or decimal bytes (1000 MB) + for (i = 0; i < byteFormatOrder.length; ++i) { + byteFormat = byteFormatOrder[i]; - // Return number shifted by shift bits to the right or to the left if shift is negative - return (shift >= 0) ? number >> shift : number << -shift; -}; + if (format.indexOf(byteFormat.marker) > -1) { + // check for space before + if (format.indexOf(' ' + byteFormat.marker) >-1) { + bytes = ' '; + } -exports.BITXOR = function(number1, number2) { - number1 = utils.parseNumber(number1); - number2 = utils.parseNumber(number2); - if (utils.anyIsError(number1, number2)) { - return error.value; - } + // remove the marker (with the space if it had one) + format = format.replace(bytes + byteFormat.marker, ''); - // Return error if either number is less than 0 - if (number1 < 0 || number2 < 0) { - return error.num; - } + units = formatByteUnits(value, byteFormat.suffixes, byteFormat.scale); - // Return error if either number is a non-integer - if (Math.floor(number1) !== number1 || Math.floor(number2) !== number2) { - return error.num; - } + value = units.value; + bytes = bytes + units.suffix; - // Return error if either number is greater than (2^48)-1 - if (number1 > 281474976710655 || number2 > 281474976710655) { - return error.num; - } + break; + } + } - // Return bitwise XOR of two numbers - return number1 ^ number2; -}; + // see if ordinal is wanted + if (format.indexOf('o') > -1) { + // check for space before + if (format.indexOf(' o') > -1) { + ord = ' '; + format = format.replace(' o', ''); + } else { + format = format.replace('o', ''); + } -exports.COMPLEX = function(real, imaginary, suffix) { - real = utils.parseNumber(real); - imaginary = utils.parseNumber(imaginary); - if (utils.anyIsError(real, imaginary)) { - return real; - } + if (cultures[currentCulture].ordinal) { + ord = ord + cultures[currentCulture].ordinal(value); + } + } - // Set suffix - suffix = (suffix === undefined) ? 'i' : suffix; + if (format.indexOf('[.]') > -1) { + optDec = true; + format = format.replace('[.]', '.'); + } - // Return error if suffix is neither "i" nor "j" - if (suffix !== 'i' && suffix !== 'j') { - return error.value; - } + precision = format.split('.')[1]; + thousands = format.indexOf(','); - // Return complex number - if (real === 0 && imaginary === 0) { - return 0; - } else if (real === 0) { - return (imaginary === 1) ? suffix : imaginary.toString() + suffix; - } else if (imaginary === 0) { - return real.toString(); - } else { - var sign = (imaginary > 0) ? '+' : ''; - return real.toString() + sign + ((imaginary === 1) ? suffix : imaginary.toString() + suffix); - } -}; + if (precision) { + var dSplit = []; -exports.CONVERT = function(number, from_unit, to_unit) { - number = utils.parseNumber(number); - if (number instanceof Error) { - return number; - } + if (precision.indexOf('*') !== -1) { + d = value.toString(); + dSplit = d.split('.'); + if (dSplit.length > 1) { + d = toFixed(value, dSplit[1].length, roundingFunction); + } + } else { + if (precision.indexOf('[') > -1) { + precision = precision.replace(']', ''); + precision = precision.split('['); + d = toFixed(value, (precision[0].length + precision[1].length), roundingFunction, + precision[1].length); + } else { + d = toFixed(value, precision.length, roundingFunction); + } + } - // List of units supported by CONVERT and units defined by the International System of Units - // [Name, Symbol, Alternate symbols, Quantity, ISU, CONVERT, Conversion ratio] - var units = [ - ["a.u. of action", "?", null, "action", false, false, 1.05457168181818e-34], - ["a.u. of charge", "e", null, "electric_charge", false, false, 1.60217653141414e-19], - ["a.u. of energy", "Eh", null, "energy", false, false, 4.35974417757576e-18], - ["a.u. of length", "a?", null, "length", false, false, 5.29177210818182e-11], - ["a.u. of mass", "m?", null, "mass", false, false, 9.10938261616162e-31], - ["a.u. of time", "?/Eh", null, "time", false, false, 2.41888432650516e-17], - ["admiralty knot", "admkn", null, "speed", false, true, 0.514773333], - ["ampere", "A", null, "electric_current", true, false, 1], - ["ampere per meter", "A/m", null, "magnetic_field_intensity", true, false, 1], - ["ångström", "Å", ["ang"], "length", false, true, 1e-10], - ["are", "ar", null, "area", false, true, 100], - ["astronomical unit", "ua", null, "length", false, false, 1.49597870691667e-11], - ["bar", "bar", null, "pressure", false, false, 100000], - ["barn", "b", null, "area", false, false, 1e-28], - ["becquerel", "Bq", null, "radioactivity", true, false, 1], - ["bit", "bit", ["b"], "information", false, true, 1], - ["btu", "BTU", ["btu"], "energy", false, true, 1055.05585262], - ["byte", "byte", null, "information", false, true, 8], - ["candela", "cd", null, "luminous_intensity", true, false, 1], - ["candela per square metre", "cd/m?", null, "luminance", true, false, 1], - ["coulomb", "C", null, "electric_charge", true, false, 1], - ["cubic ångström", "ang3", ["ang^3"], "volume", false, true, 1e-30], - ["cubic foot", "ft3", ["ft^3"], "volume", false, true, 0.028316846592], - ["cubic inch", "in3", ["in^3"], "volume", false, true, 0.000016387064], - ["cubic light-year", "ly3", ["ly^3"], "volume", false, true, 8.46786664623715e-47], - ["cubic metre", "m?", null, "volume", true, true, 1], - ["cubic mile", "mi3", ["mi^3"], "volume", false, true, 4168181825.44058], - ["cubic nautical mile", "Nmi3", ["Nmi^3"], "volume", false, true, 6352182208], - ["cubic Pica", "Pica3", ["Picapt3", "Pica^3", "Picapt^3"], "volume", false, true, 7.58660370370369e-8], - ["cubic yard", "yd3", ["yd^3"], "volume", false, true, 0.764554857984], - ["cup", "cup", null, "volume", false, true, 0.0002365882365], - ["dalton", "Da", ["u"], "mass", false, false, 1.66053886282828e-27], - ["day", "d", ["day"], "time", false, true, 86400], - ["degree", "°", null, "angle", false, false, 0.0174532925199433], - ["degrees Rankine", "Rank", null, "temperature", false, true, 0.555555555555556], - ["dyne", "dyn", ["dy"], "force", false, true, 0.00001], - ["electronvolt", "eV", ["ev"], "energy", false, true, 1.60217656514141], - ["ell", "ell", null, "length", false, true, 1.143], - ["erg", "erg", ["e"], "energy", false, true, 1e-7], - ["farad", "F", null, "electric_capacitance", true, false, 1], - ["fluid ounce", "oz", null, "volume", false, true, 0.0000295735295625], - ["foot", "ft", null, "length", false, true, 0.3048], - ["foot-pound", "flb", null, "energy", false, true, 1.3558179483314], - ["gal", "Gal", null, "acceleration", false, false, 0.01], - ["gallon", "gal", null, "volume", false, true, 0.003785411784], - ["gauss", "G", ["ga"], "magnetic_flux_density", false, true, 1], - ["grain", "grain", null, "mass", false, true, 0.0000647989], - ["gram", "g", null, "mass", false, true, 0.001], - ["gray", "Gy", null, "absorbed_dose", true, false, 1], - ["gross registered ton", "GRT", ["regton"], "volume", false, true, 2.8316846592], - ["hectare", "ha", null, "area", false, true, 10000], - ["henry", "H", null, "inductance", true, false, 1], - ["hertz", "Hz", null, "frequency", true, false, 1], - ["horsepower", "HP", ["h"], "power", false, true, 745.69987158227], - ["horsepower-hour", "HPh", ["hh", "hph"], "energy", false, true, 2684519.538], - ["hour", "h", ["hr"], "time", false, true, 3600], - ["imperial gallon (U.K.)", "uk_gal", null, "volume", false, true, 0.00454609], - ["imperial hundredweight", "lcwt", ["uk_cwt", "hweight"], "mass", false, true, 50.802345], - ["imperial quart (U.K)", "uk_qt", null, "volume", false, true, 0.0011365225], - ["imperial ton", "brton", ["uk_ton", "LTON"], "mass", false, true, 1016.046909], - ["inch", "in", null, "length", false, true, 0.0254], - ["international acre", "uk_acre", null, "area", false, true, 4046.8564224], - ["IT calorie", "cal", null, "energy", false, true, 4.1868], - ["joule", "J", null, "energy", true, true, 1], - ["katal", "kat", null, "catalytic_activity", true, false, 1], - ["kelvin", "K", ["kel"], "temperature", true, true, 1], - ["kilogram", "kg", null, "mass", true, true, 1], - ["knot", "kn", null, "speed", false, true, 0.514444444444444], - ["light-year", "ly", null, "length", false, true, 9460730472580800], - ["litre", "L", ["l", "lt"], "volume", false, true, 0.001], - ["lumen", "lm", null, "luminous_flux", true, false, 1], - ["lux", "lx", null, "illuminance", true, false, 1], - ["maxwell", "Mx", null, "magnetic_flux", false, false, 1e-18], - ["measurement ton", "MTON", null, "volume", false, true, 1.13267386368], - ["meter per hour", "m/h", ["m/hr"], "speed", false, true, 0.00027777777777778], - ["meter per second", "m/s", ["m/sec"], "speed", true, true, 1], - ["meter per second squared", "m?s??", null, "acceleration", true, false, 1], - ["parsec", "pc", ["parsec"], "length", false, true, 30856775814671900], - ["meter squared per second", "m?/s", null, "kinematic_viscosity", true, false, 1], - ["metre", "m", null, "length", true, true, 1], - ["miles per hour", "mph", null, "speed", false, true, 0.44704], - ["millimetre of mercury", "mmHg", null, "pressure", false, false, 133.322], - ["minute", "?", null, "angle", false, false, 0.000290888208665722], - ["minute", "min", ["mn"], "time", false, true, 60], - ["modern teaspoon", "tspm", null, "volume", false, true, 0.000005], - ["mole", "mol", null, "amount_of_substance", true, false, 1], - ["morgen", "Morgen", null, "area", false, true, 2500], - ["n.u. of action", "?", null, "action", false, false, 1.05457168181818e-34], - ["n.u. of mass", "m?", null, "mass", false, false, 9.10938261616162e-31], - ["n.u. of speed", "c?", null, "speed", false, false, 299792458], - ["n.u. of time", "?/(me?c??)", null, "time", false, false, 1.28808866778687e-21], - ["nautical mile", "M", ["Nmi"], "length", false, true, 1852], - ["newton", "N", null, "force", true, true, 1], - ["œrsted", "Oe ", null, "magnetic_field_intensity", false, false, 79.5774715459477], - ["ohm", "Ω", null, "electric_resistance", true, false, 1], - ["ounce mass", "ozm", null, "mass", false, true, 0.028349523125], - ["pascal", "Pa", null, "pressure", true, false, 1], - ["pascal second", "Pa?s", null, "dynamic_viscosity", true, false, 1], - ["pferdestärke", "PS", null, "power", false, true, 735.49875], - ["phot", "ph", null, "illuminance", false, false, 0.0001], - ["pica (1/6 inch)", "pica", null, "length", false, true, 0.00035277777777778], - ["pica (1/72 inch)", "Pica", ["Picapt"], "length", false, true, 0.00423333333333333], - ["poise", "P", null, "dynamic_viscosity", false, false, 0.1], - ["pond", "pond", null, "force", false, true, 0.00980665], - ["pound force", "lbf", null, "force", false, true, 4.4482216152605], - ["pound mass", "lbm", null, "mass", false, true, 0.45359237], - ["quart", "qt", null, "volume", false, true, 0.000946352946], - ["radian", "rad", null, "angle", true, false, 1], - ["second", "?", null, "angle", false, false, 0.00000484813681109536], - ["second", "s", ["sec"], "time", true, true, 1], - ["short hundredweight", "cwt", ["shweight"], "mass", false, true, 45.359237], - ["siemens", "S", null, "electrical_conductance", true, false, 1], - ["sievert", "Sv", null, "equivalent_dose", true, false, 1], - ["slug", "sg", null, "mass", false, true, 14.59390294], - ["square ångström", "ang2", ["ang^2"], "area", false, true, 1e-20], - ["square foot", "ft2", ["ft^2"], "area", false, true, 0.09290304], - ["square inch", "in2", ["in^2"], "area", false, true, 0.00064516], - ["square light-year", "ly2", ["ly^2"], "area", false, true, 8.95054210748189e+31], - ["square meter", "m?", null, "area", true, true, 1], - ["square mile", "mi2", ["mi^2"], "area", false, true, 2589988.110336], - ["square nautical mile", "Nmi2", ["Nmi^2"], "area", false, true, 3429904], - ["square Pica", "Pica2", ["Picapt2", "Pica^2", "Picapt^2"], "area", false, true, 0.00001792111111111], - ["square yard", "yd2", ["yd^2"], "area", false, true, 0.83612736], - ["statute mile", "mi", null, "length", false, true, 1609.344], - ["steradian", "sr", null, "solid_angle", true, false, 1], - ["stilb", "sb", null, "luminance", false, false, 0.0001], - ["stokes", "St", null, "kinematic_viscosity", false, false, 0.0001], - ["stone", "stone", null, "mass", false, true, 6.35029318], - ["tablespoon", "tbs", null, "volume", false, true, 0.0000147868], - ["teaspoon", "tsp", null, "volume", false, true, 0.00000492892], - ["tesla", "T", null, "magnetic_flux_density", true, true, 1], - ["thermodynamic calorie", "c", null, "energy", false, true, 4.184], - ["ton", "ton", null, "mass", false, true, 907.18474], - ["tonne", "t", null, "mass", false, false, 1000], - ["U.K. pint", "uk_pt", null, "volume", false, true, 0.00056826125], - ["U.S. bushel", "bushel", null, "volume", false, true, 0.03523907], - ["U.S. oil barrel", "barrel", null, "volume", false, true, 0.158987295], - ["U.S. pint", "pt", ["us_pt"], "volume", false, true, 0.000473176473], - ["U.S. survey mile", "survey_mi", null, "length", false, true, 1609.347219], - ["U.S. survey/statute acre", "us_acre", null, "area", false, true, 4046.87261], - ["volt", "V", null, "voltage", true, false, 1], - ["watt", "W", null, "power", true, true, 1], - ["watt-hour", "Wh", ["wh"], "energy", false, true, 3600], - ["weber", "Wb", null, "magnetic_flux", true, false, 1], - ["yard", "yd", null, "length", false, true, 0.9144], - ["year", "yr", null, "time", false, true, 31557600] - ]; - - // Binary prefixes - // [Name, Prefix power of 2 value, Previx value, Abbreviation, Derived from] - var binary_prefixes = { - Yi: ["yobi", 80, 1208925819614629174706176, "Yi", "yotta"], - Zi: ["zebi", 70, 1180591620717411303424, "Zi", "zetta"], - Ei: ["exbi", 60, 1152921504606846976, "Ei", "exa"], - Pi: ["pebi", 50, 1125899906842624, "Pi", "peta"], - Ti: ["tebi", 40, 1099511627776, "Ti", "tera"], - Gi: ["gibi", 30, 1073741824, "Gi", "giga"], - Mi: ["mebi", 20, 1048576, "Mi", "mega"], - ki: ["kibi", 10, 1024, "ki", "kilo"] - }; - - // Unit prefixes - // [Name, Multiplier, Abbreviation] - var unit_prefixes = { - Y: ["yotta", 1e+24, "Y"], - Z: ["zetta", 1e+21, "Z"], - E: ["exa", 1e+18, "E"], - P: ["peta", 1e+15, "P"], - T: ["tera", 1e+12, "T"], - G: ["giga", 1e+09, "G"], - M: ["mega", 1e+06, "M"], - k: ["kilo", 1e+03, "k"], - h: ["hecto", 1e+02, "h"], - e: ["dekao", 1e+01, "e"], - d: ["deci", 1e-01, "d"], - c: ["centi", 1e-02, "c"], - m: ["milli", 1e-03, "m"], - u: ["micro", 1e-06, "u"], - n: ["nano", 1e-09, "n"], - p: ["pico", 1e-12, "p"], - f: ["femto", 1e-15, "f"], - a: ["atto", 1e-18, "a"], - z: ["zepto", 1e-21, "z"], - y: ["yocto", 1e-24, "y"] - }; + dSplit = d.split('.'); + w = dSplit[0]; - // Initialize units and multipliers - var from = null; - var to = null; - var base_from_unit = from_unit; - var base_to_unit = to_unit; - var from_multiplier = 1; - var to_multiplier = 1; - var alt; + if (dSplit.length > 1 && dSplit[1].length) { + var p = sep ? abbr + sep : cultures[currentCulture].delimiters.decimal; + d = p + dSplit[1]; + } else { + d = ''; + } - // Lookup from and to units - for (var i = 0; i < units.length; i++) { - alt = (units[i][2] === null) ? [] : units[i][2]; - if (units[i][1] === base_from_unit || alt.indexOf(base_from_unit) >= 0) { - from = units[i]; - } - if (units[i][1] === base_to_unit || alt.indexOf(base_to_unit) >= 0) { - to = units[i]; - } - } + if (optDec && Number(d.slice(1)) === 0) { + d = ''; + } + } else { + w = toFixed(value, 0, roundingFunction); + } - // Lookup from prefix - if (from === null) { - var from_binary_prefix = binary_prefixes[from_unit.substring(0, 2)]; - var from_unit_prefix = unit_prefixes[from_unit.substring(0, 1)]; + // format number + if (w.indexOf('-') > -1) { + w = w.slice(1); + neg = true; + } - // Handle dekao unit prefix (only unit prefix with two characters) - if (from_unit.substring(0, 2) === 'da') { - from_unit_prefix = ["dekao", 1e+01, "da"]; - } + if (w.length < minlen) { + w = zeroes(minlen - w.length) + w; + } - // Handle binary prefixes first (so that 'Yi' is processed before 'Y') - if (from_binary_prefix) { - from_multiplier = from_binary_prefix[2]; - base_from_unit = from_unit.substring(2); - } else if (from_unit_prefix) { - from_multiplier = from_unit_prefix[1]; - base_from_unit = from_unit.substring(from_unit_prefix[2].length); - } + if (thousands > -1) { + w = w.toString().replace(/(\d)(?=(\d{3})+(?!\d))/g, '$1' + + cultures[currentCulture].delimiters.thousands); + } - // Lookup from unit - for (var j = 0; j < units.length; j++) { - alt = (units[j][2] === null) ? [] : units[j][2]; - if (units[j][1] === base_from_unit || alt.indexOf(base_from_unit) >= 0) { - from = units[j]; - } - } - } + if (format.indexOf('.') === 0) { + w = ''; + } - // Lookup to prefix - if (to === null) { - var to_binary_prefix = binary_prefixes[to_unit.substring(0, 2)]; - var to_unit_prefix = unit_prefixes[to_unit.substring(0, 1)]; + indexOpenP = format.indexOf('('); + indexMinus = format.indexOf('-'); - // Handle dekao unit prefix (only unit prefix with two characters) - if (to_unit.substring(0, 2) === 'da') { - to_unit_prefix = ["dekao", 1e+01, "da"]; - } + if (indexOpenP < indexMinus) { + paren = ((negP && neg) ? '(' : '') + (((forcedNeg && neg) || (!negP && neg)) ? '-' : ''); + } else { + paren = (((forcedNeg && neg) || (!negP && neg)) ? '-' : '') + ((negP && neg) ? '(' : ''); + } - // Handle binary prefixes first (so that 'Yi' is processed before 'Y') - if (to_binary_prefix) { - to_multiplier = to_binary_prefix[2]; - base_to_unit = to_unit.substring(2); - } else if (to_unit_prefix) { - to_multiplier = to_unit_prefix[1]; - base_to_unit = to_unit.substring(to_unit_prefix[2].length); + return prefix + + paren + ((!neg && signed && value !== 0) ? '+' : '') + + w + d + + ((ord) ? ord : '') + + ((abbr && !sep) ? abbr : '') + + ((bytes) ? bytes : '') + + ((negP && neg) ? ')' : '') + + postfix; } - // Lookup to unit - for (var k = 0; k < units.length; k++) { - alt = (units[k][2] === null) ? [] : units[k][2]; - if (units[k][1] === base_to_unit || alt.indexOf(base_to_unit) >= 0) { - to = units[k]; - } - } - } + /************************************ + Top Level Functions + ************************************/ - // Return error if a unit does not exist - if (from === null || to === null) { - return error.na; - } + numbro = function(input) { + if (numbro.isNumbro(input)) { + input = input.value(); + } else if (typeof input === 'string' || typeof input === 'number') { + input = numbro.fn.unformat(input); + } else { + input = NaN; + } - // Return error if units represent different quantities - if (from[3] !== to[3]) { - return error.na; - } + return new Numbro(Number(input)); + }; - // Return converted number - return number * from[6] * from_multiplier / (to[6] * to_multiplier); -}; + // version number + numbro.version = VERSION; -exports.DEC2BIN = function(number, places) { - number = utils.parseNumber(number); - if (number instanceof Error) { - return number; - } + // compare numbro object + numbro.isNumbro = function(obj) { + return obj instanceof Numbro; + }; - // Return error if number is not decimal, is lower than -512, or is greater than 511 - if (!/^-?[0-9]{1,3}$/.test(number) || number < -512 || number > 511) { - return error.num; - } + /** + * This function allow the user to set a new language with a fallback if + * the language does not exist. If no fallback language is provided, + * it fallbacks to english. + * + * @deprecated Since in version 1.6.0. It will be deleted in version 2.0 + * `setCulture` should be used instead. + */ + numbro.setLanguage = function(newLanguage, fallbackLanguage) { + console.warn('`setLanguage` is deprecated since version 1.6.0. Use `setCulture` instead'); + var key = newLanguage, + prefix = newLanguage.split('-')[0], + matchingLanguage = null; + if (!languages[key]) { + Object.keys(languages).forEach(function(language) { + if (!matchingLanguage && language.split('-')[0] === prefix) { + matchingLanguage = language; + } + }); + key = matchingLanguage || fallbackLanguage || 'en-US'; + } + chooseCulture(key); + }; - // Ignore places and return a 10-character binary number if number is negative - if (number < 0) { - return '1' + text.REPT('0', 9 - (512 + number).toString(2).length) + (512 + number).toString(2); - } + /** + * This function allow the user to set a new culture with a fallback if + * the culture does not exist. If no fallback culture is provided, + * it falls back to "en-US". + */ + numbro.setCulture = function(newCulture, fallbackCulture) { + var key = newCulture, + suffix = newCulture.split('-')[1], + matchingCulture = null; + if (!cultures[key]) { + if (suffix) { + Object.keys(cultures).forEach(function(language) { + if (!matchingCulture && language.split('-')[1] === suffix) { + matchingCulture = language; + } + }); + } - // Convert decimal number to binary - var result = parseInt(number, 10).toString(2); + key = matchingCulture || fallbackCulture || 'en-US'; + } + chooseCulture(key); + }; - // Return binary number using the minimum number of characters necessary if places is undefined - if (typeof places === 'undefined') { - return result; - } else { - // Return error if places is nonnumeric - if (isNaN(places)) { - return error.value; - } - - // Return error if places is negative - if (places < 0) { - return error.num; - } + /** + * This function will load languages and then set the global language. If + * no arguments are passed in, it will simply return the current global + * language key. + * + * @deprecated Since in version 1.6.0. It will be deleted in version 2.0 + * `culture` should be used instead. + */ + numbro.language = function(key, values) { + console.warn('`language` is deprecated since version 1.6.0. Use `culture` instead'); - // Truncate places in case it is not an integer - places = Math.floor(places); + if (!key) { + return currentCulture; + } - // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) - return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; - } -}; + if (key && !values) { + if (!languages[key]) { + throw new Error('Unknown language : ' + key); + } + chooseCulture(key); + } -exports.DEC2HEX = function(number, places) { - number = utils.parseNumber(number); - if (number instanceof Error) { - return number; - } + if (values || !languages[key]) { + setCulture(key, values); + } - // Return error if number is not decimal, is lower than -549755813888, or is greater than 549755813887 - if (!/^-?[0-9]{1,12}$/.test(number) || number < -549755813888 || number > 549755813887) { - return error.num; - } + return numbro; + }; - // Ignore places and return a 10-character hexadecimal number if number is negative - if (number < 0) { - return (1099511627776 + number).toString(16); - } + /** + * This function will load cultures and then set the global culture. If + * no arguments are passed in, it will simply return the current global + * culture code. + */ + numbro.culture = function(code, values) { + if (!code) { + return currentCulture; + } - // Convert decimal number to hexadecimal - var result = parseInt(number, 10).toString(16); + if (code && !values) { + if (!cultures[code]) { + throw new Error('Unknown culture : ' + code); + } + chooseCulture(code); + } - // Return hexadecimal number using the minimum number of characters necessary if places is undefined - if (typeof places === 'undefined') { - return result; - } else { - // Return error if places is nonnumeric - if (isNaN(places)) { - return error.value; - } + if (values || !cultures[code]) { + setCulture(code, values); + } - // Return error if places is negative - if (places < 0) { - return error.num; - } + return numbro; + }; - // Truncate places in case it is not an integer - places = Math.floor(places); + /** + * This function provides access to the loaded language data. If + * no arguments are passed in, it will simply return the current + * global language object. + * + * @deprecated Since in version 1.6.0. It will be deleted in version 2.0 + * `culture` should be used instead. + */ + numbro.languageData = function(key) { + console.warn('`languageData` is deprecated since version 1.6.0. Use `cultureData` instead'); - // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) - return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; - } -}; + if (!key) { + return languages[currentCulture]; + } -exports.DEC2OCT = function(number, places) { - number = utils.parseNumber(number); - if (number instanceof Error) { - return number; - } + if (!languages[key]) { + throw new Error('Unknown language : ' + key); + } - // Return error if number is not decimal, is lower than -549755813888, or is greater than 549755813887 - if (!/^-?[0-9]{1,9}$/.test(number) || number < -536870912 || number > 536870911) { - return error.num; - } + return languages[key]; + }; - // Ignore places and return a 10-character octal number if number is negative - if (number < 0) { - return (1073741824 + number).toString(8); - } + /** + * This function provides access to the loaded culture data. If + * no arguments are passed in, it will simply return the current + * global culture object. + */ + numbro.cultureData = function(code) { + if (!code) { + return cultures[currentCulture]; + } - // Convert decimal number to octal - var result = parseInt(number, 10).toString(8); + if (!cultures[code]) { + throw new Error('Unknown culture : ' + code); + } - // Return octal number using the minimum number of characters necessary if places is undefined - if (typeof places === 'undefined') { - return result; - } else { - // Return error if places is nonnumeric - if (isNaN(places)) { - return error.value; - } + return cultures[code]; + }; - // Return error if places is negative - if (places < 0) { - return error.num; - } + numbro.culture('en-US', enUS); - // Truncate places in case it is not an integer - places = Math.floor(places); + /** + * @deprecated Since in version 1.6.0. It will be deleted in version 2.0 + * `cultures` should be used instead. + */ + numbro.languages = function() { + console.warn('`languages` is deprecated since version 1.6.0. Use `cultures` instead'); - // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) - return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; - } -}; + return languages; + }; -exports.DELTA = function(number1, number2) { - // Set number2 to zero if undefined - number2 = (number2 === undefined) ? 0 : number2; - number1 = utils.parseNumber(number1); - number2 = utils.parseNumber(number2); - if (utils.anyIsError(number1, number2)) { - return error.value; - } + numbro.cultures = function() { + return cultures; + }; - // Return delta - return (number1 === number2) ? 1 : 0; -}; + numbro.zeroFormat = function(format) { + zeroFormat = typeof(format) === 'string' ? format : null; + }; -// TODO: why is upper_bound not used ? The excel documentation has no examples with upper_bound -exports.ERF = function(lower_bound, upper_bound) { - // Set number2 to zero if undefined - upper_bound = (upper_bound === undefined) ? 0 : upper_bound; + numbro.defaultFormat = function(format) { + defaultFormat = typeof(format) === 'string' ? format : '0.0'; + }; - lower_bound = utils.parseNumber(lower_bound); - upper_bound = utils.parseNumber(upper_bound); - if (utils.anyIsError(lower_bound, upper_bound)) { - return error.value; - } + numbro.defaultCurrencyFormat = function (format) { + defaultCurrencyFormat = typeof(format) === 'string' ? format : '0$'; + }; - return jStat.erf(lower_bound); -}; + numbro.validate = function(val, culture) { -// TODO -exports.ERF.PRECISE = function() { - throw new Error('ERF.PRECISE is not implemented'); -}; + var _decimalSep, + _thousandSep, + _currSymbol, + _valArray, + _abbrObj, + _thousandRegEx, + cultureData, + temp; -exports.ERFC = function(x) { - // Return error if x is not a number - if (isNaN(x)) { - return error.value; - } + //coerce val to string + if (typeof val !== 'string') { + val += ''; + if (console.warn) { + console.warn('Numbro.js: Value is not string. It has been co-erced to: ', val); + } + } - return jStat.erfc(x); -}; + //trim whitespaces from either sides + val = val.trim(); -// TODO -exports.ERFC.PRECISE = function() { - throw new Error('ERFC.PRECISE is not implemented'); -}; + //replace the initial '+' or '-' sign if present + val = val.replace(/^[+-]?/, ''); -exports.GESTEP = function(number, step) { - step = step || 0; - number = utils.parseNumber(number); - if (utils.anyIsError(step, number)) { - return number; - } + //if val is just digits return true + if ( !! val.match(/^\d+$/)) { + return true; + } - // Return delta - return (number >= step) ? 1 : 0; -}; + //if val is empty return false + if (val === '') { + return false; + } -exports.HEX2BIN = function(number, places) { - // Return error if number is not hexadecimal or contains more than ten characters (10 digits) - if (!/^[0-9A-Fa-f]{1,10}$/.test(number)) { - return error.num; - } - - // Check if number is negative - var negative = (number.length === 10 && number.substring(0, 1).toLowerCase() === 'f') ? true : false; - - // Convert hexadecimal number to decimal - var decimal = (negative) ? parseInt(number, 16) - 1099511627776 : parseInt(number, 16); - - // Return error if number is lower than -512 or greater than 511 - if (decimal < -512 || decimal > 511) { - return error.num; - } - - // Ignore places and return a 10-character binary number if number is negative - if (negative) { - return '1' + text.REPT('0', 9 - (512 + decimal).toString(2).length) + (512 + decimal).toString(2); - } - - // Convert decimal number to binary - var result = decimal.toString(2); + //get the decimal and thousands separator from numbro.cultureData + try { + //check if the culture is understood by numbro. if not, default it to current culture + cultureData = numbro.cultureData(culture); + } catch (e) { + cultureData = numbro.cultureData(numbro.culture()); + } - // Return binary number using the minimum number of characters necessary if places is undefined - if (places === undefined) { - return result; - } else { - // Return error if places is nonnumeric - if (isNaN(places)) { - return error.value; - } + //setup the delimiters and currency symbol based on culture + _currSymbol = cultureData.currency.symbol; + _abbrObj = cultureData.abbreviations; + _decimalSep = cultureData.delimiters.decimal; + if (cultureData.delimiters.thousands === '.') { + _thousandSep = '\\.'; + } else { + _thousandSep = cultureData.delimiters.thousands; + } - // Return error if places is negative - if (places < 0) { - return error.num; - } + // validating currency symbol + temp = val.match(/^[^\d\.\,]+/); + if (temp !== null) { + val = val.substr(1); + if (temp[0] !== _currSymbol) { + return false; + } + } - // Truncate places in case it is not an integer - places = Math.floor(places); + //validating abbreviation symbol + temp = val.match(/[^\d]+$/); + if (temp !== null) { + val = val.slice(0, -1); + if (temp[0] !== _abbrObj.thousand && temp[0] !== _abbrObj.million && + temp[0] !== _abbrObj.billion && temp[0] !== _abbrObj.trillion) { + return false; + } + } - // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) - return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; - } -}; + _thousandRegEx = new RegExp(_thousandSep + '{2}'); -exports.HEX2DEC = function(number) { - // Return error if number is not hexadecimal or contains more than ten characters (10 digits) - if (!/^[0-9A-Fa-f]{1,10}$/.test(number)) { - return error.num; - } + if (!val.match(/[^\d.,]/g)) { + _valArray = val.split(_decimalSep); + if (_valArray.length > 2) { + return false; + } else { + if (_valArray.length < 2) { + return ( !! _valArray[0].match(/^\d+.*\d$/) && !_valArray[0].match(_thousandRegEx)); + } else { + if (_valArray[0] === '') { + // for values without leading zero eg. .984 + return (!_valArray[0].match(_thousandRegEx) && + !!_valArray[1].match(/^\d+$/)); - // Convert hexadecimal number to decimal - var decimal = parseInt(number, 16); + } else if (_valArray[0].length === 1) { + return ( !! _valArray[0].match(/^\d+$/) && + !_valArray[0].match(_thousandRegEx) && + !! _valArray[1].match(/^\d+$/)); + } else { + return ( !! _valArray[0].match(/^\d+.*\d$/) && + !_valArray[0].match(_thousandRegEx) && + !! _valArray[1].match(/^\d+$/)); + } + } + } + } - // Return decimal number - return (decimal >= 549755813888) ? decimal - 1099511627776 : decimal; -}; + return false; + }; -exports.HEX2OCT = function(number, places) { - // Return error if number is not hexadecimal or contains more than ten characters (10 digits) - if (!/^[0-9A-Fa-f]{1,10}$/.test(number)) { - return error.num; - } + /** + * * @deprecated Since in version 1.6.0. It will be deleted in version 2.0 + * `loadCulturesInNode` should be used instead. + */ + numbro.loadLanguagesInNode = function() { + console.warn('`loadLanguagesInNode` is deprecated since version 1.6.0. Use `loadCulturesInNode` instead'); - // Convert hexadecimal number to decimal - var decimal = parseInt(number, 16); + numbro.loadCulturesInNode(); + }; - // Return error if number is positive and greater than 0x1fffffff (536870911) - if (decimal > 536870911 && decimal < 1098974756864) { - return error.num; - } + numbro.loadCulturesInNode = function() { + // TODO: Rename the folder in 2.0.0 + var cultures = __webpack_require__(27); - // Ignore places and return a 10-character octal number if number is negative - if (decimal >= 1098974756864) { - return (decimal - 1098437885952).toString(8); - } + for(var langLocaleCode in cultures) { + if(langLocaleCode) { + numbro.culture(langLocaleCode, cultures[langLocaleCode]); + } + } + }; - // Convert decimal number to octal - var result = decimal.toString(8); + /************************************ + Helpers + ************************************/ - // Return octal number using the minimum number of characters necessary if places is undefined - if (places === undefined) { - return result; - } else { - // Return error if places is nonnumeric - if (isNaN(places)) { - return error.value; + function setCulture(code, values) { + cultures[code] = values; } - // Return error if places is negative - if (places < 0) { - return error.num; + function chooseCulture(code) { + currentCulture = code; + var defaults = cultures[code].defaults; + if (defaults && defaults.format) { + numbro.defaultFormat(defaults.format); + } + if (defaults && defaults.currencyFormat) { + numbro.defaultCurrencyFormat(defaults.currencyFormat); + } } - // Truncate places in case it is not an integer - places = Math.floor(places); + function inNodejsRuntime() { + return (typeof process !== 'undefined') && + (process.browser === undefined) && + process.title && + ( + process.title.indexOf('node') !== -1 || + process.title.indexOf('meteor-tool') > 0 || + process.title === 'grunt' || + process.title === 'gulp' + ) && + ("function" !== 'undefined'); + } - // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) - return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; - } -}; + /************************************ + Floating-point helpers + ************************************/ -exports.IMABS = function(inumber) { - // Lookup real and imaginary coefficients using exports.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); + // The floating-point helper functions and implementation + // borrows heavily from sinful.js: http://guipn.github.io/sinful.js/ - // Return error if either coefficient is not a number - if (utils.anyIsError(x, y)) { - return error.value; - } + /** + * Array.prototype.reduce for browsers that don't support it + * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/Reduce#Compatibility + */ + if ('function' !== typeof Array.prototype.reduce) { + Array.prototype.reduce = function(callback, optInitialValue) { - // Return absolute value of complex number - return Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2)); -}; + if (null === this || 'undefined' === typeof this) { + // At the moment all modern browsers, that support strict mode, have + // native implementation of Array.prototype.reduce. For instance, IE8 + // does not support strict mode, so this check is actually useless. + throw new TypeError('Array.prototype.reduce called on null or undefined'); + } -exports.IMAGINARY = function(inumber) { - if (inumber === undefined || inumber === true || inumber === false) { - return error.value; - } + if ('function' !== typeof callback) { + throw new TypeError(callback + ' is not a function'); + } - // Return 0 if inumber is equal to 0 - if (inumber === 0 || inumber === '0') { - return 0; - } + var index, + value, + length = this.length >>> 0, + isValueSet = false; - // Handle special cases - if (['i', 'j'].indexOf(inumber) >= 0) { - return 1; - } + if (1 < arguments.length) { + value = optInitialValue; + isValueSet = true; + } - // Normalize imaginary coefficient - inumber = inumber.replace('+i', '+1i').replace('-i', '-1i').replace('+j', '+1j').replace('-j', '-1j'); + for (index = 0; length > index; ++index) { + if (this.hasOwnProperty(index)) { + if (isValueSet) { + value = callback(value, this[index], index, this); + } else { + value = this[index]; + isValueSet = true; + } + } + } - // Lookup sign - var plus = inumber.indexOf('+'); - var minus = inumber.indexOf('-'); - if (plus === 0) { - plus = inumber.indexOf('+', 1); - } + if (!isValueSet) { + throw new TypeError('Reduce of empty array with no initial value'); + } - if (minus === 0) { - minus = inumber.indexOf('-', 1); - } + return value; + }; + } - // Lookup imaginary unit - var last = inumber.substring(inumber.length - 1, inumber.length); - var unit = (last === 'i' || last === 'j'); - if (plus >= 0 || minus >= 0) { - // Return error if imaginary unit is neither i nor j - if (!unit) { - return error.num; + /** + * Computes the multiplier necessary to make x >= 1, + * effectively eliminating miscalculations caused by + * finite precision. + */ + function multiplier(x) { + var parts = x.toString().split('.'); + if (parts.length < 2) { + return 1; + } + return Math.pow(10, parts[1].length); } - // Return imaginary coefficient of complex number - if (plus >= 0) { - return (isNaN(inumber.substring(0, plus)) || isNaN(inumber.substring(plus + 1, inumber.length - 1))) ? - error.num : - Number(inumber.substring(plus + 1, inumber.length - 1)); - } else { - return (isNaN(inumber.substring(0, minus)) || isNaN(inumber.substring(minus + 1, inumber.length - 1))) ? - error.num : - -Number(inumber.substring(minus + 1, inumber.length - 1)); - } - } else { - if (unit) { - return (isNaN(inumber.substring(0, inumber.length - 1))) ? error.num : inumber.substring(0, inumber.length - 1); - } else { - return (isNaN(inumber)) ? error.num : 0; + /** + * Given a variable number of arguments, returns the maximum + * multiplier that must be used to normalize an operation involving + * all of them. + */ + function correctionFactor() { + var args = Array.prototype.slice.call(arguments); + return args.reduce(function(prev, next) { + var mp = multiplier(prev), + mn = multiplier(next); + return mp > mn ? mp : mn; + }, -Infinity); } - } -}; -exports.IMARGUMENT = function(inumber) { - // Lookup real and imaginary coefficients using exports.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); + /************************************ + Numbro Prototype + ************************************/ - // Return error if either coefficient is not a number - if (utils.anyIsError(x, y)) { - return error.value; - } - // Return error if inumber is equal to zero - if (x === 0 && y === 0) { - return error.div0; - } + numbro.fn = Numbro.prototype = { - // Return PI/2 if x is equal to zero and y is positive - if (x === 0 && y > 0) { - return Math.PI / 2; - } + clone: function() { + return numbro(this); + }, - // Return -PI/2 if x is equal to zero and y is negative - if (x === 0 && y < 0) { - return -Math.PI / 2; - } + format: function(inputString, roundingFunction) { + return formatNumbro(this, + inputString ? inputString : defaultFormat, + (roundingFunction !== undefined) ? roundingFunction : Math.round + ); + }, - // Return zero if x is negative and y is equal to zero - if (y === 0 && x > 0) { - return 0; - } + formatCurrency: function(inputString, roundingFunction) { + return formatCurrency(this, + cultures[currentCulture].currency.symbol, + inputString ? inputString : defaultCurrencyFormat, + (roundingFunction !== undefined) ? roundingFunction : Math.round + ); + }, - // Return zero if x is negative and y is equal to zero - if (y === 0 && x < 0) { - return -Math.PI; - } + formatForeignCurrency: function(currencySymbol, inputString, roundingFunction) { + return formatForeignCurrency(this, + currencySymbol, + inputString ? inputString : defaultCurrencyFormat, + (roundingFunction !== undefined) ? roundingFunction : Math.round + ); + }, - // Return argument of complex number - if (x > 0) { - return Math.atan(y / x); - } else if (x < 0 && y >= 0) { - return Math.atan(y / x) + Math.PI; - } else { - return Math.atan(y / x) - Math.PI; - } -}; + unformat: function(inputString) { + if (typeof inputString === 'number') { + return inputString; + } else if (typeof inputString === 'string') { + var result = unformatNumbro(this, inputString); -exports.IMCONJUGATE = function(inumber) { - // Lookup real and imaginary coefficients using exports.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); + // Any unparseable string (represented as NaN in the result) is + // converted into undefined. + return isNaN(result) ? undefined : result; + } else { + return undefined; + } + }, - if (utils.anyIsError(x, y)) { - return error.value; - } + binaryByteUnits: function() { + return formatByteUnits(this._value, bytes.binary.suffixes, bytes.binary.scale).suffix; + }, - // Lookup imaginary unit - var unit = inumber.substring(inumber.length - 1); - unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + byteUnits: function() { + return formatByteUnits(this._value, bytes.general.suffixes, bytes.general.scale).suffix; + }, - // Return conjugate of complex number - return (y !== 0) ? exports.COMPLEX(x, -y, unit) : inumber; -}; + decimalByteUnits: function() { + return formatByteUnits(this._value, bytes.decimal.suffixes, bytes.decimal.scale).suffix; + }, -exports.IMCOS = function(inumber) { - // Lookup real and imaginary coefficients using exports.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); + value: function() { + return this._value; + }, - if (utils.anyIsError(x, y)) { - return error.value; - } + valueOf: function() { + return this._value; + }, - // Lookup imaginary unit - var unit = inumber.substring(inumber.length - 1); - unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + set: function(value) { + this._value = Number(value); + return this; + }, - // Return cosine of complex number - return exports.COMPLEX(Math.cos(x) * (Math.exp(y) + Math.exp(-y)) / 2, -Math.sin(x) * (Math.exp(y) - Math.exp(-y)) / 2, unit); -}; + add: function(value) { + var corrFactor = correctionFactor.call(null, this._value, value); -exports.IMCOSH = function(inumber) { - // Lookup real and imaginary coefficients using exports.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); + function cback(accum, curr) { + return accum + corrFactor * curr; + } + this._value = [this._value, value].reduce(cback, 0) / corrFactor; + return this; + }, - if (utils.anyIsError(x, y)) { - return error.value; - } + subtract: function(value) { + var corrFactor = correctionFactor.call(null, this._value, value); - // Lookup imaginary unit - var unit = inumber.substring(inumber.length - 1); - unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + function cback(accum, curr) { + return accum - corrFactor * curr; + } + this._value = [value].reduce(cback, this._value * corrFactor) / corrFactor; + return this; + }, - // Return hyperbolic cosine of complex number - return exports.COMPLEX(Math.cos(y) * (Math.exp(x) + Math.exp(-x)) / 2, Math.sin(y) * (Math.exp(x) - Math.exp(-x)) / 2, unit); -}; + multiply: function(value) { + function cback(accum, curr) { + var corrFactor = correctionFactor(accum, curr), + result = accum * corrFactor; + result *= curr * corrFactor; + result /= corrFactor * corrFactor; + return result; + } + this._value = [this._value, value].reduce(cback, 1); + return this; + }, -exports.IMCOT = function(inumber) { - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); + divide: function(value) { + function cback(accum, curr) { + var corrFactor = correctionFactor(accum, curr); + return (accum * corrFactor) / (curr * corrFactor); + } + this._value = [this._value, value].reduce(cback); + return this; + }, - if (utils.anyIsError(x, y)) { - return error.value; - } + difference: function(value) { + return Math.abs(numbro(this._value).subtract(value).value()); + } - // Return cotangent of complex number - return exports.IMDIV(exports.IMCOS(inumber), exports.IMSIN(inumber)); -}; + }; -exports.IMDIV = function(inumber1, inumber2) { - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var a = exports.IMREAL(inumber1); - var b = exports.IMAGINARY(inumber1); - var c = exports.IMREAL(inumber2); - var d = exports.IMAGINARY(inumber2); + /************************************ + Exposing Numbro + ************************************/ - if (utils.anyIsError(a, b, c, d)) { - return error.value; - } + if (inNodejsRuntime()) { + //Todo: Rename the folder in 2.0.0 + numbro.loadCulturesInNode(); + } - // Lookup imaginary unit - var unit1 = inumber1.substring(inumber1.length - 1); - var unit2 = inumber2.substring(inumber2.length - 1); - var unit = 'i'; - if (unit1 === 'j') { - unit = 'j'; - } else if (unit2 === 'j') { - unit = 'j'; - } - - // Return error if inumber2 is null - if (c === 0 && d === 0) { - return error.num; - } + // CommonJS module is defined + if (hasModule) { + module.exports = numbro; + } else { + /*global ender:false */ + if (typeof ender === 'undefined') { + // here, `this` means `window` in the browser, or `global` on the server + // add `numbro` as a global object via a string identifier, + // for Closure Compiler 'advanced' mode + this.numbro = numbro; + } - // Return exponential of complex number - var den = c * c + d * d; - return exports.COMPLEX((a * c + b * d) / den, (b * c - a * d) / den, unit); -}; + /*global define:false */ + if (true) { + !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = function() { + return numbro; + }.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__), + __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); + } + } -exports.IMEXP = function(inumber) { - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); +}.call(typeof window === 'undefined' ? this : window)); - if (utils.anyIsError(x, y)) { - return error.value; - } +/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(10))) - // Lookup imaginary unit - var unit = inumber.substring(inumber.length - 1); - unit = (unit === 'i' || unit === 'j') ? unit : 'i'; +/***/ }), +/* 10 */ +/***/ (function(module, exports) { - // Return exponential of complex number - var e = Math.exp(x); - return exports.COMPLEX(e * Math.cos(y), e * Math.sin(y), unit); -}; +// shim for using process in browser +var process = module.exports = {}; -exports.IMLN = function(inumber) { - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); +// cached from whatever global is present so that test runners that stub it +// don't break things. But we need to wrap it in a try catch in case it is +// wrapped in strict mode code which doesn't define any globals. It's inside a +// function because try/catches deoptimize in certain engines. - if (utils.anyIsError(x, y)) { - return error.value; - } +var cachedSetTimeout; +var cachedClearTimeout; - // Lookup imaginary unit - var unit = inumber.substring(inumber.length - 1); - unit = (unit === 'i' || unit === 'j') ? unit : 'i'; +function defaultSetTimout() { + throw new Error('setTimeout has not been defined'); +} +function defaultClearTimeout () { + throw new Error('clearTimeout has not been defined'); +} +(function () { + try { + if (typeof setTimeout === 'function') { + cachedSetTimeout = setTimeout; + } else { + cachedSetTimeout = defaultSetTimout; + } + } catch (e) { + cachedSetTimeout = defaultSetTimout; + } + try { + if (typeof clearTimeout === 'function') { + cachedClearTimeout = clearTimeout; + } else { + cachedClearTimeout = defaultClearTimeout; + } + } catch (e) { + cachedClearTimeout = defaultClearTimeout; + } +} ()) +function runTimeout(fun) { + if (cachedSetTimeout === setTimeout) { + //normal enviroments in sane situations + return setTimeout(fun, 0); + } + // if setTimeout wasn't available but was latter defined + if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) { + cachedSetTimeout = setTimeout; + return setTimeout(fun, 0); + } + try { + // when when somebody has screwed with setTimeout but no I.E. maddness + return cachedSetTimeout(fun, 0); + } catch(e){ + try { + // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally + return cachedSetTimeout.call(null, fun, 0); + } catch(e){ + // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error + return cachedSetTimeout.call(this, fun, 0); + } + } - // Return exponential of complex number - return exports.COMPLEX(Math.log(Math.sqrt(x * x + y * y)), Math.atan(y / x), unit); -}; -exports.IMLOG10 = function(inumber) { - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); +} +function runClearTimeout(marker) { + if (cachedClearTimeout === clearTimeout) { + //normal enviroments in sane situations + return clearTimeout(marker); + } + // if clearTimeout wasn't available but was latter defined + if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) { + cachedClearTimeout = clearTimeout; + return clearTimeout(marker); + } + try { + // when when somebody has screwed with setTimeout but no I.E. maddness + return cachedClearTimeout(marker); + } catch (e){ + try { + // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally + return cachedClearTimeout.call(null, marker); + } catch (e){ + // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error. + // Some versions of I.E. have different rules for clearTimeout vs setTimeout + return cachedClearTimeout.call(this, marker); + } + } - if (utils.anyIsError(x, y)) { - return error.value; - } - // Lookup imaginary unit - var unit = inumber.substring(inumber.length - 1); - unit = (unit === 'i' || unit === 'j') ? unit : 'i'; - // Return exponential of complex number - return exports.COMPLEX(Math.log(Math.sqrt(x * x + y * y)) / Math.log(10), Math.atan(y / x) / Math.log(10), unit); -}; +} +var queue = []; +var draining = false; +var currentQueue; +var queueIndex = -1; -exports.IMLOG2 = function(inumber) { - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); +function cleanUpNextTick() { + if (!draining || !currentQueue) { + return; + } + draining = false; + if (currentQueue.length) { + queue = currentQueue.concat(queue); + } else { + queueIndex = -1; + } + if (queue.length) { + drainQueue(); + } +} - if (utils.anyIsError(x, y)) { - return error.value; - } +function drainQueue() { + if (draining) { + return; + } + var timeout = runTimeout(cleanUpNextTick); + draining = true; - // Lookup imaginary unit - var unit = inumber.substring(inumber.length - 1); - unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + var len = queue.length; + while(len) { + currentQueue = queue; + queue = []; + while (++queueIndex < len) { + if (currentQueue) { + currentQueue[queueIndex].run(); + } + } + queueIndex = -1; + len = queue.length; + } + currentQueue = null; + draining = false; + runClearTimeout(timeout); +} - // Return exponential of complex number - return exports.COMPLEX(Math.log(Math.sqrt(x * x + y * y)) / Math.log(2), Math.atan(y / x) / Math.log(2), unit); +process.nextTick = function (fun) { + var args = new Array(arguments.length - 1); + if (arguments.length > 1) { + for (var i = 1; i < arguments.length; i++) { + args[i - 1] = arguments[i]; + } + } + queue.push(new Item(fun, args)); + if (queue.length === 1 && !draining) { + runTimeout(drainQueue); + } }; -exports.IMPOWER = function(inumber, number) { - number = utils.parseNumber(number); - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); - if (utils.anyIsError(number, x, y)) { - return error.value; - } +// v8 likes predictible objects +function Item(fun, array) { + this.fun = fun; + this.array = array; +} +Item.prototype.run = function () { + this.fun.apply(null, this.array); +}; +process.title = 'browser'; +process.browser = true; +process.env = {}; +process.argv = []; +process.version = ''; // empty string to avoid regexp issues +process.versions = {}; - // Lookup imaginary unit - var unit = inumber.substring(inumber.length - 1); - unit = (unit === 'i' || unit === 'j') ? unit : 'i'; +function noop() {} - // Calculate power of modulus - var p = Math.pow(exports.IMABS(inumber), number); +process.on = noop; +process.addListener = noop; +process.once = noop; +process.off = noop; +process.removeListener = noop; +process.removeAllListeners = noop; +process.emit = noop; - // Calculate argument - var t = exports.IMARGUMENT(inumber); - - // Return exponential of complex number - return exports.COMPLEX(p * Math.cos(number * t), p * Math.sin(number * t), unit); +process.binding = function (name) { + throw new Error('process.binding is not supported'); }; -exports.IMPRODUCT = function() { - // Initialize result - var result = arguments[0]; +process.cwd = function () { return '/' }; +process.chdir = function (dir) { + throw new Error('process.chdir is not supported'); +}; +process.umask = function() { return 0; }; - if (!arguments.length) { - return error.value; - } - // Loop on all numbers - for (var i = 1; i < arguments.length; i++) { - // Lookup coefficients of two complex numbers - var a = exports.IMREAL(result); - var b = exports.IMAGINARY(result); - var c = exports.IMREAL(arguments[i]); - var d = exports.IMAGINARY(arguments[i]); +/***/ }), +/* 11 */ +/***/ (function(module, exports, __webpack_require__) { - if (utils.anyIsError(a, b, c, d)) { - return error.value; +(function (window, factory) { + if (true) { + module.exports = factory(); + } else if (typeof define === 'function' && define.amd) { + define(factory); + } else { + window.jStat = factory(); } +})(this, function () { +var jStat = (function(Math, undefined) { - // Complute product of two complex numbers - result = exports.COMPLEX(a * c - b * d, a * d + b * c); - } +// For quick reference. +var concat = Array.prototype.concat; +var slice = Array.prototype.slice; +var toString = Object.prototype.toString; - // Return product of complex numbers - return result; +// Calculate correction for IEEE error +// TODO: This calculation can be improved. +function calcRdx(n, m) { + var val = n > m ? n : m; + return Math.pow(10, + 17 - ~~(Math.log(((val > 0) ? val : -val)) * Math.LOG10E)); +} + + +var isArray = Array.isArray || function isArray(arg) { + return toString.call(arg) === '[object Array]'; }; -exports.IMREAL = function(inumber) { - if (inumber === undefined || inumber === true || inumber === false) { - return error.value; - } - // Return 0 if inumber is equal to 0 - if (inumber === 0 || inumber === '0') { - return 0; - } +function isFunction(arg) { + return toString.call(arg) === '[object Function]'; +} - // Handle special cases - if (['i', '+i', '1i', '+1i', '-i', '-1i', 'j', '+j', '1j', '+1j', '-j', '-1j'].indexOf(inumber) >= 0) { - return 0; - } - // Lookup sign - var plus = inumber.indexOf('+'); - var minus = inumber.indexOf('-'); - if (plus === 0) { - plus = inumber.indexOf('+', 1); - } - if (minus === 0) { - minus = inumber.indexOf('-', 1); - } +function isNumber(arg) { + return typeof arg === 'number' && arg === arg; +} - // Lookup imaginary unit - var last = inumber.substring(inumber.length - 1, inumber.length); - var unit = (last === 'i' || last === 'j'); - if (plus >= 0 || minus >= 0) { - // Return error if imaginary unit is neither i nor j - if (!unit) { - return error.num; - } +// Converts the jStat matrix to vector. +function toVector(arr) { + return concat.apply([], arr); +} - // Return real coefficient of complex number - if (plus >= 0) { - return (isNaN(inumber.substring(0, plus)) || isNaN(inumber.substring(plus + 1, inumber.length - 1))) ? - error.num : - Number(inumber.substring(0, plus)); - } else { - return (isNaN(inumber.substring(0, minus)) || isNaN(inumber.substring(minus + 1, inumber.length - 1))) ? - error.num : - Number(inumber.substring(0, minus)); - } - } else { - if (unit) { - return (isNaN(inumber.substring(0, inumber.length - 1))) ? error.num : 0; - } else { - return (isNaN(inumber)) ? error.num : inumber; - } - } -}; -exports.IMSEC = function(inumber) { - // Return error if inumber is a logical value - if (inumber === true || inumber === false) { - return error.value; - } +// The one and only jStat constructor. +function jStat() { + return new jStat._init(arguments); +} - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); - if (utils.anyIsError(x, y)) { - return error.value; - } +// TODO: Remove after all references in src files have been removed. +jStat.fn = jStat.prototype; - // Return secant of complex number - return exports.IMDIV('1', exports.IMCOS(inumber)); -}; -exports.IMSECH = function(inumber) { - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); +// By separating the initializer from the constructor it's easier to handle +// always returning a new instance whether "new" was used or not. +jStat._init = function _init(args) { + var i; - if (utils.anyIsError(x, y)) { - return error.value; - } + // If first argument is an array, must be vector or matrix. + if (isArray(args[0])) { + // Check if matrix. + if (isArray(args[0][0])) { + // See if a mapping function was also passed. + if (isFunction(args[1])) + args[0] = jStat.map(args[0], args[1]); + // Iterate over each is faster than this.push.apply(this, args[0]. + for (var i = 0; i < args[0].length; i++) + this[i] = args[0][i]; + this.length = args[0].length; - // Return hyperbolic secant of complex number - return exports.IMDIV('1', exports.IMCOSH(inumber)); -}; + // Otherwise must be a vector. + } else { + this[0] = isFunction(args[1]) ? jStat.map(args[0], args[1]) : args[0]; + this.length = 1; + } -exports.IMSIN = function(inumber) { - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); + // If first argument is number, assume creation of sequence. + } else if (isNumber(args[0])) { + this[0] = jStat.seq.apply(null, args); + this.length = 1; - if (utils.anyIsError(x, y)) { - return error.value; + // Handle case when jStat object is passed to jStat. + } else if (args[0] instanceof jStat) { + // Duplicate the object and pass it back. + return jStat(args[0].toArray()); + + // Unexpected argument value, return empty jStat object. + // TODO: This is strange behavior. Shouldn't this throw or some such to let + // the user know they had bad arguments? + } else { + this[0] = []; + this.length = 1; } - // Lookup imaginary unit - var unit = inumber.substring(inumber.length - 1); - unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + return this; +}; +jStat._init.prototype = jStat.prototype; +jStat._init.constructor = jStat; - // Return sine of complex number - return exports.COMPLEX(Math.sin(x) * (Math.exp(y) + Math.exp(-y)) / 2, Math.cos(x) * (Math.exp(y) - Math.exp(-y)) / 2, unit); + +// Utility functions. +// TODO: for internal use only? +jStat.utils = { + calcRdx: calcRdx, + isArray: isArray, + isFunction: isFunction, + isNumber: isNumber, + toVector: toVector }; -exports.IMSINH = function(inumber) { - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); - if (utils.anyIsError(x, y)) { - return error.value; +// Easily extend the jStat object. +// TODO: is this seriously necessary? +jStat.extend = function extend(obj) { + var i, j; + + if (arguments.length === 1) { + for (j in obj) + jStat[j] = obj[j]; + return this; } - // Lookup imaginary unit - var unit = inumber.substring(inumber.length - 1); - unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + for (var i = 1; i < arguments.length; i++) { + for (j in arguments[i]) + obj[j] = arguments[i][j]; + } - // Return hyperbolic sine of complex number - return exports.COMPLEX(Math.cos(y) * (Math.exp(x) - Math.exp(-x)) / 2, Math.sin(y) * (Math.exp(x) + Math.exp(-x)) / 2, unit); + return obj; }; -exports.IMSQRT = function(inumber) { - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); - if (utils.anyIsError(x, y)) { - return error.value; - } +// Returns the number of rows in the matrix. +jStat.rows = function rows(arr) { + return arr.length || 1; +}; - // Lookup imaginary unit - var unit = inumber.substring(inumber.length - 1); - unit = (unit === 'i' || unit === 'j') ? unit : 'i'; - // Calculate power of modulus - var s = Math.sqrt(exports.IMABS(inumber)); +// Returns the number of columns in the matrix. +jStat.cols = function cols(arr) { + return arr[0].length || 1; +}; - // Calculate argument - var t = exports.IMARGUMENT(inumber); - // Return exponential of complex number - return exports.COMPLEX(s * Math.cos(t / 2), s * Math.sin(t / 2), unit); +// Returns the dimensions of the object { rows: i, cols: j } +jStat.dimensions = function dimensions(arr) { + return { + rows: jStat.rows(arr), + cols: jStat.cols(arr) + }; }; -exports.IMCSC = function (inumber) { - // Return error if inumber is a logical value - if (inumber === true || inumber === false) { - return error.value; - } - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); - - // Return error if either coefficient is not a number - if (utils.anyIsError(x, y)) { - return error.num; +// Returns a specified row as a vector or return a sub matrix by pick some rows +jStat.row = function row(arr, index) { + if (isArray(index)) { + return index.map(function(i) { + return jStat.row(arr, i); + }) } - - // Return cosecant of complex number - return exports.IMDIV('1', exports.IMSIN(inumber)); + return arr[index]; }; -exports.IMCSCH = function (inumber) { - // Return error if inumber is a logical value - if (inumber === true || inumber === false) { - return error.value; - } - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); +// return row as array +// rowa([[1,2],[3,4]],0) -> [1,2] +jStat.rowa = function rowa(arr, i) { + return jStat.row(arr, i); +}; - // Return error if either coefficient is not a number - if (utils.anyIsError(x, y)) { - return error.num; - } - // Return hyperbolic cosecant of complex number - return exports.IMDIV('1', exports.IMSINH(inumber)); +// Returns the specified column as a vector or return a sub matrix by pick some +// columns +jStat.col = function col(arr, index) { + if (isArray(index)) { + var submat = jStat.arange(arr.length).map(function(i) { + return new Array(index.length); + }); + index.forEach(function(ind, i){ + jStat.arange(arr.length).forEach(function(j) { + submat[j][i] = arr[j][ind]; + }); + }); + return submat; + } + var column = new Array(arr.length); + for (var i = 0; i < arr.length; i++) + column[i] = [arr[i][index]]; + return column; }; -exports.IMSUB = function(inumber1, inumber2) { - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var a = this.IMREAL(inumber1); - var b = this.IMAGINARY(inumber1); - var c = this.IMREAL(inumber2); - var d = this.IMAGINARY(inumber2); - if (utils.anyIsError(a, b, c, d)) { - return error.value; - } +// return column as array +// cola([[1,2],[3,4]],0) -> [1,3] +jStat.cola = function cola(arr, i) { + return jStat.col(arr, i).map(function(a){ return a[0] }); +}; - // Lookup imaginary unit - var unit1 = inumber1.substring(inumber1.length - 1); - var unit2 = inumber2.substring(inumber2.length - 1); - var unit = 'i'; - if (unit1 === 'j') { - unit = 'j'; - } else if (unit2 === 'j') { - unit = 'j'; - } - // Return _ of two complex numbers - return this.COMPLEX(a - c, b - d, unit); +// Returns the diagonal of the matrix +jStat.diag = function diag(arr) { + var nrow = jStat.rows(arr); + var res = new Array(nrow); + for (var row = 0; row < nrow; row++) + res[row] = [arr[row][row]]; + return res; }; -exports.IMSUM = function() { - if (!arguments.length) { - return error.value; - } - var args = utils.flatten(arguments); - // Initialize result - var result = args[0]; +// Returns the anti-diagonal of the matrix +jStat.antidiag = function antidiag(arr) { + var nrow = jStat.rows(arr) - 1; + var res = new Array(nrow); + for (var i = 0; nrow >= 0; nrow--, i++) + res[i] = [arr[i][nrow]]; + return res; +}; - // Loop on all numbers - for (var i = 1; i < args.length; i++) { - // Lookup coefficients of two complex numbers - var a = this.IMREAL(result); - var b = this.IMAGINARY(result); - var c = this.IMREAL(args[i]); - var d = this.IMAGINARY(args[i]); +// Transpose a matrix or array. +jStat.transpose = function transpose(arr) { + var obj = []; + var objArr, rows, cols, j, i; - if (utils.anyIsError(a, b, c, d)) { - return error.value; - } + // Make sure arr is in matrix format. + if (!isArray(arr[0])) + arr = [arr]; - // Complute product of two complex numbers - result = this.COMPLEX(a + c, b + d); + rows = arr.length; + cols = arr[0].length; + + for (var i = 0; i < cols; i++) { + objArr = new Array(rows); + for (j = 0; j < rows; j++) + objArr[j] = arr[j][i]; + obj.push(objArr); } - // Return sum of complex numbers - return result; + // If obj is vector, return only single array. + return obj.length === 1 ? obj[0] : obj; }; -exports.IMTAN = function(inumber) { - // Return error if inumber is a logical value - if (inumber === true || inumber === false) { - return error.value; - } - // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] - var x = exports.IMREAL(inumber); - var y = exports.IMAGINARY(inumber); +// Map a function to an array or array of arrays. +// "toAlter" is an internal variable. +jStat.map = function map(arr, func, toAlter) { + var row, nrow, ncol, res, col; - if (utils.anyIsError(x, y)) { - return error.value; + if (!isArray(arr[0])) + arr = [arr]; + + nrow = arr.length; + ncol = arr[0].length; + res = toAlter ? arr : new Array(nrow); + + for (row = 0; row < nrow; row++) { + // if the row doesn't exist, create it + if (!res[row]) + res[row] = new Array(ncol); + for (col = 0; col < ncol; col++) + res[row][col] = func(arr[row][col], row, col); } - // Return tangent of complex number - return this.IMDIV(this.IMSIN(inumber), this.IMCOS(inumber)); + return res.length === 1 ? res[0] : res; }; -exports.OCT2BIN = function(number, places) { - // Return error if number is not hexadecimal or contains more than ten characters (10 digits) - if (!/^[0-7]{1,10}$/.test(number)) { - return error.num; - } - // Check if number is negative - var negative = (number.length === 10 && number.substring(0, 1) === '7') ? true : false; +// Cumulatively combine the elements of an array or array of arrays using a function. +jStat.cumreduce = function cumreduce(arr, func, toAlter) { + var row, nrow, ncol, res, col; - // Convert octal number to decimal - var decimal = (negative) ? parseInt(number, 8) - 1073741824 : parseInt(number, 8); + if (!isArray(arr[0])) + arr = [arr]; - // Return error if number is lower than -512 or greater than 511 - if (decimal < -512 || decimal > 511) { - return error.num; - } + nrow = arr.length; + ncol = arr[0].length; + res = toAlter ? arr : new Array(nrow); - // Ignore places and return a 10-character binary number if number is negative - if (negative) { - return '1' + text.REPT('0', 9 - (512 + decimal).toString(2).length) + (512 + decimal).toString(2); + for (row = 0; row < nrow; row++) { + // if the row doesn't exist, create it + if (!res[row]) + res[row] = new Array(ncol); + if (ncol > 0) + res[row][0] = arr[row][0]; + for (col = 1; col < ncol; col++) + res[row][col] = func(res[row][col-1], arr[row][col]); } + return res.length === 1 ? res[0] : res; +}; - // Convert decimal number to binary - var result = decimal.toString(2); - // Return binary number using the minimum number of characters necessary if places is undefined - if (typeof places === 'undefined') { - return result; - } else { - // Return error if places is nonnumeric - if (isNaN(places)) { - return error.value; - } +// Destructively alter an array. +jStat.alter = function alter(arr, func) { + return jStat.map(arr, func, true); +}; - // Return error if places is negative - if (places < 0) { - return error.num; - } - // Truncate places in case it is not an integer - places = Math.floor(places); +// Generate a rows x cols matrix according to the supplied function. +jStat.create = function create(rows, cols, func) { + var res = new Array(rows); + var i, j; - // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) - return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; + if (isFunction(cols)) { + func = cols; + cols = rows; } -}; -exports.OCT2DEC = function(number) { - // Return error if number is not octal or contains more than ten characters (10 digits) - if (!/^[0-7]{1,10}$/.test(number)) { - return error.num; + for (var i = 0; i < rows; i++) { + res[i] = new Array(cols); + for (j = 0; j < cols; j++) + res[i][j] = func(i, j); } - // Convert octal number to decimal - var decimal = parseInt(number, 8); - - // Return decimal number - return (decimal >= 536870912) ? decimal - 1073741824 : decimal; + return res; }; -exports.OCT2HEX = function(number, places) { - // Return error if number is not octal or contains more than ten characters (10 digits) - if (!/^[0-7]{1,10}$/.test(number)) { - return error.num; - } - - // Convert octal number to decimal - var decimal = parseInt(number, 8); - // Ignore places and return a 10-character octal number if number is negative - if (decimal >= 536870912) { - return 'ff' + (decimal + 3221225472).toString(16); - } +function retZero() { return 0; } - // Convert decimal number to hexadecimal - var result = decimal.toString(16); - // Return hexadecimal number using the minimum number of characters necessary if places is undefined - if (places === undefined) { - return result; - } else { - // Return error if places is nonnumeric - if (isNaN(places)) { - return error.value; - } +// Generate a rows x cols matrix of zeros. +jStat.zeros = function zeros(rows, cols) { + if (!isNumber(cols)) + cols = rows; + return jStat.create(rows, cols, retZero); +}; - // Return error if places is negative - if (places < 0) { - return error.num; - } - // Truncate places in case it is not an integer - places = Math.floor(places); +function retOne() { return 1; } - // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) - return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; - } + +// Generate a rows x cols matrix of ones. +jStat.ones = function ones(rows, cols) { + if (!isNumber(cols)) + cols = rows; + return jStat.create(rows, cols, retOne); }; -/***/ }), -/* 12 */ -/***/ (function(module, exports, __webpack_require__) { +// Generate a rows x cols matrix of uniformly random numbers. +jStat.rand = function rand(rows, cols) { + if (!isNumber(cols)) + cols = rows; + return jStat.create(rows, cols, Math.random); +}; -var utils = __webpack_require__(2); -var numbro = __webpack_require__(14); -var error = __webpack_require__(0); -exports.UNIQUE = function () { - var result = []; - for (var i = 0; i < arguments.length; ++i) { - var hasElement = false; - var element = arguments[i]; +function retIdent(i, j) { return i === j ? 1 : 0; } - // Check if we've already seen this element. - for (var j = 0; j < result.length; ++j) { - hasElement = result[j] === element; - if (hasElement) { break; } - } - // If we did not find it, add it to the result. - if (!hasElement) { - result.push(element); - } - } - return result; +// Generate an identity matrix of size row x cols. +jStat.identity = function identity(rows, cols) { + if (!isNumber(cols)) + cols = rows; + return jStat.create(rows, cols, retIdent); }; -exports.FLATTEN = utils.flatten; -exports.ARGS2ARRAY = function () { - return Array.prototype.slice.call(arguments, 0); -}; +// Tests whether a matrix is symmetric +jStat.symmetric = function symmetric(arr) { + var issymmetric = true; + var size = arr.length; + var row, col; -exports.REFERENCE = function (context, reference) { - if (!arguments.length) { - return error.error; + if (arr.length !== arr[0].length) + return false; + + for (row = 0; row < size; row++) { + for (col = 0; col < size; col++) + if (arr[col][row] !== arr[row][col]) + return false; } - try { - var path = reference.split('.'); - var result = context; - for (var i = 0; i < path.length; ++i) { - var step = path[i]; - if (step[step.length - 1] === ']') { - var opening = step.indexOf('['); - var index = step.substring(opening + 1, step.length - 1); - result = result[step.substring(0, opening)][index]; - } else { - result = result[step]; - } - } - return result; - } catch (error) {} -}; -exports.JOIN = function (array, separator) { - return array.join(separator); + return true; }; -exports.NUMBERS = function () { - var possibleNumbers = utils.flatten(arguments); - return possibleNumbers.filter(function (el) { - return typeof el === 'number'; - }); -}; -exports.NUMERAL = function (number, format) { - return numbro(number).format(format); +// Set all values to zero. +jStat.clear = function clear(arr) { + return jStat.alter(arr, retZero); }; -/***/ }), -/* 13 */ -/***/ (function(module, exports) { - -this.j$ = this.jStat = (function(Math, undefined) { - -// For quick reference. -var concat = Array.prototype.concat; -var slice = Array.prototype.slice; -var toString = Object.prototype.toString; +// Generate sequence. +jStat.seq = function seq(min, max, length, func) { + if (!isFunction(func)) + func = false; -// Calculate correction for IEEE error -// TODO: This calculation can be improved. -function calcRdx(n, m) { - var val = n > m ? n : m; - return Math.pow(10, - 17 - ~~(Math.log(((val > 0) ? val : -val)) * Math.LOG10E)); -} + var arr = []; + var hival = calcRdx(min, max); + var step = (max * hival - min * hival) / ((length - 1) * hival); + var current = min; + var cnt; + // Current is assigned using a technique to compensate for IEEE error. + // TODO: Needs better implementation. + for (cnt = 0; + current <= max && cnt < length; + cnt++, current = (min * hival + step * hival * cnt) / hival) { + arr.push((func ? func(current, cnt) : current)); + } -var isArray = Array.isArray || function isArray(arg) { - return toString.call(arg) === '[object Array]'; + return arr; }; -function isFunction(arg) { - return toString.call(arg) === '[object Function]'; -} - +// arange(5) -> [0,1,2,3,4] +// arange(1,5) -> [1,2,3,4] +// arange(5,1,-1) -> [5,4,3,2] +jStat.arange = function arange(start, end, step) { + var rl = []; + step = step || 1; + if (end === undefined) { + end = start; + start = 0; + } + if (start === end || step === 0) { + return []; + } + if (start < end && step < 0) { + return []; + } + if (start > end && step > 0) { + return []; + } + if (step > 0) { + for (i = start; i < end; i += step) { + rl.push(i); + } + } else { + for (i = start; i > end; i += step) { + rl.push(i); + } + } + return rl; +}; -function isNumber(arg) { - return typeof arg === 'number' && arg === arg; -} +// A=[[1,2,3],[4,5,6],[7,8,9]] +// slice(A,{row:{end:2},col:{start:1}}) -> [[2,3],[5,6]] +// slice(A,1,{start:1}) -> [5,6] +// as numpy code A[:2,1:] +jStat.slice = (function(){ + function _slice(list, start, end, step) { + // note it's not equal to range.map mode it's a bug + var i; + var rl = []; + var length = list.length; + if (start === undefined && end === undefined && step === undefined) { + return jStat.copy(list); + } -// Converts the jStat matrix to vector. -function toVector(arr) { - return concat.apply([], arr); -} + start = start || 0; + end = end || list.length; + start = start >= 0 ? start : length + start; + end = end >= 0 ? end : length + end; + step = step || 1; + if (start === end || step === 0) { + return []; + } + if (start < end && step < 0) { + return []; + } + if (start > end && step > 0) { + return []; + } + if (step > 0) { + for (i = start; i < end; i += step) { + rl.push(list[i]); + } + } else { + for (i = start; i > end;i += step) { + rl.push(list[i]); + } + } + return rl; + } + function slice(list, rcSlice) { + rcSlice = rcSlice || {}; + if (isNumber(rcSlice.row)) { + if (isNumber(rcSlice.col)) + return list[rcSlice.row][rcSlice.col]; + var row = jStat.rowa(list, rcSlice.row); + var colSlice = rcSlice.col || {}; + return _slice(row, colSlice.start, colSlice.end, colSlice.step); + } -// The one and only jStat constructor. -function jStat() { - return new jStat._init(arguments); -} + if (isNumber(rcSlice.col)) { + var col = jStat.cola(list, rcSlice.col); + var rowSlice = rcSlice.row || {}; + return _slice(col, rowSlice.start, rowSlice.end, rowSlice.step); + } + var rowSlice = rcSlice.row || {}; + var colSlice = rcSlice.col || {}; + var rows = _slice(list, rowSlice.start, rowSlice.end, rowSlice.step); + return rows.map(function(row) { + return _slice(row, colSlice.start, colSlice.end, colSlice.step); + }); + } -// TODO: Remove after all references in src files have been removed. -jStat.fn = jStat.prototype; + return slice; +}()); -// By separating the initializer from the constructor it's easier to handle -// always returning a new instance whether "new" was used or not. -jStat._init = function _init(args) { - var i; +// A=[[1,2,3],[4,5,6],[7,8,9]] +// sliceAssign(A,{row:{start:1},col:{start:1}},[[0,0],[0,0]]) +// A=[[1,2,3],[4,0,0],[7,0,0]] +jStat.sliceAssign = function sliceAssign(A, rcSlice, B) { + if (isNumber(rcSlice.row)) { + if (isNumber(rcSlice.col)) + return A[rcSlice.row][rcSlice.col] = B; + rcSlice.col = rcSlice.col || {}; + rcSlice.col.start = rcSlice.col.start || 0; + rcSlice.col.end = rcSlice.col.end || A[0].length; + rcSlice.col.step = rcSlice.col.step || 1; + var nl = jStat.arange(rcSlice.col.start, + Math.min(A.length, rcSlice.col.end), + rcSlice.col.step); + var m = rcSlice.row; + nl.forEach(function(n, i) { + A[m][n] = B[i]; + }); + return A; + } - // If first argument is an array, must be vector or matrix. - if (isArray(args[0])) { - // Check if matrix. - if (isArray(args[0][0])) { - // See if a mapping function was also passed. - if (isFunction(args[1])) - args[0] = jStat.map(args[0], args[1]); - // Iterate over each is faster than this.push.apply(this, args[0]. - for (var i = 0; i < args[0].length; i++) - this[i] = args[0][i]; - this.length = args[0].length; + if (isNumber(rcSlice.col)) { + rcSlice.row = rcSlice.row || {}; + rcSlice.row.start = rcSlice.row.start || 0; + rcSlice.row.end = rcSlice.row.end || A.length; + rcSlice.row.step = rcSlice.row.step || 1; + var ml = jStat.arange(rcSlice.row.start, + Math.min(A[0].length, rcSlice.row.end), + rcSlice.row.step); + var n = rcSlice.col; + ml.forEach(function(m, j) { + A[m][n] = B[j]; + }); + return A; + } - // Otherwise must be a vector. - } else { - this[0] = isFunction(args[1]) ? jStat.map(args[0], args[1]) : args[0]; - this.length = 1; - } + if (B[0].length === undefined) { + B = [B]; + } + rcSlice.row.start = rcSlice.row.start || 0; + rcSlice.row.end = rcSlice.row.end || A.length; + rcSlice.row.step = rcSlice.row.step || 1; + rcSlice.col.start = rcSlice.col.start || 0; + rcSlice.col.end = rcSlice.col.end || A[0].length; + rcSlice.col.step = rcSlice.col.step || 1; + var ml = jStat.arange(rcSlice.row.start, + Math.min(A.length, rcSlice.row.end), + rcSlice.row.step); + var nl = jStat.arange(rcSlice.col.start, + Math.min(A[0].length, rcSlice.col.end), + rcSlice.col.step); + ml.forEach(function(m, i) { + nl.forEach(function(n, j) { + A[m][n] = B[i][j]; + }); + }); + return A; +}; - // If first argument is number, assume creation of sequence. - } else if (isNumber(args[0])) { - this[0] = jStat.seq.apply(null, args); - this.length = 1; - // Handle case when jStat object is passed to jStat. - } else if (args[0] instanceof jStat) { - // Duplicate the object and pass it back. - return jStat(args[0].toArray()); +// [1,2,3] -> +// [[1,0,0],[0,2,0],[0,0,3]] +jStat.diagonal = function diagonal(diagArray) { + var mat = jStat.zeros(diagArray.length, diagArray.length); + diagArray.forEach(function(t, i) { + mat[i][i] = t; + }); + return mat; +}; - // Unexpected argument value, return empty jStat object. - // TODO: This is strange behavior. Shouldn't this throw or some such to let - // the user know they had bad arguments? - } else { - this[0] = []; - this.length = 1; - } - return this; +// return copy of A +jStat.copy = function copy(A) { + return A.map(function(row) { + if (isNumber(row)) + return row; + return row.map(function(t) { + return t; + }); + }); }; -jStat._init.prototype = jStat.prototype; -jStat._init.constructor = jStat; -// Utility functions. -// TODO: for internal use only? -jStat.utils = { - calcRdx: calcRdx, - isArray: isArray, - isFunction: isFunction, - isNumber: isNumber, - toVector: toVector -}; +// TODO: Go over this entire implementation. Seems a tragic waste of resources +// doing all this work. Instead, and while ugly, use new Function() to generate +// a custom function for each static method. +// Quick reference. +var jProto = jStat.prototype; -// Easily extend the jStat object. -// TODO: is this seriously necessary? -jStat.extend = function extend(obj) { - var i, j; +// Default length. +jProto.length = 0; - if (arguments.length === 1) { - for (j in obj) - jStat[j] = obj[j]; - return this; - } +// For internal use only. +// TODO: Check if they're actually used, and if they are then rename them +// to _* +jProto.push = Array.prototype.push; +jProto.sort = Array.prototype.sort; +jProto.splice = Array.prototype.splice; +jProto.slice = Array.prototype.slice; - for (var i = 1; i < arguments.length; i++) { - for (j in arguments[i]) - obj[j] = arguments[i][j]; - } - return obj; +// Return a clean array. +jProto.toArray = function toArray() { + return this.length > 1 ? slice.call(this) : slice.call(this)[0]; }; -// Returns the number of rows in the matrix. -jStat.rows = function rows(arr) { - return arr.length || 1; +// Map a function to a matrix or vector. +jProto.map = function map(func, toAlter) { + return jStat(jStat.map(this, func, toAlter)); }; -// Returns the number of columns in the matrix. -jStat.cols = function cols(arr) { - return arr[0].length || 1; +// Cumulatively combine the elements of a matrix or vector using a function. +jProto.cumreduce = function cumreduce(func, toAlter) { + return jStat(jStat.cumreduce(this, func, toAlter)); }; -// Returns the dimensions of the object { rows: i, cols: j } -jStat.dimensions = function dimensions(arr) { - return { - rows: jStat.rows(arr), - cols: jStat.cols(arr) - }; +// Destructively alter an array. +jProto.alter = function alter(func) { + jStat.alter(this, func); + return this; }; -// Returns a specified row as a vector or return a sub matrix by pick some rows -jStat.row = function row(arr, index) { - if (isArray(index)) { - return index.map(function(i) { - return jStat.row(arr, i); - }) - } - return arr[index]; -}; +// Extend prototype with methods that have no argument. +(function(funcs) { + for (var i = 0; i < funcs.length; i++) (function(passfunc) { + jProto[passfunc] = function(func) { + var self = this, + results; + // Check for callback. + if (func) { + setTimeout(function() { + func.call(self, jProto[passfunc].call(self)); + }); + return this; + } + results = jStat[passfunc](this); + return isArray(results) ? jStat(results) : results; + }; + })(funcs[i]); +})('transpose clear symmetric rows cols dimensions diag antidiag'.split(' ')); -// return row as array -// rowa([[1,2],[3,4]],0) -> [1,2] -jStat.rowa = function rowa(arr, i) { - return jStat.row(arr, i); -}; +// Extend prototype with methods that have one argument. +(function(funcs) { + for (var i = 0; i < funcs.length; i++) (function(passfunc) { + jProto[passfunc] = function(index, func) { + var self = this; + // check for callback + if (func) { + setTimeout(function() { + func.call(self, jProto[passfunc].call(self, index)); + }); + return this; + } + return jStat(jStat[passfunc](this, index)); + }; + })(funcs[i]); +})('row col'.split(' ')); -// Returns the specified column as a vector or return a sub matrix by pick some -// columns -jStat.col = function col(arr, index) { - if (isArray(index)) { - var submat = jStat.arange(arr.length).map(function(i) { - return new Array(index.length); - }); - index.forEach(function(ind, i){ - jStat.arange(arr.length).forEach(function(j) { - submat[j][i] = arr[j][ind]; - }); - }); - return submat; - } - var column = new Array(arr.length); - for (var i = 0; i < arr.length; i++) - column[i] = [arr[i][index]]; - return column; -}; +// Extend prototype with simple shortcut methods. +(function(funcs) { + for (var i = 0; i < funcs.length; i++) (function(passfunc) { + jProto[passfunc] = new Function( + 'return jStat(jStat.' + passfunc + '.apply(null, arguments));'); + })(funcs[i]); +})('create zeros ones rand identity'.split(' ')); -// return column as array -// cola([[1,2],[3,4]],0) -> [1,3] -jStat.cola = function cola(arr, i) { - return jStat.col(arr, i).map(function(a){ return a[0] }); -}; +// Exposing jStat. +return jStat; +}(Math)); +(function(jStat, Math) { -// Returns the diagonal of the matrix -jStat.diag = function diag(arr) { - var nrow = jStat.rows(arr); - var res = new Array(nrow); - for (var row = 0; row < nrow; row++) - res[row] = [arr[row][row]]; - return res; -}; - - -// Returns the anti-diagonal of the matrix -jStat.antidiag = function antidiag(arr) { - var nrow = jStat.rows(arr) - 1; - var res = new Array(nrow); - for (var i = 0; nrow >= 0; nrow--, i++) - res[i] = [arr[i][nrow]]; - return res; -}; - -// Transpose a matrix or array. -jStat.transpose = function transpose(arr) { - var obj = []; - var objArr, rows, cols, j, i; +var isFunction = jStat.utils.isFunction; - // Make sure arr is in matrix format. - if (!isArray(arr[0])) - arr = [arr]; +// Ascending functions for sort +function ascNum(a, b) { return a - b; } - rows = arr.length; - cols = arr[0].length; +function clip(arg, min, max) { + return Math.max(min, Math.min(arg, max)); +} - for (var i = 0; i < cols; i++) { - objArr = new Array(rows); - for (j = 0; j < rows; j++) - objArr[j] = arr[j][i]; - obj.push(objArr); - } - // If obj is vector, return only single array. - return obj.length === 1 ? obj[0] : obj; +// sum of an array +jStat.sum = function sum(arr) { + var sum = 0; + var i = arr.length; + while (--i >= 0) + sum += arr[i]; + return sum; }; -// Map a function to an array or array of arrays. -// "toAlter" is an internal variable. -jStat.map = function map(arr, func, toAlter) { - var row, nrow, ncol, res, col; - - if (!isArray(arr[0])) - arr = [arr]; +// sum squared +jStat.sumsqrd = function sumsqrd(arr) { + var sum = 0; + var i = arr.length; + while (--i >= 0) + sum += arr[i] * arr[i]; + return sum; +}; - nrow = arr.length; - ncol = arr[0].length; - res = toAlter ? arr : new Array(nrow); - for (row = 0; row < nrow; row++) { - // if the row doesn't exist, create it - if (!res[row]) - res[row] = new Array(ncol); - for (col = 0; col < ncol; col++) - res[row][col] = func(arr[row][col], row, col); +// sum of squared errors of prediction (SSE) +jStat.sumsqerr = function sumsqerr(arr) { + var mean = jStat.mean(arr); + var sum = 0; + var i = arr.length; + var tmp; + while (--i >= 0) { + tmp = arr[i] - mean; + sum += tmp * tmp; } - - return res.length === 1 ? res[0] : res; + return sum; }; +// sum of an array in each row +jStat.sumrow = function sumrow(arr) { + var sum = 0; + var i = arr.length; + while (--i >= 0) + sum += arr[i]; + return sum; +}; -// Cumulatively combine the elements of an array or array of arrays using a function. -jStat.cumreduce = function cumreduce(arr, func, toAlter) { - var row, nrow, ncol, res, col; - - if (!isArray(arr[0])) - arr = [arr]; - - nrow = arr.length; - ncol = arr[0].length; - res = toAlter ? arr : new Array(nrow); - - for (row = 0; row < nrow; row++) { - // if the row doesn't exist, create it - if (!res[row]) - res[row] = new Array(ncol); - if (ncol > 0) - res[row][0] = arr[row][0]; - for (col = 1; col < ncol; col++) - res[row][col] = func(res[row][col-1], arr[row][col]); - } - return res.length === 1 ? res[0] : res; +// product of an array +jStat.product = function product(arr) { + var prod = 1; + var i = arr.length; + while (--i >= 0) + prod *= arr[i]; + return prod; }; -// Destructively alter an array. -jStat.alter = function alter(arr, func) { - return jStat.map(arr, func, true); +// minimum value of an array +jStat.min = function min(arr) { + var low = arr[0]; + var i = 0; + while (++i < arr.length) + if (arr[i] < low) + low = arr[i]; + return low; }; -// Generate a rows x cols matrix according to the supplied function. -jStat.create = function create(rows, cols, func) { - var res = new Array(rows); - var i, j; +// maximum value of an array +jStat.max = function max(arr) { + var high = arr[0]; + var i = 0; + while (++i < arr.length) + if (arr[i] > high) + high = arr[i]; + return high; +}; - if (isFunction(cols)) { - func = cols; - cols = rows; - } - for (var i = 0; i < rows; i++) { - res[i] = new Array(cols); - for (j = 0; j < cols; j++) - res[i][j] = func(i, j); +// unique values of an array +jStat.unique = function unique(arr) { + var hash = {}, _arr = []; + for(var i = 0; i < arr.length; i++) { + if (!hash[arr[i]]) { + hash[arr[i]] = true; + _arr.push(arr[i]); + } } - - return res; + return _arr; }; -function retZero() { return 0; } - - -// Generate a rows x cols matrix of zeros. -jStat.zeros = function zeros(rows, cols) { - if (!isNumber(cols)) - cols = rows; - return jStat.create(rows, cols, retZero); +// mean value of an array +jStat.mean = function mean(arr) { + return jStat.sum(arr) / arr.length; }; -function retOne() { return 1; } - - -// Generate a rows x cols matrix of ones. -jStat.ones = function ones(rows, cols) { - if (!isNumber(cols)) - cols = rows; - return jStat.create(rows, cols, retOne); +// mean squared error (MSE) +jStat.meansqerr = function meansqerr(arr) { + return jStat.sumsqerr(arr) / arr.length; }; -// Generate a rows x cols matrix of uniformly random numbers. -jStat.rand = function rand(rows, cols) { - if (!isNumber(cols)) - cols = rows; - return jStat.create(rows, cols, Math.random); +// geometric mean of an array +jStat.geomean = function geomean(arr) { + return Math.pow(jStat.product(arr), 1 / arr.length); }; -function retIdent(i, j) { return i === j ? 1 : 0; } +// median of an array +jStat.median = function median(arr) { + var arrlen = arr.length; + var _arr = arr.slice().sort(ascNum); + // check if array is even or odd, then return the appropriate + return !(arrlen & 1) + ? (_arr[(arrlen / 2) - 1 ] + _arr[(arrlen / 2)]) / 2 + : _arr[(arrlen / 2) | 0 ]; +}; -// Generate an identity matrix of size row x cols. -jStat.identity = function identity(rows, cols) { - if (!isNumber(cols)) - cols = rows; - return jStat.create(rows, cols, retIdent); +// cumulative sum of an array +jStat.cumsum = function cumsum(arr) { + return jStat.cumreduce(arr, function (a, b) { return a + b; }); }; -// Tests whether a matrix is symmetric -jStat.symmetric = function symmetric(arr) { - var issymmetric = true; - var size = arr.length; - var row, col; - - if (arr.length !== arr[0].length) - return false; +// cumulative product of an array +jStat.cumprod = function cumprod(arr) { + return jStat.cumreduce(arr, function (a, b) { return a * b; }); +}; - for (row = 0; row < size; row++) { - for (col = 0; col < size; col++) - if (arr[col][row] !== arr[row][col]) - return false; - } - return true; +// successive differences of a sequence +jStat.diff = function diff(arr) { + var diffs = []; + var arrLen = arr.length; + var i; + for (var i = 1; i < arrLen; i++) + diffs.push(arr[i] - arr[i - 1]); + return diffs; }; -// Set all values to zero. -jStat.clear = function clear(arr) { - return jStat.alter(arr, retZero); +// ranks of an array +jStat.rank = function (arr) { + var arrlen = arr.length; + var sorted = arr.slice().sort(ascNum); + var ranks = new Array(arrlen); + for (var i = 0; i < arrlen; i++) { + var first = sorted.indexOf(arr[i]); + var last = sorted.lastIndexOf(arr[i]); + if (first === last) { + var val = first; + } else { + var val = (first + last) / 2; + } + ranks[i] = val + 1; + } + return ranks; }; -// Generate sequence. -jStat.seq = function seq(min, max, length, func) { - if (!isFunction(func)) - func = false; - - var arr = []; - var hival = calcRdx(min, max); - var step = (max * hival - min * hival) / ((length - 1) * hival); - var current = min; - var cnt; +// mode of an array +// if there are multiple modes of an array, return all of them +// is this the appropriate way of handling it? +jStat.mode = function mode(arr) { + var arrLen = arr.length; + var _arr = arr.slice().sort(ascNum); + var count = 1; + var maxCount = 0; + var numMaxCount = 0; + var mode_arr = []; + var i; - // Current is assigned using a technique to compensate for IEEE error. - // TODO: Needs better implementation. - for (cnt = 0; - current <= max; - cnt++, current = (min * hival + step * hival * cnt) / hival) { - arr.push((func ? func(current, cnt) : current)); + for (var i = 0; i < arrLen; i++) { + if (_arr[i] === _arr[i + 1]) { + count++; + } else { + if (count > maxCount) { + mode_arr = [_arr[i]]; + maxCount = count; + numMaxCount = 0; + } + // are there multiple max counts + else if (count === maxCount) { + mode_arr.push(_arr[i]); + numMaxCount++; + } + // resetting count for new value in array + count = 1; + } } - return arr; + return numMaxCount === 0 ? mode_arr[0] : mode_arr; }; -// arange(5) -> [0,1,2,3,4] -// arange(1,5) -> [1,2,3,4] -// arange(5,1,-1) -> [5,4,3,2] -jStat.arange = function arange(start, end, step) { - var rl = []; - step = step || 1; - if (end === undefined) { - end = start; - start = 0; - } - if (start === end || step === 0) { - return []; - } - if (start < end && step < 0) { - return []; - } - if (start > end && step > 0) { - return []; - } - if (step > 0) { - for (i = start; i < end; i += step) { - rl.push(i); - } - } else { - for (i = start; i > end; i += step) { - rl.push(i); - } - } - return rl; +// range of an array +jStat.range = function range(arr) { + return jStat.max(arr) - jStat.min(arr); }; +// variance of an array +// flag = true indicates sample instead of population +jStat.variance = function variance(arr, flag) { + return jStat.sumsqerr(arr) / (arr.length - (flag ? 1 : 0)); +}; -// A=[[1,2,3],[4,5,6],[7,8,9]] -// slice(A,{row:{end:2},col:{start:1}}) -> [[2,3],[5,6]] -// slice(A,1,{start:1}) -> [5,6] -// as numpy code A[:2,1:] -jStat.slice = (function(){ - function _slice(list, start, end, step) { - // note it's not equal to range.map mode it's a bug - var i; - var rl = []; - var length = list.length; - if (start === undefined && end === undefined && step === undefined) { - return jStat.copy(list); - } - - start = start || 0; - end = end || list.length; - start = start >= 0 ? start : length + start; - end = end >= 0 ? end : length + end; - step = step || 1; - if (start === end || step === 0) { - return []; - } - if (start < end && step < 0) { - return []; - } - if (start > end && step > 0) { - return []; - } - if (step > 0) { - for (i = start; i < end; i += step) { - rl.push(list[i]); - } - } else { - for (i = start; i > end;i += step) { - rl.push(list[i]); - } - } - return rl; - } - - function slice(list, rcSlice) { - rcSlice = rcSlice || {}; - if (isNumber(rcSlice.row)) { - if (isNumber(rcSlice.col)) - return list[rcSlice.row][rcSlice.col]; - var row = jStat.rowa(list, rcSlice.row); - var colSlice = rcSlice.col || {}; - return _slice(row, colSlice.start, colSlice.end, colSlice.step); - } - - if (isNumber(rcSlice.col)) { - var col = jStat.cola(list, rcSlice.col); - var rowSlice = rcSlice.row || {}; - return _slice(col, rowSlice.start, rowSlice.end, rowSlice.step); - } +// pooled variance of an array of arrays +jStat.pooledvariance = function pooledvariance(arr) { + var sumsqerr = arr.reduce(function (a, samples) {return a + jStat.sumsqerr(samples);}, 0); + var count = arr.reduce(function (a, samples) {return a + samples.length;}, 0); + return sumsqerr / (count - arr.length); +}; - var rowSlice = rcSlice.row || {}; - var colSlice = rcSlice.col || {}; - var rows = _slice(list, rowSlice.start, rowSlice.end, rowSlice.step); - return rows.map(function(row) { - return _slice(row, colSlice.start, colSlice.end, colSlice.step); - }); +// deviation of an array +jStat.deviation = function (arr) { + var mean = jStat.mean(arr); + var arrlen = arr.length; + var dev = new Array(arrlen); + for (var i = 0; i < arrlen; i++) { + dev[i] = arr[i] - mean; } + return dev; +}; - return slice; -}()); +// standard deviation of an array +// flag = true indicates sample instead of population +jStat.stdev = function stdev(arr, flag) { + return Math.sqrt(jStat.variance(arr, flag)); +}; +// pooled standard deviation of an array of arrays +jStat.pooledstdev = function pooledstdev(arr) { + return Math.sqrt(jStat.pooledvariance(arr)); +}; -// A=[[1,2,3],[4,5,6],[7,8,9]] -// sliceAssign(A,{row:{start:1},col:{start:1}},[[0,0],[0,0]]) -// A=[[1,2,3],[4,0,0],[7,0,0]] -jStat.sliceAssign = function sliceAssign(A, rcSlice, B) { - if (isNumber(rcSlice.row)) { - if (isNumber(rcSlice.col)) - return A[rcSlice.row][rcSlice.col] = B; - rcSlice.col = rcSlice.col || {}; - rcSlice.col.start = rcSlice.col.start || 0; - rcSlice.col.end = rcSlice.col.end || A[0].length; - rcSlice.col.step = rcSlice.col.step || 1; - var nl = jStat.arange(rcSlice.col.start, - Math.min(A.length, rcSlice.col.end), - rcSlice.col.step); - var m = rcSlice.row; - nl.forEach(function(n, i) { - A[m][n] = B[i]; - }); - return A; +// mean deviation (mean absolute deviation) of an array +jStat.meandev = function meandev(arr) { + var mean = jStat.mean(arr); + var a = []; + for (var i = arr.length - 1; i >= 0; i--) { + a.push(Math.abs(arr[i] - mean)); } + return jStat.mean(a); +}; - if (isNumber(rcSlice.col)) { - rcSlice.row = rcSlice.row || {}; - rcSlice.row.start = rcSlice.row.start || 0; - rcSlice.row.end = rcSlice.row.end || A.length; - rcSlice.row.step = rcSlice.row.step || 1; - var ml = jStat.arange(rcSlice.row.start, - Math.min(A[0].length, rcSlice.row.end), - rcSlice.row.step); - var n = rcSlice.col; - ml.forEach(function(m, j) { - A[m][n] = B[j]; - }); - return A; - } - if (B[0].length === undefined) { - B = [B]; +// median deviation (median absolute deviation) of an array +jStat.meddev = function meddev(arr) { + var median = jStat.median(arr); + var a = []; + for (var i = arr.length - 1; i >= 0; i--) { + a.push(Math.abs(arr[i] - median)); } - rcSlice.row.start = rcSlice.row.start || 0; - rcSlice.row.end = rcSlice.row.end || A.length; - rcSlice.row.step = rcSlice.row.step || 1; - rcSlice.col.start = rcSlice.col.start || 0; - rcSlice.col.end = rcSlice.col.end || A[0].length; - rcSlice.col.step = rcSlice.col.step || 1; - var ml = jStat.arange(rcSlice.row.start, - Math.min(A.length, rcSlice.row.end), - rcSlice.row.step); - var nl = jStat.arange(rcSlice.col.start, - Math.min(A[0].length, rcSlice.col.end), - rcSlice.col.step); - ml.forEach(function(m, i) { - nl.forEach(function(n, j) { - A[m][n] = B[i][j]; - }); - }); - return A; + return jStat.median(a); }; -// [1,2,3] -> -// [[1,0,0],[0,2,0],[0,0,3]] -jStat.diagonal = function diagonal(diagArray) { - var mat = jStat.zeros(diagArray.length, diagArray.length); - diagArray.forEach(function(t, i) { - mat[i][i] = t; - }); - return mat; +// coefficient of variation +jStat.coeffvar = function coeffvar(arr) { + return jStat.stdev(arr) / jStat.mean(arr); }; -// return copy of A -jStat.copy = function copy(A) { - return A.map(function(row) { - if (isNumber(row)) - return row; - return row.map(function(t) { - return t; - }); - }); +// quartiles of an array +jStat.quartiles = function quartiles(arr) { + var arrlen = arr.length; + var _arr = arr.slice().sort(ascNum); + return [ + _arr[ Math.round((arrlen) / 4) - 1 ], + _arr[ Math.round((arrlen) / 2) - 1 ], + _arr[ Math.round((arrlen) * 3 / 4) - 1 ] + ]; }; -// TODO: Go over this entire implementation. Seems a tragic waste of resources -// doing all this work. Instead, and while ugly, use new Function() to generate -// a custom function for each static method. - -// Quick reference. -var jProto = jStat.prototype; - -// Default length. -jProto.length = 0; +// Arbitary quantiles of an array. Direct port of the scipy.stats +// implementation by Pierre GF Gerard-Marchant. +jStat.quantiles = function quantiles(arr, quantilesArray, alphap, betap) { + var sortedArray = arr.slice().sort(ascNum); + var quantileVals = [quantilesArray.length]; + var n = arr.length; + var i, p, m, aleph, k, gamma; -// For internal use only. -// TODO: Check if they're actually used, and if they are then rename them -// to _* -jProto.push = Array.prototype.push; -jProto.sort = Array.prototype.sort; -jProto.splice = Array.prototype.splice; -jProto.slice = Array.prototype.slice; + if (typeof alphap === 'undefined') + alphap = 3 / 8; + if (typeof betap === 'undefined') + betap = 3 / 8; + for (var i = 0; i < quantilesArray.length; i++) { + p = quantilesArray[i]; + m = alphap + p * (1 - alphap - betap); + aleph = n * p + m; + k = Math.floor(clip(aleph, 1, n - 1)); + gamma = clip(aleph - k, 0, 1); + quantileVals[i] = (1 - gamma) * sortedArray[k - 1] + gamma * sortedArray[k]; + } -// Return a clean array. -jProto.toArray = function toArray() { - return this.length > 1 ? slice.call(this) : slice.call(this)[0]; + return quantileVals; }; +// Returns the k-th percentile of values in a range, where k is in the +// range 0..1, exclusive. +jStat.percentile = function percentile(arr, k) { + var _arr = arr.slice().sort(ascNum); + var realIndex = k * (_arr.length - 1); + var index = parseInt(realIndex); + var frac = realIndex - index; + + if (index + 1 < _arr.length) { + return _arr[index] * (1 - frac) + _arr[index + 1] * frac; + } else { + return _arr[index]; + } +} -// Map a function to a matrix or vector. -jProto.map = function map(func, toAlter) { - return jStat(jStat.map(this, func, toAlter)); + +// The percentile rank of score in a given array. Returns the percentage +// of all values in the input array that are less than (kind='strict') or +// less or equal than (kind='weak') score. Default is weak. +jStat.percentileOfScore = function percentileOfScore(arr, score, kind) { + var counter = 0; + var len = arr.length; + var strict = false; + var value, i; + + if (kind === 'strict') + strict = true; + + for (var i = 0; i < len; i++) { + value = arr[i]; + if ((strict && value < score) || + (!strict && value <= score)) { + counter++; + } + } + + return counter / len; }; -// Cumulatively combine the elements of a matrix or vector using a function. -jProto.cumreduce = function cumreduce(func, toAlter) { - return jStat(jStat.cumreduce(this, func, toAlter)); +// Histogram (bin count) data +jStat.histogram = function histogram(arr, bins) { + var first = jStat.min(arr); + var binCnt = bins || 4; + var binWidth = (jStat.max(arr) - first) / binCnt; + var len = arr.length; + var bins = []; + var i; + + for (var i = 0; i < binCnt; i++) + bins[i] = 0; + for (var i = 0; i < len; i++) + bins[Math.min(Math.floor(((arr[i] - first) / binWidth)), binCnt - 1)] += 1; + + return bins; }; -// Destructively alter an array. -jProto.alter = function alter(func) { - jStat.alter(this, func); - return this; +// covariance of two arrays +jStat.covariance = function covariance(arr1, arr2) { + var u = jStat.mean(arr1); + var v = jStat.mean(arr2); + var arr1Len = arr1.length; + var sq_dev = new Array(arr1Len); + var i; + + for (var i = 0; i < arr1Len; i++) + sq_dev[i] = (arr1[i] - u) * (arr2[i] - v); + + return jStat.sum(sq_dev) / (arr1Len - 1); }; -// Extend prototype with methods that have no argument. +// (pearson's) population correlation coefficient, rho +jStat.corrcoeff = function corrcoeff(arr1, arr2) { + return jStat.covariance(arr1, arr2) / + jStat.stdev(arr1, 1) / + jStat.stdev(arr2, 1); +}; + + // (spearman's) rank correlation coefficient, sp +jStat.spearmancoeff = function (arr1, arr2) { + arr1 = jStat.rank(arr1); + arr2 = jStat.rank(arr2); + //return pearson's correlation of the ranks: + return jStat.corrcoeff(arr1, arr2); +} + + +// statistical standardized moments (general form of skew/kurt) +jStat.stanMoment = function stanMoment(arr, n) { + var mu = jStat.mean(arr); + var sigma = jStat.stdev(arr); + var len = arr.length; + var skewSum = 0; + + for (var i = 0; i < len; i++) + skewSum += Math.pow((arr[i] - mu) / sigma, n); + + return skewSum / arr.length; +}; + +// (pearson's) moment coefficient of skewness +jStat.skewness = function skewness(arr) { + return jStat.stanMoment(arr, 3); +}; + +// (pearson's) (excess) kurtosis +jStat.kurtosis = function kurtosis(arr) { + return jStat.stanMoment(arr, 4) - 3; +}; + + +var jProto = jStat.prototype; + + +// Extend jProto with method for calculating cumulative sums and products. +// This differs from the similar extension below as cumsum and cumprod should +// not be run again in the case fullbool === true. +// If a matrix is passed, automatically assume operation should be done on the +// columns. (function(funcs) { for (var i = 0; i < funcs.length; i++) (function(passfunc) { - jProto[passfunc] = function(func) { - var self = this, - results; - // Check for callback. + // If a matrix is passed, automatically assume operation should be done on + // the columns. + jProto[passfunc] = function(fullbool, func) { + var arr = []; + var i = 0; + var tmpthis = this; + // Assignment reassignation depending on how parameters were passed in. + if (isFunction(fullbool)) { + func = fullbool; + fullbool = false; + } + // Check if a callback was passed with the function. if (func) { setTimeout(function() { - func.call(self, jProto[passfunc].call(self)); + func.call(tmpthis, jProto[passfunc].call(tmpthis, fullbool)); }); return this; } - results = jStat[passfunc](this); - return isArray(results) ? jStat(results) : results; + // Check if matrix and run calculations. + if (this.length > 1) { + tmpthis = fullbool === true ? this : this.transpose(); + for (; i < tmpthis.length; i++) + arr[i] = jStat[passfunc](tmpthis[i]); + return arr; + } + // Pass fullbool if only vector, not a matrix. for variance and stdev. + return jStat[passfunc](this[0], fullbool); }; })(funcs[i]); -})('transpose clear symmetric rows cols dimensions diag antidiag'.split(' ')); +})(('cumsum cumprod').split(' ')); -// Extend prototype with methods that have one argument. +// Extend jProto with methods which don't require arguments and work on columns. (function(funcs) { for (var i = 0; i < funcs.length; i++) (function(passfunc) { - jProto[passfunc] = function(index, func) { - var self = this; - // check for callback + // If a matrix is passed, automatically assume operation should be done on + // the columns. + jProto[passfunc] = function(fullbool, func) { + var arr = []; + var i = 0; + var tmpthis = this; + // Assignment reassignation depending on how parameters were passed in. + if (isFunction(fullbool)) { + func = fullbool; + fullbool = false; + } + // Check if a callback was passed with the function. if (func) { setTimeout(function() { - func.call(self, jProto[passfunc].call(self, index)); + func.call(tmpthis, jProto[passfunc].call(tmpthis, fullbool)); }); return this; } - return jStat(jStat[passfunc](this, index)); + // Check if matrix and run calculations. + if (this.length > 1) { + if (passfunc !== 'sumrow') + tmpthis = fullbool === true ? this : this.transpose(); + for (; i < tmpthis.length; i++) + arr[i] = jStat[passfunc](tmpthis[i]); + return fullbool === true + ? jStat[passfunc](jStat.utils.toVector(arr)) + : arr; + } + // Pass fullbool if only vector, not a matrix. for variance and stdev. + return jStat[passfunc](this[0], fullbool); }; })(funcs[i]); -})('row col'.split(' ')); +})(('sum sumsqrd sumsqerr sumrow product min max unique mean meansqerr ' + + 'geomean median diff rank mode range variance deviation stdev meandev ' + + 'meddev coeffvar quartiles histogram skewness kurtosis').split(' ')); -// Extend prototype with simple shortcut methods. +// Extend jProto with functions that take arguments. Operations on matrices are +// done on columns. (function(funcs) { for (var i = 0; i < funcs.length; i++) (function(passfunc) { - jProto[passfunc] = new Function( - 'return jStat(jStat.' + passfunc + '.apply(null, arguments));'); - })(funcs[i]); -})('create zeros ones rand identity'.split(' ')); - - -// Exposing jStat. -return jStat; + jProto[passfunc] = function() { + var arr = []; + var i = 0; + var tmpthis = this; + var args = Array.prototype.slice.call(arguments); -}(Math)); -(function(jStat, Math) { + // If the last argument is a function, we assume it's a callback; we + // strip the callback out and call the function again. + if (isFunction(args[args.length - 1])) { + var callbackFunction = args[args.length - 1]; + var argsToPass = args.slice(0, args.length - 1); -var isFunction = jStat.utils.isFunction; + setTimeout(function() { + callbackFunction.call(tmpthis, + jProto[passfunc].apply(tmpthis, argsToPass)); + }); + return this; -// Ascending functions for sort -function ascNum(a, b) { return a - b; } - -function clip(arg, min, max) { - return Math.max(min, Math.min(arg, max)); -} + // Otherwise we curry the function args and call normally. + } else { + var callbackFunction = undefined; + var curriedFunction = function curriedFunction(vector) { + return jStat[passfunc].apply(tmpthis, [vector].concat(args)); + } + } + // If this is a matrix, run column-by-column. + if (this.length > 1) { + tmpthis = tmpthis.transpose(); + for (; i < tmpthis.length; i++) + arr[i] = curriedFunction(tmpthis[i]); + return arr; + } -// sum of an array -jStat.sum = function sum(arr) { - var sum = 0; - var i = arr.length; - while (--i >= 0) - sum += arr[i]; - return sum; -}; + // Otherwise run on the vector. + return curriedFunction(this[0]); + }; + })(funcs[i]); +})('quantiles percentileOfScore'.split(' ')); +}(jStat, Math)); +// Special functions // +(function(jStat, Math) { -// sum squared -jStat.sumsqrd = function sumsqrd(arr) { - var sum = 0; - var i = arr.length; - while (--i >= 0) - sum += arr[i] * arr[i]; - return sum; +// Log-gamma function +jStat.gammaln = function gammaln(x) { + var j = 0; + var cof = [ + 76.18009172947146, -86.50532032941677, 24.01409824083091, + -1.231739572450155, 0.1208650973866179e-2, -0.5395239384953e-5 + ]; + var ser = 1.000000000190015; + var xx, y, tmp; + tmp = (y = xx = x) + 5.5; + tmp -= (xx + 0.5) * Math.log(tmp); + for (; j < 6; j++) + ser += cof[j] / ++y; + return Math.log(2.5066282746310005 * ser / xx) - tmp; }; -// sum of squared errors of prediction (SSE) -jStat.sumsqerr = function sumsqerr(arr) { - var mean = jStat.mean(arr); - var sum = 0; - var i = arr.length; - var tmp; - while (--i >= 0) { - tmp = arr[i] - mean; - sum += tmp * tmp; +// gamma of x +jStat.gammafn = function gammafn(x) { + var p = [-1.716185138865495, 24.76565080557592, -379.80425647094563, + 629.3311553128184, 866.9662027904133, -31451.272968848367, + -36144.413418691176, 66456.14382024054 + ]; + var q = [-30.8402300119739, 315.35062697960416, -1015.1563674902192, + -3107.771671572311, 22538.118420980151, 4755.8462775278811, + -134659.9598649693, -115132.2596755535]; + var fact = false; + var n = 0; + var xden = 0; + var xnum = 0; + var y = x; + var i, z, yi, res, sum, ysq; + if (y <= 0) { + res = y % 1 + 3.6e-16; + if (res) { + fact = (!(y & 1) ? 1 : -1) * Math.PI / Math.sin(Math.PI * res); + y = 1 - y; + } else { + return Infinity; + } } - return sum; -}; - -// sum of an array in each row -jStat.sumrow = function sumrow(arr) { - var sum = 0; - var i = arr.length; - while (--i >= 0) - sum += arr[i]; - return sum; -}; - -// product of an array -jStat.product = function product(arr) { - var prod = 1; - var i = arr.length; - while (--i >= 0) - prod *= arr[i]; - return prod; + yi = y; + if (y < 1) { + z = y++; + } else { + z = (y -= n = (y | 0) - 1) - 1; + } + for (var i = 0; i < 8; ++i) { + xnum = (xnum + p[i]) * z; + xden = xden * z + q[i]; + } + res = xnum / xden + 1; + if (yi < y) { + res /= yi; + } else if (yi > y) { + for (var i = 0; i < n; ++i) { + res *= y; + y++; + } + } + if (fact) { + res = fact / res; + } + return res; }; -// minimum value of an array -jStat.min = function min(arr) { - var low = arr[0]; - var i = 0; - while (++i < arr.length) - if (arr[i] < low) - low = arr[i]; - return low; +// lower incomplete gamma function, which is usually typeset with a +// lower-case greek gamma as the function symbol +jStat.gammap = function gammap(a, x) { + return jStat.lowRegGamma(a, x) * jStat.gammafn(a); }; -// maximum value of an array -jStat.max = function max(arr) { - var high = arr[0]; - var i = 0; - while (++i < arr.length) - if (arr[i] > high) - high = arr[i]; - return high; -}; - +// The lower regularized incomplete gamma function, usually written P(a,x) +jStat.lowRegGamma = function lowRegGamma(a, x) { + var aln = jStat.gammaln(a); + var ap = a; + var sum = 1 / a; + var del = sum; + var b = x + 1 - a; + var c = 1 / 1.0e-30; + var d = 1 / b; + var h = d; + var i = 1; + // calculate maximum number of itterations required for a + var ITMAX = -~(Math.log((a >= 1) ? a : 1 / a) * 8.5 + a * 0.4 + 17); + var an, endval; -// unique values of an array -jStat.unique = function unique(arr) { - var hash = {}, _arr = []; - for(var i = 0; i < arr.length; i++) { - if (!hash[arr[i]]) { - hash[arr[i]] = true; - _arr.push(arr[i]); + if (x < 0 || a <= 0) { + return NaN; + } else if (x < a + 1) { + for (; i <= ITMAX; i++) { + sum += del *= x / ++ap; } + return (sum * Math.exp(-x + a * Math.log(x) - (aln))); } - return _arr; -}; + for (; i <= ITMAX; i++) { + an = -i * (i - a); + b += 2; + d = an * d + b; + c = b + an / c; + d = 1 / d; + h *= d * c; + } -// mean value of an array -jStat.mean = function mean(arr) { - return jStat.sum(arr) / arr.length; + return (1 - h * Math.exp(-x + a * Math.log(x) - (aln))); }; - -// mean squared error (MSE) -jStat.meansqerr = function meansqerr(arr) { - return jStat.sumsqerr(arr) / arr.length; +// natural log factorial of n +jStat.factorialln = function factorialln(n) { + return n < 0 ? NaN : jStat.gammaln(n + 1); }; +// factorial of n +jStat.factorial = function factorial(n) { + return n < 0 ? NaN : jStat.gammafn(n + 1); +}; -// geometric mean of an array -jStat.geomean = function geomean(arr) { - return Math.pow(jStat.product(arr), 1 / arr.length); +// combinations of n, m +jStat.combination = function combination(n, m) { + // make sure n or m don't exceed the upper limit of usable values + return (n > 170 || m > 170) + ? Math.exp(jStat.combinationln(n, m)) + : (jStat.factorial(n) / jStat.factorial(m)) / jStat.factorial(n - m); }; -// median of an array -jStat.median = function median(arr) { - var arrlen = arr.length; - var _arr = arr.slice().sort(ascNum); - // check if array is even or odd, then return the appropriate - return !(arrlen & 1) - ? (_arr[(arrlen / 2) - 1 ] + _arr[(arrlen / 2)]) / 2 - : _arr[(arrlen / 2) | 0 ]; +jStat.combinationln = function combinationln(n, m){ + return jStat.factorialln(n) - jStat.factorialln(m) - jStat.factorialln(n - m); }; -// cumulative sum of an array -jStat.cumsum = function cumsum(arr) { - return jStat.cumreduce(arr, function (a, b) { return a + b; }); +// permutations of n, m +jStat.permutation = function permutation(n, m) { + return jStat.factorial(n) / jStat.factorial(n - m); }; -// cumulative product of an array -jStat.cumprod = function cumprod(arr) { - return jStat.cumreduce(arr, function (a, b) { return a * b; }); +// beta function +jStat.betafn = function betafn(x, y) { + // ensure arguments are positive + if (x <= 0 || y <= 0) + return undefined; + // make sure x + y doesn't exceed the upper limit of usable values + return (x + y > 170) + ? Math.exp(jStat.betaln(x, y)) + : jStat.gammafn(x) * jStat.gammafn(y) / jStat.gammafn(x + y); }; -// successive differences of a sequence -jStat.diff = function diff(arr) { - var diffs = []; - var arrLen = arr.length; - var i; - for (var i = 1; i < arrLen; i++) - diffs.push(arr[i] - arr[i - 1]); - return diffs; +// natural logarithm of beta function +jStat.betaln = function betaln(x, y) { + return jStat.gammaln(x) + jStat.gammaln(y) - jStat.gammaln(x + y); }; -// ranks of an array -jStat.rank = function (arr) { - var arrlen = arr.length; - var sorted = arr.slice().sort(ascNum); - var ranks = new Array(arrlen); - for (var i = 0; i < arrlen; i++) { - var first = sorted.indexOf(arr[i]); - var last = sorted.lastIndexOf(arr[i]); - if (first === last) { - var val = first; - } else { - var val = (first + last) / 2; - } - ranks[i] = val + 1; - } - return ranks; -}; - +// Evaluates the continued fraction for incomplete beta function by modified +// Lentz's method. +jStat.betacf = function betacf(x, a, b) { + var fpmin = 1e-30; + var m = 1; + var qab = a + b; + var qap = a + 1; + var qam = a - 1; + var c = 1; + var d = 1 - qab * x / qap; + var m2, aa, del, h; -// mode of an array -// if there are multiple modes of an array, return all of them -// is this the appropriate way of handling it? -jStat.mode = function mode(arr) { - var arrLen = arr.length; - var _arr = arr.slice().sort(ascNum); - var count = 1; - var maxCount = 0; - var numMaxCount = 0; - var mode_arr = []; - var i; + // These q's will be used in factors that occur in the coefficients + if (Math.abs(d) < fpmin) + d = fpmin; + d = 1 / d; + h = d; - for (var i = 0; i < arrLen; i++) { - if (_arr[i] === _arr[i + 1]) { - count++; - } else { - if (count > maxCount) { - mode_arr = [_arr[i]]; - maxCount = count; - numMaxCount = 0; - } - // are there multiple max counts - else if (count === maxCount) { - mode_arr.push(_arr[i]); - numMaxCount++; - } - // resetting count for new value in array - count = 1; - } + for (; m <= 100; m++) { + m2 = 2 * m; + aa = m * (b - m) * x / ((qam + m2) * (a + m2)); + // One step (the even one) of the recurrence + d = 1 + aa * d; + if (Math.abs(d) < fpmin) + d = fpmin; + c = 1 + aa / c; + if (Math.abs(c) < fpmin) + c = fpmin; + d = 1 / d; + h *= d * c; + aa = -(a + m) * (qab + m) * x / ((a + m2) * (qap + m2)); + // Next step of the recurrence (the odd one) + d = 1 + aa * d; + if (Math.abs(d) < fpmin) + d = fpmin; + c = 1 + aa / c; + if (Math.abs(c) < fpmin) + c = fpmin; + d = 1 / d; + del = d * c; + h *= del; + if (Math.abs(del - 1.0) < 3e-7) + break; } - return numMaxCount === 0 ? mode_arr[0] : mode_arr; + return h; }; -// range of an array -jStat.range = function range(arr) { - return jStat.max(arr) - jStat.min(arr); -}; +// Returns the inverse of the lower regularized inomplete gamma function +jStat.gammapinv = function gammapinv(p, a) { + var j = 0; + var a1 = a - 1; + var EPS = 1e-8; + var gln = jStat.gammaln(a); + var x, err, t, u, pp, lna1, afac; -// variance of an array -// flag = true indicates sample instead of population -jStat.variance = function variance(arr, flag) { - return jStat.sumsqerr(arr) / (arr.length - (flag ? 1 : 0)); -}; + if (p >= 1) + return Math.max(100, a + 100 * Math.sqrt(a)); + if (p <= 0) + return 0; + if (a > 1) { + lna1 = Math.log(a1); + afac = Math.exp(a1 * (lna1 - 1) - gln); + pp = (p < 0.5) ? p : 1 - p; + t = Math.sqrt(-2 * Math.log(pp)); + x = (2.30753 + t * 0.27061) / (1 + t * (0.99229 + t * 0.04481)) - t; + if (p < 0.5) + x = -x; + x = Math.max(1e-3, + a * Math.pow(1 - 1 / (9 * a) - x / (3 * Math.sqrt(a)), 3)); + } else { + t = 1 - a * (0.253 + a * 0.12); + if (p < t) + x = Math.pow(p / t, 1 / a); + else + x = 1 - Math.log(1 - (p - t) / (1 - t)); + } -// deviation of an array -jStat.deviation = function (arr) { - var mean = jStat.mean(arr); - var arrlen = arr.length; - var dev = new Array(arrlen); - for (var i = 0; i < arrlen; i++) { - dev[i] = arr[i] - mean; + for(; j < 12; j++) { + if (x <= 0) + return 0; + err = jStat.lowRegGamma(a, x) - p; + if (a > 1) + t = afac * Math.exp(-(x - a1) + a1 * (Math.log(x) - lna1)); + else + t = Math.exp(-x + a1 * Math.log(x) - gln); + u = err / t; + x -= (t = u / (1 - 0.5 * Math.min(1, u * ((a - 1) / x - 1)))); + if (x <= 0) + x = 0.5 * (x + t); + if (Math.abs(t) < EPS * x) + break; } - return dev; -}; -// standard deviation of an array -// flag = true indicates sample instead of population -jStat.stdev = function stdev(arr, flag) { - return Math.sqrt(jStat.variance(arr, flag)); + return x; }; -// mean deviation (mean absolute deviation) of an array -jStat.meandev = function meandev(arr) { - var devSum = 0; - var mean = jStat.mean(arr); - var i; - for (var i = arr.length - 1; i >= 0; i--) - devSum += Math.abs(arr[i] - mean); - return devSum / arr.length; -}; +// Returns the error function erf(x) +jStat.erf = function erf(x) { + var cof = [-1.3026537197817094, 6.4196979235649026e-1, 1.9476473204185836e-2, + -9.561514786808631e-3, -9.46595344482036e-4, 3.66839497852761e-4, + 4.2523324806907e-5, -2.0278578112534e-5, -1.624290004647e-6, + 1.303655835580e-6, 1.5626441722e-8, -8.5238095915e-8, + 6.529054439e-9, 5.059343495e-9, -9.91364156e-10, + -2.27365122e-10, 9.6467911e-11, 2.394038e-12, + -6.886027e-12, 8.94487e-13, 3.13092e-13, + -1.12708e-13, 3.81e-16, 7.106e-15, + -1.523e-15, -9.4e-17, 1.21e-16, + -2.8e-17]; + var j = cof.length - 1; + var isneg = false; + var d = 0; + var dd = 0; + var t, ty, tmp, res; + if (x < 0) { + x = -x; + isneg = true; + } -// median deviation (median absolute deviation) of an array -jStat.meddev = function meddev(arr) { - var devSum = 0; - var median = jStat.median(arr); - var i; - for (var i = arr.length - 1; i >= 0; i--) - devSum += Math.abs(arr[i] - median); - return devSum / arr.length; -}; + t = 2 / (2 + x); + ty = 4 * t - 2; + for(; j > 0; j--) { + tmp = d; + d = ty * d - dd + cof[j]; + dd = tmp; + } -// coefficient of variation -jStat.coeffvar = function coeffvar(arr) { - return jStat.stdev(arr) / jStat.mean(arr); + res = t * Math.exp(-x * x + 0.5 * (cof[0] + ty * d) - dd); + return isneg ? res - 1 : 1 - res; }; -// quartiles of an array -jStat.quartiles = function quartiles(arr) { - var arrlen = arr.length; - var _arr = arr.slice().sort(ascNum); - return [ - _arr[ Math.round((arrlen) / 4) - 1 ], - _arr[ Math.round((arrlen) / 2) - 1 ], - _arr[ Math.round((arrlen) * 3 / 4) - 1 ] - ]; +// Returns the complmentary error function erfc(x) +jStat.erfc = function erfc(x) { + return 1 - jStat.erf(x); }; -// Arbitary quantiles of an array. Direct port of the scipy.stats -// implementation by Pierre GF Gerard-Marchant. -jStat.quantiles = function quantiles(arr, quantilesArray, alphap, betap) { - var sortedArray = arr.slice().sort(ascNum); - var quantileVals = [quantilesArray.length]; - var n = arr.length; - var i, p, m, aleph, k, gamma; - - if (typeof alphap === 'undefined') - alphap = 3 / 8; - if (typeof betap === 'undefined') - betap = 3 / 8; - - for (var i = 0; i < quantilesArray.length; i++) { - p = quantilesArray[i]; - m = alphap + p * (1 - alphap - betap); - aleph = n * p + m; - k = Math.floor(clip(aleph, 1, n - 1)); - gamma = clip(aleph - k, 0, 1); - quantileVals[i] = (1 - gamma) * sortedArray[k - 1] + gamma * sortedArray[k]; +// Returns the inverse of the complementary error function +jStat.erfcinv = function erfcinv(p) { + var j = 0; + var x, err, t, pp; + if (p >= 2) + return -100; + if (p <= 0) + return 100; + pp = (p < 1) ? p : 2 - p; + t = Math.sqrt(-2 * Math.log(pp / 2)); + x = -0.70711 * ((2.30753 + t * 0.27061) / + (1 + t * (0.99229 + t * 0.04481)) - t); + for (; j < 2; j++) { + err = jStat.erfc(x) - pp; + x += err / (1.12837916709551257 * Math.exp(-x * x) - x * err); } - - return quantileVals; + return (p < 1) ? x : -x; }; -// Returns the k-th percentile of values in a range, where k is in the -// range 0..1, exclusive. -jStat.percentile = function percentile(arr, k) { - var _arr = arr.slice().sort(ascNum); - var realIndex = k * (_arr.length - 1); - var index = parseInt(realIndex); - var frac = realIndex - index; - - if (index + 1 < _arr.length) { - return _arr[index] * (1 - frac) + _arr[index + 1] * frac; - } else { - return _arr[index]; - } -} - -// The percentile rank of score in a given array. Returns the percentage -// of all values in the input array that are less than (kind='strict') or -// less or equal than (kind='weak') score. Default is weak. -jStat.percentileOfScore = function percentileOfScore(arr, score, kind) { - var counter = 0; - var len = arr.length; - var strict = false; - var value, i; - - if (kind === 'strict') - strict = true; - - for (var i = 0; i < len; i++) { - value = arr[i]; - if ((strict && value < score) || - (!strict && value <= score)) { - counter++; - } +// Returns the inverse of the incomplete beta function +jStat.ibetainv = function ibetainv(p, a, b) { + var EPS = 1e-8; + var a1 = a - 1; + var b1 = b - 1; + var j = 0; + var lna, lnb, pp, t, u, err, x, al, h, w, afac; + if (p <= 0) + return 0; + if (p >= 1) + return 1; + if (a >= 1 && b >= 1) { + pp = (p < 0.5) ? p : 1 - p; + t = Math.sqrt(-2 * Math.log(pp)); + x = (2.30753 + t * 0.27061) / (1 + t* (0.99229 + t * 0.04481)) - t; + if (p < 0.5) + x = -x; + al = (x * x - 3) / 6; + h = 2 / (1 / (2 * a - 1) + 1 / (2 * b - 1)); + w = (x * Math.sqrt(al + h) / h) - (1 / (2 * b - 1) - 1 / (2 * a - 1)) * + (al + 5 / 6 - 2 / (3 * h)); + x = a / (a + b * Math.exp(2 * w)); + } else { + lna = Math.log(a / (a + b)); + lnb = Math.log(b / (a + b)); + t = Math.exp(a * lna) / a; + u = Math.exp(b * lnb) / b; + w = t + u; + if (p < t / w) + x = Math.pow(a * w * p, 1 / a); + else + x = 1 - Math.pow(b * w * (1 - p), 1 / b); } - - return counter / len; -}; - - -// Histogram (bin count) data -jStat.histogram = function histogram(arr, bins) { - var first = jStat.min(arr); - var binCnt = bins || 4; - var binWidth = (jStat.max(arr) - first) / binCnt; - var len = arr.length; - var bins = []; - var i; - - for (var i = 0; i < binCnt; i++) - bins[i] = 0; - for (var i = 0; i < len; i++) - bins[Math.min(Math.floor(((arr[i] - first) / binWidth)), binCnt - 1)] += 1; - - return bins; -}; - - -// covariance of two arrays -jStat.covariance = function covariance(arr1, arr2) { - var u = jStat.mean(arr1); - var v = jStat.mean(arr2); - var arr1Len = arr1.length; - var sq_dev = new Array(arr1Len); - var i; - - for (var i = 0; i < arr1Len; i++) - sq_dev[i] = (arr1[i] - u) * (arr2[i] - v); - - return jStat.sum(sq_dev) / (arr1Len - 1); + afac = -jStat.gammaln(a) - jStat.gammaln(b) + jStat.gammaln(a + b); + for(; j < 10; j++) { + if (x === 0 || x === 1) + return x; + err = jStat.ibeta(x, a, b) - p; + t = Math.exp(a1 * Math.log(x) + b1 * Math.log(1 - x) + afac); + u = err / t; + x -= (t = u / (1 - 0.5 * Math.min(1, u * (a1 / x - b1 / (1 - x))))); + if (x <= 0) + x = 0.5 * (x + t); + if (x >= 1) + x = 0.5 * (x + t + 1); + if (Math.abs(t) < EPS * x && j > 0) + break; + } + return x; }; -// (pearson's) population correlation coefficient, rho -jStat.corrcoeff = function corrcoeff(arr1, arr2) { - return jStat.covariance(arr1, arr2) / - jStat.stdev(arr1, 1) / - jStat.stdev(arr2, 1); +// Returns the incomplete beta function I_x(a,b) +jStat.ibeta = function ibeta(x, a, b) { + // Factors in front of the continued fraction. + var bt = (x === 0 || x === 1) ? 0 : + Math.exp(jStat.gammaln(a + b) - jStat.gammaln(a) - + jStat.gammaln(b) + a * Math.log(x) + b * + Math.log(1 - x)); + if (x < 0 || x > 1) + return false; + if (x < (a + 1) / (a + b + 2)) + // Use continued fraction directly. + return bt * jStat.betacf(x, a, b) / a; + // else use continued fraction after making the symmetry transformation. + return 1 - bt * jStat.betacf(1 - x, b, a) / b; }; - // (spearman's) rank correlation coefficient, sp -jStat.spearmancoeff = function (arr1, arr2) { - arr1 = jStat.rank(arr1); - arr2 = jStat.rank(arr2); - var arr1dev = jStat.deviation(arr1); - var arr2dev = jStat.deviation(arr2); - return jStat.sum(arr1dev.map(function (x, i) { - return x * arr2dev[i]; - })) / - Math.sqrt(jStat.sum(arr1dev.map(function (x) { - return Math.pow(x, 2); - })) * jStat.sum(arr2dev.map(function (x) { - return Math.pow(x, 2); - })) - ); -} - - -// statistical standardized moments (general form of skew/kurt) -jStat.stanMoment = function stanMoment(arr, n) { - var mu = jStat.mean(arr); - var sigma = jStat.stdev(arr); - var len = arr.length; - var skewSum = 0; - - for (var i = 0; i < len; i++) - skewSum += Math.pow((arr[i] - mu) / sigma, n); - return skewSum / arr.length; +// Returns a normal deviate (mu=0, sigma=1). +// If n and m are specified it returns a object of normal deviates. +jStat.randn = function randn(n, m) { + var u, v, x, y, q, mat; + if (!m) + m = n; + if (n) + return jStat.create(n, m, function() { return jStat.randn(); }); + do { + u = Math.random(); + v = 1.7156 * (Math.random() - 0.5); + x = u - 0.449871; + y = Math.abs(v) + 0.386595; + q = x * x + y * (0.19600 * y - 0.25472 * x); + } while (q > 0.27597 && (q > 0.27846 || v * v > -4 * Math.log(u) * u * u)); + return v / u; }; -// (pearson's) moment coefficient of skewness -jStat.skewness = function skewness(arr) { - return jStat.stanMoment(arr, 3); -}; -// (pearson's) (excess) kurtosis -jStat.kurtosis = function kurtosis(arr) { - return jStat.stanMoment(arr, 4) - 3; +// Returns a gamma deviate by the method of Marsaglia and Tsang. +jStat.randg = function randg(shape, n, m) { + var oalph = shape; + var a1, a2, u, v, x, mat; + if (!m) + m = n; + if (!shape) + shape = 1; + if (n) { + mat = jStat.zeros(n,m); + mat.alter(function() { return jStat.randg(shape); }); + return mat; + } + if (shape < 1) + shape += 1; + a1 = shape - 1 / 3; + a2 = 1 / Math.sqrt(9 * a1); + do { + do { + x = jStat.randn(); + v = 1 + a2 * x; + } while(v <= 0); + v = v * v * v; + u = Math.random(); + } while(u > 1 - 0.331 * Math.pow(x, 4) && + Math.log(u) > 0.5 * x*x + a1 * (1 - v + Math.log(v))); + // alpha > 1 + if (shape == oalph) + return a1 * v; + // alpha < 1 + do { + u = Math.random(); + } while(u === 0); + return Math.pow(u, 1 / oalph) * a1 * v; }; -var jProto = jStat.prototype; +// making use of static methods on the instance +(function(funcs) { + for (var i = 0; i < funcs.length; i++) (function(passfunc) { + jStat.fn[passfunc] = function() { + return jStat( + jStat.map(this, function(value) { return jStat[passfunc](value); })); + } + })(funcs[i]); +})('gammaln gammafn factorial factorialln'.split(' ')); -// Extend jProto with method for calculating cumulative sums and products. -// This differs from the similar extension below as cumsum and cumprod should -// not be run again in the case fullbool === true. -// If a matrix is passed, automatically assume operation should be done on the -// columns. (function(funcs) { for (var i = 0; i < funcs.length; i++) (function(passfunc) { - // If a matrix is passed, automatically assume operation should be done on - // the columns. - jProto[passfunc] = function(fullbool, func) { - var arr = []; - var i = 0; - var tmpthis = this; - // Assignment reassignation depending on how parameters were passed in. - if (isFunction(fullbool)) { - func = fullbool; - fullbool = false; - } - // Check if a callback was passed with the function. - if (func) { - setTimeout(function() { - func.call(tmpthis, jProto[passfunc].call(tmpthis, fullbool)); - }); - return this; - } - // Check if matrix and run calculations. - if (this.length > 1) { - tmpthis = fullbool === true ? this : this.transpose(); - for (; i < tmpthis.length; i++) - arr[i] = jStat[passfunc](tmpthis[i]); - return arr; - } - // Pass fullbool if only vector, not a matrix. for variance and stdev. - return jStat[passfunc](this[0], fullbool); + jStat.fn[passfunc] = function() { + return jStat(jStat[passfunc].apply(null, arguments)); }; })(funcs[i]); -})(('cumsum cumprod').split(' ')); +})('randn'.split(' ')); +}(jStat, Math)); +(function(jStat, Math) { -// Extend jProto with methods which don't require arguments and work on columns. -(function(funcs) { - for (var i = 0; i < funcs.length; i++) (function(passfunc) { - // If a matrix is passed, automatically assume operation should be done on - // the columns. - jProto[passfunc] = function(fullbool, func) { - var arr = []; - var i = 0; - var tmpthis = this; - // Assignment reassignation depending on how parameters were passed in. - if (isFunction(fullbool)) { - func = fullbool; - fullbool = false; - } - // Check if a callback was passed with the function. - if (func) { - setTimeout(function() { - func.call(tmpthis, jProto[passfunc].call(tmpthis, fullbool)); - }); - return this; - } - // Check if matrix and run calculations. - if (this.length > 1) { - if (passfunc !== 'sumrow') - tmpthis = fullbool === true ? this : this.transpose(); - for (; i < tmpthis.length; i++) - arr[i] = jStat[passfunc](tmpthis[i]); - return fullbool === true - ? jStat[passfunc](jStat.utils.toVector(arr)) - : arr; - } - // Pass fullbool if only vector, not a matrix. for variance and stdev. - return jStat[passfunc](this[0], fullbool); +// generate all distribution instance methods +(function(list) { + for (var i = 0; i < list.length; i++) (function(func) { + // distribution instance method + jStat[func] = function(a, b, c) { + if (!(this instanceof arguments.callee)) + return new arguments.callee(a, b, c); + this._a = a; + this._b = b; + this._c = c; + return this; }; - })(funcs[i]); -})(('sum sumsqrd sumsqerr sumrow product min max unique mean meansqerr ' + - 'geomean median diff rank mode range variance deviation stdev meandev ' + - 'meddev coeffvar quartiles histogram skewness kurtosis').split(' ')); + // distribution method to be used on a jStat instance + jStat.fn[func] = function(a, b, c) { + var newthis = jStat[func](a, b, c); + newthis.data = this; + return newthis; + }; + // sample instance method + jStat[func].prototype.sample = function(arr) { + var a = this._a; + var b = this._b; + var c = this._c; + if (arr) + return jStat.alter(arr, function() { + return jStat[func].sample(a, b, c); + }); + else + return jStat[func].sample(a, b, c); + }; + // generate the pdf, cdf and inv instance methods + (function(vals) { + for (var i = 0; i < vals.length; i++) (function(fnfunc) { + jStat[func].prototype[fnfunc] = function(x) { + var a = this._a; + var b = this._b; + var c = this._c; + if (!x && x !== 0) + x = this.data; + if (typeof x !== 'number') { + return jStat.fn.map.call(x, function(x) { + return jStat[func][fnfunc](x, a, b, c); + }); + } + return jStat[func][fnfunc](x, a, b, c); + }; + })(vals[i]); + })('pdf cdf inv'.split(' ')); + // generate the mean, median, mode and variance instance methods + (function(vals) { + for (var i = 0; i < vals.length; i++) (function(fnfunc) { + jStat[func].prototype[fnfunc] = function() { + return jStat[func][fnfunc](this._a, this._b, this._c); + }; + })(vals[i]); + })('mean median mode variance'.split(' ')); + })(list[i]); +})(( + 'beta centralF cauchy chisquare exponential gamma invgamma kumaraswamy ' + + 'laplace lognormal noncentralt normal pareto studentt weibull uniform ' + + 'binomial negbin hypgeom poisson triangular tukey arcsine' +).split(' ')); -// Extend jProto with functions that take arguments. Operations on matrices are -// done on columns. -(function(funcs) { - for (var i = 0; i < funcs.length; i++) (function(passfunc) { - jProto[passfunc] = function() { - var arr = []; - var i = 0; - var tmpthis = this; - var args = Array.prototype.slice.call(arguments); - // If the last argument is a function, we assume it's a callback; we - // strip the callback out and call the function again. - if (isFunction(args[args.length - 1])) { - var callbackFunction = args[args.length - 1]; - var argsToPass = args.slice(0, args.length - 1); +// extend beta function with static methods +jStat.extend(jStat.beta, { + pdf: function pdf(x, alpha, beta) { + // PDF is zero outside the support + if (x > 1 || x < 0) + return 0; + // PDF is one for the uniform case + if (alpha == 1 && beta == 1) + return 1; - setTimeout(function() { - callbackFunction.call(tmpthis, - jProto[passfunc].apply(tmpthis, argsToPass)); - }); - return this; + if (alpha < 512 && beta < 512) { + return (Math.pow(x, alpha - 1) * Math.pow(1 - x, beta - 1)) / + jStat.betafn(alpha, beta); + } else { + return Math.exp((alpha - 1) * Math.log(x) + + (beta - 1) * Math.log(1 - x) - + jStat.betaln(alpha, beta)); + } + }, - // Otherwise we curry the function args and call normally. - } else { - var callbackFunction = undefined; - var curriedFunction = function curriedFunction(vector) { - return jStat[passfunc].apply(tmpthis, [vector].concat(args)); - } - } + cdf: function cdf(x, alpha, beta) { + return (x > 1 || x < 0) ? (x > 1) * 1 : jStat.ibeta(x, alpha, beta); + }, - // If this is a matrix, run column-by-column. - if (this.length > 1) { - tmpthis = tmpthis.transpose(); - for (; i < tmpthis.length; i++) - arr[i] = curriedFunction(tmpthis[i]); - return arr; - } + inv: function inv(x, alpha, beta) { + return jStat.ibetainv(x, alpha, beta); + }, - // Otherwise run on the vector. - return curriedFunction(this[0]); - }; - })(funcs[i]); -})('quantiles percentileOfScore'.split(' ')); + mean: function mean(alpha, beta) { + return alpha / (alpha + beta); + }, -}(this.jStat, Math)); -// Special functions // -(function(jStat, Math) { + median: function median(alpha, beta) { + return jStat.ibetainv(0.5, alpha, beta); + }, -// Log-gamma function -jStat.gammaln = function gammaln(x) { - var j = 0; - var cof = [ - 76.18009172947146, -86.50532032941677, 24.01409824083091, - -1.231739572450155, 0.1208650973866179e-2, -0.5395239384953e-5 - ]; - var ser = 1.000000000190015; - var xx, y, tmp; - tmp = (y = xx = x) + 5.5; - tmp -= (xx + 0.5) * Math.log(tmp); - for (; j < 6; j++) - ser += cof[j] / ++y; - return Math.log(2.5066282746310005 * ser / xx) - tmp; -}; + mode: function mode(alpha, beta) { + return (alpha - 1 ) / ( alpha + beta - 2); + }, + // return a random sample + sample: function sample(alpha, beta) { + var u = jStat.randg(alpha); + return u / (u + jStat.randg(beta)); + }, -// gamma of x -jStat.gammafn = function gammafn(x) { - var p = [-1.716185138865495, 24.76565080557592, -379.80425647094563, - 629.3311553128184, 866.9662027904133, -31451.272968848367, - -36144.413418691176, 66456.14382024054 - ]; - var q = [-30.8402300119739, 315.35062697960416, -1015.1563674902192, - -3107.771671572311, 22538.118420980151, 4755.8462775278811, - -134659.9598649693, -115132.2596755535]; - var fact = false; - var n = 0; - var xden = 0; - var xnum = 0; - var y = x; - var i, z, yi, res, sum, ysq; - if (y <= 0) { - res = y % 1 + 3.6e-16; - if (res) { - fact = (!(y & 1) ? 1 : -1) * Math.PI / Math.sin(Math.PI * res); - y = 1 - y; - } else { - return Infinity; - } - } - yi = y; - if (y < 1) { - z = y++; - } else { - z = (y -= n = (y | 0) - 1) - 1; - } - for (var i = 0; i < 8; ++i) { - xnum = (xnum + p[i]) * z; - xden = xden * z + q[i]; + variance: function variance(alpha, beta) { + return (alpha * beta) / (Math.pow(alpha + beta, 2) * (alpha + beta + 1)); } - res = xnum / xden + 1; - if (yi < y) { - res /= yi; - } else if (yi > y) { - for (var i = 0; i < n; ++i) { - res *= y; - y++; +}); + +// extend F function with static methods +jStat.extend(jStat.centralF, { + // This implementation of the pdf function avoids float overflow + // See the way that R calculates this value: + // https://svn.r-project.org/R/trunk/src/nmath/df.c + pdf: function pdf(x, df1, df2) { + var p, q, f; + + if (x < 0) + return 0; + + if (df1 <= 2) { + if (x === 0 && df1 < 2) { + return Infinity; + } + if (x === 0 && df1 === 2) { + return 1; + } + return (1 / jStat.betafn(df1 / 2, df2 / 2)) * + Math.pow(df1 / df2, df1 / 2) * + Math.pow(x, (df1/2) - 1) * + Math.pow((1 + (df1 / df2) * x), -(df1 + df2) / 2); } - } - if (fact) { - res = fact / res; - } - return res; -}; + p = (df1 * x) / (df2 + x * df1); + q = df2 / (df2 + x * df1); + f = df1 * q / 2.0; + return f * jStat.binomial.pdf((df1 - 2) / 2, (df1 + df2 - 2) / 2, p); + }, -// lower incomplete gamma function, which is usually typeset with a -// lower-case greek gamma as the function symbol -jStat.gammap = function gammap(a, x) { - return jStat.lowRegGamma(a, x) * jStat.gammafn(a); -}; + cdf: function cdf(x, df1, df2) { + if (x < 0) + return 0; + return jStat.ibeta((df1 * x) / (df1 * x + df2), df1 / 2, df2 / 2); + }, + inv: function inv(x, df1, df2) { + return df2 / (df1 * (1 / jStat.ibetainv(x, df1 / 2, df2 / 2) - 1)); + }, -// The lower regularized incomplete gamma function, usually written P(a,x) -jStat.lowRegGamma = function lowRegGamma(a, x) { - var aln = jStat.gammaln(a); - var ap = a; - var sum = 1 / a; - var del = sum; - var b = x + 1 - a; - var c = 1 / 1.0e-30; - var d = 1 / b; - var h = d; - var i = 1; - // calculate maximum number of itterations required for a - var ITMAX = -~(Math.log((a >= 1) ? a : 1 / a) * 8.5 + a * 0.4 + 17); - var an, endval; + mean: function mean(df1, df2) { + return (df2 > 2) ? df2 / (df2 - 2) : undefined; + }, - if (x < 0 || a <= 0) { - return NaN; - } else if (x < a + 1) { - for (; i <= ITMAX; i++) { - sum += del *= x / ++ap; - } - return (sum * Math.exp(-x + a * Math.log(x) - (aln))); - } + mode: function mode(df1, df2) { + return (df1 > 2) ? (df2 * (df1 - 2)) / (df1 * (df2 + 2)) : undefined; + }, - for (; i <= ITMAX; i++) { - an = -i * (i - a); - b += 2; - d = an * d + b; - c = b + an / c; - d = 1 / d; - h *= d * c; + // return a random sample + sample: function sample(df1, df2) { + var x1 = jStat.randg(df1 / 2) * 2; + var x2 = jStat.randg(df2 / 2) * 2; + return (x1 / df1) / (x2 / df2); + }, + + variance: function variance(df1, df2) { + if (df2 <= 4) + return undefined; + return 2 * df2 * df2 * (df1 + df2 - 2) / + (df1 * (df2 - 2) * (df2 - 2) * (df2 - 4)); } +}); - return (1 - h * Math.exp(-x + a * Math.log(x) - (aln))); -}; -// natural log factorial of n -jStat.factorialln = function factorialln(n) { - return n < 0 ? NaN : jStat.gammaln(n + 1); -}; +// extend cauchy function with static methods +jStat.extend(jStat.cauchy, { + pdf: function pdf(x, local, scale) { + if (scale < 0) { return 0; } -// factorial of n -jStat.factorial = function factorial(n) { - return n < 0 ? NaN : jStat.gammafn(n + 1); -}; + return (scale / (Math.pow(x - local, 2) + Math.pow(scale, 2))) / Math.PI; + }, -// combinations of n, m -jStat.combination = function combination(n, m) { - // make sure n or m don't exceed the upper limit of usable values - return (n > 170 || m > 170) - ? Math.exp(jStat.combinationln(n, m)) - : (jStat.factorial(n) / jStat.factorial(m)) / jStat.factorial(n - m); -}; + cdf: function cdf(x, local, scale) { + return Math.atan((x - local) / scale) / Math.PI + 0.5; + }, + inv: function(p, local, scale) { + return local + scale * Math.tan(Math.PI * (p - 0.5)); + }, -jStat.combinationln = function combinationln(n, m){ - return jStat.factorialln(n) - jStat.factorialln(m) - jStat.factorialln(n - m); -}; + median: function median(local, scale) { + return local; + }, + mode: function mode(local, scale) { + return local; + }, -// permutations of n, m -jStat.permutation = function permutation(n, m) { - return jStat.factorial(n) / jStat.factorial(n - m); -}; + sample: function sample(local, scale) { + return jStat.randn() * + Math.sqrt(1 / (2 * jStat.randg(0.5))) * scale + local; + } +}); -// beta function -jStat.betafn = function betafn(x, y) { - // ensure arguments are positive - if (x <= 0 || y <= 0) - return undefined; - // make sure x + y doesn't exceed the upper limit of usable values - return (x + y > 170) - ? Math.exp(jStat.betaln(x, y)) - : jStat.gammafn(x) * jStat.gammafn(y) / jStat.gammafn(x + y); -}; +// extend chisquare function with static methods +jStat.extend(jStat.chisquare, { + pdf: function pdf(x, dof) { + if (x < 0) + return 0; + return (x === 0 && dof === 2) ? 0.5 : + Math.exp((dof / 2 - 1) * Math.log(x) - x / 2 - (dof / 2) * + Math.log(2) - jStat.gammaln(dof / 2)); + }, -// natural logarithm of beta function -jStat.betaln = function betaln(x, y) { - return jStat.gammaln(x) + jStat.gammaln(y) - jStat.gammaln(x + y); -}; + cdf: function cdf(x, dof) { + if (x < 0) + return 0; + return jStat.lowRegGamma(dof / 2, x / 2); + }, + inv: function(p, dof) { + return 2 * jStat.gammapinv(p, 0.5 * dof); + }, -// Evaluates the continued fraction for incomplete beta function by modified -// Lentz's method. -jStat.betacf = function betacf(x, a, b) { - var fpmin = 1e-30; - var m = 1; - var qab = a + b; - var qap = a + 1; - var qam = a - 1; - var c = 1; - var d = 1 - qab * x / qap; - var m2, aa, del, h; + mean : function(dof) { + return dof; + }, - // These q's will be used in factors that occur in the coefficients - if (Math.abs(d) < fpmin) - d = fpmin; - d = 1 / d; - h = d; + // TODO: this is an approximation (is there a better way?) + median: function median(dof) { + return dof * Math.pow(1 - (2 / (9 * dof)), 3); + }, - for (; m <= 100; m++) { - m2 = 2 * m; - aa = m * (b - m) * x / ((qam + m2) * (a + m2)); - // One step (the even one) of the recurrence - d = 1 + aa * d; - if (Math.abs(d) < fpmin) - d = fpmin; - c = 1 + aa / c; - if (Math.abs(c) < fpmin) - c = fpmin; - d = 1 / d; - h *= d * c; - aa = -(a + m) * (qab + m) * x / ((a + m2) * (qap + m2)); - // Next step of the recurrence (the odd one) - d = 1 + aa * d; - if (Math.abs(d) < fpmin) - d = fpmin; - c = 1 + aa / c; - if (Math.abs(c) < fpmin) - c = fpmin; - d = 1 / d; - del = d * c; - h *= del; - if (Math.abs(del - 1.0) < 3e-7) - break; + mode: function mode(dof) { + return (dof - 2 > 0) ? dof - 2 : 0; + }, + + sample: function sample(dof) { + return jStat.randg(dof / 2) * 2; + }, + + variance: function variance(dof) { + return 2 * dof; } +}); - return h; -}; -// Returns the inverse of the lower regularized inomplete gamma function -jStat.gammapinv = function gammapinv(p, a) { - var j = 0; - var a1 = a - 1; - var EPS = 1e-8; - var gln = jStat.gammaln(a); - var x, err, t, u, pp, lna1, afac; +// extend exponential function with static methods +jStat.extend(jStat.exponential, { + pdf: function pdf(x, rate) { + return x < 0 ? 0 : rate * Math.exp(-rate * x); + }, - if (p >= 1) - return Math.max(100, a + 100 * Math.sqrt(a)); - if (p <= 0) - return 0; - if (a > 1) { - lna1 = Math.log(a1); - afac = Math.exp(a1 * (lna1 - 1) - gln); - pp = (p < 0.5) ? p : 1 - p; - t = Math.sqrt(-2 * Math.log(pp)); - x = (2.30753 + t * 0.27061) / (1 + t * (0.99229 + t * 0.04481)) - t; - if (p < 0.5) - x = -x; - x = Math.max(1e-3, - a * Math.pow(1 - 1 / (9 * a) - x / (3 * Math.sqrt(a)), 3)); - } else { - t = 1 - a * (0.253 + a * 0.12); - if (p < t) - x = Math.pow(p / t, 1 / a); - else - x = 1 - Math.log(1 - (p - t) / (1 - t)); - } + cdf: function cdf(x, rate) { + return x < 0 ? 0 : 1 - Math.exp(-rate * x); + }, - for(; j < 12; j++) { - if (x <= 0) - return 0; - err = jStat.lowRegGamma(a, x) - p; - if (a > 1) - t = afac * Math.exp(-(x - a1) + a1 * (Math.log(x) - lna1)); - else - t = Math.exp(-x + a1 * Math.log(x) - gln); - u = err / t; - x -= (t = u / (1 - 0.5 * Math.min(1, u * ((a - 1) / x - 1)))); - if (x <= 0) - x = 0.5 * (x + t); - if (Math.abs(t) < EPS * x) - break; - } + inv: function(p, rate) { + return -Math.log(1 - p) / rate; + }, - return x; -}; + mean : function(rate) { + return 1 / rate; + }, + median: function (rate) { + return (1 / rate) * Math.log(2); + }, -// Returns the error function erf(x) -jStat.erf = function erf(x) { - var cof = [-1.3026537197817094, 6.4196979235649026e-1, 1.9476473204185836e-2, - -9.561514786808631e-3, -9.46595344482036e-4, 3.66839497852761e-4, - 4.2523324806907e-5, -2.0278578112534e-5, -1.624290004647e-6, - 1.303655835580e-6, 1.5626441722e-8, -8.5238095915e-8, - 6.529054439e-9, 5.059343495e-9, -9.91364156e-10, - -2.27365122e-10, 9.6467911e-11, 2.394038e-12, - -6.886027e-12, 8.94487e-13, 3.13092e-13, - -1.12708e-13, 3.81e-16, 7.106e-15, - -1.523e-15, -9.4e-17, 1.21e-16, - -2.8e-17]; - var j = cof.length - 1; - var isneg = false; - var d = 0; - var dd = 0; - var t, ty, tmp, res; + mode: function mode(rate) { + return 0; + }, - if (x < 0) { - x = -x; - isneg = true; + sample: function sample(rate) { + return -1 / rate * Math.log(Math.random()); + }, + + variance : function(rate) { + return Math.pow(rate, -2); } +}); - t = 2 / (2 + x); - ty = 4 * t - 2; - for(; j > 0; j--) { - tmp = d; - d = ty * d - dd + cof[j]; - dd = tmp; - } - res = t * Math.exp(-x * x + 0.5 * (cof[0] + ty * d) - dd); - return isneg ? res - 1 : 1 - res; -}; +// extend gamma function with static methods +jStat.extend(jStat.gamma, { + pdf: function pdf(x, shape, scale) { + if (x < 0) + return 0; + return (x === 0 && shape === 1) ? 1 / scale : + Math.exp((shape - 1) * Math.log(x) - x / scale - + jStat.gammaln(shape) - shape * Math.log(scale)); + }, + cdf: function cdf(x, shape, scale) { + if (x < 0) + return 0; + return jStat.lowRegGamma(shape, x / scale); + }, -// Returns the complmentary error function erfc(x) -jStat.erfc = function erfc(x) { - return 1 - jStat.erf(x); -}; + inv: function(p, shape, scale) { + return jStat.gammapinv(p, shape) * scale; + }, + mean : function(shape, scale) { + return shape * scale; + }, -// Returns the inverse of the complementary error function -jStat.erfcinv = function erfcinv(p) { - var j = 0; - var x, err, t, pp; - if (p >= 2) - return -100; - if (p <= 0) - return 100; - pp = (p < 1) ? p : 2 - p; - t = Math.sqrt(-2 * Math.log(pp / 2)); - x = -0.70711 * ((2.30753 + t * 0.27061) / - (1 + t * (0.99229 + t * 0.04481)) - t); - for (; j < 2; j++) { - err = jStat.erfc(x) - pp; - x += err / (1.12837916709551257 * Math.exp(-x * x) - x * err); - } - return (p < 1) ? x : -x; -}; + mode: function mode(shape, scale) { + if(shape > 1) return (shape - 1) * scale; + return undefined; + }, + sample: function sample(shape, scale) { + return jStat.randg(shape) * scale; + }, -// Returns the inverse of the incomplete beta function -jStat.ibetainv = function ibetainv(p, a, b) { - var EPS = 1e-8; - var a1 = a - 1; - var b1 = b - 1; - var j = 0; - var lna, lnb, pp, t, u, err, x, al, h, w, afac; - if (p <= 0) - return 0; - if (p >= 1) - return 1; - if (a >= 1 && b >= 1) { - pp = (p < 0.5) ? p : 1 - p; - t = Math.sqrt(-2 * Math.log(pp)); - x = (2.30753 + t * 0.27061) / (1 + t* (0.99229 + t * 0.04481)) - t; - if (p < 0.5) - x = -x; - al = (x * x - 3) / 6; - h = 2 / (1 / (2 * a - 1) + 1 / (2 * b - 1)); - w = (x * Math.sqrt(al + h) / h) - (1 / (2 * b - 1) - 1 / (2 * a - 1)) * - (al + 5 / 6 - 2 / (3 * h)); - x = a / (a + b * Math.exp(2 * w)); - } else { - lna = Math.log(a / (a + b)); - lnb = Math.log(b / (a + b)); - t = Math.exp(a * lna) / a; - u = Math.exp(b * lnb) / b; - w = t + u; - if (p < t / w) - x = Math.pow(a * w * p, 1 / a); - else - x = 1 - Math.pow(b * w * (1 - p), 1 / b); + variance: function variance(shape, scale) { + return shape * scale * scale; } - afac = -jStat.gammaln(a) - jStat.gammaln(b) + jStat.gammaln(a + b); - for(; j < 10; j++) { - if (x === 0 || x === 1) - return x; - err = jStat.ibeta(x, a, b) - p; - t = Math.exp(a1 * Math.log(x) + b1 * Math.log(1 - x) + afac); - u = err / t; - x -= (t = u / (1 - 0.5 * Math.min(1, u * (a1 / x - b1 / (1 - x))))); +}); + +// extend inverse gamma function with static methods +jStat.extend(jStat.invgamma, { + pdf: function pdf(x, shape, scale) { if (x <= 0) - x = 0.5 * (x + t); - if (x >= 1) - x = 0.5 * (x + t + 1); - if (Math.abs(t) < EPS * x && j > 0) - break; - } - return x; -}; + return 0; + return Math.exp(-(shape + 1) * Math.log(x) - scale / x - + jStat.gammaln(shape) + shape * Math.log(scale)); + }, + cdf: function cdf(x, shape, scale) { + if (x <= 0) + return 0; + return 1 - jStat.lowRegGamma(shape, scale / x); + }, -// Returns the incomplete beta function I_x(a,b) -jStat.ibeta = function ibeta(x, a, b) { - // Factors in front of the continued fraction. - var bt = (x === 0 || x === 1) ? 0 : - Math.exp(jStat.gammaln(a + b) - jStat.gammaln(a) - - jStat.gammaln(b) + a * Math.log(x) + b * - Math.log(1 - x)); - if (x < 0 || x > 1) - return false; - if (x < (a + 1) / (a + b + 2)) - // Use continued fraction directly. - return bt * jStat.betacf(x, a, b) / a; - // else use continued fraction after making the symmetry transformation. - return 1 - bt * jStat.betacf(1 - x, b, a) / b; -}; + inv: function(p, shape, scale) { + return scale / jStat.gammapinv(1 - p, shape); + }, + mean : function(shape, scale) { + return (shape > 1) ? scale / (shape - 1) : undefined; + }, -// Returns a normal deviate (mu=0, sigma=1). -// If n and m are specified it returns a object of normal deviates. -jStat.randn = function randn(n, m) { - var u, v, x, y, q, mat; - if (!m) - m = n; - if (n) - return jStat.create(n, m, function() { return jStat.randn(); }); - do { - u = Math.random(); - v = 1.7156 * (Math.random() - 0.5); - x = u - 0.449871; - y = Math.abs(v) + 0.386595; - q = x * x + y * (0.19600 * y - 0.25472 * x); - } while (q > 0.27597 && (q > 0.27846 || v * v > -4 * Math.log(u) * u * u)); - return v / u; -}; + mode: function mode(shape, scale) { + return scale / (shape + 1); + }, + sample: function sample(shape, scale) { + return scale / jStat.randg(shape); + }, -// Returns a gamma deviate by the method of Marsaglia and Tsang. -jStat.randg = function randg(shape, n, m) { - var oalph = shape; - var a1, a2, u, v, x, mat; - if (!m) - m = n; - if (!shape) - shape = 1; - if (n) { - mat = jStat.zeros(n,m); - mat.alter(function() { return jStat.randg(shape); }); - return mat; + variance: function variance(shape, scale) { + if (shape <= 2) + return undefined; + return scale * scale / ((shape - 1) * (shape - 1) * (shape - 2)); } - if (shape < 1) - shape += 1; - a1 = shape - 1 / 3; - a2 = 1 / Math.sqrt(9 * a1); - do { - do { - x = jStat.randn(); - v = 1 + a2 * x; - } while(v <= 0); - v = v * v * v; - u = Math.random(); - } while(u > 1 - 0.331 * Math.pow(x, 4) && - Math.log(u) > 0.5 * x*x + a1 * (1 - v + Math.log(v))); - // alpha > 1 - if (shape == oalph) - return a1 * v; - // alpha < 1 - do { - u = Math.random(); - } while(u === 0); - return Math.pow(u, 1 / oalph) * a1 * v; -}; +}); -// making use of static methods on the instance -(function(funcs) { - for (var i = 0; i < funcs.length; i++) (function(passfunc) { - jStat.fn[passfunc] = function() { - return jStat( - jStat.map(this, function(value) { return jStat[passfunc](value); })); - } - })(funcs[i]); -})('gammaln gammafn factorial factorialln'.split(' ')); +// extend kumaraswamy function with static methods +jStat.extend(jStat.kumaraswamy, { + pdf: function pdf(x, alpha, beta) { + if (x === 0 && alpha === 1) + return beta; + else if (x === 1 && beta === 1) + return alpha; + return Math.exp(Math.log(alpha) + Math.log(beta) + (alpha - 1) * + Math.log(x) + (beta - 1) * + Math.log(1 - Math.pow(x, alpha))); + }, + cdf: function cdf(x, alpha, beta) { + if (x < 0) + return 0; + else if (x > 1) + return 1; + return (1 - Math.pow(1 - Math.pow(x, alpha), beta)); + }, -(function(funcs) { - for (var i = 0; i < funcs.length; i++) (function(passfunc) { - jStat.fn[passfunc] = function() { - return jStat(jStat[passfunc].apply(null, arguments)); - }; - })(funcs[i]); -})('randn'.split(' ')); - -}(this.jStat, Math)); -(function(jStat, Math) { - -// generate all distribution instance methods -(function(list) { - for (var i = 0; i < list.length; i++) (function(func) { - // distribution instance method - jStat[func] = function(a, b, c) { - if (!(this instanceof arguments.callee)) - return new arguments.callee(a, b, c); - this._a = a; - this._b = b; - this._c = c; - return this; - }; - // distribution method to be used on a jStat instance - jStat.fn[func] = function(a, b, c) { - var newthis = jStat[func](a, b, c); - newthis.data = this; - return newthis; - }; - // sample instance method - jStat[func].prototype.sample = function(arr) { - var a = this._a; - var b = this._b; - var c = this._c; - if (arr) - return jStat.alter(arr, function() { - return jStat[func].sample(a, b, c); - }); - else - return jStat[func].sample(a, b, c); - }; - // generate the pdf, cdf and inv instance methods - (function(vals) { - for (var i = 0; i < vals.length; i++) (function(fnfunc) { - jStat[func].prototype[fnfunc] = function(x) { - var a = this._a; - var b = this._b; - var c = this._c; - if (!x && x !== 0) - x = this.data; - if (typeof x !== 'number') { - return jStat.fn.map.call(x, function(x) { - return jStat[func][fnfunc](x, a, b, c); - }); - } - return jStat[func][fnfunc](x, a, b, c); - }; - })(vals[i]); - })('pdf cdf inv'.split(' ')); - // generate the mean, median, mode and variance instance methods - (function(vals) { - for (var i = 0; i < vals.length; i++) (function(fnfunc) { - jStat[func].prototype[fnfunc] = function() { - return jStat[func][fnfunc](this._a, this._b, this._c); - }; - })(vals[i]); - })('mean median mode variance'.split(' ')); - })(list[i]); -})(( - 'beta centralF cauchy chisquare exponential gamma invgamma kumaraswamy ' + - 'laplace lognormal noncentralt normal pareto studentt weibull uniform ' + - 'binomial negbin hypgeom poisson triangular' -).split(' ')); - - - -// extend beta function with static methods -jStat.extend(jStat.beta, { - pdf: function pdf(x, alpha, beta) { - // PDF is zero outside the support - if (x > 1 || x < 0) - return 0; - // PDF is one for the uniform case - if (alpha == 1 && beta == 1) - return 1; - - if (alpha < 512 && beta < 512) { - return (Math.pow(x, alpha - 1) * Math.pow(1 - x, beta - 1)) / - jStat.betafn(alpha, beta); - } else { - return Math.exp((alpha - 1) * Math.log(x) + - (beta - 1) * Math.log(1 - x) - - jStat.betaln(alpha, beta)); - } - }, - - cdf: function cdf(x, alpha, beta) { - return (x > 1 || x < 0) ? (x > 1) * 1 : jStat.ibeta(x, alpha, beta); - }, - - inv: function inv(x, alpha, beta) { - return jStat.ibetainv(x, alpha, beta); + inv: function inv(p, alpha, beta) { + return Math.pow(1 - Math.pow(1 - p, 1 / beta), 1 / alpha); }, - mean: function mean(alpha, beta) { - return alpha / (alpha + beta); + mean : function(alpha, beta) { + return (beta * jStat.gammafn(1 + 1 / alpha) * + jStat.gammafn(beta)) / (jStat.gammafn(1 + 1 / alpha + beta)); }, median: function median(alpha, beta) { - return jStat.ibetainv(0.5, alpha, beta); + return Math.pow(1 - Math.pow(2, -1 / beta), 1 / alpha); }, mode: function mode(alpha, beta) { - return (alpha - 1 ) / ( alpha + beta - 2); - }, - - // return a random sample - sample: function sample(alpha, beta) { - var u = jStat.randg(alpha); - return u / (u + jStat.randg(beta)); + if (!(alpha >= 1 && beta >= 1 && (alpha !== 1 && beta !== 1))) + return undefined; + return Math.pow((alpha - 1) / (alpha * beta - 1), 1 / alpha); }, variance: function variance(alpha, beta) { - return (alpha * beta) / (Math.pow(alpha + beta, 2) * (alpha + beta + 1)); + throw new Error('variance not yet implemented'); + // TODO: complete this } }); -// extend F function with static methods -jStat.extend(jStat.centralF, { - // This implementation of the pdf function avoids float overflow - // See the way that R calculates this value: - // https://svn.r-project.org/R/trunk/src/nmath/df.c - pdf: function pdf(x, df1, df2) { - var p, q, f; - - if (x < 0) - return 0; - if (df1 <= 2) { - if (x === 0 && df1 < 2) { - return Infinity; - } - if (x === 0 && df1 === 2) { - return 1; - } - return Math.sqrt((Math.pow(df1 * x, df1) * Math.pow(df2, df2)) / - (Math.pow(df1 * x + df2, df1 + df2))) / - (x * jStat.betafn(df1/2, df2/2)); - } - p = (df1 * x) / (df2 + x * df1); - q = df2 / (df2 + x * df1); - f = df1 * q / 2.0; - return f * jStat.binomial.pdf((df1 - 2) / 2, (df1 + df2 - 2) / 2, p); +// extend lognormal function with static methods +jStat.extend(jStat.lognormal, { + pdf: function pdf(x, mu, sigma) { + if (x <= 0) + return 0; + return Math.exp(-Math.log(x) - 0.5 * Math.log(2 * Math.PI) - + Math.log(sigma) - Math.pow(Math.log(x) - mu, 2) / + (2 * sigma * sigma)); }, - cdf: function cdf(x, df1, df2) { + cdf: function cdf(x, mu, sigma) { if (x < 0) return 0; - return jStat.ibeta((df1 * x) / (df1 * x + df2), df1 / 2, df2 / 2); + return 0.5 + + (0.5 * jStat.erf((Math.log(x) - mu) / Math.sqrt(2 * sigma * sigma))); }, - inv: function inv(x, df1, df2) { - return df2 / (df1 * (1 / jStat.ibetainv(x, df1 / 2, df2 / 2) - 1)); + inv: function(p, mu, sigma) { + return Math.exp(-1.41421356237309505 * sigma * jStat.erfcinv(2 * p) + mu); }, - mean: function mean(df1, df2) { - return (df2 > 2) ? df2 / (df2 - 2) : undefined; + mean: function mean(mu, sigma) { + return Math.exp(mu + sigma * sigma / 2); }, - mode: function mode(df1, df2) { - return (df1 > 2) ? (df2 * (df1 - 2)) / (df1 * (df2 + 2)) : undefined; + median: function median(mu, sigma) { + return Math.exp(mu); }, - // return a random sample - sample: function sample(df1, df2) { - var x1 = jStat.randg(df1 / 2) * 2; - var x2 = jStat.randg(df2 / 2) * 2; - return (x1 / df1) / (x2 / df2); + mode: function mode(mu, sigma) { + return Math.exp(mu - sigma * sigma); }, - variance: function variance(df1, df2) { - if (df2 <= 4) - return undefined; - return 2 * df2 * df2 * (df1 + df2 - 2) / - (df1 * (df2 - 2) * (df2 - 2) * (df2 - 4)); + sample: function sample(mu, sigma) { + return Math.exp(jStat.randn() * sigma + mu); + }, + + variance: function variance(mu, sigma) { + return (Math.exp(sigma * sigma) - 1) * Math.exp(2 * mu + sigma * sigma); } }); -// extend cauchy function with static methods -jStat.extend(jStat.cauchy, { - pdf: function pdf(x, local, scale) { - if (scale < 0) { return 0; } - return (scale / (Math.pow(x - local, 2) + Math.pow(scale, 2))) / Math.PI; - }, +// extend noncentralt function with static methods +jStat.extend(jStat.noncentralt, { + pdf: function pdf(x, dof, ncp) { + var tol = 1e-14; + if (Math.abs(ncp) < tol) // ncp approx 0; use student-t + return jStat.studentt.pdf(x, dof) - cdf: function cdf(x, local, scale) { - return Math.atan((x - local) / scale) / Math.PI + 0.5; - }, + if (Math.abs(x) < tol) { // different formula for x == 0 + return Math.exp(jStat.gammaln((dof + 1) / 2) - ncp * ncp / 2 - + 0.5 * Math.log(Math.PI * dof) - jStat.gammaln(dof / 2)); + } - inv: function(p, local, scale) { - return local + scale * Math.tan(Math.PI * (p - 0.5)); + // formula for x != 0 + return dof / x * + (jStat.noncentralt.cdf(x * Math.sqrt(1 + 2 / dof), dof+2, ncp) - + jStat.noncentralt.cdf(x, dof, ncp)); }, - median: function median(local, scale) { - return local; - }, + cdf: function cdf(x, dof, ncp) { + var tol = 1e-14; + var min_iterations = 200; - mode: function mode(local, scale) { - return local; - }, + if (Math.abs(ncp) < tol) // ncp approx 0; use student-t + return jStat.studentt.cdf(x, dof); - sample: function sample(local, scale) { - return jStat.randn() * - Math.sqrt(1 / (2 * jStat.randg(0.5))) * scale + local; + // turn negative x into positive and flip result afterwards + var flip = false; + if (x < 0) { + flip = true; + ncp = -ncp; + } + + var prob = jStat.normal.cdf(-ncp, 0, 1); + var value = tol + 1; + // use value at last two steps to determine convergence + var lastvalue = value; + var y = x * x / (x * x + dof); + var j = 0; + var p = Math.exp(-ncp * ncp / 2); + var q = Math.exp(-ncp * ncp / 2 - 0.5 * Math.log(2) - + jStat.gammaln(3 / 2)) * ncp; + while (j < min_iterations || lastvalue > tol || value > tol) { + lastvalue = value; + if (j > 0) { + p *= (ncp * ncp) / (2 * j); + q *= (ncp * ncp) / (2 * (j + 1 / 2)); + } + value = p * jStat.beta.cdf(y, j + 0.5, dof / 2) + + q * jStat.beta.cdf(y, j+1, dof/2); + prob += 0.5 * value; + j++; + } + + return flip ? (1 - prob) : prob; } }); - -// extend chisquare function with static methods -jStat.extend(jStat.chisquare, { - pdf: function pdf(x, dof) { - if (x < 0) - return 0; - return (x === 0 && dof === 2) ? 0.5 : - Math.exp((dof / 2 - 1) * Math.log(x) - x / 2 - (dof / 2) * - Math.log(2) - jStat.gammaln(dof / 2)); +// extend normal function with static methods +jStat.extend(jStat.normal, { + pdf: function pdf(x, mean, std) { + return Math.exp(-0.5 * Math.log(2 * Math.PI) - + Math.log(std) - Math.pow(x - mean, 2) / (2 * std * std)); }, - cdf: function cdf(x, dof) { - if (x < 0) - return 0; - return jStat.lowRegGamma(dof / 2, x / 2); + cdf: function cdf(x, mean, std) { + return 0.5 * (1 + jStat.erf((x - mean) / Math.sqrt(2 * std * std))); }, - inv: function(p, dof) { - return 2 * jStat.gammapinv(p, 0.5 * dof); + inv: function(p, mean, std) { + return -1.41421356237309505 * std * jStat.erfcinv(2 * p) + mean; }, - mean : function(dof) { - return dof; + mean : function(mean, std) { + return mean; }, - // TODO: this is an approximation (is there a better way?) - median: function median(dof) { - return dof * Math.pow(1 - (2 / (9 * dof)), 3); + median: function median(mean, std) { + return mean; }, - mode: function mode(dof) { - return (dof - 2 > 0) ? dof - 2 : 0; + mode: function (mean, std) { + return mean; }, - sample: function sample(dof) { - return jStat.randg(dof / 2) * 2; + sample: function sample(mean, std) { + return jStat.randn() * std + mean; }, - variance: function variance(dof) { - return 2 * dof; + variance : function(mean, std) { + return std * std; } }); -// extend exponential function with static methods -jStat.extend(jStat.exponential, { - pdf: function pdf(x, rate) { - return x < 0 ? 0 : rate * Math.exp(-rate * x); - }, - - cdf: function cdf(x, rate) { - return x < 0 ? 0 : 1 - Math.exp(-rate * x); +// extend pareto function with static methods +jStat.extend(jStat.pareto, { + pdf: function pdf(x, scale, shape) { + if (x < scale) + return 0; + return (shape * Math.pow(scale, shape)) / Math.pow(x, shape + 1); }, - inv: function(p, rate) { - return -Math.log(1 - p) / rate; + cdf: function cdf(x, scale, shape) { + if (x < scale) + return 0; + return 1 - Math.pow(scale / x, shape); }, - mean : function(rate) { - return 1 / rate; + inv: function inv(p, scale, shape) { + return scale / Math.pow(1 - p, 1 / shape); }, - median: function (rate) { - return (1 / rate) * Math.log(2); + mean: function mean(scale, shape) { + if (shape <= 1) + return undefined; + return (shape * Math.pow(scale, shape)) / (shape - 1); }, - mode: function mode(rate) { - return 0; + median: function median(scale, shape) { + return scale * (shape * Math.SQRT2); }, - sample: function sample(rate) { - return -1 / rate * Math.log(Math.random()); + mode: function mode(scale, shape) { + return scale; }, - variance : function(rate) { - return Math.pow(rate, -2); + variance : function(scale, shape) { + if (shape <= 2) + return undefined; + return (scale*scale * shape) / (Math.pow(shape - 1, 2) * (shape - 2)); } }); -// extend gamma function with static methods -jStat.extend(jStat.gamma, { - pdf: function pdf(x, shape, scale) { - if (x < 0) - return 0; - return (x === 0 && shape === 1) ? 1 / scale : - Math.exp((shape - 1) * Math.log(x) - x / scale - - jStat.gammaln(shape) - shape * Math.log(scale)); +// extend studentt function with static methods +jStat.extend(jStat.studentt, { + pdf: function pdf(x, dof) { + dof = dof > 1e100 ? 1e100 : dof; + return (1/(Math.sqrt(dof) * jStat.betafn(0.5, dof/2))) * + Math.pow(1 + ((x * x) / dof), -((dof + 1) / 2)); }, - cdf: function cdf(x, shape, scale) { - if (x < 0) - return 0; - return jStat.lowRegGamma(shape, x / scale); + cdf: function cdf(x, dof) { + var dof2 = dof / 2; + return jStat.ibeta((x + Math.sqrt(x * x + dof)) / + (2 * Math.sqrt(x * x + dof)), dof2, dof2); }, - inv: function(p, shape, scale) { - return jStat.gammapinv(p, shape) * scale; + inv: function(p, dof) { + var x = jStat.ibetainv(2 * Math.min(p, 1 - p), 0.5 * dof, 0.5); + x = Math.sqrt(dof * (1 - x) / x); + return (p > 0.5) ? x : -x; }, - mean : function(shape, scale) { - return shape * scale; + mean: function mean(dof) { + return (dof > 1) ? 0 : undefined; }, - mode: function mode(shape, scale) { - if(shape > 1) return (shape - 1) * scale; - return undefined; + median: function median(dof) { + return 0; }, - sample: function sample(shape, scale) { - return jStat.randg(shape) * scale; + mode: function mode(dof) { + return 0; }, - variance: function variance(shape, scale) { - return shape * scale * scale; + sample: function sample(dof) { + return jStat.randn() * Math.sqrt(dof / (2 * jStat.randg(dof / 2))); + }, + + variance: function variance(dof) { + return (dof > 2) ? dof / (dof - 2) : (dof > 1) ? Infinity : undefined; } }); -// extend inverse gamma function with static methods -jStat.extend(jStat.invgamma, { - pdf: function pdf(x, shape, scale) { - if (x <= 0) + + +// extend weibull function with static methods +jStat.extend(jStat.weibull, { + pdf: function pdf(x, scale, shape) { + if (x < 0 || scale < 0 || shape < 0) return 0; - return Math.exp(-(shape + 1) * Math.log(x) - scale / x - - jStat.gammaln(shape) + shape * Math.log(scale)); + return (shape / scale) * Math.pow((x / scale), (shape - 1)) * + Math.exp(-(Math.pow((x / scale), shape))); }, - cdf: function cdf(x, shape, scale) { - if (x <= 0) - return 0; - return 1 - jStat.lowRegGamma(shape, scale / x); + cdf: function cdf(x, scale, shape) { + return x < 0 ? 0 : 1 - Math.exp(-Math.pow((x / scale), shape)); }, - inv: function(p, shape, scale) { - return scale / jStat.gammapinv(1 - p, shape); + inv: function(p, scale, shape) { + return scale * Math.pow(-Math.log(1 - p), 1 / shape); }, - mean : function(shape, scale) { - return (shape > 1) ? scale / (shape - 1) : undefined; + mean : function(scale, shape) { + return scale * jStat.gammafn(1 + 1 / shape); }, - mode: function mode(shape, scale) { - return scale / (shape + 1); + median: function median(scale, shape) { + return scale * Math.pow(Math.log(2), 1 / shape); }, - sample: function sample(shape, scale) { - return scale / jStat.randg(shape); + mode: function mode(scale, shape) { + if (shape <= 1) + return 0; + return scale * Math.pow((shape - 1) / shape, 1 / shape); }, - variance: function variance(shape, scale) { - if (shape <= 2) - return undefined; - return scale * scale / ((shape - 1) * (shape - 1) * (shape - 2)); + sample: function sample(scale, shape) { + return scale * Math.pow(-Math.log(Math.random()), 1 / shape); + }, + + variance: function variance(scale, shape) { + return scale * scale * jStat.gammafn(1 + 2 / shape) - + Math.pow(jStat.weibull.mean(scale, shape), 2); } }); -// extend kumaraswamy function with static methods -jStat.extend(jStat.kumaraswamy, { - pdf: function pdf(x, alpha, beta) { - if (x === 0 && alpha === 1) - return beta; - else if (x === 1 && beta === 1) - return alpha; - return Math.exp(Math.log(alpha) + Math.log(beta) + (alpha - 1) * - Math.log(x) + (beta - 1) * - Math.log(1 - Math.pow(x, alpha))); + +// extend uniform function with static methods +jStat.extend(jStat.uniform, { + pdf: function pdf(x, a, b) { + return (x < a || x > b) ? 0 : 1 / (b - a); }, - cdf: function cdf(x, alpha, beta) { - if (x < 0) + cdf: function cdf(x, a, b) { + if (x < a) return 0; - else if (x > 1) - return 1; - return (1 - Math.pow(1 - Math.pow(x, alpha), beta)); + else if (x < b) + return (x - a) / (b - a); + return 1; }, - inv: function inv(p, alpha, beta) { - return Math.pow(1 - Math.pow(1 - p, 1 / beta), 1 / alpha); + inv: function(p, a, b) { + return a + (p * (b - a)); }, - mean : function(alpha, beta) { - return (beta * jStat.gammafn(1 + 1 / alpha) * - jStat.gammafn(beta)) / (jStat.gammafn(1 + 1 / alpha + beta)); + mean: function mean(a, b) { + return 0.5 * (a + b); }, - median: function median(alpha, beta) { - return Math.pow(1 - Math.pow(2, -1 / beta), 1 / alpha); + median: function median(a, b) { + return jStat.mean(a, b); }, - mode: function mode(alpha, beta) { - if (!(alpha >= 1 && beta >= 1 && (alpha !== 1 && beta !== 1))) - return undefined; - return Math.pow((alpha - 1) / (alpha * beta - 1), 1 / alpha); + mode: function mode(a, b) { + throw new Error('mode is not yet implemented'); }, - variance: function variance(alpha, beta) { - throw new Error('variance not yet implemented'); - // TODO: complete this + sample: function sample(a, b) { + return (a / 2 + b / 2) + (b / 2 - a / 2) * (2 * Math.random() - 1); + }, + + variance: function variance(a, b) { + return Math.pow(b - a, 2) / 12; } }); -// extend lognormal function with static methods -jStat.extend(jStat.lognormal, { - pdf: function pdf(x, mu, sigma) { - if (x <= 0) - return 0; - return Math.exp(-Math.log(x) - 0.5 * Math.log(2 * Math.PI) - - Math.log(sigma) - Math.pow(Math.log(x) - mu, 2) / - (2 * sigma * sigma)); +// extend uniform function with static methods +jStat.extend(jStat.binomial, { + pdf: function pdf(k, n, p) { + return (p === 0 || p === 1) ? + ((n * p) === k ? 1 : 0) : + jStat.combination(n, k) * Math.pow(p, k) * Math.pow(1 - p, n - k); }, - cdf: function cdf(x, mu, sigma) { - if (x < 0) - return 0; - return 0.5 + - (0.5 * jStat.erf((Math.log(x) - mu) / Math.sqrt(2 * sigma * sigma))); - }, - - inv: function(p, mu, sigma) { - return Math.exp(-1.41421356237309505 * sigma * jStat.erfcinv(2 * p) + mu); - }, - - mean: function mean(mu, sigma) { - return Math.exp(mu + sigma * sigma / 2); - }, + cdf: function cdf(x, n, p) { + var binomarr = [], + k = 0; + if (x < 0) { + return 0; + } + if (x < n) { + for (; k <= x; k++) { + binomarr[ k ] = jStat.binomial.pdf(k, n, p); + } + return jStat.sum(binomarr); + } + return 1; + } +}); - median: function median(mu, sigma) { - return Math.exp(mu); - }, - mode: function mode(mu, sigma) { - return Math.exp(mu - sigma * sigma); - }, - sample: function sample(mu, sigma) { - return Math.exp(jStat.randn() * sigma + mu); +// extend uniform function with static methods +jStat.extend(jStat.negbin, { + pdf: function pdf(k, r, p) { + if (k !== k >>> 0) + return false; + if (k < 0) + return 0; + return jStat.combination(k + r - 1, r - 1) * + Math.pow(1 - p, k) * Math.pow(p, r); }, - variance: function variance(mu, sigma) { - return (Math.exp(sigma * sigma) - 1) * Math.exp(2 * mu + sigma * sigma); + cdf: function cdf(x, r, p) { + var sum = 0, + k = 0; + if (x < 0) return 0; + for (; k <= x; k++) { + sum += jStat.negbin.pdf(k, r, p); + } + return sum; } }); -// extend noncentralt function with static methods -jStat.extend(jStat.noncentralt, { - pdf: function pdf(x, dof, ncp) { - var tol = 1e-14; - if (Math.abs(ncp) < tol) // ncp approx 0; use student-t - return jStat.studentt.pdf(x, dof) +// extend uniform function with static methods +jStat.extend(jStat.hypgeom, { + pdf: function pdf(k, N, m, n) { + // Hypergeometric PDF. - if (Math.abs(x) < tol) { // different formula for x == 0 - return Math.exp(jStat.gammaln((dof + 1) / 2) - ncp * ncp / 2 - - 0.5 * Math.log(Math.PI * dof) - jStat.gammaln(dof / 2)); - } + // A simplification of the CDF algorithm below. - // formula for x != 0 - return dof / x * - (jStat.noncentralt.cdf(x * Math.sqrt(1 + 2 / dof), dof+2, ncp) - - jStat.noncentralt.cdf(x, dof, ncp)); - }, + // k = number of successes drawn + // N = population size + // m = number of successes in population + // n = number of items drawn from population - cdf: function cdf(x, dof, ncp) { - var tol = 1e-14; - var min_iterations = 200; + if(k !== k | 0) { + return false; + } else if(k < 0 || k < m - (N - n)) { + // It's impossible to have this few successes drawn. + return 0; + } else if(k > n || k > m) { + // It's impossible to have this many successes drawn. + return 0; + } else if (m * 2 > N) { + // More than half the population is successes. - if (Math.abs(ncp) < tol) // ncp approx 0; use student-t - return jStat.studentt.cdf(x, dof); + if(n * 2 > N) { + // More than half the population is sampled. - // turn negative x into positive and flip result afterwards - var flip = false; - if (x < 0) { - flip = true; - ncp = -ncp; - } + return jStat.hypgeom.pdf(N - m - n + k, N, N - m, N - n) + } else { + // Half or less of the population is sampled. - var prob = jStat.normal.cdf(-ncp, 0, 1); - var value = tol + 1; - // use value at last two steps to determine convergence - var lastvalue = value; - var y = x * x / (x * x + dof); - var j = 0; - var p = Math.exp(-ncp * ncp / 2); - var q = Math.exp(-ncp * ncp / 2 - 0.5 * Math.log(2) - - jStat.gammaln(3 / 2)) * ncp; - while (j < min_iterations || lastvalue > tol || value > tol) { - lastvalue = value; - if (j > 0) { - p *= (ncp * ncp) / (2 * j); - q *= (ncp * ncp) / (2 * (j + 1 / 2)); + return jStat.hypgeom.pdf(n - k, N, N - m, n); } - value = p * jStat.beta.cdf(y, j + 0.5, dof / 2) + - q * jStat.beta.cdf(y, j+1, dof/2); - prob += 0.5 * value; - j++; - } - return flip ? (1 - prob) : prob; - } -}); + } else if(n * 2 > N) { + // Half or less is successes. + return jStat.hypgeom.pdf(m - k, N, m, N - n); -// extend normal function with static methods -jStat.extend(jStat.normal, { - pdf: function pdf(x, mean, std) { - return Math.exp(-0.5 * Math.log(2 * Math.PI) - - Math.log(std) - Math.pow(x - mean, 2) / (2 * std * std)); - }, + } else if(m < n) { + // We want to have the number of things sampled to be less than the + // successes available. So swap the definitions of successful and sampled. + return jStat.hypgeom.pdf(k, N, n, m); + } else { + // If we get here, half or less of the population was sampled, half or + // less of it was successes, and we had fewer sampled things than + // successes. Now we can do this complicated iterative algorithm in an + // efficient way. - cdf: function cdf(x, mean, std) { - return 0.5 * (1 + jStat.erf((x - mean) / Math.sqrt(2 * std * std))); - }, + // The basic premise of the algorithm is that we partially normalize our + // intermediate product to keep it in a numerically good region, and then + // finish the normalization at the end. - inv: function(p, mean, std) { - return -1.41421356237309505 * std * jStat.erfcinv(2 * p) + mean; - }, + // This variable holds the scaled probability of the current number of + // successes. + var scaledPDF = 1; - mean : function(mean, std) { - return mean; - }, + // This keeps track of how much we have normalized. + var samplesDone = 0; - median: function median(mean, std) { - return mean; - }, + for(var i = 0; i < k; i++) { + // For every possible number of successes up to that observed... - mode: function (mean, std) { - return mean; - }, + while(scaledPDF > 1 && samplesDone < n) { + // Intermediate result is growing too big. Apply some of the + // normalization to shrink everything. - sample: function sample(mean, std) { - return jStat.randn() * std + mean; - }, + scaledPDF *= 1 - (m / (N - samplesDone)); - variance : function(mean, std) { - return std * std; - } -}); + // Say we've normalized by this sample already. + samplesDone++; + } + // Work out the partially-normalized hypergeometric PDF for the next + // number of successes + scaledPDF *= (n - i) * (m - i) / ((i + 1) * (N - m - n + i + 1)); + } + for(; samplesDone < n; samplesDone++) { + // Apply all the rest of the normalization + scaledPDF *= 1 - (m / (N - samplesDone)); + } -// extend pareto function with static methods -jStat.extend(jStat.pareto, { - pdf: function pdf(x, scale, shape) { - if (x < scale) - return 0; - return (shape * Math.pow(scale, shape)) / Math.pow(x, shape + 1); + // Bound answer sanely before returning. + return Math.min(1, Math.max(0, scaledPDF)); + } }, - cdf: function cdf(x, scale, shape) { - if (x < scale) - return 0; - return 1 - Math.pow(scale / x, shape); - }, + cdf: function cdf(x, N, m, n) { + // Hypergeometric CDF. - inv: function inv(p, scale, shape) { - return scale / Math.pow(1 - p, 1 / shape); - }, + // This algorithm is due to Prof. Thomas S. Ferguson, , + // and comes from his hypergeometric test calculator at + // . - mean: function mean(scale, shape) { - if (shape <= 1) - return undefined; - return (shape * Math.pow(scale, shape)) / (shape - 1); - }, + // x = number of successes drawn + // N = population size + // m = number of successes in population + // n = number of items drawn from population - median: function median(scale, shape) { - return scale * (shape * Math.SQRT2); - }, + if(x < 0 || x < m - (N - n)) { + // It's impossible to have this few successes drawn or fewer. + return 0; + } else if(x >= n || x >= m) { + // We will always have this many successes or fewer. + return 1; + } else if (m * 2 > N) { + // More than half the population is successes. - mode: function mode(scale, shape) { - return scale; - }, + if(n * 2 > N) { + // More than half the population is sampled. - variance : function(scale, shape) { - if (shape <= 2) - return undefined; - return (scale*scale * shape) / (Math.pow(shape - 1, 2) * (shape - 2)); - } -}); + return jStat.hypgeom.cdf(N - m - n + x, N, N - m, N - n) + } else { + // Half or less of the population is sampled. + return 1 - jStat.hypgeom.cdf(n - x - 1, N, N - m, n); + } + } else if(n * 2 > N) { + // Half or less is successes. -// extend studentt function with static methods -jStat.extend(jStat.studentt, { - pdf: function pdf(x, dof) { - dof = dof > 1e100 ? 1e100 : dof; - return (1/(Math.sqrt(dof) * jStat.betafn(0.5, dof/2))) * - Math.pow(1 + ((x * x) / dof), -((dof + 1) / 2)); - }, + return 1 - jStat.hypgeom.cdf(m - x - 1, N, m, N - n); - cdf: function cdf(x, dof) { - var dof2 = dof / 2; - return jStat.ibeta((x + Math.sqrt(x * x + dof)) / - (2 * Math.sqrt(x * x + dof)), dof2, dof2); - }, + } else if(m < n) { + // We want to have the number of things sampled to be less than the + // successes available. So swap the definitions of successful and sampled. + return jStat.hypgeom.cdf(x, N, n, m); + } else { + // If we get here, half or less of the population was sampled, half or + // less of it was successes, and we had fewer sampled things than + // successes. Now we can do this complicated iterative algorithm in an + // efficient way. - inv: function(p, dof) { - var x = jStat.ibetainv(2 * Math.min(p, 1 - p), 0.5 * dof, 0.5); - x = Math.sqrt(dof * (1 - x) / x); - return (p > 0.5) ? x : -x; - }, + // The basic premise of the algorithm is that we partially normalize our + // intermediate sum to keep it in a numerically good region, and then + // finish the normalization at the end. - mean: function mean(dof) { - return (dof > 1) ? 0 : undefined; - }, + // Holds the intermediate, scaled total CDF. + var scaledCDF = 1; - median: function median(dof) { - return 0; - }, + // This variable holds the scaled probability of the current number of + // successes. + var scaledPDF = 1; - mode: function mode(dof) { - return 0; - }, + // This keeps track of how much we have normalized. + var samplesDone = 0; - sample: function sample(dof) { - return jStat.randn() * Math.sqrt(dof / (2 * jStat.randg(dof / 2))); - }, + for(var i = 0; i < x; i++) { + // For every possible number of successes up to that observed... - variance: function variance(dof) { - return (dof > 2) ? dof / (dof - 2) : (dof > 1) ? Infinity : undefined; + while(scaledCDF > 1 && samplesDone < n) { + // Intermediate result is growing too big. Apply some of the + // normalization to shrink everything. + + var factor = 1 - (m / (N - samplesDone)); + + scaledPDF *= factor; + scaledCDF *= factor; + + // Say we've normalized by this sample already. + samplesDone++; + } + + // Work out the partially-normalized hypergeometric PDF for the next + // number of successes + scaledPDF *= (n - i) * (m - i) / ((i + 1) * (N - m - n + i + 1)); + + // Add to the CDF answer. + scaledCDF += scaledPDF; + } + + for(; samplesDone < n; samplesDone++) { + // Apply all the rest of the normalization + scaledCDF *= 1 - (m / (N - samplesDone)); + } + + // Bound answer sanely before returning. + return Math.min(1, Math.max(0, scaledCDF)); + } } }); -// extend weibull function with static methods -jStat.extend(jStat.weibull, { - pdf: function pdf(x, scale, shape) { - if (x < 0 || scale < 0 || shape < 0) +// extend uniform function with static methods +jStat.extend(jStat.poisson, { + pdf: function pdf(k, l) { + if (l < 0 || (k % 1) !== 0 || k < 0) { return 0; - return (shape / scale) * Math.pow((x / scale), (shape - 1)) * - Math.exp(-(Math.pow((x / scale), shape))); + } + + return Math.pow(l, k) * Math.exp(-l) / jStat.factorial(k); }, - cdf: function cdf(x, scale, shape) { - return x < 0 ? 0 : 1 - Math.exp(-Math.pow((x / scale), shape)); + cdf: function cdf(x, l) { + var sumarr = [], + k = 0; + if (x < 0) return 0; + for (; k <= x; k++) { + sumarr.push(jStat.poisson.pdf(k, l)); + } + return jStat.sum(sumarr); }, - inv: function(p, scale, shape) { - return scale * Math.pow(-Math.log(1 - p), 1 / shape); + mean : function(l) { + return l; }, - mean : function(scale, shape) { - return scale * jStat.gammafn(1 + 1 / shape); + variance : function(l) { + return l; }, - median: function median(scale, shape) { - return scale * Math.pow(Math.log(2), 1 / shape); + sample: function sample(l) { + var p = 1, k = 0, L = Math.exp(-l); + do { + k++; + p *= Math.random(); + } while (p > L); + return k - 1; + } +}); + +// extend triangular function with static methods +jStat.extend(jStat.triangular, { + pdf: function pdf(x, a, b, c) { + if (b <= a || c < a || c > b) { + return NaN; + } else { + if (x < a || x > b) { + return 0; + } else if (x < c) { + return (2 * (x - a)) / ((b - a) * (c - a)); + } else if (x === c) { + return (2 / (b - a)); + } else { // x > c + return (2 * (b - x)) / ((b - a) * (b - c)); + } + } }, - mode: function mode(scale, shape) { - if (shape <= 1) + cdf: function cdf(x, a, b, c) { + if (b <= a || c < a || c > b) + return NaN; + if (x <= a) return 0; - return scale * Math.pow((shape - 1) / shape, 1 / shape); + else if (x >= b) + return 1; + if (x <= c) + return Math.pow(x - a, 2) / ((b - a) * (c - a)); + else // x > c + return 1 - Math.pow(b - x, 2) / ((b - a) * (b - c)); }, - sample: function sample(scale, shape) { - return scale * Math.pow(-Math.log(Math.random()), 1 / shape); + inv: function inv(p, a, b, c) { + if (b <= a || c < a || c > b) { + return NaN; + } else { + if (p <= ((c - a) / (b - a))) { + return a + (b - a) * Math.sqrt(p * ((c - a) / (b - a))); + } else { // p > ((c - a) / (b - a)) + return a + (b - a) * (1 - Math.sqrt((1 - p) * (1 - ((c - a) / (b - a))))); + } + } }, - variance: function variance(scale, shape) { - return scale * scale * jStat.gammafn(1 + 2 / shape) - - Math.pow(jStat.weibull.mean(scale, shape), 2); + mean: function mean(a, b, c) { + return (a + b + c) / 3; + }, + + median: function median(a, b, c) { + if (c <= (a + b) / 2) { + return b - Math.sqrt((b - a) * (b - c)) / Math.sqrt(2); + } else if (c > (a + b) / 2) { + return a + Math.sqrt((b - a) * (c - a)) / Math.sqrt(2); + } + }, + + mode: function mode(a, b, c) { + return c; + }, + + sample: function sample(a, b, c) { + var u = Math.random(); + if (u < ((c - a) / (b - a))) + return a + Math.sqrt(u * (b - a) * (c - a)) + return b - Math.sqrt((1 - u) * (b - a) * (b - c)); + }, + + variance: function variance(a, b, c) { + return (a * a + b * b + c * c - a * b - a * c - b * c) / 18; } }); - -// extend uniform function with static methods -jStat.extend(jStat.uniform, { +// extend arcsine function with static methods +jStat.extend(jStat.arcsine, { pdf: function pdf(x, a, b) { - return (x < a || x > b) ? 0 : 1 / (b - a); + if (b <= a) return NaN; + + return (x <= a || x >= b) ? 0 : + (2 / Math.PI) * + Math.pow(Math.pow(b - a, 2) - + Math.pow(2 * x - a - b, 2), -0.5); }, cdf: function cdf(x, a, b) { if (x < a) return 0; else if (x < b) - return (x - a) / (b - a); + return (2 / Math.PI) * Math.asin(Math.sqrt((x - a)/(b - a))); return 1; }, inv: function(p, a, b) { - return a + (p * (b - a)); + return a + (0.5 - 0.5 * Math.cos(Math.PI * p)) * (b - a); }, mean: function mean(a, b) { - return 0.5 * (a + b); + if (b <= a) return NaN; + return (a + b) / 2; }, median: function median(a, b) { - return jStat.mean(a, b); + if (b <= a) return NaN; + return (a + b) / 2; }, mode: function mode(a, b) { @@ -8640,400 +8766,415 @@ jStat.extend(jStat.uniform, { }, sample: function sample(a, b) { - return (a / 2 + b / 2) + (b / 2 - a / 2) * (2 * Math.random() - 1); + return ((a + b) / 2) + ((b - a) / 2) * + Math.sin(2 * Math.PI * jStat.uniform.sample(0, 1)); }, variance: function variance(a, b) { - return Math.pow(b - a, 2) / 12; + if (b <= a) return NaN; + return Math.pow(b - a, 2) / 8; } }); +function laplaceSign(x) { return x / Math.abs(x); } -// extend uniform function with static methods -jStat.extend(jStat.binomial, { - pdf: function pdf(k, n, p) { - return (p === 0 || p === 1) ? - ((n * p) === k ? 1 : 0) : - jStat.combination(n, k) * Math.pow(p, k) * Math.pow(1 - p, n - k); +jStat.extend(jStat.laplace, { + pdf: function pdf(x, mu, b) { + return (b <= 0) ? 0 : (Math.exp(-Math.abs(x - mu) / b)) / (2 * b); }, - cdf: function cdf(x, n, p) { - var binomarr = [], - k = 0; - if (x < 0) { - return 0; - } - if (x < n) { - for (; k <= x; k++) { - binomarr[ k ] = jStat.binomial.pdf(k, n, p); - } - return jStat.sum(binomarr); + cdf: function cdf(x, mu, b) { + if (b <= 0) { return 0; } + + if(x < mu) { + return 0.5 * Math.exp((x - mu) / b); + } else { + return 1 - 0.5 * Math.exp(- (x - mu) / b); } - return 1; - } -}); + }, + mean: function(mu, b) { + return mu; + }, + median: function(mu, b) { + return mu; + }, -// extend uniform function with static methods -jStat.extend(jStat.negbin, { - pdf: function pdf(k, r, p) { - if (k !== k >>> 0) - return false; - if (k < 0) - return 0; - return jStat.combination(k + r - 1, r - 1) * - Math.pow(1 - p, k) * Math.pow(p, r); + mode: function(mu, b) { + return mu; }, - cdf: function cdf(x, r, p) { - var sum = 0, - k = 0; - if (x < 0) return 0; - for (; k <= x; k++) { - sum += jStat.negbin.pdf(k, r, p); - } - return sum; - } + variance: function(mu, b) { + return 2 * b * b; + }, + + sample: function sample(mu, b) { + var u = Math.random() - 0.5; + + return mu - (b * laplaceSign(u) * Math.log(1 - (2 * Math.abs(u)))); + } }); +function tukeyWprob(w, rr, cc) { + var nleg = 12; + var ihalf = 6; + + var C1 = -30; + var C2 = -50; + var C3 = 60; + var bb = 8; + var wlar = 3; + var wincr1 = 2; + var wincr2 = 3; + var xleg = [ + 0.981560634246719250690549090149, + 0.904117256370474856678465866119, + 0.769902674194304687036893833213, + 0.587317954286617447296702418941, + 0.367831498998180193752691536644, + 0.125233408511468915472441369464 + ]; + var aleg = [ + 0.047175336386511827194615961485, + 0.106939325995318430960254718194, + 0.160078328543346226334652529543, + 0.203167426723065921749064455810, + 0.233492536538354808760849898925, + 0.249147045813402785000562436043 + ]; + var qsqz = w * 0.5; -// extend uniform function with static methods -jStat.extend(jStat.hypgeom, { - pdf: function pdf(k, N, m, n) { - // Hypergeometric PDF. + // if w >= 16 then the integral lower bound (occurs for c=20) + // is 0.99999999999995 so return a value of 1. - // A simplification of the CDF algorithm below. + if (qsqz >= bb) + return 1.0; - // k = number of successes drawn - // N = population size - // m = number of successes in population - // n = number of items drawn from population + // find (f(w/2) - 1) ^ cc + // (first term in integral of hartley's form). - if(k !== k | 0) { - return false; - } else if(k < 0 || k < m - (N - n)) { - // It's impossible to have this few successes drawn. - return 0; - } else if(k > n || k > m) { - // It's impossible to have this many successes drawn. - return 0; - } else if (m * 2 > N) { - // More than half the population is successes. + var pr_w = 2 * jStat.normal.cdf(qsqz, 0, 1, 1, 0) - 1; // erf(qsqz / M_SQRT2) + // if pr_w ^ cc < 2e-22 then set pr_w = 0 + if (pr_w >= Math.exp(C2 / cc)) + pr_w = Math.pow(pr_w, cc); + else + pr_w = 0.0; - if(n * 2 > N) { - // More than half the population is sampled. + // if w is large then the second component of the + // integral is small, so fewer intervals are needed. - return jStat.hypgeom.pdf(N - m - n + k, N, N - m, N - n) - } else { - // Half or less of the population is sampled. + var wincr; + if (w > wlar) + wincr = wincr1; + else + wincr = wincr2; - return jStat.hypgeom.pdf(n - k, N, N - m, n); - } + // find the integral of second term of hartley's form + // for the integral of the range for equal-length + // intervals using legendre quadrature. limits of + // integration are from (w/2, 8). two or three + // equal-length intervals are used. - } else if(n * 2 > N) { - // Half or less is successes. + // blb and bub are lower and upper limits of integration. - return jStat.hypgeom.pdf(m - k, N, m, N - n); + var blb = qsqz; + var binc = (bb - qsqz) / wincr; + var bub = blb + binc; + var einsum = 0.0; - } else if(m < n) { - // We want to have the number of things sampled to be less than the - // successes available. So swap the definitions of successful and sampled. - return jStat.hypgeom.pdf(k, N, n, m); - } else { - // If we get here, half or less of the population was sampled, half or - // less of it was successes, and we had fewer sampled things than - // successes. Now we can do this complicated iterative algorithm in an - // efficient way. + // integrate over each interval - // The basic premise of the algorithm is that we partially normalize our - // intermediate product to keep it in a numerically good region, and then - // finish the normalization at the end. + var cc1 = cc - 1.0; + for (var wi = 1; wi <= wincr; wi++) { + var elsum = 0.0; + var a = 0.5 * (bub + blb); - // This variable holds the scaled probability of the current number of - // successes. - var scaledPDF = 1; + // legendre quadrature with order = nleg - // This keeps track of how much we have normalized. - var samplesDone = 0; + var b = 0.5 * (bub - blb); - for(var i = 0; i < k; i++) { - // For every possible number of successes up to that observed... + for (var jj = 1; jj <= nleg; jj++) { + var j, xx; + if (ihalf < jj) { + j = (nleg - jj) + 1; + xx = xleg[j-1]; + } else { + j = jj; + xx = -xleg[j-1]; + } + var c = b * xx; + var ac = a + c; - while(scaledPDF > 1 && samplesDone < n) { - // Intermediate result is growing too big. Apply some of the - // normalization to shrink everything. + // if exp(-qexpo/2) < 9e-14, + // then doesn't contribute to integral - scaledPDF *= 1 - (m / (N - samplesDone)); + var qexpo = ac * ac; + if (qexpo > C3) + break; - // Say we've normalized by this sample already. - samplesDone++; - } + var pplus = 2 * jStat.normal.cdf(ac, 0, 1, 1, 0); + var pminus= 2 * jStat.normal.cdf(ac, w, 1, 1, 0); - // Work out the partially-normalized hypergeometric PDF for the next - // number of successes - scaledPDF *= (n - i) * (m - i) / ((i + 1) * (N - m - n + i + 1)); - } + // if rinsum ^ (cc-1) < 9e-14, + // then doesn't contribute to integral - for(; samplesDone < n; samplesDone++) { - // Apply all the rest of the normalization - scaledPDF *= 1 - (m / (N - samplesDone)); + var rinsum = (pplus * 0.5) - (pminus * 0.5); + if (rinsum >= Math.exp(C1 / cc1)) { + rinsum = (aleg[j-1] * Math.exp(-(0.5 * qexpo))) * Math.pow(rinsum, cc1); + elsum += rinsum; } - - // Bound answer sanely before returning. - return Math.min(1, Math.max(0, scaledPDF)); } - }, + elsum *= (((2.0 * b) * cc) / Math.sqrt(2 * Math.PI)); + einsum += elsum; + blb = bub; + bub += binc; + } - cdf: function cdf(x, N, m, n) { - // Hypergeometric CDF. + // if pr_w ^ rr < 9e-14, then return 0 + pr_w += einsum; + if (pr_w <= Math.exp(C1 / rr)) + return 0; - // This algorithm is due to Prof. Thomas S. Ferguson, , - // and comes from his hypergeometric test calculator at - // . + pr_w = Math.pow(pr_w, rr); + if (pr_w >= 1) // 1 was iMax was eps + return 1; + return pr_w; +} - // x = number of successes drawn - // N = population size - // m = number of successes in population - // n = number of items drawn from population +function tukeyQinv(p, c, v) { + var p0 = 0.322232421088; + var q0 = 0.993484626060e-01; + var p1 = -1.0; + var q1 = 0.588581570495; + var p2 = -0.342242088547; + var q2 = 0.531103462366; + var p3 = -0.204231210125; + var q3 = 0.103537752850; + var p4 = -0.453642210148e-04; + var q4 = 0.38560700634e-02; + var c1 = 0.8832; + var c2 = 0.2368; + var c3 = 1.214; + var c4 = 1.208; + var c5 = 1.4142; + var vmax = 120.0; + + var ps = 0.5 - 0.5 * p; + var yi = Math.sqrt(Math.log(1.0 / (ps * ps))); + var t = yi + (((( yi * p4 + p3) * yi + p2) * yi + p1) * yi + p0) + / (((( yi * q4 + q3) * yi + q2) * yi + q1) * yi + q0); + if (v < vmax) t += (t * t * t + t) / v / 4.0; + var q = c1 - c2 * t; + if (v < vmax) q += -c3 / v + c4 * t / v; + return t * (q * Math.log(c - 1.0) + c5); +} - if(x < 0 || x < m - (N - n)) { - // It's impossible to have this few successes drawn or fewer. +jStat.extend(jStat.tukey, { + cdf: function cdf(q, nmeans, df) { + // Identical implementation as the R ptukey() function as of commit 68947 + var rr = 1; + var cc = nmeans; + + var nlegq = 16; + var ihalfq = 8; + + var eps1 = -30.0; + var eps2 = 1.0e-14; + var dhaf = 100.0; + var dquar = 800.0; + var deigh = 5000.0; + var dlarg = 25000.0; + var ulen1 = 1.0; + var ulen2 = 0.5; + var ulen3 = 0.25; + var ulen4 = 0.125; + var xlegq = [ + 0.989400934991649932596154173450, + 0.944575023073232576077988415535, + 0.865631202387831743880467897712, + 0.755404408355003033895101194847, + 0.617876244402643748446671764049, + 0.458016777657227386342419442984, + 0.281603550779258913230460501460, + 0.950125098376374401853193354250e-1 + ]; + var alegq = [ + 0.271524594117540948517805724560e-1, + 0.622535239386478928628438369944e-1, + 0.951585116824927848099251076022e-1, + 0.124628971255533872052476282192, + 0.149595988816576732081501730547, + 0.169156519395002538189312079030, + 0.182603415044923588866763667969, + 0.189450610455068496285396723208 + ]; + + if (q <= 0) return 0; - } else if(x >= n || x >= m) { - // We will always have this many successes or fewer. - return 1; - } else if (m * 2 > N) { - // More than half the population is successes. - if(n * 2 > N) { - // More than half the population is sampled. + // df must be > 1 + // there must be at least two values - return jStat.hypgeom.cdf(N - m - n + x, N, N - m, N - n) - } else { - // Half or less of the population is sampled. + if (df < 2 || rr < 1 || cc < 2) return NaN; - return 1 - jStat.hypgeom.cdf(n - x - 1, N, N - m, n); - } + if (!Number.isFinite(q)) + return 1; - } else if(n * 2 > N) { - // Half or less is successes. + if (df > dlarg) + return tukeyWprob(q, rr, cc); - return 1 - jStat.hypgeom.cdf(m - x - 1, N, m, N - n); + // calculate leading constant - } else if(m < n) { - // We want to have the number of things sampled to be less than the - // successes available. So swap the definitions of successful and sampled. - return jStat.hypgeom.cdf(x, N, n, m); - } else { - // If we get here, half or less of the population was sampled, half or - // less of it was successes, and we had fewer sampled things than - // successes. Now we can do this complicated iterative algorithm in an - // efficient way. + var f2 = df * 0.5; + var f2lf = ((f2 * Math.log(df)) - (df * Math.log(2))) - jStat.gammaln(f2); + var f21 = f2 - 1.0; - // The basic premise of the algorithm is that we partially normalize our - // intermediate sum to keep it in a numerically good region, and then - // finish the normalization at the end. + // integral is divided into unit, half-unit, quarter-unit, or + // eighth-unit length intervals depending on the value of the + // degrees of freedom. - // Holds the intermediate, scaled total CDF. - var scaledCDF = 1; + var ff4 = df * 0.25; + var ulen; + if (df <= dhaf) ulen = ulen1; + else if (df <= dquar) ulen = ulen2; + else if (df <= deigh) ulen = ulen3; + else ulen = ulen4; - // This variable holds the scaled probability of the current number of - // successes. - var scaledPDF = 1; + f2lf += Math.log(ulen); - // This keeps track of how much we have normalized. - var samplesDone = 0; + // integrate over each subinterval - for(var i = 0; i < x; i++) { - // For every possible number of successes up to that observed... + var ans = 0.0; - while(scaledCDF > 1 && samplesDone < n) { - // Intermediate result is growing too big. Apply some of the - // normalization to shrink everything. + for (var i = 1; i <= 50; i++) { + var otsum = 0.0; - var factor = 1 - (m / (N - samplesDone)); + // legendre quadrature with order = nlegq + // nodes (stored in xlegq) are symmetric around zero. - scaledPDF *= factor; - scaledCDF *= factor; + var twa1 = (2 * i - 1) * ulen; - // Say we've normalized by this sample already. - samplesDone++; + for (var jj = 1; jj <= nlegq; jj++) { + var j, t1; + if (ihalfq < jj) { + j = jj - ihalfq - 1; + t1 = (f2lf + (f21 * Math.log(twa1 + (xlegq[j] * ulen)))) + - (((xlegq[j] * ulen) + twa1) * ff4); + } else { + j = jj - 1; + t1 = (f2lf + (f21 * Math.log(twa1 - (xlegq[j] * ulen)))) + + (((xlegq[j] * ulen) - twa1) * ff4); } - // Work out the partially-normalized hypergeometric PDF for the next - // number of successes - scaledPDF *= (n - i) * (m - i) / ((i + 1) * (N - m - n + i + 1)); + // if exp(t1) < 9e-14, then doesn't contribute to integral + var qsqz; + if (t1 >= eps1) { + if (ihalfq < jj) { + qsqz = q * Math.sqrt(((xlegq[j] * ulen) + twa1) * 0.5); + } else { + qsqz = q * Math.sqrt(((-(xlegq[j] * ulen)) + twa1) * 0.5); + } - // Add to the CDF answer. - scaledCDF += scaledPDF; - } + // call wprob to find integral of range portion - for(; samplesDone < n; samplesDone++) { - // Apply all the rest of the normalization - scaledCDF *= 1 - (m / (N - samplesDone)); + var wprb = tukeyWprob(qsqz, rr, cc); + var rotsum = (wprb * alegq[j]) * Math.exp(t1); + otsum += rotsum; + } + // end legendre integral for interval i + // L200: } - // Bound answer sanely before returning. - return Math.min(1, Math.max(0, scaledCDF)); - } - } -}); - + // if integral for interval i < 1e-14, then stop. + // However, in order to avoid small area under left tail, + // at least 1 / ulen intervals are calculated. + if (i * ulen >= 1.0 && otsum <= eps2) + break; + // end of interval i + // L330: -// extend uniform function with static methods -jStat.extend(jStat.poisson, { - pdf: function pdf(k, l) { - if (l < 0 || (k % 1) !== 0 || k < 0) { - return 0; + ans += otsum; } - return Math.pow(l, k) * Math.exp(-l) / jStat.factorial(k); - }, - - cdf: function cdf(x, l) { - var sumarr = [], - k = 0; - if (x < 0) return 0; - for (; k <= x; k++) { - sumarr.push(jStat.poisson.pdf(k, l)); + if (otsum > eps2) { // not converged + throw new Error('tukey.cdf failed to converge'); } - return jStat.sum(sumarr); + if (ans > 1) + ans = 1; + return ans; }, - mean : function(l) { - return l; - }, + inv: function(p, nmeans, df) { + // Identical implementation as the R qtukey() function as of commit 68947 + var rr = 1; + var cc = nmeans; - variance : function(l) { - return l; - }, + var eps = 0.0001; + var maxiter = 50; - sample: function sample(l) { - var p = 1, k = 0, L = Math.exp(-l); - do { - k++; - p *= Math.random(); - } while (p > L); - return k - 1; - } -}); + // df must be > 1 ; there must be at least two values + if (df < 2 || rr < 1 || cc < 2) return NaN; -// extend triangular function with static methods -jStat.extend(jStat.triangular, { - pdf: function pdf(x, a, b, c) { - if (b <= a || c < a || c > b) { - return NaN; - } else { - if (x < a || x > b) { - return 0; - } else if (x < c) { - return (2 * (x - a)) / ((b - a) * (c - a)); - } else if (x === c) { - return (2 / (b - a)); - } else { // x > c - return (2 * (b - x)) / ((b - a) * (b - c)); - } - } - }, + if (p < 0 || p > 1) return NaN; + if (p === 0) return 0; + if (p === 1) return Infinity; - cdf: function cdf(x, a, b, c) { - if (b <= a || c < a || c > b) - return NaN; - if (x <= a) - return 0; - else if (x >= b) - return 1; - if (x <= c) - return Math.pow(x - a, 2) / ((b - a) * (c - a)); - else // x > c - return 1 - Math.pow(b - x, 2) / ((b - a) * (b - c)); - }, + // Initial value - inv: function inv(p, a, b, c) { - if (b <= a || c < a || c > b) { - return NaN; - } else { - if (p <= ((c - a) / (b - a))) { - return a + (b - a) * Math.sqrt(p * ((c - a) / (b - a))); - } else { // p > ((c - a) / (b - a)) - return a + (b - a) * (1 - Math.sqrt((1 - p) * (1 - ((c - a) / (b - a))))); - } - } - }, + var x0 = tukeyQinv(p, cc, df); - mean: function mean(a, b, c) { - return (a + b + c) / 3; - }, + // Find prob(value < x0) - median: function median(a, b, c) { - if (c <= (a + b) / 2) { - return b - Math.sqrt((b - a) * (b - c)) / Math.sqrt(2); - } else if (c > (a + b) / 2) { - return a + Math.sqrt((b - a) * (c - a)) / Math.sqrt(2); - } - }, + var valx0 = jStat.tukey.cdf(x0, nmeans, df) - p; - mode: function mode(a, b, c) { - return c; - }, + // Find the second iterate and prob(value < x1). + // If the first iterate has probability value + // exceeding p then second iterate is 1 less than + // first iterate; otherwise it is 1 greater. - sample: function sample(a, b, c) { - var u = Math.random(); - if (u < ((c - a) / (b - a))) - return a + Math.sqrt(u * (b - a) * (c - a)) - return b - Math.sqrt((1 - u) * (b - a) * (b - c)); - }, + var x1; + if (valx0 > 0.0) + x1 = Math.max(0.0, x0 - 1.0); + else + x1 = x0 + 1.0; + var valx1 = jStat.tukey.cdf(x1, nmeans, df) - p; - variance: function variance(a, b, c) { - return (a * a + b * b + c * c - a * b - a * c - b * c) / 18; - } -}); + // Find new iterate -function laplaceSign(x) { return x / Math.abs(x); } + var ans; + for(var iter = 1; iter < maxiter; iter++) { + ans = x1 - ((valx1 * (x1 - x0)) / (valx1 - valx0)); + valx0 = valx1; -jStat.extend(jStat.laplace, { - pdf: function pdf(x, mu, b) { - return (b <= 0) ? 0 : (Math.exp(-Math.abs(x - mu) / b)) / (2 * b); - }, - - cdf: function cdf(x, mu, b) { - if (b <= 0) { return 0; } - - if(x < mu) { - return 0.5 * Math.exp((x - mu) / b); - } else { - return 1 - 0.5 * Math.exp(- (x - mu) / b); - } - }, - - mean: function(mu, b) { - return mu; - }, + // New iterate must be >= 0 - median: function(mu, b) { - return mu; - }, + x0 = x1; + if (ans < 0.0) { + ans = 0.0; + valx1 = -p; + } + // Find prob(value < new iterate) - mode: function(mu, b) { - return mu; - }, + valx1 = jStat.tukey.cdf(ans, nmeans, df) - p; + x1 = ans; - variance: function(mu, b) { - return 2 * b * b; - }, + // If the difference between two successive + // iterates is less than eps, stop - sample: function sample(mu, b) { - var u = Math.random() - 0.5; + var xabs = Math.abs(x1 - x0); + if (xabs < eps) + return ans; + } - return mu - (b * laplaceSign(u) * Math.log(1 - (2 * Math.abs(u)))); + throw new Error('tukey.inv failed to converge'); } }); -}(this.jStat, Math)); +}(jStat, Math)); /* Provides functions for the solution of linear system of equations, integration, extrapolation, * interpolation, eigenvalue problems, differential equations and PCA analysis. */ @@ -9106,6 +9247,17 @@ jStat.extend({ return jStat.map(arr, function(value) { return value * arg; }); }, + outer:function(A,B){ + /* outer([1,2,3],[4,5,6]) + === + [[1],[2],[3]] times [[4,5,6]] + -> + [[4,5,6],[8,10,12],[12,15,18]] + */ + return jStat.multiply(A.map(function(t){return [t]}),[B]); + }, + + // outer([1,2,3],[4,5,6]) // === // [[1],[2],[3]] times [[4,5,6]] @@ -9300,6 +9452,7 @@ jStat.extend({ var m = jStat.aug(a, b), h = m.length, w = m[0].length; + var c = 0; // find max pivot for (var y = 0; y < h; y++) { var maxrow = y; @@ -9355,7 +9508,7 @@ jStat.extend({ } jStat.arange(size - 1, -1, -1).forEach(function(i) { - parts = jStat.arange(i + 1,size).map(function(j) { + parts = jStat.arange(i + 1, size).map(function(j) { return x[j] * A[i][j]; }); x[i] = (b[i] - jStat.sum(parts)) / A[i][i]; @@ -9390,6 +9543,7 @@ jStat.extend({ return x; }, + // A -> [L,U] // A=LU // L is lower triangular matrix @@ -9442,6 +9596,7 @@ jStat.extend({ return T; }, + gauss_jacobi: function gauss_jacobi(a, b, x, r) { var i = 0; var j = 0; @@ -9589,9 +9744,14 @@ jStat.extend({ // find a orthogonal matrix Q st. // Qx=y // y is [||x||,0,0,...] + + // quick ref + var sum = jStat.sum; + var range = jStat.arange; + function get_Q1(x) { var size = x.length; - var norm_x = jStat.norm(x,2); + var norm_x = jStat.norm(x, 2); var e1 = jStat.zeros(1, size)[0]; e1[0] = 1; var u = jStat.add(jStat.multiply(jStat.multiply(e1, norm_x), -1), x); @@ -9618,8 +9778,38 @@ jStat.extend({ return [Q, R]; } - return qr; - })(), + function qr2(x) { + // quick impletation + // https://www.stat.wisc.edu/~larget/math496/qr.html + + var n = x.length; + var p = x[0].length; + + x = jStat.copy(x); + r = jStat.zeros(p, p); + + var i,j,k; + for(j = 0; j < p; j++){ + r[j][j] = Math.sqrt(sum(range(n).map(function(i){ + return x[i][j] * x[i][j]; + }))); + for(i = 0; i < n; i++){ + x[i][j] = x[i][j] / r[j][j]; + } + for(k = j+1; k < p; k++){ + r[j][k] = sum(range(n).map(function(i){ + return x[i][j] * x[i][k]; + })); + for(i = 0; i < n; i++){ + x[i][k] = x[i][k] - x[i][j]*r[j][k]; + } + } + } + return [x, r]; + } + + return qr2; + }()), lstsq: (function(A, b) { // solve least squard problem for Ax=b as QR decomposition way if b is @@ -9661,14 +9851,26 @@ jStat.extend({ var Q1 = jStat.slice(Q,{col:{end:attrs}}); var R1 = jStat.slice(R,{row:{end:attrs}}); var RI = R_I(R1); - var x = jStat.multiply(jStat.multiply(RI, jStat.transpose(Q1)), b); + var Q2 = jStat.transpose(Q1); + + if(Q2[0].length === undefined){ + Q2 = [Q2]; // The confusing jStat.multifly implementation threat nature process again. + } + + var x = jStat.multiply(jStat.multiply(RI, Q2), b); + + if(x.length === undefined){ + x = [[x]]; // The confusing jStat.multifly implementation threat nature process again. + } + + if (array_mode) return x.map(function(i){ return i[0] }); return x; } return qr_solve; - })(), + }()), jacobi: function jacobi(a) { var condition = 1; @@ -9993,7 +10195,7 @@ jStat.extend({ }(funcs[i])); }('add divide multiply subtract dot pow exp log abs norm angle'.split(' '))); -}(this.jStat, Math)); +}(jStat, Math)); (function(jStat, Math) { var slice = [].slice; @@ -10192,6 +10394,72 @@ jStat.extend(jStat.fn, { } }); +// Tukey's range test +jStat.extend({ + // 2 parameter lists + // (mean1, mean2, n1, n2, sd) + // (array1, array2, sd) + qscore: function qscore() { + var args = slice.call(arguments); + var mean1, mean2, n1, n2, sd; + if (isNumber(args[0])) { + mean1 = args[0]; + mean2 = args[1]; + n1 = args[2]; + n2 = args[3]; + sd = args[4]; + } else { + mean1 = jStat.mean(args[0]); + mean2 = jStat.mean(args[1]); + n1 = args[0].length; + n2 = args[1].length; + sd = args[2]; + } + return Math.abs(mean1 - mean2) / (sd * Math.sqrt((1 / n1 + 1 / n2) / 2)); + }, + + // 3 different parameter lists: + // (qscore, n, k) + // (mean1, mean2, n1, n2, sd, n, k) + // (array1, array2, sd, n, k) + qtest: function qtest() { + var args = slice.call(arguments); + + var qscore; + if (args.length === 3) { + qscore = args[0]; + args = args.slice(1); + } else if (args.length === 7) { + qscore = jStat.qscore(args[0], args[1], args[2], args[3], args[4]); + args = args.slice(5); + } else { + qscore = jStat.qscore(args[0], args[1], args[2]); + args = args.slice(3); + } + + var n = args[0]; + var k = args[1]; + + return 1 - jStat.tukey.cdf(qscore, k, n - k); + }, + + tukeyhsd: function tukeyhsd(arrays) { + var sd = jStat.pooledstdev(arrays); + var means = arrays.map(function (arr) {return jStat.mean(arr);}); + var n = arrays.reduce(function (n, arr) {return n + arr.length;}, 0); + + var results = []; + for (var i = 0; i < arrays.length; ++i) { + for (var j = i + 1; j < arrays.length; ++j) { + var p = jStat.qtest(means[i], means[j], arrays[i].length, arrays[j].length, sd, n, arrays.length); + results.push([[i, j], p]); + } + } + + return results; + } +}); + // Error Bounds jStat.extend({ // 2 different parameter setups @@ -10270,8 +10538,8 @@ jStat.extend(jStat.fn, { } }); -}(this.jStat, Math)); -this.jStat.models=(function(){ +}(jStat, Math)); +jStat.models = (function(){ function sub_regress(endog, exog) { return ols(endog, exog); @@ -10387,4105 +10655,6524 @@ this.jStat.models=(function(){ return { ols: ols_wrap }; })(); + // Make it compatible with previous version. + jStat.jStat = jStat; + + return jStat; +}); /***/ }), -/* 14 */ +/* 12 */ /***/ (function(module, exports, __webpack_require__) { -/* WEBPACK VAR INJECTION */(function(process) {var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*! - * numbro.js - * version : 1.9.3 - * author : Företagsplatsen AB - * license : MIT - * http://www.foretagsplatsen.se - */ +var utils = __webpack_require__(1); +var numbro = __webpack_require__(9); +var error = __webpack_require__(0); -(function () { - 'use strict'; +exports.UNIQUE = function () { + var result = []; + for (var i = 0; i < arguments.length; ++i) { + var hasElement = false; + var element = arguments[i]; - /************************************ - Constants - ************************************/ + // Check if we've already seen this element. + for (var j = 0; j < result.length; ++j) { + hasElement = result[j] === element; + if (hasElement) { break; } + } - var numbro, - VERSION = '1.9.3', - binarySuffixes = ['B', 'KiB', 'MiB', 'GiB', 'TiB', 'PiB', 'EiB', 'ZiB', 'YiB'], - decimalSuffixes = ['B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'], - bytes = { - general: { scale: 1024, suffixes: decimalSuffixes, marker: 'bd' }, - binary: { scale: 1024, suffixes: binarySuffixes, marker: 'b' }, - decimal: { scale: 1000, suffixes: decimalSuffixes, marker: 'd' } - }, - // general must be before the others because it reuses their characters! - byteFormatOrder = [ bytes.general, bytes.binary, bytes.decimal ], - // internal storage for culture config files - cultures = {}, - // Todo: Remove in 2.0.0 - languages = cultures, - currentCulture = 'en-US', - zeroFormat = null, - defaultFormat = '0,0', - defaultCurrencyFormat = '0$', - // check for nodeJS - hasModule = (typeof module !== 'undefined' && module.exports), - // default culture - enUS = { - delimiters: { - thousands: ',', - decimal: '.' - }, - abbreviations: { - thousand: 'k', - million: 'm', - billion: 'b', - trillion: 't' - }, - ordinal: function(number) { - var b = number % 10; - return (~~(number % 100 / 10) === 1) ? 'th' : - (b === 1) ? 'st' : - (b === 2) ? 'nd' : - (b === 3) ? 'rd' : 'th'; - }, - currency: { - symbol: '$', - position: 'prefix' - }, - defaults: { - currencyFormat: ',0000 a' - }, - formats: { - fourDigits: '0000 a', - fullWithTwoDecimals: '$ ,0.00', - fullWithTwoDecimalsNoCurrency: ',0.00' - } - }; + // If we did not find it, add it to the result. + if (!hasElement) { + result.push(element); + } + } + return result; +}; - /************************************ - Constructors - ************************************/ +exports.FLATTEN = utils.flatten; +exports.ARGS2ARRAY = function () { + return Array.prototype.slice.call(arguments, 0); +}; - // Numbro prototype object - function Numbro(number) { - this._value = number; +exports.REFERENCE = function (context, reference) { + if (!arguments.length) { + return error.error; + } + try { + var path = reference.split('.'); + var result = context; + for (var i = 0; i < path.length; ++i) { + var step = path[i]; + if (step[step.length - 1] === ']') { + var opening = step.indexOf('['); + var index = step.substring(opening + 1, step.length - 1); + result = result[step.substring(0, opening)][index]; + } else { + result = result[step]; + } } + return result; + } catch (error) {} +}; - function zeroes(count) { - var i, ret = ''; +exports.JOIN = function (array, separator) { + return array.join(separator); +}; - for (i = 0; i < count; i++) { - ret += '0'; - } +exports.NUMBERS = function () { + var possibleNumbers = utils.flatten(arguments); + return possibleNumbers.filter(function (el) { + return typeof el === 'number'; + }); +}; - return ret; - } - /** - * Implementation of toFixed() for numbers with exponents - * This function may return negative representations for zero values e.g. "-0.0" - */ - function toFixedLargeSmall(value, precision) { - var mantissa, - beforeDec, - afterDec, - exponent, - prefix, - endStr, - zerosStr, - str; +exports.NUMERAL = function (number, format) { + return numbro(number).format(format); +}; - str = value.toString(); - mantissa = str.split('e')[0]; - exponent = str.split('e')[1]; +/***/ }), +/* 13 */ +/***/ (function(module, exports, __webpack_require__) { - beforeDec = mantissa.split('.')[0]; - afterDec = mantissa.split('.')[1] || ''; +var error = __webpack_require__(0); +var jStat = __webpack_require__(11).jStat; +var text = __webpack_require__(6); +var utils = __webpack_require__(1); +var bessel = __webpack_require__(88); - if (+exponent > 0) { - // exponent is positive - add zeros after the numbers - str = beforeDec + afterDec + zeroes(exponent - afterDec.length); - } else { - // exponent is negative +function isValidBinaryNumber(number) { + return (/^[01]{1,10}$/).test(number); +} - if (+beforeDec < 0) { - prefix = '-0'; - } else { - prefix = '0'; - } +exports.BESSELI = function(x, n) { + x = utils.parseNumber(x); + n = utils.parseNumber(n); + if (utils.anyIsError(x, n)) { + return error.value; + } - // tack on the decimal point if needed - if (precision > 0) { - prefix += '.'; - } + return bessel.besseli(x, n); +}; - zerosStr = zeroes((-1 * exponent) - 1); - // substring off the end to satisfy the precision - endStr = (zerosStr + Math.abs(beforeDec) + afterDec).substr(0, precision); - str = prefix + endStr; - } +exports.BESSELJ = function(x, n) { + x = utils.parseNumber(x); + n = utils.parseNumber(n); + if (utils.anyIsError(x, n)) { + return error.value; + } - // only add percision 0's if the exponent is positive - if (+exponent > 0 && precision > 0) { - str += '.' + zeroes(precision); - } + return bessel.besselj(x, n); +}; - return str; - } +exports.BESSELK = function(x, n) { + x = utils.parseNumber(x); + n = utils.parseNumber(n); + if (utils.anyIsError(x, n)) { + return error.value; + } - /** - * Implementation of toFixed() that treats floats more like decimals - * - * Fixes binary rounding issues (eg. (0.615).toFixed(2) === '0.61') that present - * problems for accounting- and finance-related software. - * - * Also removes negative signs for zero-formatted numbers. e.g. -0.01 w/ precision 1 -> 0.0 - */ - function toFixed(value, precision, roundingFunction, optionals) { - var power = Math.pow(10, precision), - optionalsRegExp, - output; + return bessel.besselk(x, n); +}; - if (value.toString().indexOf('e') > -1) { - // toFixed returns scientific notation for numbers above 1e21 and below 1e-7 - output = toFixedLargeSmall(value, precision); - // remove the leading negative sign if it exists and should not be present (e.g. -0.00) - if (output.charAt(0) === '-' && +output >= 0) { - output = output.substr(1); // chop off the '-' - } - } - else { - // Multiply up by precision, round accurately, then divide and use native toFixed(): - output = (roundingFunction(value + 'e+' + precision) / power).toFixed(precision); - } +exports.BESSELY = function(x, n) { + x = utils.parseNumber(x); + n = utils.parseNumber(n); + if (utils.anyIsError(x, n)) { + return error.value; + } - if (optionals) { - optionalsRegExp = new RegExp('0{1,' + optionals + '}$'); - output = output.replace(optionalsRegExp, ''); - } + return bessel.bessely(x, n); +}; - return output; - } +exports.BIN2DEC = function(number) { + // Return error if number is not binary or contains more than 10 characters (10 digits) + if (!isValidBinaryNumber(number)) { + return error.num; + } - /************************************ - Formatting - ************************************/ + // Convert binary number to decimal + var result = parseInt(number, 2); - // determine what type of formatting we need to do - function formatNumbro(n, format, roundingFunction) { - var output, - escapedFormat = format.replace(/\{[^\{\}]*\}/g, ''); + // Handle negative numbers + var stringified = number.toString(); + if (stringified.length === 10 && stringified.substring(0, 1) === '1') { + return parseInt(stringified.substring(1), 2) - 512; + } else { + return result; + } +}; - // figure out what kind of format we are dealing with - if (escapedFormat.indexOf('$') > -1) { // currency!!!!! - output = formatCurrency(n, cultures[currentCulture].currency.symbol, format, roundingFunction); - } else if (escapedFormat.indexOf('%') > -1) { // percentage - output = formatPercentage(n, format, roundingFunction); - } else if (escapedFormat.indexOf(':') > -1) { // time - output = formatTime(n, format); - } else { // plain ol' numbers or bytes - output = formatNumber(n._value, format, roundingFunction); - } - // return string - return output; +exports.BIN2HEX = function(number, places) { + // Return error if number is not binary or contains more than 10 characters (10 digits) + if (!isValidBinaryNumber(number)) { + return error.num; + } + + // Ignore places and return a 10-character hexadecimal number if number is negative + var stringified = number.toString(); + if (stringified.length === 10 && stringified.substring(0, 1) === '1') { + return (1099511627264 + parseInt(stringified.substring(1), 2)).toString(16); + } + + // Convert binary number to hexadecimal + var result = parseInt(number, 2).toString(16); + + // Return hexadecimal number using the minimum number of characters necessary if places is undefined + if (places === undefined) { + return result; + } else { + // Return error if places is nonnumeric + if (isNaN(places)) { + return error.value; } - // revert to number - function unformatNumbro(n, string) { - var stringOriginal = string, - thousandRegExp, - millionRegExp, - billionRegExp, - trillionRegExp, - bytesMultiplier = false, - power; + // Return error if places is negative + if (places < 0) { + return error.num; + } - if (string.indexOf(':') > -1) { - n._value = unformatTime(string); - } else { - if (string === zeroFormat) { - n._value = 0; - } else { - if (cultures[currentCulture].delimiters.decimal !== '.') { - string = string.replace(/\./g, '').replace(cultures[currentCulture].delimiters.decimal, '.'); - } + // Truncate places in case it is not an integer + places = Math.floor(places); - // see if abbreviations are there so that we can multiply to the correct number - thousandRegExp = new RegExp('[^a-zA-Z]' + cultures[currentCulture].abbreviations.thousand + - '(?:\\)|(\\' + cultures[currentCulture].currency.symbol + ')?(?:\\))?)?$'); - millionRegExp = new RegExp('[^a-zA-Z]' + cultures[currentCulture].abbreviations.million + - '(?:\\)|(\\' + cultures[currentCulture].currency.symbol + ')?(?:\\))?)?$'); - billionRegExp = new RegExp('[^a-zA-Z]' + cultures[currentCulture].abbreviations.billion + - '(?:\\)|(\\' + cultures[currentCulture].currency.symbol + ')?(?:\\))?)?$'); - trillionRegExp = new RegExp('[^a-zA-Z]' + cultures[currentCulture].abbreviations.trillion + - '(?:\\)|(\\' + cultures[currentCulture].currency.symbol + ')?(?:\\))?)?$'); + // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) + return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; + } +}; - // see if bytes are there so that we can multiply to the correct number - for (power = 1; power < binarySuffixes.length && !bytesMultiplier; ++power) { - if (string.indexOf(binarySuffixes[power]) > -1) { - bytesMultiplier = Math.pow(1024, power); - } else if (string.indexOf(decimalSuffixes[power]) > -1) { - bytesMultiplier = Math.pow(1000, power); - } - } +exports.BIN2OCT = function(number, places) { + // Return error if number is not binary or contains more than 10 characters (10 digits) + if (!isValidBinaryNumber(number)) { + return error.num; + } - var str = string.replace(/[^0-9\.]+/g, ''); - if (str === '') { - // An empty string is not a number. - n._value = NaN; + // Ignore places and return a 10-character octal number if number is negative + var stringified = number.toString(); + if (stringified.length === 10 && stringified.substring(0, 1) === '1') { + return (1073741312 + parseInt(stringified.substring(1), 2)).toString(8); + } - } else { - // do some math to create our number - n._value = ((bytesMultiplier) ? bytesMultiplier : 1) * - ((stringOriginal.match(thousandRegExp)) ? Math.pow(10, 3) : 1) * - ((stringOriginal.match(millionRegExp)) ? Math.pow(10, 6) : 1) * - ((stringOriginal.match(billionRegExp)) ? Math.pow(10, 9) : 1) * - ((stringOriginal.match(trillionRegExp)) ? Math.pow(10, 12) : 1) * - ((string.indexOf('%') > -1) ? 0.01 : 1) * - (((string.split('-').length + - Math.min(string.split('(').length - 1, string.split(')').length - 1)) % 2) ? 1 : -1) * - Number(str); + // Convert binary number to octal + var result = parseInt(number, 2).toString(8); - // round if we are talking about bytes - n._value = (bytesMultiplier) ? Math.ceil(n._value) : n._value; - } - } - } - return n._value; + // Return octal number using the minimum number of characters necessary if places is undefined + if (places === undefined) { + return result; + } else { + // Return error if places is nonnumeric + if (isNaN(places)) { + return error.value; } - function formatCurrency(n, currencySymbol, originalFormat, roundingFunction) { - var format = originalFormat, - symbolIndex = format.indexOf('$'), - openParenIndex = format.indexOf('('), - plusSignIndex = format.indexOf('+'), - minusSignIndex = format.indexOf('-'), - space = '', - decimalSeparator = '', - spliceIndex, - output; + // Return error if places is negative + if (places < 0) { + return error.num; + } - if(format.indexOf('$') === -1){ - // Use defaults instead of the format provided - if (cultures[currentCulture].currency.position === 'infix') { - decimalSeparator = currencySymbol; - if (cultures[currentCulture].currency.spaceSeparated) { - decimalSeparator = ' ' + decimalSeparator + ' '; - } - } else if (cultures[currentCulture].currency.spaceSeparated) { - space = ' '; - } - } else { - // check for space before or after currency - if (format.indexOf(' $') > -1) { - space = ' '; - format = format.replace(' $', ''); - } else if (format.indexOf('$ ') > -1) { - space = ' '; - format = format.replace('$ ', ''); - } else { - format = format.replace('$', ''); - } - } + // Truncate places in case it is not an integer + places = Math.floor(places); - // Format The Number - output = formatNumber(n._value, format, roundingFunction, decimalSeparator); + // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) + return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; + } +}; - if (originalFormat.indexOf('$') === -1) { - // Use defaults instead of the format provided - switch (cultures[currentCulture].currency.position) { - case 'postfix': - if (output.indexOf(')') > -1) { - output = output.split(''); - output.splice(-1, 0, space + currencySymbol); - output = output.join(''); - } else { - output = output + space + currencySymbol; - } - break; - case 'infix': - break; - case 'prefix': - if (output.indexOf('(') > -1 || output.indexOf('-') > -1) { - output = output.split(''); - spliceIndex = Math.max(openParenIndex, minusSignIndex) + 1; - - output.splice(spliceIndex, 0, currencySymbol + space); - output = output.join(''); - } else { - output = currencySymbol + space + output; - } - break; - default: - throw Error('Currency position should be among ["prefix", "infix", "postfix"]'); - } - } else { - // position the symbol - if (symbolIndex <= 1) { - if (output.indexOf('(') > -1 || output.indexOf('+') > -1 || output.indexOf('-') > -1) { - output = output.split(''); - spliceIndex = 1; - if (symbolIndex < openParenIndex || symbolIndex < plusSignIndex || symbolIndex < minusSignIndex) { - // the symbol appears before the "(", "+" or "-" - spliceIndex = 0; - } - output.splice(spliceIndex, 0, currencySymbol + space); - output = output.join(''); - } else { - output = currencySymbol + space + output; - } - } else { - if (output.indexOf(')') > -1) { - output = output.split(''); - output.splice(-1, 0, space + currencySymbol); - output = output.join(''); - } else { - output = output + space + currencySymbol; - } - } - } +exports.BITAND = function(number1, number2) { + // Return error if either number is a non-numeric value + number1 = utils.parseNumber(number1); + number2 = utils.parseNumber(number2); + if (utils.anyIsError(number1, number2)) { + return error.value; + } - return output; - } + // Return error if either number is less than 0 + if (number1 < 0 || number2 < 0) { + return error.num; + } - function formatForeignCurrency(n, foreignCurrencySymbol, originalFormat, roundingFunction) { - return formatCurrency(n, foreignCurrencySymbol, originalFormat, roundingFunction); - } + // Return error if either number is a non-integer + if (Math.floor(number1) !== number1 || Math.floor(number2) !== number2) { + return error.num; + } - function formatPercentage(n, format, roundingFunction) { - var space = '', - output, - value = n._value * 100; + // Return error if either number is greater than (2^48)-1 + if (number1 > 281474976710655 || number2 > 281474976710655) { + return error.num; + } - // check for space before % - if (format.indexOf(' %') > -1) { - space = ' '; - format = format.replace(' %', ''); - } else { - format = format.replace('%', ''); - } + // Return bitwise AND of two numbers + return number1 & number2; +}; - output = formatNumber(value, format, roundingFunction); +exports.BITLSHIFT = function(number, shift) { + number = utils.parseNumber(number); + shift = utils.parseNumber(shift); + if (utils.anyIsError(number, shift)) { + return error.value; + } - if (output.indexOf(')') > -1) { - output = output.split(''); - output.splice(-1, 0, space + '%'); - output = output.join(''); - } else { - output = output + space + '%'; - } + // Return error if number is less than 0 + if (number < 0) { + return error.num; + } - return output; - } + // Return error if number is a non-integer + if (Math.floor(number) !== number) { + return error.num; + } - function formatTime(n) { - var hours = Math.floor(n._value / 60 / 60), - minutes = Math.floor((n._value - (hours * 60 * 60)) / 60), - seconds = Math.round(n._value - (hours * 60 * 60) - (minutes * 60)); - return hours + ':' + - ((minutes < 10) ? '0' + minutes : minutes) + ':' + - ((seconds < 10) ? '0' + seconds : seconds); - } + // Return error if number is greater than (2^48)-1 + if (number > 281474976710655) { + return error.num; + } - function unformatTime(string) { - var timeArray = string.split(':'), - seconds = 0; - // turn hours and minutes into seconds and add them all up - if (timeArray.length === 3) { - // hours - seconds = seconds + (Number(timeArray[0]) * 60 * 60); - // minutes - seconds = seconds + (Number(timeArray[1]) * 60); - // seconds - seconds = seconds + Number(timeArray[2]); - } else if (timeArray.length === 2) { - // minutes - seconds = seconds + (Number(timeArray[0]) * 60); - // seconds - seconds = seconds + Number(timeArray[1]); - } - return Number(seconds); - } + // Return error if the absolute value of shift is greater than 53 + if (Math.abs(shift) > 53) { + return error.num; + } - function formatByteUnits (value, suffixes, scale) { - var suffix = suffixes[0], - power, - min, - max, - abs = Math.abs(value); + // Return number shifted by shift bits to the left or to the right if shift is negative + return (shift >= 0) ? number << shift : number >> -shift; +}; - if (abs >= scale) { - for (power = 1; power < suffixes.length; ++power) { - min = Math.pow(scale, power); - max = Math.pow(scale, power + 1); +exports.BITOR = function(number1, number2) { + number1 = utils.parseNumber(number1); + number2 = utils.parseNumber(number2); + if (utils.anyIsError(number1, number2)) { + return error.value; + } - if (abs >= min && abs < max) { - suffix = suffixes[power]; - value = value / min; - break; - } - } + // Return error if either number is less than 0 + if (number1 < 0 || number2 < 0) { + return error.num; + } - // values greater than or equal to [scale] YB never set the suffix - if (suffix === suffixes[0]) { - value = value / Math.pow(scale, suffixes.length - 1); - suffix = suffixes[suffixes.length - 1]; - } - } + // Return error if either number is a non-integer + if (Math.floor(number1) !== number1 || Math.floor(number2) !== number2) { + return error.num; + } - return { value: value, suffix: suffix }; - } + // Return error if either number is greater than (2^48)-1 + if (number1 > 281474976710655 || number2 > 281474976710655) { + return error.num; + } - function formatNumber (value, format, roundingFunction, sep) { - var negP = false, - signed = false, - optDec = false, - abbr = '', - abbrK = false, // force abbreviation to thousands - abbrM = false, // force abbreviation to millions - abbrB = false, // force abbreviation to billions - abbrT = false, // force abbreviation to trillions - abbrForce = false, // force abbreviation - bytes = '', - byteFormat, - units, - ord = '', - abs = Math.abs(value), - totalLength, - length, - minimumPrecision, - pow, - w, - intPrecision, - precision, - prefix, - postfix, - thousands, - d = '', - forcedNeg = false, - neg = false, - indexOpenP, - size, - indexMinus, - paren = '', - minlen, - i; + // Return bitwise OR of two numbers + return number1 | number2; +}; - // check if number is zero and a custom zero format has been set - if (value === 0 && zeroFormat !== null) { - return zeroFormat; - } +exports.BITRSHIFT = function(number, shift) { + number = utils.parseNumber(number); + shift = utils.parseNumber(shift); + if (utils.anyIsError(number, shift)) { + return error.value; + } - if (!isFinite(value)) { - return '' + value; - } + // Return error if number is less than 0 + if (number < 0) { + return error.num; + } - if (format.indexOf('{') === 0) { - var end = format.indexOf('}'); - if (end === -1) { - throw Error('Format should also contain a "}"'); - } - prefix = format.slice(1, end); - format = format.slice(end + 1); - } else { - prefix = ''; - } + // Return error if number is a non-integer + if (Math.floor(number) !== number) { + return error.num; + } - if (format.indexOf('}') === format.length - 1) { - var start = format.indexOf('{'); - if (start === -1) { - throw Error('Format should also contain a "{"'); - } - postfix = format.slice(start + 1, -1); - format = format.slice(0, start + 1); - } else { - postfix = ''; - } + // Return error if number is greater than (2^48)-1 + if (number > 281474976710655) { + return error.num; + } + + // Return error if the absolute value of shift is greater than 53 + if (Math.abs(shift) > 53) { + return error.num; + } + + // Return number shifted by shift bits to the right or to the left if shift is negative + return (shift >= 0) ? number >> shift : number << -shift; +}; + +exports.BITXOR = function(number1, number2) { + number1 = utils.parseNumber(number1); + number2 = utils.parseNumber(number2); + if (utils.anyIsError(number1, number2)) { + return error.value; + } + + // Return error if either number is less than 0 + if (number1 < 0 || number2 < 0) { + return error.num; + } + + // Return error if either number is a non-integer + if (Math.floor(number1) !== number1 || Math.floor(number2) !== number2) { + return error.num; + } + + // Return error if either number is greater than (2^48)-1 + if (number1 > 281474976710655 || number2 > 281474976710655) { + return error.num; + } + + // Return bitwise XOR of two numbers + return number1 ^ number2; +}; + +exports.COMPLEX = function(real, imaginary, suffix) { + real = utils.parseNumber(real); + imaginary = utils.parseNumber(imaginary); + if (utils.anyIsError(real, imaginary)) { + return real; + } + + // Set suffix + suffix = (suffix === undefined) ? 'i' : suffix; + + // Return error if suffix is neither "i" nor "j" + if (suffix !== 'i' && suffix !== 'j') { + return error.value; + } + + // Return complex number + if (real === 0 && imaginary === 0) { + return 0; + } else if (real === 0) { + return (imaginary === 1) ? suffix : imaginary.toString() + suffix; + } else if (imaginary === 0) { + return real.toString(); + } else { + var sign = (imaginary > 0) ? '+' : ''; + return real.toString() + sign + ((imaginary === 1) ? suffix : imaginary.toString() + suffix); + } +}; + +exports.CONVERT = function(number, from_unit, to_unit) { + number = utils.parseNumber(number); + if (number instanceof Error) { + return number; + } + + // List of units supported by CONVERT and units defined by the International System of Units + // [Name, Symbol, Alternate symbols, Quantity, ISU, CONVERT, Conversion ratio] + var units = [ + ["a.u. of action", "?", null, "action", false, false, 1.05457168181818e-34], + ["a.u. of charge", "e", null, "electric_charge", false, false, 1.60217653141414e-19], + ["a.u. of energy", "Eh", null, "energy", false, false, 4.35974417757576e-18], + ["a.u. of length", "a?", null, "length", false, false, 5.29177210818182e-11], + ["a.u. of mass", "m?", null, "mass", false, false, 9.10938261616162e-31], + ["a.u. of time", "?/Eh", null, "time", false, false, 2.41888432650516e-17], + ["admiralty knot", "admkn", null, "speed", false, true, 0.514773333], + ["ampere", "A", null, "electric_current", true, false, 1], + ["ampere per meter", "A/m", null, "magnetic_field_intensity", true, false, 1], + ["ångström", "Å", ["ang"], "length", false, true, 1e-10], + ["are", "ar", null, "area", false, true, 100], + ["astronomical unit", "ua", null, "length", false, false, 1.49597870691667e-11], + ["bar", "bar", null, "pressure", false, false, 100000], + ["barn", "b", null, "area", false, false, 1e-28], + ["becquerel", "Bq", null, "radioactivity", true, false, 1], + ["bit", "bit", ["b"], "information", false, true, 1], + ["btu", "BTU", ["btu"], "energy", false, true, 1055.05585262], + ["byte", "byte", null, "information", false, true, 8], + ["candela", "cd", null, "luminous_intensity", true, false, 1], + ["candela per square metre", "cd/m?", null, "luminance", true, false, 1], + ["coulomb", "C", null, "electric_charge", true, false, 1], + ["cubic ångström", "ang3", ["ang^3"], "volume", false, true, 1e-30], + ["cubic foot", "ft3", ["ft^3"], "volume", false, true, 0.028316846592], + ["cubic inch", "in3", ["in^3"], "volume", false, true, 0.000016387064], + ["cubic light-year", "ly3", ["ly^3"], "volume", false, true, 8.46786664623715e-47], + ["cubic metre", "m?", null, "volume", true, true, 1], + ["cubic mile", "mi3", ["mi^3"], "volume", false, true, 4168181825.44058], + ["cubic nautical mile", "Nmi3", ["Nmi^3"], "volume", false, true, 6352182208], + ["cubic Pica", "Pica3", ["Picapt3", "Pica^3", "Picapt^3"], "volume", false, true, 7.58660370370369e-8], + ["cubic yard", "yd3", ["yd^3"], "volume", false, true, 0.764554857984], + ["cup", "cup", null, "volume", false, true, 0.0002365882365], + ["dalton", "Da", ["u"], "mass", false, false, 1.66053886282828e-27], + ["day", "d", ["day"], "time", false, true, 86400], + ["degree", "°", null, "angle", false, false, 0.0174532925199433], + ["degrees Rankine", "Rank", null, "temperature", false, true, 0.555555555555556], + ["dyne", "dyn", ["dy"], "force", false, true, 0.00001], + ["electronvolt", "eV", ["ev"], "energy", false, true, 1.60217656514141], + ["ell", "ell", null, "length", false, true, 1.143], + ["erg", "erg", ["e"], "energy", false, true, 1e-7], + ["farad", "F", null, "electric_capacitance", true, false, 1], + ["fluid ounce", "oz", null, "volume", false, true, 0.0000295735295625], + ["foot", "ft", null, "length", false, true, 0.3048], + ["foot-pound", "flb", null, "energy", false, true, 1.3558179483314], + ["gal", "Gal", null, "acceleration", false, false, 0.01], + ["gallon", "gal", null, "volume", false, true, 0.003785411784], + ["gauss", "G", ["ga"], "magnetic_flux_density", false, true, 1], + ["grain", "grain", null, "mass", false, true, 0.0000647989], + ["gram", "g", null, "mass", false, true, 0.001], + ["gray", "Gy", null, "absorbed_dose", true, false, 1], + ["gross registered ton", "GRT", ["regton"], "volume", false, true, 2.8316846592], + ["hectare", "ha", null, "area", false, true, 10000], + ["henry", "H", null, "inductance", true, false, 1], + ["hertz", "Hz", null, "frequency", true, false, 1], + ["horsepower", "HP", ["h"], "power", false, true, 745.69987158227], + ["horsepower-hour", "HPh", ["hh", "hph"], "energy", false, true, 2684519.538], + ["hour", "h", ["hr"], "time", false, true, 3600], + ["imperial gallon (U.K.)", "uk_gal", null, "volume", false, true, 0.00454609], + ["imperial hundredweight", "lcwt", ["uk_cwt", "hweight"], "mass", false, true, 50.802345], + ["imperial quart (U.K)", "uk_qt", null, "volume", false, true, 0.0011365225], + ["imperial ton", "brton", ["uk_ton", "LTON"], "mass", false, true, 1016.046909], + ["inch", "in", null, "length", false, true, 0.0254], + ["international acre", "uk_acre", null, "area", false, true, 4046.8564224], + ["IT calorie", "cal", null, "energy", false, true, 4.1868], + ["joule", "J", null, "energy", true, true, 1], + ["katal", "kat", null, "catalytic_activity", true, false, 1], + ["kelvin", "K", ["kel"], "temperature", true, true, 1], + ["kilogram", "kg", null, "mass", true, true, 1], + ["knot", "kn", null, "speed", false, true, 0.514444444444444], + ["light-year", "ly", null, "length", false, true, 9460730472580800], + ["litre", "L", ["l", "lt"], "volume", false, true, 0.001], + ["lumen", "lm", null, "luminous_flux", true, false, 1], + ["lux", "lx", null, "illuminance", true, false, 1], + ["maxwell", "Mx", null, "magnetic_flux", false, false, 1e-18], + ["measurement ton", "MTON", null, "volume", false, true, 1.13267386368], + ["meter per hour", "m/h", ["m/hr"], "speed", false, true, 0.00027777777777778], + ["meter per second", "m/s", ["m/sec"], "speed", true, true, 1], + ["meter per second squared", "m?s??", null, "acceleration", true, false, 1], + ["parsec", "pc", ["parsec"], "length", false, true, 30856775814671900], + ["meter squared per second", "m?/s", null, "kinematic_viscosity", true, false, 1], + ["metre", "m", null, "length", true, true, 1], + ["miles per hour", "mph", null, "speed", false, true, 0.44704], + ["millimetre of mercury", "mmHg", null, "pressure", false, false, 133.322], + ["minute", "?", null, "angle", false, false, 0.000290888208665722], + ["minute", "min", ["mn"], "time", false, true, 60], + ["modern teaspoon", "tspm", null, "volume", false, true, 0.000005], + ["mole", "mol", null, "amount_of_substance", true, false, 1], + ["morgen", "Morgen", null, "area", false, true, 2500], + ["n.u. of action", "?", null, "action", false, false, 1.05457168181818e-34], + ["n.u. of mass", "m?", null, "mass", false, false, 9.10938261616162e-31], + ["n.u. of speed", "c?", null, "speed", false, false, 299792458], + ["n.u. of time", "?/(me?c??)", null, "time", false, false, 1.28808866778687e-21], + ["nautical mile", "M", ["Nmi"], "length", false, true, 1852], + ["newton", "N", null, "force", true, true, 1], + ["œrsted", "Oe ", null, "magnetic_field_intensity", false, false, 79.5774715459477], + ["ohm", "Ω", null, "electric_resistance", true, false, 1], + ["ounce mass", "ozm", null, "mass", false, true, 0.028349523125], + ["pascal", "Pa", null, "pressure", true, false, 1], + ["pascal second", "Pa?s", null, "dynamic_viscosity", true, false, 1], + ["pferdestärke", "PS", null, "power", false, true, 735.49875], + ["phot", "ph", null, "illuminance", false, false, 0.0001], + ["pica (1/6 inch)", "pica", null, "length", false, true, 0.00035277777777778], + ["pica (1/72 inch)", "Pica", ["Picapt"], "length", false, true, 0.00423333333333333], + ["poise", "P", null, "dynamic_viscosity", false, false, 0.1], + ["pond", "pond", null, "force", false, true, 0.00980665], + ["pound force", "lbf", null, "force", false, true, 4.4482216152605], + ["pound mass", "lbm", null, "mass", false, true, 0.45359237], + ["quart", "qt", null, "volume", false, true, 0.000946352946], + ["radian", "rad", null, "angle", true, false, 1], + ["second", "?", null, "angle", false, false, 0.00000484813681109536], + ["second", "s", ["sec"], "time", true, true, 1], + ["short hundredweight", "cwt", ["shweight"], "mass", false, true, 45.359237], + ["siemens", "S", null, "electrical_conductance", true, false, 1], + ["sievert", "Sv", null, "equivalent_dose", true, false, 1], + ["slug", "sg", null, "mass", false, true, 14.59390294], + ["square ångström", "ang2", ["ang^2"], "area", false, true, 1e-20], + ["square foot", "ft2", ["ft^2"], "area", false, true, 0.09290304], + ["square inch", "in2", ["in^2"], "area", false, true, 0.00064516], + ["square light-year", "ly2", ["ly^2"], "area", false, true, 8.95054210748189e+31], + ["square meter", "m?", null, "area", true, true, 1], + ["square mile", "mi2", ["mi^2"], "area", false, true, 2589988.110336], + ["square nautical mile", "Nmi2", ["Nmi^2"], "area", false, true, 3429904], + ["square Pica", "Pica2", ["Picapt2", "Pica^2", "Picapt^2"], "area", false, true, 0.00001792111111111], + ["square yard", "yd2", ["yd^2"], "area", false, true, 0.83612736], + ["statute mile", "mi", null, "length", false, true, 1609.344], + ["steradian", "sr", null, "solid_angle", true, false, 1], + ["stilb", "sb", null, "luminance", false, false, 0.0001], + ["stokes", "St", null, "kinematic_viscosity", false, false, 0.0001], + ["stone", "stone", null, "mass", false, true, 6.35029318], + ["tablespoon", "tbs", null, "volume", false, true, 0.0000147868], + ["teaspoon", "tsp", null, "volume", false, true, 0.00000492892], + ["tesla", "T", null, "magnetic_flux_density", true, true, 1], + ["thermodynamic calorie", "c", null, "energy", false, true, 4.184], + ["ton", "ton", null, "mass", false, true, 907.18474], + ["tonne", "t", null, "mass", false, false, 1000], + ["U.K. pint", "uk_pt", null, "volume", false, true, 0.00056826125], + ["U.S. bushel", "bushel", null, "volume", false, true, 0.03523907], + ["U.S. oil barrel", "barrel", null, "volume", false, true, 0.158987295], + ["U.S. pint", "pt", ["us_pt"], "volume", false, true, 0.000473176473], + ["U.S. survey mile", "survey_mi", null, "length", false, true, 1609.347219], + ["U.S. survey/statute acre", "us_acre", null, "area", false, true, 4046.87261], + ["volt", "V", null, "voltage", true, false, 1], + ["watt", "W", null, "power", true, true, 1], + ["watt-hour", "Wh", ["wh"], "energy", false, true, 3600], + ["weber", "Wb", null, "magnetic_flux", true, false, 1], + ["yard", "yd", null, "length", false, true, 0.9144], + ["year", "yr", null, "time", false, true, 31557600] + ]; + + // Binary prefixes + // [Name, Prefix power of 2 value, Previx value, Abbreviation, Derived from] + var binary_prefixes = { + Yi: ["yobi", 80, 1208925819614629174706176, "Yi", "yotta"], + Zi: ["zebi", 70, 1180591620717411303424, "Zi", "zetta"], + Ei: ["exbi", 60, 1152921504606846976, "Ei", "exa"], + Pi: ["pebi", 50, 1125899906842624, "Pi", "peta"], + Ti: ["tebi", 40, 1099511627776, "Ti", "tera"], + Gi: ["gibi", 30, 1073741824, "Gi", "giga"], + Mi: ["mebi", 20, 1048576, "Mi", "mega"], + ki: ["kibi", 10, 1024, "ki", "kilo"] + }; + + // Unit prefixes + // [Name, Multiplier, Abbreviation] + var unit_prefixes = { + Y: ["yotta", 1e+24, "Y"], + Z: ["zetta", 1e+21, "Z"], + E: ["exa", 1e+18, "E"], + P: ["peta", 1e+15, "P"], + T: ["tera", 1e+12, "T"], + G: ["giga", 1e+09, "G"], + M: ["mega", 1e+06, "M"], + k: ["kilo", 1e+03, "k"], + h: ["hecto", 1e+02, "h"], + e: ["dekao", 1e+01, "e"], + d: ["deci", 1e-01, "d"], + c: ["centi", 1e-02, "c"], + m: ["milli", 1e-03, "m"], + u: ["micro", 1e-06, "u"], + n: ["nano", 1e-09, "n"], + p: ["pico", 1e-12, "p"], + f: ["femto", 1e-15, "f"], + a: ["atto", 1e-18, "a"], + z: ["zepto", 1e-21, "z"], + y: ["yocto", 1e-24, "y"] + }; + + // Initialize units and multipliers + var from = null; + var to = null; + var base_from_unit = from_unit; + var base_to_unit = to_unit; + var from_multiplier = 1; + var to_multiplier = 1; + var alt; + + // Lookup from and to units + for (var i = 0; i < units.length; i++) { + alt = (units[i][2] === null) ? [] : units[i][2]; + if (units[i][1] === base_from_unit || alt.indexOf(base_from_unit) >= 0) { + from = units[i]; + } + if (units[i][1] === base_to_unit || alt.indexOf(base_to_unit) >= 0) { + to = units[i]; + } + } + + // Lookup from prefix + if (from === null) { + var from_binary_prefix = binary_prefixes[from_unit.substring(0, 2)]; + var from_unit_prefix = unit_prefixes[from_unit.substring(0, 1)]; + + // Handle dekao unit prefix (only unit prefix with two characters) + if (from_unit.substring(0, 2) === 'da') { + from_unit_prefix = ["dekao", 1e+01, "da"]; + } + + // Handle binary prefixes first (so that 'Yi' is processed before 'Y') + if (from_binary_prefix) { + from_multiplier = from_binary_prefix[2]; + base_from_unit = from_unit.substring(2); + } else if (from_unit_prefix) { + from_multiplier = from_unit_prefix[1]; + base_from_unit = from_unit.substring(from_unit_prefix[2].length); + } + + // Lookup from unit + for (var j = 0; j < units.length; j++) { + alt = (units[j][2] === null) ? [] : units[j][2]; + if (units[j][1] === base_from_unit || alt.indexOf(base_from_unit) >= 0) { + from = units[j]; + } + } + } + + // Lookup to prefix + if (to === null) { + var to_binary_prefix = binary_prefixes[to_unit.substring(0, 2)]; + var to_unit_prefix = unit_prefixes[to_unit.substring(0, 1)]; + + // Handle dekao unit prefix (only unit prefix with two characters) + if (to_unit.substring(0, 2) === 'da') { + to_unit_prefix = ["dekao", 1e+01, "da"]; + } + + // Handle binary prefixes first (so that 'Yi' is processed before 'Y') + if (to_binary_prefix) { + to_multiplier = to_binary_prefix[2]; + base_to_unit = to_unit.substring(2); + } else if (to_unit_prefix) { + to_multiplier = to_unit_prefix[1]; + base_to_unit = to_unit.substring(to_unit_prefix[2].length); + } + + // Lookup to unit + for (var k = 0; k < units.length; k++) { + alt = (units[k][2] === null) ? [] : units[k][2]; + if (units[k][1] === base_to_unit || alt.indexOf(base_to_unit) >= 0) { + to = units[k]; + } + } + } + + // Return error if a unit does not exist + if (from === null || to === null) { + return error.na; + } + + // Return error if units represent different quantities + if (from[3] !== to[3]) { + return error.na; + } + + // Return converted number + return number * from[6] * from_multiplier / (to[6] * to_multiplier); +}; + +exports.DEC2BIN = function(number, places) { + number = utils.parseNumber(number); + if (number instanceof Error) { + return number; + } + + // Return error if number is not decimal, is lower than -512, or is greater than 511 + if (!/^-?[0-9]{1,3}$/.test(number) || number < -512 || number > 511) { + return error.num; + } + + // Ignore places and return a 10-character binary number if number is negative + if (number < 0) { + return '1' + text.REPT('0', 9 - (512 + number).toString(2).length) + (512 + number).toString(2); + } + + // Convert decimal number to binary + var result = parseInt(number, 10).toString(2); + + // Return binary number using the minimum number of characters necessary if places is undefined + if (typeof places === 'undefined') { + return result; + } else { + // Return error if places is nonnumeric + if (isNaN(places)) { + return error.value; + } + + // Return error if places is negative + if (places < 0) { + return error.num; + } + + // Truncate places in case it is not an integer + places = Math.floor(places); + + // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) + return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; + } +}; + +exports.DEC2HEX = function(number, places) { + number = utils.parseNumber(number); + if (number instanceof Error) { + return number; + } + + // Return error if number is not decimal, is lower than -549755813888, or is greater than 549755813887 + if (!/^-?[0-9]{1,12}$/.test(number) || number < -549755813888 || number > 549755813887) { + return error.num; + } + + // Ignore places and return a 10-character hexadecimal number if number is negative + if (number < 0) { + return (1099511627776 + number).toString(16); + } + + // Convert decimal number to hexadecimal + var result = parseInt(number, 10).toString(16); + + // Return hexadecimal number using the minimum number of characters necessary if places is undefined + if (typeof places === 'undefined') { + return result; + } else { + // Return error if places is nonnumeric + if (isNaN(places)) { + return error.value; + } + + // Return error if places is negative + if (places < 0) { + return error.num; + } + + // Truncate places in case it is not an integer + places = Math.floor(places); + + // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) + return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; + } +}; + +exports.DEC2OCT = function(number, places) { + number = utils.parseNumber(number); + if (number instanceof Error) { + return number; + } + + // Return error if number is not decimal, is lower than -549755813888, or is greater than 549755813887 + if (!/^-?[0-9]{1,9}$/.test(number) || number < -536870912 || number > 536870911) { + return error.num; + } + + // Ignore places and return a 10-character octal number if number is negative + if (number < 0) { + return (1073741824 + number).toString(8); + } + + // Convert decimal number to octal + var result = parseInt(number, 10).toString(8); + + // Return octal number using the minimum number of characters necessary if places is undefined + if (typeof places === 'undefined') { + return result; + } else { + // Return error if places is nonnumeric + if (isNaN(places)) { + return error.value; + } + + // Return error if places is negative + if (places < 0) { + return error.num; + } + + // Truncate places in case it is not an integer + places = Math.floor(places); + + // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) + return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; + } +}; + +exports.DELTA = function(number1, number2) { + // Set number2 to zero if undefined + number2 = (number2 === undefined) ? 0 : number2; + number1 = utils.parseNumber(number1); + number2 = utils.parseNumber(number2); + if (utils.anyIsError(number1, number2)) { + return error.value; + } + + // Return delta + return (number1 === number2) ? 1 : 0; +}; + +// TODO: why is upper_bound not used ? The excel documentation has no examples with upper_bound +exports.ERF = function(lower_bound, upper_bound) { + // Set number2 to zero if undefined + upper_bound = (upper_bound === undefined) ? 0 : upper_bound; + + lower_bound = utils.parseNumber(lower_bound); + upper_bound = utils.parseNumber(upper_bound); + if (utils.anyIsError(lower_bound, upper_bound)) { + return error.value; + } + + return jStat.erf(lower_bound); +}; + +// TODO +exports.ERF.PRECISE = function() { + throw new Error('ERF.PRECISE is not implemented'); +}; + +exports.ERFC = function(x) { + // Return error if x is not a number + if (isNaN(x)) { + return error.value; + } + + return jStat.erfc(x); +}; + +// TODO +exports.ERFC.PRECISE = function() { + throw new Error('ERFC.PRECISE is not implemented'); +}; + +exports.GESTEP = function(number, step) { + step = step || 0; + number = utils.parseNumber(number); + if (utils.anyIsError(step, number)) { + return number; + } + + // Return delta + return (number >= step) ? 1 : 0; +}; + +exports.HEX2BIN = function(number, places) { + // Return error if number is not hexadecimal or contains more than ten characters (10 digits) + if (!/^[0-9A-Fa-f]{1,10}$/.test(number)) { + return error.num; + } + + // Check if number is negative + var negative = (number.length === 10 && number.substring(0, 1).toLowerCase() === 'f') ? true : false; + + // Convert hexadecimal number to decimal + var decimal = (negative) ? parseInt(number, 16) - 1099511627776 : parseInt(number, 16); + + // Return error if number is lower than -512 or greater than 511 + if (decimal < -512 || decimal > 511) { + return error.num; + } + + // Ignore places and return a 10-character binary number if number is negative + if (negative) { + return '1' + text.REPT('0', 9 - (512 + decimal).toString(2).length) + (512 + decimal).toString(2); + } + + // Convert decimal number to binary + var result = decimal.toString(2); + + // Return binary number using the minimum number of characters necessary if places is undefined + if (places === undefined) { + return result; + } else { + // Return error if places is nonnumeric + if (isNaN(places)) { + return error.value; + } + + // Return error if places is negative + if (places < 0) { + return error.num; + } + + // Truncate places in case it is not an integer + places = Math.floor(places); + + // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) + return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; + } +}; + +exports.HEX2DEC = function(number) { + // Return error if number is not hexadecimal or contains more than ten characters (10 digits) + if (!/^[0-9A-Fa-f]{1,10}$/.test(number)) { + return error.num; + } + + // Convert hexadecimal number to decimal + var decimal = parseInt(number, 16); + + // Return decimal number + return (decimal >= 549755813888) ? decimal - 1099511627776 : decimal; +}; + +exports.HEX2OCT = function(number, places) { + // Return error if number is not hexadecimal or contains more than ten characters (10 digits) + if (!/^[0-9A-Fa-f]{1,10}$/.test(number)) { + return error.num; + } + + // Convert hexadecimal number to decimal + var decimal = parseInt(number, 16); + + // Return error if number is positive and greater than 0x1fffffff (536870911) + if (decimal > 536870911 && decimal < 1098974756864) { + return error.num; + } + + // Ignore places and return a 10-character octal number if number is negative + if (decimal >= 1098974756864) { + return (decimal - 1098437885952).toString(8); + } + + // Convert decimal number to octal + var result = decimal.toString(8); + + // Return octal number using the minimum number of characters necessary if places is undefined + if (places === undefined) { + return result; + } else { + // Return error if places is nonnumeric + if (isNaN(places)) { + return error.value; + } + + // Return error if places is negative + if (places < 0) { + return error.num; + } + + // Truncate places in case it is not an integer + places = Math.floor(places); + + // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) + return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; + } +}; + +exports.IMABS = function(inumber) { + // Lookup real and imaginary coefficients using exports.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + // Return error if either coefficient is not a number + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Return absolute value of complex number + return Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2)); +}; + +exports.IMAGINARY = function(inumber) { + if (inumber === undefined || inumber === true || inumber === false) { + return error.value; + } + + // Return 0 if inumber is equal to 0 + if (inumber === 0 || inumber === '0') { + return 0; + } + + // Handle special cases + if (['i', 'j'].indexOf(inumber) >= 0) { + return 1; + } + + // Normalize imaginary coefficient + inumber = inumber.replace('+i', '+1i').replace('-i', '-1i').replace('+j', '+1j').replace('-j', '-1j'); + + // Lookup sign + var plus = inumber.indexOf('+'); + var minus = inumber.indexOf('-'); + if (plus === 0) { + plus = inumber.indexOf('+', 1); + } + + if (minus === 0) { + minus = inumber.indexOf('-', 1); + } + + // Lookup imaginary unit + var last = inumber.substring(inumber.length - 1, inumber.length); + var unit = (last === 'i' || last === 'j'); + + if (plus >= 0 || minus >= 0) { + // Return error if imaginary unit is neither i nor j + if (!unit) { + return error.num; + } + + // Return imaginary coefficient of complex number + if (plus >= 0) { + return (isNaN(inumber.substring(0, plus)) || isNaN(inumber.substring(plus + 1, inumber.length - 1))) ? + error.num : + Number(inumber.substring(plus + 1, inumber.length - 1)); + } else { + return (isNaN(inumber.substring(0, minus)) || isNaN(inumber.substring(minus + 1, inumber.length - 1))) ? + error.num : + -Number(inumber.substring(minus + 1, inumber.length - 1)); + } + } else { + if (unit) { + return (isNaN(inumber.substring(0, inumber.length - 1))) ? error.num : inumber.substring(0, inumber.length - 1); + } else { + return (isNaN(inumber)) ? error.num : 0; + } + } +}; + +exports.IMARGUMENT = function(inumber) { + // Lookup real and imaginary coefficients using exports.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + // Return error if either coefficient is not a number + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Return error if inumber is equal to zero + if (x === 0 && y === 0) { + return error.div0; + } + + // Return PI/2 if x is equal to zero and y is positive + if (x === 0 && y > 0) { + return Math.PI / 2; + } + + // Return -PI/2 if x is equal to zero and y is negative + if (x === 0 && y < 0) { + return -Math.PI / 2; + } + + // Return zero if x is negative and y is equal to zero + if (y === 0 && x > 0) { + return 0; + } + + // Return zero if x is negative and y is equal to zero + if (y === 0 && x < 0) { + return -Math.PI; + } + + // Return argument of complex number + if (x > 0) { + return Math.atan(y / x); + } else if (x < 0 && y >= 0) { + return Math.atan(y / x) + Math.PI; + } else { + return Math.atan(y / x) - Math.PI; + } +}; + +exports.IMCONJUGATE = function(inumber) { + // Lookup real and imaginary coefficients using exports.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Lookup imaginary unit + var unit = inumber.substring(inumber.length - 1); + unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + + // Return conjugate of complex number + return (y !== 0) ? exports.COMPLEX(x, -y, unit) : inumber; +}; + +exports.IMCOS = function(inumber) { + // Lookup real and imaginary coefficients using exports.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Lookup imaginary unit + var unit = inumber.substring(inumber.length - 1); + unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + + // Return cosine of complex number + return exports.COMPLEX(Math.cos(x) * (Math.exp(y) + Math.exp(-y)) / 2, -Math.sin(x) * (Math.exp(y) - Math.exp(-y)) / 2, unit); +}; + +exports.IMCOSH = function(inumber) { + // Lookup real and imaginary coefficients using exports.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Lookup imaginary unit + var unit = inumber.substring(inumber.length - 1); + unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + + // Return hyperbolic cosine of complex number + return exports.COMPLEX(Math.cos(y) * (Math.exp(x) + Math.exp(-x)) / 2, Math.sin(y) * (Math.exp(x) - Math.exp(-x)) / 2, unit); +}; + +exports.IMCOT = function(inumber) { + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Return cotangent of complex number + return exports.IMDIV(exports.IMCOS(inumber), exports.IMSIN(inumber)); +}; + +exports.IMDIV = function(inumber1, inumber2) { + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var a = exports.IMREAL(inumber1); + var b = exports.IMAGINARY(inumber1); + var c = exports.IMREAL(inumber2); + var d = exports.IMAGINARY(inumber2); + + if (utils.anyIsError(a, b, c, d)) { + return error.value; + } + + // Lookup imaginary unit + var unit1 = inumber1.substring(inumber1.length - 1); + var unit2 = inumber2.substring(inumber2.length - 1); + var unit = 'i'; + if (unit1 === 'j') { + unit = 'j'; + } else if (unit2 === 'j') { + unit = 'j'; + } + + // Return error if inumber2 is null + if (c === 0 && d === 0) { + return error.num; + } + + // Return exponential of complex number + var den = c * c + d * d; + return exports.COMPLEX((a * c + b * d) / den, (b * c - a * d) / den, unit); +}; + +exports.IMEXP = function(inumber) { + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Lookup imaginary unit + var unit = inumber.substring(inumber.length - 1); + unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + + // Return exponential of complex number + var e = Math.exp(x); + return exports.COMPLEX(e * Math.cos(y), e * Math.sin(y), unit); +}; + +exports.IMLN = function(inumber) { + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Lookup imaginary unit + var unit = inumber.substring(inumber.length - 1); + unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + + // Return exponential of complex number + return exports.COMPLEX(Math.log(Math.sqrt(x * x + y * y)), Math.atan(y / x), unit); +}; + +exports.IMLOG10 = function(inumber) { + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Lookup imaginary unit + var unit = inumber.substring(inumber.length - 1); + unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + + // Return exponential of complex number + return exports.COMPLEX(Math.log(Math.sqrt(x * x + y * y)) / Math.log(10), Math.atan(y / x) / Math.log(10), unit); +}; + +exports.IMLOG2 = function(inumber) { + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Lookup imaginary unit + var unit = inumber.substring(inumber.length - 1); + unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + + // Return exponential of complex number + return exports.COMPLEX(Math.log(Math.sqrt(x * x + y * y)) / Math.log(2), Math.atan(y / x) / Math.log(2), unit); +}; + +exports.IMPOWER = function(inumber, number) { + number = utils.parseNumber(number); + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + if (utils.anyIsError(number, x, y)) { + return error.value; + } + + // Lookup imaginary unit + var unit = inumber.substring(inumber.length - 1); + unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + + // Calculate power of modulus + var p = Math.pow(exports.IMABS(inumber), number); + + // Calculate argument + var t = exports.IMARGUMENT(inumber); + + // Return exponential of complex number + return exports.COMPLEX(p * Math.cos(number * t), p * Math.sin(number * t), unit); +}; + +exports.IMPRODUCT = function() { + // Initialize result + var result = arguments[0]; + + if (!arguments.length) { + return error.value; + } + + // Loop on all numbers + for (var i = 1; i < arguments.length; i++) { + // Lookup coefficients of two complex numbers + var a = exports.IMREAL(result); + var b = exports.IMAGINARY(result); + var c = exports.IMREAL(arguments[i]); + var d = exports.IMAGINARY(arguments[i]); + + if (utils.anyIsError(a, b, c, d)) { + return error.value; + } + + // Complute product of two complex numbers + result = exports.COMPLEX(a * c - b * d, a * d + b * c); + } + + // Return product of complex numbers + return result; +}; + +exports.IMREAL = function(inumber) { + if (inumber === undefined || inumber === true || inumber === false) { + return error.value; + } + + // Return 0 if inumber is equal to 0 + if (inumber === 0 || inumber === '0') { + return 0; + } + + // Handle special cases + if (['i', '+i', '1i', '+1i', '-i', '-1i', 'j', '+j', '1j', '+1j', '-j', '-1j'].indexOf(inumber) >= 0) { + return 0; + } + + // Lookup sign + var plus = inumber.indexOf('+'); + var minus = inumber.indexOf('-'); + if (plus === 0) { + plus = inumber.indexOf('+', 1); + } + if (minus === 0) { + minus = inumber.indexOf('-', 1); + } + + // Lookup imaginary unit + var last = inumber.substring(inumber.length - 1, inumber.length); + var unit = (last === 'i' || last === 'j'); + + if (plus >= 0 || minus >= 0) { + // Return error if imaginary unit is neither i nor j + if (!unit) { + return error.num; + } + + // Return real coefficient of complex number + if (plus >= 0) { + return (isNaN(inumber.substring(0, plus)) || isNaN(inumber.substring(plus + 1, inumber.length - 1))) ? + error.num : + Number(inumber.substring(0, plus)); + } else { + return (isNaN(inumber.substring(0, minus)) || isNaN(inumber.substring(minus + 1, inumber.length - 1))) ? + error.num : + Number(inumber.substring(0, minus)); + } + } else { + if (unit) { + return (isNaN(inumber.substring(0, inumber.length - 1))) ? error.num : 0; + } else { + return (isNaN(inumber)) ? error.num : inumber; + } + } +}; + +exports.IMSEC = function(inumber) { + // Return error if inumber is a logical value + if (inumber === true || inumber === false) { + return error.value; + } + + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Return secant of complex number + return exports.IMDIV('1', exports.IMCOS(inumber)); +}; + +exports.IMSECH = function(inumber) { + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Return hyperbolic secant of complex number + return exports.IMDIV('1', exports.IMCOSH(inumber)); +}; + +exports.IMSIN = function(inumber) { + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Lookup imaginary unit + var unit = inumber.substring(inumber.length - 1); + unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + + // Return sine of complex number + return exports.COMPLEX(Math.sin(x) * (Math.exp(y) + Math.exp(-y)) / 2, Math.cos(x) * (Math.exp(y) - Math.exp(-y)) / 2, unit); +}; + +exports.IMSINH = function(inumber) { + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Lookup imaginary unit + var unit = inumber.substring(inumber.length - 1); + unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + + // Return hyperbolic sine of complex number + return exports.COMPLEX(Math.cos(y) * (Math.exp(x) - Math.exp(-x)) / 2, Math.sin(y) * (Math.exp(x) + Math.exp(-x)) / 2, unit); +}; + +exports.IMSQRT = function(inumber) { + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Lookup imaginary unit + var unit = inumber.substring(inumber.length - 1); + unit = (unit === 'i' || unit === 'j') ? unit : 'i'; + + // Calculate power of modulus + var s = Math.sqrt(exports.IMABS(inumber)); + + // Calculate argument + var t = exports.IMARGUMENT(inumber); + + // Return exponential of complex number + return exports.COMPLEX(s * Math.cos(t / 2), s * Math.sin(t / 2), unit); +}; + +exports.IMCSC = function (inumber) { + // Return error if inumber is a logical value + if (inumber === true || inumber === false) { + return error.value; + } + + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + // Return error if either coefficient is not a number + if (utils.anyIsError(x, y)) { + return error.num; + } + + // Return cosecant of complex number + return exports.IMDIV('1', exports.IMSIN(inumber)); +}; + +exports.IMCSCH = function (inumber) { + // Return error if inumber is a logical value + if (inumber === true || inumber === false) { + return error.value; + } + + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + // Return error if either coefficient is not a number + if (utils.anyIsError(x, y)) { + return error.num; + } + + // Return hyperbolic cosecant of complex number + return exports.IMDIV('1', exports.IMSINH(inumber)); +}; + +exports.IMSUB = function(inumber1, inumber2) { + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var a = this.IMREAL(inumber1); + var b = this.IMAGINARY(inumber1); + var c = this.IMREAL(inumber2); + var d = this.IMAGINARY(inumber2); + + if (utils.anyIsError(a, b, c, d)) { + return error.value; + } + + // Lookup imaginary unit + var unit1 = inumber1.substring(inumber1.length - 1); + var unit2 = inumber2.substring(inumber2.length - 1); + var unit = 'i'; + if (unit1 === 'j') { + unit = 'j'; + } else if (unit2 === 'j') { + unit = 'j'; + } + + // Return _ of two complex numbers + return this.COMPLEX(a - c, b - d, unit); +}; + +exports.IMSUM = function() { + if (!arguments.length) { + return error.value; + } + var args = utils.flatten(arguments); + + // Initialize result + var result = args[0]; + + // Loop on all numbers + for (var i = 1; i < args.length; i++) { + // Lookup coefficients of two complex numbers + var a = this.IMREAL(result); + var b = this.IMAGINARY(result); + var c = this.IMREAL(args[i]); + var d = this.IMAGINARY(args[i]); + + if (utils.anyIsError(a, b, c, d)) { + return error.value; + } + + // Complute product of two complex numbers + result = this.COMPLEX(a + c, b + d); + } + + // Return sum of complex numbers + return result; +}; + +exports.IMTAN = function(inumber) { + // Return error if inumber is a logical value + if (inumber === true || inumber === false) { + return error.value; + } + + // Lookup real and imaginary coefficients using Formula.js [http://formulajs.org] + var x = exports.IMREAL(inumber); + var y = exports.IMAGINARY(inumber); + + if (utils.anyIsError(x, y)) { + return error.value; + } + + // Return tangent of complex number + return this.IMDIV(this.IMSIN(inumber), this.IMCOS(inumber)); +}; + +exports.OCT2BIN = function(number, places) { + // Return error if number is not hexadecimal or contains more than ten characters (10 digits) + if (!/^[0-7]{1,10}$/.test(number)) { + return error.num; + } + + // Check if number is negative + var negative = (number.length === 10 && number.substring(0, 1) === '7') ? true : false; + + // Convert octal number to decimal + var decimal = (negative) ? parseInt(number, 8) - 1073741824 : parseInt(number, 8); + + // Return error if number is lower than -512 or greater than 511 + if (decimal < -512 || decimal > 511) { + return error.num; + } + + // Ignore places and return a 10-character binary number if number is negative + if (negative) { + return '1' + text.REPT('0', 9 - (512 + decimal).toString(2).length) + (512 + decimal).toString(2); + } + + // Convert decimal number to binary + var result = decimal.toString(2); + + // Return binary number using the minimum number of characters necessary if places is undefined + if (typeof places === 'undefined') { + return result; + } else { + // Return error if places is nonnumeric + if (isNaN(places)) { + return error.value; + } + + // Return error if places is negative + if (places < 0) { + return error.num; + } + + // Truncate places in case it is not an integer + places = Math.floor(places); + + // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) + return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; + } +}; + +exports.OCT2DEC = function(number) { + // Return error if number is not octal or contains more than ten characters (10 digits) + if (!/^[0-7]{1,10}$/.test(number)) { + return error.num; + } + + // Convert octal number to decimal + var decimal = parseInt(number, 8); + + // Return decimal number + return (decimal >= 536870912) ? decimal - 1073741824 : decimal; +}; + +exports.OCT2HEX = function(number, places) { + // Return error if number is not octal or contains more than ten characters (10 digits) + if (!/^[0-7]{1,10}$/.test(number)) { + return error.num; + } + + // Convert octal number to decimal + var decimal = parseInt(number, 8); + + // Ignore places and return a 10-character octal number if number is negative + if (decimal >= 536870912) { + return 'ff' + (decimal + 3221225472).toString(16); + } + + // Convert decimal number to hexadecimal + var result = decimal.toString(16); + + // Return hexadecimal number using the minimum number of characters necessary if places is undefined + if (places === undefined) { + return result; + } else { + // Return error if places is nonnumeric + if (isNaN(places)) { + return error.value; + } - // check for min length - var info; - if (format.indexOf('.') === -1) { - info = format.match(/([0-9]+).*/); - } else { - info = format.match(/([0-9]+)\..*/); - } - minlen = info === null ? -1 : info[1].length; + // Return error if places is negative + if (places < 0) { + return error.num; + } - // see if we should use parentheses for negative number or if we should prefix with a sign - // if both are present we default to parentheses - if (format.indexOf('-') !== -1) { - forcedNeg = true; - } - if (format.indexOf('(') > -1) { - negP = true; - format = format.slice(1, -1); - } else if (format.indexOf('+') > -1) { - signed = true; - format = format.replace(/\+/g, ''); - } + // Truncate places in case it is not an integer + places = Math.floor(places); - // see if abbreviation is wanted - if (format.indexOf('a') > -1) { - intPrecision = format.split('.')[0].match(/[0-9]+/g) || ['0']; - intPrecision = parseInt(intPrecision[0], 10); + // Pad return value with leading 0s (zeros) if necessary (using Underscore.string) + return (places >= result.length) ? text.REPT('0', places - result.length) + result : error.num; + } +}; - // check if abbreviation is specified - abbrK = format.indexOf('aK') >= 0; - abbrM = format.indexOf('aM') >= 0; - abbrB = format.indexOf('aB') >= 0; - abbrT = format.indexOf('aT') >= 0; - abbrForce = abbrK || abbrM || abbrB || abbrT; - // check for space before abbreviation - if (format.indexOf(' a') > -1) { - abbr = ' '; - format = format.replace(' a', ''); - } else { - format = format.replace('a', ''); - } +/***/ }), +/* 14 */ +/***/ (function(module, exports, __webpack_require__) { - totalLength = Math.floor(Math.log(abs) / Math.LN10) + 1; +"use strict"; - minimumPrecision = totalLength % 3; - minimumPrecision = minimumPrecision === 0 ? 3 : minimumPrecision; - if (intPrecision && abs !== 0) { +exports.__esModule = true; +var SUPPORTED_FORMULAS = ['ABS', 'ACCRINT', 'ACOS', 'ACOSH', 'ACOT', 'ACOTH', 'ADD', 'AGGREGATE', 'AND', 'ARABIC', 'ARGS2ARRAY', 'ASIN', 'ASINH', 'ATAN', 'ATAN2', 'ATANH', 'AVEDEV', 'AVERAGE', 'AVERAGEA', 'AVERAGEIF', 'AVERAGEIFS', 'BASE', 'BESSELI', 'BESSELJ', 'BESSELK', 'BESSELY', 'BETA.DIST', 'BETA.INV', 'BETADIST', 'BETAINV', 'BIN2DEC', 'BIN2HEX', 'BIN2OCT', 'BINOM.DIST', 'BINOM.DIST.RANGE', 'BINOM.INV', 'BINOMDIST', 'BITAND', 'BITLSHIFT', 'BITOR', 'BITRSHIFT', 'BITXOR', 'CEILING', 'CEILINGMATH', 'CEILINGPRECISE', 'CHAR', 'CHISQ.DIST', 'CHISQ.DIST.RT', 'CHISQ.INV', 'CHISQ.INV.RT', 'CHOOSE', 'CHOOSE', 'CLEAN', 'CODE', 'COLUMN', 'COLUMNS', 'COMBIN', 'COMBINA', 'COMPLEX', 'CONCATENATE', 'CONFIDENCE', 'CONFIDENCE.NORM', 'CONFIDENCE.T', 'CONVERT', 'CORREL', 'COS', 'COSH', 'COT', 'COTH', 'COUNT', 'COUNTA', 'COUNTBLANK', 'COUNTIF', 'COUNTIFS', 'COUNTIN', 'COUNTUNIQUE', 'COVARIANCE.P', 'COVARIANCE.S', 'CSC', 'CSCH', 'CUMIPMT', 'CUMPRINC', 'DATE', 'DATEVALUE', 'DAY', 'DAYS', 'DAYS360', 'DB', 'DDB', 'DEC2BIN', 'DEC2HEX', 'DEC2OCT', 'DECIMAL', 'DEGREES', 'DELTA', 'DEVSQ', 'DIVIDE', 'DOLLAR', 'DOLLARDE', 'DOLLARFR', 'E', 'EDATE', 'EFFECT', 'EOMONTH', 'EQ', 'ERF', 'ERFC', 'EVEN', 'EXACT', 'EXPON.DIST', 'EXPONDIST', 'F.DIST', 'F.DIST.RT', 'F.INV', 'F.INV.RT', 'FACT', 'FACTDOUBLE', 'FALSE', 'FDIST', 'FDISTRT', 'FIND', 'FINV', 'FINVRT', 'FISHER', 'FISHERINV', 'FIXED', 'FLATTEN', 'FLOOR', 'FORECAST', 'FREQUENCY', 'FV', 'FVSCHEDULE', 'GAMMA', 'GAMMA.DIST', 'GAMMA.INV', 'GAMMADIST', 'GAMMAINV', 'GAMMALN', 'GAMMALN.PRECISE', 'GAUSS', 'GCD', 'GEOMEAN', 'GESTEP', 'GROWTH', 'GTE', 'HARMEAN', 'HEX2BIN', 'HEX2DEC', 'HEX2OCT', 'HOUR', 'HTML2TEXT', 'HYPGEOM.DIST', 'HYPGEOMDIST', 'IF', 'IMABS', 'IMAGINARY', 'IMARGUMENT', 'IMCONJUGATE', 'IMCOS', 'IMCOSH', 'IMCOT', 'IMCSC', 'IMCSCH', 'IMDIV', 'IMEXP', 'IMLN', 'IMLOG10', 'IMLOG2', 'IMPOWER', 'IMPRODUCT', 'IMREAL', 'IMSEC', 'IMSECH', 'IMSIN', 'IMSINH', 'IMSQRT', 'IMSUB', 'IMSUM', 'IMTAN', 'INT', 'INTERCEPT', 'INTERVAL', 'IPMT', 'IRR', 'ISBINARY', 'ISBLANK', 'ISEVEN', 'ISLOGICAL', 'ISNONTEXT', 'ISNUMBER', 'ISODD', 'ISODD', 'ISOWEEKNUM', 'ISPMT', 'ISTEXT', 'JOIN', 'KURT', 'LARGE', 'LCM', 'LEFT', 'LEN', 'LINEST', 'LN', 'LOG', 'LOG10', 'LOGEST', 'LOGNORM.DIST', 'LOGNORM.INV', 'LOGNORMDIST', 'LOGNORMINV', 'LOWER', 'LT', 'LTE', 'MATCH', 'MAX', 'MAXA', 'MEDIAN', 'MID', 'MIN', 'MINA', 'MINUS', 'MINUTE', 'MIRR', 'MOD', 'MODE.MULT', 'MODE.SNGL', 'MODEMULT', 'MODESNGL', 'MONTH', 'MROUND', 'MULTINOMIAL', 'MULTIPLY', 'NE', 'NEGBINOM.DIST', 'NEGBINOMDIST', 'NETWORKDAYS', 'NOMINAL', 'NORM.DIST', 'NORM.INV', 'NORM.S.DIST', 'NORM.S.INV', 'NORMDIST', 'NORMINV', 'NORMSDIST', 'NORMSINV', 'NOT', 'NOW', 'NPER', 'NPV', 'NUMBERS', 'NUMERAL', 'OCT2BIN', 'OCT2DEC', 'OCT2HEX', 'ODD', 'OR', 'PDURATION', 'PEARSON', 'PERCENTILEEXC', 'PERCENTILEINC', 'PERCENTRANKEXC', 'PERCENTRANKINC', 'PERMUT', 'PERMUTATIONA', 'PHI', 'PI', 'PMT', 'POISSON.DIST', 'POISSONDIST', 'POW', 'POWER', 'PPMT', 'PROB', 'PRODUCT', 'PROPER', 'PV', 'QUARTILE.EXC', 'QUARTILE.INC', 'QUARTILEEXC', 'QUARTILEINC', 'QUOTIENT', 'RADIANS', 'RAND', 'RANDBETWEEN', 'RANK.AVG', 'RANK.EQ', 'RANKAVG', 'RANKEQ', 'RATE', 'REFERENCE', 'REGEXEXTRACT', 'REGEXMATCH', 'REGEXREPLACE', 'REPLACE', 'REPT', 'RIGHT', 'ROMAN', 'ROUND', 'ROUNDDOWN', 'ROUNDUP', 'ROW', 'ROWS', 'RRI', 'RSQ', 'SEARCH', 'SEC', 'SECH', 'SECOND', 'SERIESSUM', 'SIGN', 'SIN', 'SINH', 'SKEW', 'SKEW.P', 'SKEWP', 'SLN', 'SLOPE', 'SMALL', 'SPLIT', 'SPLIT', 'SQRT', 'SQRTPI', 'STANDARDIZE', 'STDEV.P', 'STDEV.S', 'STDEVA', 'STDEVP', 'STDEVPA', 'STDEVS', 'STEYX', 'SUBSTITUTE', 'SUBTOTAL', 'SUM', 'SUMIF', 'SUMIFS', 'SUMPRODUCT', 'SUMSQ', 'SUMX2MY2', 'SUMX2PY2', 'SUMXMY2', 'SWITCH', 'SYD', 'T', 'T.DIST', 'T.DIST.2T', 'T.DIST.RT', 'T.INV', 'T.INV.2T', 'TAN', 'TANH', 'TBILLEQ', 'TBILLPRICE', 'TBILLYIELD', 'TDIST', 'TDIST2T', 'TDISTRT', 'TEXT', 'TIME', 'TIMEVALUE', 'TINV', 'TINV2T', 'TODAY', 'TRANSPOSE', 'TREND', 'TRIM', 'TRIMMEAN', 'TRUE', 'TRUNC', 'UNICHAR', 'UNICODE', 'UNIQUE', 'UPPER', 'VALUE', 'VAR.P', 'VAR.S', 'VARA', 'VARP', 'VARPA', 'VARS', 'WEEKDAY', 'WEEKNUM', 'WEIBULL.DIST', 'WEIBULLDIST', 'WORKDAY', 'XIRR', 'XNPV', 'XOR', 'YEAR', 'YEARFRAC']; - length = Math.floor(Math.log(abs) / Math.LN10) + 1 - intPrecision; +exports['default'] = SUPPORTED_FORMULAS; - pow = 3 * ~~((Math.min(intPrecision, totalLength) - minimumPrecision) / 3); +/***/ }), +/* 15 */ +/***/ (function(module, exports, __webpack_require__) { - abs = abs / Math.pow(10, pow); +"use strict"; - if (format.indexOf('.') === -1 && intPrecision > 3) { - format += '[.]'; - size = length === 0 ? 0 : 3 * ~~(length / 3) - length; - size = size < 0 ? size + 3 : size; +exports.__esModule = true; +exports.rowLabelToIndex = rowLabelToIndex; +exports.rowIndexToLabel = rowIndexToLabel; +exports.columnLabelToIndex = columnLabelToIndex; +exports.columnIndexToLabel = columnIndexToLabel; +exports.extractLabel = extractLabel; +exports.toLabel = toLabel; +/** + * Convert row label to index. + * + * @param {String} label Row label (eq. '1', '5') + * @returns {Number} Returns -1 if label is not recognized otherwise proper row index. + */ +function rowLabelToIndex(label) { + var result = parseInt(label, 10); - format += zeroes(size); - } - } + if (isNaN(result)) { + result = -1; + } else { + result = Math.max(result - 1, -1); + } - if (Math.floor(Math.log(Math.abs(value)) / Math.LN10) + 1 !== intPrecision) { - if (abs >= Math.pow(10, 12) && !abbrForce || abbrT) { - // trillion - abbr = abbr + cultures[currentCulture].abbreviations.trillion; - value = value / Math.pow(10, 12); - } else if (abs < Math.pow(10, 12) && abs >= Math.pow(10, 9) && !abbrForce || abbrB) { - // billion - abbr = abbr + cultures[currentCulture].abbreviations.billion; - value = value / Math.pow(10, 9); - } else if (abs < Math.pow(10, 9) && abs >= Math.pow(10, 6) && !abbrForce || abbrM) { - // million - abbr = abbr + cultures[currentCulture].abbreviations.million; - value = value / Math.pow(10, 6); - } else if (abs < Math.pow(10, 6) && abs >= Math.pow(10, 3) && !abbrForce || abbrK) { - // thousand - abbr = abbr + cultures[currentCulture].abbreviations.thousand; - value = value / Math.pow(10, 3); - } - } - } + return result; +} - // see if we are formatting - // binary-decimal bytes (1024 MB), binary bytes (1024 MiB), or decimal bytes (1000 MB) - for (i = 0; i < byteFormatOrder.length; ++i) { - byteFormat = byteFormatOrder[i]; +/** + * Convert row index to label. + * + * @param {Number} row Row index. + * @returns {String} Returns row label (eq. '1', '7'). + */ +function rowIndexToLabel(row) { + var result = ''; - if (format.indexOf(byteFormat.marker) > -1) { - // check for space before - if (format.indexOf(' ' + byteFormat.marker) >-1) { - bytes = ' '; - } + if (row >= 0) { + result = '' + (row + 1); + } - // remove the marker (with the space if it had one) - format = format.replace(bytes + byteFormat.marker, ''); + return result; +} - units = formatByteUnits(value, byteFormat.suffixes, byteFormat.scale); +var COLUMN_LABEL_BASE = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'; +var COLUMN_LABEL_BASE_LENGTH = COLUMN_LABEL_BASE.length; - value = units.value; - bytes = bytes + units.suffix; +/** + * Convert column label to index. + * + * @param {String} label Column label (eq. 'ABB', 'CNQ') + * @returns {Number} Returns -1 if label is not recognized otherwise proper column index. + */ +function columnLabelToIndex(label) { + var result = 0; - break; - } - } + if (typeof label === 'string') { + label = label.toUpperCase(); - // see if ordinal is wanted - if (format.indexOf('o') > -1) { - // check for space before - if (format.indexOf(' o') > -1) { - ord = ' '; - format = format.replace(' o', ''); - } else { - format = format.replace('o', ''); - } + for (var i = 0, j = label.length - 1; i < label.length; i += 1, j -= 1) { + result += Math.pow(COLUMN_LABEL_BASE_LENGTH, j) * (COLUMN_LABEL_BASE.indexOf(label[i]) + 1); + } + } + --result; - if (cultures[currentCulture].ordinal) { - ord = ord + cultures[currentCulture].ordinal(value); - } - } + return result; +} - if (format.indexOf('[.]') > -1) { - optDec = true; - format = format.replace('[.]', '.'); - } +/** + * Convert column index to label. + * + * @param {Number} column Column index. + * @returns {String} Returns column label (eq. 'ABB', 'CNQ'). + */ +function columnIndexToLabel(column) { + var result = ''; - w = value.toString().split('.')[0]; - precision = format.split('.')[1]; - thousands = format.indexOf(','); + while (column >= 0) { + result = String.fromCharCode(column % COLUMN_LABEL_BASE_LENGTH + 97) + result; + column = Math.floor(column / COLUMN_LABEL_BASE_LENGTH) - 1; + } - if (precision) { - if (precision.indexOf('*') !== -1) { - d = toFixed(value, value.toString().split('.')[1].length, roundingFunction); - } else { - if (precision.indexOf('[') > -1) { - precision = precision.replace(']', ''); - precision = precision.split('['); - d = toFixed(value, (precision[0].length + precision[1].length), roundingFunction, - precision[1].length); - } else { - d = toFixed(value, precision.length, roundingFunction); - } - } + return result.toUpperCase(); +} + +var LABEL_EXTRACT_REGEXP = /^([$])?([A-Za-z]+)([$])?([0-9]+)$/; + +/** + * Extract cell coordinates. + * + * @param {String} label Cell coordinates (eq. 'A1', '$B6', '$N$98'). + * @returns {Array} Returns an array of objects. + */ +function extractLabel(label) { + if (typeof label !== 'string' || !LABEL_EXTRACT_REGEXP.test(label)) { + return []; + } + + var _label$toUpperCase$ma = label.toUpperCase().match(LABEL_EXTRACT_REGEXP), + columnAbs = _label$toUpperCase$ma[1], + column = _label$toUpperCase$ma[2], + rowAbs = _label$toUpperCase$ma[3], + row = _label$toUpperCase$ma[4]; + + return [{ + index: rowLabelToIndex(row), + label: row, + isAbsolute: rowAbs === '$' + }, { + index: columnLabelToIndex(column), + label: column, + isAbsolute: columnAbs === '$' + }]; +} + +/** + * Convert row and column indexes into cell label. + * + * @param {Object} row Object with `index` and `isAbsolute` properties. + * @param {Object} column Object with `index` and `isAbsolute` properties. + * @returns {String} Returns cell label. + */ +function toLabel(row, column) { + var rowLabel = (row.isAbsolute ? '$' : '') + rowIndexToLabel(row.index); + var columnLabel = (column.isAbsolute ? '$' : '') + columnIndexToLabel(column.index); + + return columnLabel + rowLabel; +} + +/***/ }), +/* 16 */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; - w = d.split('.')[0]; - if (d.split('.')[1].length) { - var p = sep ? abbr + sep : cultures[currentCulture].delimiters.decimal; - d = p + d.split('.')[1]; - } else { - d = ''; - } +exports.__esModule = true; +exports.rowLabelToIndex = exports.rowIndexToLabel = exports.columnLabelToIndex = exports.columnIndexToLabel = exports.toLabel = exports.extractLabel = exports.error = exports.Parser = exports.ERROR_VALUE = exports.ERROR_REF = exports.ERROR_NUM = exports.ERROR_NULL = exports.ERROR_NOT_AVAILABLE = exports.ERROR_NAME = exports.ERROR_DIV_ZERO = exports.ERROR = exports.SUPPORTED_FORMULAS = undefined; - if (optDec && Number(d.slice(1)) === 0) { - d = ''; - } - } else { - w = toFixed(value, 0, roundingFunction); - } +var _parser = __webpack_require__(17); - // format number - if (w.indexOf('-') > -1) { - w = w.slice(1); - neg = true; - } +var _parser2 = _interopRequireDefault(_parser); - if (w.length < minlen) { - w = zeroes(minlen - w.length) + w; - } +var _supportedFormulas = __webpack_require__(14); - if (thousands > -1) { - w = w.toString().replace(/(\d)(?=(\d{3})+(?!\d))/g, '$1' + - cultures[currentCulture].delimiters.thousands); - } +var _supportedFormulas2 = _interopRequireDefault(_supportedFormulas); - if (format.indexOf('.') === 0) { - w = ''; - } +var _error = __webpack_require__(2); - indexOpenP = format.indexOf('('); - indexMinus = format.indexOf('-'); +var _error2 = _interopRequireDefault(_error); - if (indexOpenP < indexMinus) { - paren = ((negP && neg) ? '(' : '') + (((forcedNeg && neg) || (!negP && neg)) ? '-' : ''); - } else { - paren = (((forcedNeg && neg) || (!negP && neg)) ? '-' : '') + ((negP && neg) ? '(' : ''); - } +var _cell = __webpack_require__(15); - return prefix + - paren + ((!neg && signed && value !== 0) ? '+' : '') + - w + d + - ((ord) ? ord : '') + - ((abbr && !sep) ? abbr : '') + - ((bytes) ? bytes : '') + - ((negP && neg) ? ')' : '') + - postfix; - } +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } - /************************************ - Top Level Functions - ************************************/ +exports.SUPPORTED_FORMULAS = _supportedFormulas2['default']; +exports.ERROR = _error.ERROR; +exports.ERROR_DIV_ZERO = _error.ERROR_DIV_ZERO; +exports.ERROR_NAME = _error.ERROR_NAME; +exports.ERROR_NOT_AVAILABLE = _error.ERROR_NOT_AVAILABLE; +exports.ERROR_NULL = _error.ERROR_NULL; +exports.ERROR_NUM = _error.ERROR_NUM; +exports.ERROR_REF = _error.ERROR_REF; +exports.ERROR_VALUE = _error.ERROR_VALUE; +exports.Parser = _parser2['default']; +exports.error = _error2['default']; +exports.extractLabel = _cell.extractLabel; +exports.toLabel = _cell.toLabel; +exports.columnIndexToLabel = _cell.columnIndexToLabel; +exports.columnLabelToIndex = _cell.columnLabelToIndex; +exports.rowIndexToLabel = _cell.rowIndexToLabel; +exports.rowLabelToIndex = _cell.rowLabelToIndex; - numbro = function(input) { - if (numbro.isNumbro(input)) { - input = input.value(); - } else if (input === 0 || typeof input === 'undefined') { - input = 0; - } else if (!Number(input)) { - input = numbro.fn.unformat(input); - } +/***/ }), +/* 17 */ +/***/ (function(module, exports, __webpack_require__) { - return new Numbro(Number(input)); - }; +"use strict"; - // version number - numbro.version = VERSION; - // compare numbro object - numbro.isNumbro = function(obj) { - return obj instanceof Numbro; - }; +exports.__esModule = true; - /** - * This function allow the user to set a new language with a fallback if - * the language does not exist. If no fallback language is provided, - * it fallbacks to english. - * - * @deprecated Since in version 1.6.0. It will be deleted in version 2.0 - * `setCulture` should be used instead. - */ - numbro.setLanguage = function(newLanguage, fallbackLanguage) { - console.warn('`setLanguage` is deprecated since version 1.6.0. Use `setCulture` instead'); - var key = newLanguage, - prefix = newLanguage.split('-')[0], - matchingLanguage = null; - if (!languages[key]) { - Object.keys(languages).forEach(function(language) { - if (!matchingLanguage && language.split('-')[0] === prefix) { - matchingLanguage = language; - } - }); - key = matchingLanguage || fallbackLanguage || 'en-US'; - } - chooseCulture(key); - }; +var _tinyEmitter = __webpack_require__(18); - /** - * This function allow the user to set a new culture with a fallback if - * the culture does not exist. If no fallback culture is provided, - * it falls back to "en-US". - */ - numbro.setCulture = function(newCulture, fallbackCulture) { - var key = newCulture, - suffix = newCulture.split('-')[1], - matchingCulture = null; - if (!cultures[key]) { - if (suffix) { - Object.keys(cultures).forEach(function(language) { - if (!matchingCulture && language.split('-')[1] === suffix) { - matchingCulture = language; - } - }); - } +var _tinyEmitter2 = _interopRequireDefault(_tinyEmitter); - key = matchingCulture || fallbackCulture || 'en-US'; - } - chooseCulture(key); - }; +var _evaluateByOperator = __webpack_require__(19); - /** - * This function will load languages and then set the global language. If - * no arguments are passed in, it will simply return the current global - * language key. - * - * @deprecated Since in version 1.6.0. It will be deleted in version 2.0 - * `culture` should be used instead. - */ - numbro.language = function(key, values) { - console.warn('`language` is deprecated since version 1.6.0. Use `culture` instead'); +var _evaluateByOperator2 = _interopRequireDefault(_evaluateByOperator); - if (!key) { - return currentCulture; - } +var _grammarParser = __webpack_require__(101); - if (key && !values) { - if (!languages[key]) { - throw new Error('Unknown language : ' + key); - } - chooseCulture(key); - } +var _string = __webpack_require__(103); - if (values || !languages[key]) { - setCulture(key, values); - } +var _number = __webpack_require__(3); - return numbro; - }; +var _error = __webpack_require__(2); - /** - * This function will load cultures and then set the global culture. If - * no arguments are passed in, it will simply return the current global - * culture code. - */ - numbro.culture = function(code, values) { - if (!code) { - return currentCulture; - } +var _error2 = _interopRequireDefault(_error); - if (code && !values) { - if (!cultures[code]) { - throw new Error('Unknown culture : ' + code); - } - chooseCulture(code); - } +var _cell = __webpack_require__(15); - if (values || !cultures[code]) { - setCulture(code, values); - } +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } - return numbro; - }; +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - /** - * This function provides access to the loaded language data. If - * no arguments are passed in, it will simply return the current - * global language object. - * - * @deprecated Since in version 1.6.0. It will be deleted in version 2.0 - * `culture` should be used instead. - */ - numbro.languageData = function(key) { - console.warn('`languageData` is deprecated since version 1.6.0. Use `cultureData` instead'); +function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } - if (!key) { - return languages[currentCulture]; - } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } - if (!languages[key]) { - throw new Error('Unknown language : ' + key); - } +/** + * @class Parser + */ +var Parser = function (_Emitter) { + _inherits(Parser, _Emitter); - return languages[key]; + function Parser() { + _classCallCheck(this, Parser); + + var _this = _possibleConstructorReturn(this, _Emitter.call(this)); + + _this.parser = new _grammarParser.Parser(); + _this.parser.yy = { + toNumber: _number.toNumber, + trimEdges: _string.trimEdges, + invertNumber: _number.invertNumber, + throwError: function throwError(errorName) { + return _this._throwError(errorName); + }, + callVariable: function callVariable(variable) { + return _this._callVariable(variable); + }, + evaluateByOperator: _evaluateByOperator2['default'], + callFunction: _evaluateByOperator2['default'], + cellValue: function cellValue(value) { + return _this._callCellValue(value); + }, + rangeValue: function rangeValue(start, end) { + return _this._callRangeValue(start, end); + } }; + _this.variables = Object.create(null); - /** - * This function provides access to the loaded culture data. If - * no arguments are passed in, it will simply return the current - * global culture object. - */ - numbro.cultureData = function(code) { - if (!code) { - return cultures[currentCulture]; - } + _this.setVariable('TRUE', true).setVariable('FALSE', false).setVariable('NULL', null); + return _this; + } - if (!cultures[code]) { - throw new Error('Unknown culture : ' + code); - } + /** + * Parse formula expression. + * + * @param {String} expression to parse. + * @return {*} Returns an object with tow properties `error` and `result`. + */ - return cultures[code]; - }; - numbro.culture('en-US', enUS); + Parser.prototype.parse = function parse(expression) { + var result = null; + var error = null; + + try { + if (expression === '') { + result = ''; + } else { + result = this.parser.parse(expression); + } + } catch (ex) { + var message = (0, _error2['default'])(ex.message); + + if (message) { + error = message; + } else { + error = (0, _error2['default'])(_error.ERROR); + } + } - /** - * @deprecated Since in version 1.6.0. It will be deleted in version 2.0 - * `cultures` should be used instead. - */ - numbro.languages = function() { - console.warn('`languages` is deprecated since version 1.6.0. Use `cultures` instead'); + if (result instanceof Error) { + error = (0, _error2['default'])(result.message) || (0, _error2['default'])(_error.ERROR); + result = null; + } - return languages; + return { + error: error, + result: result }; + }; - numbro.cultures = function() { - return cultures; - }; + /** + * Set predefined variable name which can be visible while parsing formula expression. + * + * @param {String} name Variable name. + * @param {*} value Variable value. + * @returns {Parser} + */ - numbro.zeroFormat = function(format) { - zeroFormat = typeof(format) === 'string' ? format : null; - }; - numbro.defaultFormat = function(format) { - defaultFormat = typeof(format) === 'string' ? format : '0.0'; - }; + Parser.prototype.setVariable = function setVariable(name, value) { + this.variables[name] = value; - numbro.defaultCurrencyFormat = function (format) { - defaultCurrencyFormat = typeof(format) === 'string' ? format : '0$'; - }; + return this; + }; - numbro.validate = function(val, culture) { + /** + * Get variable name. + * + * @param {String} name Variable name. + * @returns {*} + */ - var _decimalSep, - _thousandSep, - _currSymbol, - _valArray, - _abbrObj, - _thousandRegEx, - cultureData, - temp; - //coerce val to string - if (typeof val !== 'string') { - val += ''; - if (console.warn) { - console.warn('Numbro.js: Value is not string. It has been co-erced to: ', val); - } - } + Parser.prototype.getVariable = function getVariable(name) { + return this.variables[name]; + }; - //trim whitespaces from either sides - val = val.trim(); + /** + * Retrieve variable value by its name. + * + * @param name Variable name. + * @returns {*} + * @private + */ - //replace the initial '+' or '-' sign if present - val = val.replace(/^[+-]?/, ''); - //if val is just digits return true - if ( !! val.match(/^\d+$/)) { - return true; - } + Parser.prototype._callVariable = function _callVariable(name) { + var value = this.getVariable(name); - //if val is empty return false - if (val === '') { - return false; - } + this.emit('callVariable', name, function (newValue) { + if (newValue !== void 0) { + value = newValue; + } + }); - //get the decimal and thousands separator from numbro.cultureData - try { - //check if the culture is understood by numbro. if not, default it to current culture - cultureData = numbro.cultureData(culture); - } catch (e) { - cultureData = numbro.cultureData(numbro.culture()); - } + if (value === void 0) { + throw Error(_error.ERROR_NAME); + } - //setup the delimiters and currency symbol based on culture - _currSymbol = cultureData.currency.symbol; - _abbrObj = cultureData.abbreviations; - _decimalSep = cultureData.delimiters.decimal; - if (cultureData.delimiters.thousands === '.') { - _thousandSep = '\\.'; - } else { - _thousandSep = cultureData.delimiters.thousands; - } + return value; + }; - // validating currency symbol - temp = val.match(/^[^\d\.\,]+/); - if (temp !== null) { - val = val.substr(1); - if (temp[0] !== _currSymbol) { - return false; - } - } + /** + * Retrieve value by its label (`B3`, `B$3`, `B$3`, `$B$3`). + * + * @param {String} label Coordinates. + * @returns {*} + * @private + */ - //validating abbreviation symbol - temp = val.match(/[^\d]+$/); - if (temp !== null) { - val = val.slice(0, -1); - if (temp[0] !== _abbrObj.thousand && temp[0] !== _abbrObj.million && - temp[0] !== _abbrObj.billion && temp[0] !== _abbrObj.trillion) { - return false; - } - } - _thousandRegEx = new RegExp(_thousandSep + '{2}'); + Parser.prototype._callCellValue = function _callCellValue(label) { + label = label.toUpperCase(); - if (!val.match(/[^\d.,]/g)) { - _valArray = val.split(_decimalSep); - if (_valArray.length > 2) { - return false; - } else { - if (_valArray.length < 2) { - return ( !! _valArray[0].match(/^\d+.*\d$/) && !_valArray[0].match(_thousandRegEx)); - } else { - if (_valArray[0] === '') { - // for values without leading zero eg. .984 - return (!_valArray[0].match(_thousandRegEx) && - !!_valArray[1].match(/^\d+$/)); + var _extractLabel = (0, _cell.extractLabel)(label), + row = _extractLabel[0], + column = _extractLabel[1]; - } else if (_valArray[0].length === 1) { - return ( !! _valArray[0].match(/^\d+$/) && - !_valArray[0].match(_thousandRegEx) && - !! _valArray[1].match(/^\d+$/)); - } else { - return ( !! _valArray[0].match(/^\d+.*\d$/) && - !_valArray[0].match(_thousandRegEx) && - !! _valArray[1].match(/^\d+$/)); - } - } - } - } + var value = void 0; - return false; - }; + this.emit('callCellValue', { label: label, row: row, column: column }, function (_value) { + value = _value; + }); - /** - * * @deprecated Since in version 1.6.0. It will be deleted in version 2.0 - * `loadCulturesInNode` should be used instead. - */ - numbro.loadLanguagesInNode = function() { - console.warn('`loadLanguagesInNode` is deprecated since version 1.6.0. Use `loadCulturesInNode` instead'); + return value; + }; - numbro.loadCulturesInNode(); - }; + /** + * Retrieve value by its label (`B3:A1`, `B$3:A1`, `B$3:$A1`, `$B$3:A$1`). + * + * @param {String} startLabel Coordinates of the first cell. + * @param {String} endLabel Coordinates of the last cell. + * @returns {Array} Returns an array of mixed values. + * @private + */ - numbro.loadCulturesInNode = function() { - // TODO: Rename the folder in 2.0.0 - var cultures = __webpack_require__(58); - for(var langLocaleCode in cultures) { - if(langLocaleCode) { - numbro.culture(langLocaleCode, cultures[langLocaleCode]); - } - } - }; + Parser.prototype._callRangeValue = function _callRangeValue(startLabel, endLabel) { + startLabel = startLabel.toUpperCase(); + endLabel = endLabel.toUpperCase(); - /************************************ - Helpers - ************************************/ + var _extractLabel2 = (0, _cell.extractLabel)(startLabel), + startRow = _extractLabel2[0], + startColumn = _extractLabel2[1]; - function setCulture(code, values) { - cultures[code] = values; - } + var _extractLabel3 = (0, _cell.extractLabel)(endLabel), + endRow = _extractLabel3[0], + endColumn = _extractLabel3[1]; - function chooseCulture(code) { - currentCulture = code; - var defaults = cultures[code].defaults; - if (defaults && defaults.format) { - numbro.defaultFormat(defaults.format); - } - if (defaults && defaults.currencyFormat) { - numbro.defaultCurrencyFormat(defaults.currencyFormat); - } + var startCell = {}; + var endCell = {}; + + if (startRow.index <= endRow.index) { + startCell.row = startRow; + endCell.row = endRow; + } else { + startCell.row = endRow; + endCell.row = startRow; } - function inNodejsRuntime() { - return (typeof process !== 'undefined') && - (process.browser === undefined) && - process.title && - ( - process.title.indexOf('node') === 0 || - process.title.indexOf('meteor-tool') > 0 || - process.title === 'grunt' || - process.title === 'gulp' - ) && - ("function" !== 'undefined'); + if (startColumn.index <= endColumn.index) { + startCell.column = startColumn; + endCell.column = endColumn; + } else { + startCell.column = endColumn; + endCell.column = startColumn; } - /************************************ - Floating-point helpers - ************************************/ + startCell.label = (0, _cell.toLabel)(startCell.row, startCell.column); + endCell.label = (0, _cell.toLabel)(endCell.row, endCell.column); - // The floating-point helper functions and implementation - // borrows heavily from sinful.js: http://guipn.github.io/sinful.js/ + var value = []; - /** - * Array.prototype.reduce for browsers that don't support it - * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/Reduce#Compatibility - */ - if ('function' !== typeof Array.prototype.reduce) { - Array.prototype.reduce = function(callback, optInitialValue) { + this.emit('callRangeValue', startCell, endCell, function () { + var _value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; - if (null === this || 'undefined' === typeof this) { - // At the moment all modern browsers, that support strict mode, have - // native implementation of Array.prototype.reduce. For instance, IE8 - // does not support strict mode, so this check is actually useless. - throw new TypeError('Array.prototype.reduce called on null or undefined'); - } + value = _value; + }); - if ('function' !== typeof callback) { - throw new TypeError(callback + ' is not a function'); - } + return value; + }; - var index, - value, - length = this.length >>> 0, - isValueSet = false; + /** + * Try to throw error by its name. + * + * @param {String} errorName Error name. + * @returns {String} + * @private + */ - if (1 < arguments.length) { - value = optInitialValue; - isValueSet = true; - } - for (index = 0; length > index; ++index) { - if (this.hasOwnProperty(index)) { - if (isValueSet) { - value = callback(value, this[index], index, this); - } else { - value = this[index]; - isValueSet = true; - } - } - } + Parser.prototype._throwError = function _throwError(errorName) { + if ((0, _error.isValidStrict)(errorName)) { + throw Error(errorName); + } - if (!isValueSet) { - throw new TypeError('Reduce of empty array with no initial value'); - } + throw Error(_error.ERROR); + }; - return value; - }; - } + return Parser; +}(_tinyEmitter2['default']); +exports['default'] = Parser; - /** - * Computes the multiplier necessary to make x >= 1, - * effectively eliminating miscalculations caused by - * finite precision. - */ - function multiplier(x) { - var parts = x.toString().split('.'); - if (parts.length < 2) { - return 1; - } - return Math.pow(10, parts[1].length); - } +/***/ }), +/* 18 */ +/***/ (function(module, exports) { - /** - * Given a variable number of arguments, returns the maximum - * multiplier that must be used to normalize an operation involving - * all of them. - */ - function correctionFactor() { - var args = Array.prototype.slice.call(arguments); - return args.reduce(function(prev, next) { - var mp = multiplier(prev), - mn = multiplier(next); - return mp > mn ? mp : mn; - }, -Infinity); - } +function E () { + // Keep this empty so it's easier to inherit from + // (via https://github.com/lipsmack from https://github.com/scottcorgan/tiny-emitter/issues/3) +} - /************************************ - Numbro Prototype - ************************************/ +E.prototype = { + on: function (name, callback, ctx) { + var e = this.e || (this.e = {}); + (e[name] || (e[name] = [])).push({ + fn: callback, + ctx: ctx + }); - numbro.fn = Numbro.prototype = { + return this; + }, - clone: function() { - return numbro(this); - }, + once: function (name, callback, ctx) { + var self = this; + function listener () { + self.off(name, listener); + callback.apply(ctx, arguments); + }; - format: function(inputString, roundingFunction) { - return formatNumbro(this, - inputString ? inputString : defaultFormat, - (roundingFunction !== undefined) ? roundingFunction : Math.round - ); - }, + listener._ = callback + return this.on(name, listener, ctx); + }, - formatCurrency: function(inputString, roundingFunction) { - return formatCurrency(this, - cultures[currentCulture].currency.symbol, - inputString ? inputString : defaultCurrencyFormat, - (roundingFunction !== undefined) ? roundingFunction : Math.round - ); - }, + emit: function (name) { + var data = [].slice.call(arguments, 1); + var evtArr = ((this.e || (this.e = {}))[name] || []).slice(); + var i = 0; + var len = evtArr.length; - formatForeignCurrency: function(currencySymbol, inputString, roundingFunction) { - return formatForeignCurrency(this, - currencySymbol, - inputString ? inputString : defaultCurrencyFormat, - (roundingFunction !== undefined) ? roundingFunction : Math.round - ); - }, + for (i; i < len; i++) { + evtArr[i].fn.apply(evtArr[i].ctx, data); + } - unformat: function(inputString) { - if (typeof inputString === 'number') { - return inputString; - } else if (typeof inputString === 'string') { - var result = unformatNumbro(this, inputString); + return this; + }, - // Any unparseable string (represented as NaN in the result) is - // converted into undefined. - return isNaN(result) ? undefined : result; - } else { - return undefined; - } - }, + off: function (name, callback) { + var e = this.e || (this.e = {}); + var evts = e[name]; + var liveEvents = []; - binaryByteUnits: function() { - return formatByteUnits(this._value, bytes.binary.suffixes, bytes.binary.scale).suffix; - }, + if (evts && callback) { + for (var i = 0, len = evts.length; i < len; i++) { + if (evts[i].fn !== callback && evts[i].fn._ !== callback) + liveEvents.push(evts[i]); + } + } - byteUnits: function() { - return formatByteUnits(this._value, bytes.general.suffixes, bytes.general.scale).suffix; - }, + // Remove event from queue to prevent memory leak + // Suggested by https://github.com/lazd + // Ref: https://github.com/scottcorgan/tiny-emitter/commit/c6ebfaa9bc973b33d110a84a307742b7cf94c953#commitcomment-5024910 - decimalByteUnits: function() { - return formatByteUnits(this._value, bytes.decimal.suffixes, bytes.decimal.scale).suffix; - }, + (liveEvents.length) + ? e[name] = liveEvents + : delete e[name]; - value: function() { - return this._value; - }, + return this; + } +}; - valueOf: function() { - return this._value; - }, +module.exports = E; - set: function(value) { - this._value = Number(value); - return this; - }, - add: function(value) { - var corrFactor = correctionFactor.call(null, this._value, value); +/***/ }), +/* 19 */ +/***/ (function(module, exports, __webpack_require__) { - function cback(accum, curr) { - return accum + corrFactor * curr; - } - this._value = [this._value, value].reduce(cback, 0) / corrFactor; - return this; - }, +"use strict"; - subtract: function(value) { - var corrFactor = correctionFactor.call(null, this._value, value); - function cback(accum, curr) { - return accum - corrFactor * curr; - } - this._value = [value].reduce(cback, this._value * corrFactor) / corrFactor; - return this; - }, +exports.__esModule = true; +exports['default'] = evaluateByOperator; +exports.registerOperation = registerOperation; - multiply: function(value) { - function cback(accum, curr) { - var corrFactor = correctionFactor(accum, curr), - result = accum * corrFactor; - result *= curr * corrFactor; - result /= corrFactor * corrFactor; - return result; - } - this._value = [this._value, value].reduce(cback, 1); - return this; - }, +var _add = __webpack_require__(20); - divide: function(value) { - function cback(accum, curr) { - var corrFactor = correctionFactor(accum, curr); - return (accum * corrFactor) / (curr * corrFactor); - } - this._value = [this._value, value].reduce(cback); - return this; - }, +var _add2 = _interopRequireDefault(_add); + +var _ampersand = __webpack_require__(21); + +var _ampersand2 = _interopRequireDefault(_ampersand); - difference: function(value) { - return Math.abs(numbro(this._value).subtract(value).value()); - } +var _divide = __webpack_require__(22); - }; +var _divide2 = _interopRequireDefault(_divide); - /************************************ - Exposing Numbro - ************************************/ +var _equal = __webpack_require__(23); - if (inNodejsRuntime()) { - //Todo: Rename the folder in 2.0.0 - numbro.loadCulturesInNode(); - } +var _equal2 = _interopRequireDefault(_equal); - // CommonJS module is defined - if (hasModule) { - module.exports = numbro; - } else { - /*global ender:false */ - if (typeof ender === 'undefined') { - // here, `this` means `window` in the browser, or `global` on the server - // add `numbro` as a global object via a string identifier, - // for Closure Compiler 'advanced' mode - this.numbro = numbro; - } +var _formulaFunction = __webpack_require__(24); - /*global define:false */ - if (true) { - !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = function() { - return numbro; - }.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__), - __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); - } - } +var _formulaFunction2 = _interopRequireDefault(_formulaFunction); -}.call(typeof window === 'undefined' ? this : window)); +var _greaterThan = __webpack_require__(93); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(15))) +var _greaterThan2 = _interopRequireDefault(_greaterThan); -/***/ }), -/* 15 */ -/***/ (function(module, exports) { +var _greaterThanOrEqual = __webpack_require__(94); -// shim for using process in browser -var process = module.exports = {}; +var _greaterThanOrEqual2 = _interopRequireDefault(_greaterThanOrEqual); -// cached from whatever global is present so that test runners that stub it -// don't break things. But we need to wrap it in a try catch in case it is -// wrapped in strict mode code which doesn't define any globals. It's inside a -// function because try/catches deoptimize in certain engines. +var _lessThan = __webpack_require__(95); -var cachedSetTimeout; -var cachedClearTimeout; +var _lessThan2 = _interopRequireDefault(_lessThan); -function defaultSetTimout() { - throw new Error('setTimeout has not been defined'); -} -function defaultClearTimeout () { - throw new Error('clearTimeout has not been defined'); -} -(function () { - try { - if (typeof setTimeout === 'function') { - cachedSetTimeout = setTimeout; - } else { - cachedSetTimeout = defaultSetTimout; - } - } catch (e) { - cachedSetTimeout = defaultSetTimout; - } - try { - if (typeof clearTimeout === 'function') { - cachedClearTimeout = clearTimeout; - } else { - cachedClearTimeout = defaultClearTimeout; - } - } catch (e) { - cachedClearTimeout = defaultClearTimeout; - } -} ()) -function runTimeout(fun) { - if (cachedSetTimeout === setTimeout) { - //normal enviroments in sane situations - return setTimeout(fun, 0); - } - // if setTimeout wasn't available but was latter defined - if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) { - cachedSetTimeout = setTimeout; - return setTimeout(fun, 0); - } - try { - // when when somebody has screwed with setTimeout but no I.E. maddness - return cachedSetTimeout(fun, 0); - } catch(e){ - try { - // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally - return cachedSetTimeout.call(null, fun, 0); - } catch(e){ - // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error - return cachedSetTimeout.call(this, fun, 0); - } - } +var _lessThanOrEqual = __webpack_require__(96); +var _lessThanOrEqual2 = _interopRequireDefault(_lessThanOrEqual); -} -function runClearTimeout(marker) { - if (cachedClearTimeout === clearTimeout) { - //normal enviroments in sane situations - return clearTimeout(marker); - } - // if clearTimeout wasn't available but was latter defined - if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) { - cachedClearTimeout = clearTimeout; - return clearTimeout(marker); - } - try { - // when when somebody has screwed with setTimeout but no I.E. maddness - return cachedClearTimeout(marker); - } catch (e){ - try { - // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally - return cachedClearTimeout.call(null, marker); - } catch (e){ - // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error. - // Some versions of I.E. have different rules for clearTimeout vs setTimeout - return cachedClearTimeout.call(this, marker); - } - } +var _minus = __webpack_require__(97); +var _minus2 = _interopRequireDefault(_minus); +var _multiply = __webpack_require__(98); -} -var queue = []; -var draining = false; -var currentQueue; -var queueIndex = -1; +var _multiply2 = _interopRequireDefault(_multiply); -function cleanUpNextTick() { - if (!draining || !currentQueue) { - return; - } - draining = false; - if (currentQueue.length) { - queue = currentQueue.concat(queue); - } else { - queueIndex = -1; - } - if (queue.length) { - drainQueue(); - } -} +var _notEqual = __webpack_require__(99); -function drainQueue() { - if (draining) { - return; - } - var timeout = runTimeout(cleanUpNextTick); - draining = true; +var _notEqual2 = _interopRequireDefault(_notEqual); - var len = queue.length; - while(len) { - currentQueue = queue; - queue = []; - while (++queueIndex < len) { - if (currentQueue) { - currentQueue[queueIndex].run(); - } - } - queueIndex = -1; - len = queue.length; - } - currentQueue = null; - draining = false; - runClearTimeout(timeout); -} +var _power = __webpack_require__(100); -process.nextTick = function (fun) { - var args = new Array(arguments.length - 1); - if (arguments.length > 1) { - for (var i = 1; i < arguments.length; i++) { - args[i - 1] = arguments[i]; - } - } - queue.push(new Item(fun, args)); - if (queue.length === 1 && !draining) { - runTimeout(drainQueue); - } -}; +var _power2 = _interopRequireDefault(_power); -// v8 likes predictible objects -function Item(fun, array) { - this.fun = fun; - this.array = array; -} -Item.prototype.run = function () { - this.fun.apply(null, this.array); -}; -process.title = 'browser'; -process.browser = true; -process.env = {}; -process.argv = []; -process.version = ''; // empty string to avoid regexp issues -process.versions = {}; +var _error = __webpack_require__(2); -function noop() {} +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } -process.on = noop; -process.addListener = noop; -process.once = noop; -process.off = noop; -process.removeListener = noop; -process.removeAllListeners = noop; -process.emit = noop; +/* eslint-disable import/no-named-as-default-member */ +var availableOperators = Object.create(null); -process.binding = function (name) { - throw new Error('process.binding is not supported'); -}; +/** + * Evaluate values by operator id.git + * + * @param {String} operator Operator id. + * @param {Array} [params=[]] Arguments to evaluate. + * @returns {*} + */ +function evaluateByOperator(operator) { + var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : []; -process.cwd = function () { return '/' }; -process.chdir = function (dir) { - throw new Error('process.chdir is not supported'); -}; -process.umask = function() { return 0; }; + operator = operator.toUpperCase(); + + if (!availableOperators[operator]) { + throw Error(_error.ERROR_NAME); + } + + return availableOperators[operator].apply(availableOperators, params); +} + +/** + * Register operator. + * + * @param {String|Array} symbol Symbol to register. + * @param {Function} func Logic to register for this symbol. + */ +function registerOperation(symbol, func) { + if (!Array.isArray(symbol)) { + symbol = [symbol.toUpperCase()]; + } + symbol.forEach(function (s) { + if (func.isFactory) { + availableOperators[s] = func(s); + } else { + availableOperators[s] = func; + } + }); +} +registerOperation(_add2['default'].SYMBOL, _add2['default']); +registerOperation(_ampersand2['default'].SYMBOL, _ampersand2['default']); +registerOperation(_divide2['default'].SYMBOL, _divide2['default']); +registerOperation(_equal2['default'].SYMBOL, _equal2['default']); +registerOperation(_power2['default'].SYMBOL, _power2['default']); +registerOperation(_formulaFunction2['default'].SYMBOL, _formulaFunction2['default']); +registerOperation(_greaterThan2['default'].SYMBOL, _greaterThan2['default']); +registerOperation(_greaterThanOrEqual2['default'].SYMBOL, _greaterThanOrEqual2['default']); +registerOperation(_lessThan2['default'].SYMBOL, _lessThan2['default']); +registerOperation(_lessThanOrEqual2['default'].SYMBOL, _lessThanOrEqual2['default']); +registerOperation(_multiply2['default'].SYMBOL, _multiply2['default']); +registerOperation(_notEqual2['default'].SYMBOL, _notEqual2['default']); +registerOperation(_minus2['default'].SYMBOL, _minus2['default']); /***/ }), -/* 16 */ +/* 20 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; exports.__esModule = true; - -var _tinyEmitter = __webpack_require__(78); - -var _tinyEmitter2 = _interopRequireDefault(_tinyEmitter); - -var _evaluateByOperator = __webpack_require__(17); - -var _evaluateByOperator2 = _interopRequireDefault(_evaluateByOperator); - -var _grammarParser = __webpack_require__(80); - -var _string = __webpack_require__(31); +exports.SYMBOL = undefined; +exports['default'] = func; var _number = __webpack_require__(3); -var _error = __webpack_require__(1); - -var _error2 = _interopRequireDefault(_error); - -var _cell = __webpack_require__(9); - -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } - -function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } - -/** - * @class Parser - */ -var Parser = function (_Emitter) { - _inherits(Parser, _Emitter); - - function Parser() { - _classCallCheck(this, Parser); - - var _this = _possibleConstructorReturn(this, _Emitter.call(this)); +var _error = __webpack_require__(2); - _this.parser = new _grammarParser.Parser(); - _this.parser.yy = { - toNumber: _number.toNumber, - trimEdges: _string.trimEdges, - invertNumber: _number.invertNumber, - throwError: function throwError(errorName) { - return _this._throwError(errorName); - }, - callVariable: function callVariable(variable) { - return _this._callVariable(variable); - }, - evaluateByOperator: _evaluateByOperator2['default'], - callFunction: _evaluateByOperator2['default'], - cellValue: function cellValue(value) { - return _this._callCellValue(value); - }, - rangeValue: function rangeValue(start, end) { - return _this._callRangeValue(start, end); - } - }; - _this.variables = Object.create(null); +var SYMBOL = exports.SYMBOL = '+'; - _this.setVariable('TRUE', true).setVariable('FALSE', false).setVariable('NULL', null); - return _this; +function func(first) { + for (var _len = arguments.length, rest = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + rest[_key - 1] = arguments[_key]; } - /** - * Parse formula expression. - * - * @param {String} expression to parse. - * @return {*} Returns an object with tow properties `error` and `result`. - */ - - - Parser.prototype.parse = function parse(expression) { - var result = null; - var error = null; + var result = rest.reduce(function (acc, value) { + return acc + (0, _number.toNumber)(value); + }, (0, _number.toNumber)(first)); - try { - if (expression === '') { - result = ''; - } else { - result = this.parser.parse(expression); - } - } catch (ex) { - var message = (0, _error2['default'])(ex.message); + if (isNaN(result)) { + throw Error(_error.ERROR_VALUE); + } - if (message) { - error = message; - } else { - error = (0, _error2['default'])(_error.ERROR); - } - } + return result; +} - if (result instanceof Error) { - error = (0, _error2['default'])(result.message) || (0, _error2['default'])(_error.ERROR); - result = null; - } +func.SYMBOL = SYMBOL; - return { - error: error, - result: result - }; - }; +/***/ }), +/* 21 */ +/***/ (function(module, exports, __webpack_require__) { - /** - * Set predefined variable name which can be visible while parsing formula expression. - * - * @param {String} name Variable name. - * @param {*} value Variable value. - * @returns {Parser} - */ +"use strict"; - Parser.prototype.setVariable = function setVariable(name, value) { - this.variables[name] = value; +exports.__esModule = true; +exports['default'] = func; +var SYMBOL = exports.SYMBOL = '&'; - return this; - }; +function func() { + for (var _len = arguments.length, params = Array(_len), _key = 0; _key < _len; _key++) { + params[_key] = arguments[_key]; + } - /** - * Get variable name. - * - * @param {String} name Variable name. - * @returns {*} - */ + return params.reduce(function (acc, value) { + return acc + value.toString(); + }, ''); +} +func.SYMBOL = SYMBOL; - Parser.prototype.getVariable = function getVariable(name) { - return this.variables[name]; - }; +/***/ }), +/* 22 */ +/***/ (function(module, exports, __webpack_require__) { - /** - * Retrieve variable value by its name. - * - * @param name Variable name. - * @returns {*} - * @private - */ +"use strict"; - Parser.prototype._callVariable = function _callVariable(name) { - var value = this.getVariable(name); +exports.__esModule = true; +exports.SYMBOL = undefined; +exports['default'] = func; - this.emit('callVariable', name, function (newValue) { - if (newValue !== void 0) { - value = newValue; - } - }); +var _number = __webpack_require__(3); - if (value === void 0) { - throw Error(_error.ERROR_NAME); - } +var _error = __webpack_require__(2); - return value; - }; +var SYMBOL = exports.SYMBOL = '/'; - /** - * Retrieve value by its label (`B3`, `B$3`, `B$3`, `$B$3`). - * - * @param {String} label Coordinates. - * @returns {*} - * @private - */ +function func(first) { + for (var _len = arguments.length, rest = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + rest[_key - 1] = arguments[_key]; + } + var result = rest.reduce(function (acc, value) { + return acc / (0, _number.toNumber)(value); + }, (0, _number.toNumber)(first)); - Parser.prototype._callCellValue = function _callCellValue(label) { - label = label.toUpperCase(); + if (result === Infinity) { + throw Error(_error.ERROR_DIV_ZERO); + } + if (isNaN(result)) { + throw Error(_error.ERROR_VALUE); + } - var _extractLabel = (0, _cell.extractLabel)(label), - row = _extractLabel[0], - column = _extractLabel[1]; + return result; +} - var value = void 0; +func.SYMBOL = SYMBOL; - this.emit('callCellValue', { label: label, row: row, column: column }, function (_value) { - value = _value; - }); +/***/ }), +/* 23 */ +/***/ (function(module, exports, __webpack_require__) { - return value; - }; +"use strict"; - /** - * Retrieve value by its label (`B3:A1`, `B$3:A1`, `B$3:$A1`, `$B$3:A$1`). - * - * @param {String} startLabel Coordinates of the first cell. - * @param {String} endLabel Coordinates of the last cell. - * @returns {Array} Returns an array of mixed values. - * @private - */ +exports.__esModule = true; +exports['default'] = func; +var SYMBOL = exports.SYMBOL = '='; - Parser.prototype._callRangeValue = function _callRangeValue(startLabel, endLabel) { - startLabel = startLabel.toUpperCase(); - endLabel = endLabel.toUpperCase(); +function func(exp1, exp2) { + return exp1 === exp2; +} - var _extractLabel2 = (0, _cell.extractLabel)(startLabel), - startRow = _extractLabel2[0], - startColumn = _extractLabel2[1]; +func.SYMBOL = SYMBOL; - var _extractLabel3 = (0, _cell.extractLabel)(endLabel), - endRow = _extractLabel3[0], - endColumn = _extractLabel3[1]; +/***/ }), +/* 24 */ +/***/ (function(module, exports, __webpack_require__) { - var startCell = {}; - var endCell = {}; +"use strict"; - if (startRow.index <= endRow.index) { - startCell.row = startRow; - endCell.row = endRow; - } else { - startCell.row = endRow; - endCell.row = startRow; - } - if (startColumn.index <= endColumn.index) { - startCell.column = startColumn; - endCell.column = endColumn; - } else { - startCell.column = endColumn; - endCell.column = startColumn; - } +exports.__esModule = true; +exports.SYMBOL = undefined; +exports['default'] = func; - startCell.label = (0, _cell.toLabel)(startCell.row, startCell.column); - endCell.label = (0, _cell.toLabel)(endCell.row, endCell.column); +var _formulajs = __webpack_require__(25); - var value = []; +var formulajs = _interopRequireWildcard(_formulajs); - this.emit('callRangeValue', startCell, endCell, function () { - var _value = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; +var _supportedFormulas = __webpack_require__(14); - value = _value; - }); +var _supportedFormulas2 = _interopRequireDefault(_supportedFormulas); - return value; - }; +var _error = __webpack_require__(2); - /** - * Try to throw error by its name. - * - * @param {String} errorName Error name. - * @returns {String} - * @private - */ +function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } +function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj['default'] = obj; return newObj; } } - Parser.prototype._throwError = function _throwError(errorName) { - if ((0, _error.isValidStrict)(errorName)) { - throw Error(errorName); - } +var SYMBOL = exports.SYMBOL = _supportedFormulas2['default']; - throw Error(_error.ERROR); - }; +function func(symbol) { + return function __formulaFunction() { + symbol = symbol.toUpperCase(); - return Parser; -}(_tinyEmitter2['default']); + var symbolParts = symbol.split('.'); + var foundFormula = false; + var result = void 0; -exports['default'] = Parser; + if (symbolParts.length === 1) { + if (formulajs[symbolParts[0]]) { + foundFormula = true; + result = formulajs[symbolParts[0]].apply(formulajs, arguments); + } + } else { + var length = symbolParts.length; + var index = 0; + var nestedFormula = formulajs; -/***/ }), -/* 17 */ -/***/ (function(module, exports, __webpack_require__) { + while (index < length) { + nestedFormula = nestedFormula[symbolParts[index]]; + index++; -"use strict"; + if (!nestedFormula) { + nestedFormula = null; + break; + } + } + if (nestedFormula) { + foundFormula = true; + result = nestedFormula.apply(undefined, arguments); + } + } + if (!foundFormula) { + throw Error(_error.ERROR_NAME); + } -exports.__esModule = true; -exports['default'] = evaluateByOperator; -exports.registerOperation = registerOperation; + return result; + }; +} -var _add = __webpack_require__(18); +func.isFactory = true; +func.SYMBOL = SYMBOL; -var _add2 = _interopRequireDefault(_add); +/***/ }), +/* 25 */ +/***/ (function(module, exports, __webpack_require__) { -var _ampersand = __webpack_require__(19); +var categories = [ + __webpack_require__(26), + __webpack_require__(89), + __webpack_require__(13), + __webpack_require__(90), + __webpack_require__(4), + __webpack_require__(6), + __webpack_require__(8), + __webpack_require__(91), + __webpack_require__(7), + __webpack_require__(92), + __webpack_require__(5), + __webpack_require__(12) +]; -var _ampersand2 = _interopRequireDefault(_ampersand); +for (var c in categories) { + var category = categories[c]; + for (var f in category) { + exports[f] = exports[f] || category[f]; + } +} -var _divide = __webpack_require__(20); -var _divide2 = _interopRequireDefault(_divide); +/***/ }), +/* 26 */ +/***/ (function(module, exports, __webpack_require__) { -var _equal = __webpack_require__(21); +var mathTrig = __webpack_require__(4); +var statistical = __webpack_require__(5); +var engineering = __webpack_require__(13); +var dateTime = __webpack_require__(8); -var _equal2 = _interopRequireDefault(_equal); +function set(fn, root) { + if (root) { + for (var i in root) { + fn[i] = root[i]; + } + } -var _formulaFunction = __webpack_require__(22); + return fn; +} -var _formulaFunction2 = _interopRequireDefault(_formulaFunction); +exports.BETADIST = statistical.BETA.DIST; +exports.BETAINV = statistical.BETA.INV; +exports.BINOMDIST = statistical.BINOM.DIST; +exports.CEILING = exports.ISOCEILING = set(mathTrig.CEILING.MATH, mathTrig.CEILING); +exports.CEILINGMATH = mathTrig.CEILING.MATH; +exports.CEILINGPRECISE = mathTrig.CEILING.PRECISE; +exports.CHIDIST = statistical.CHISQ.DIST; +exports.CHIDISTRT = statistical.CHISQ.DIST.RT; +exports.CHIINV = statistical.CHISQ.INV; +exports.CHIINVRT = statistical.CHISQ.INV.RT; +exports.CHITEST = statistical.CHISQ.TEST; +exports.CONFIDENCE = set(statistical.CONFIDENCE.NORM, statistical.CONFIDENCE); +exports.COVAR = statistical.COVARIANCE.P; +exports.COVARIANCEP = statistical.COVARIANCE.P; +exports.COVARIANCES = statistical.COVARIANCE.S; +exports.CRITBINOM = statistical.BINOM.INV; +exports.EXPONDIST = statistical.EXPON.DIST; +exports.ERFCPRECISE = engineering.ERFC.PRECISE; +exports.ERFPRECISE = engineering.ERF.PRECISE; +exports.FDIST = statistical.F.DIST; +exports.FDISTRT = statistical.F.DIST.RT; +exports.FINVRT = statistical.F.INV.RT; +exports.FINV = statistical.F.INV; +exports.FLOOR = set(mathTrig.FLOOR.MATH, mathTrig.FLOOR); +exports.FLOORMATH = mathTrig.FLOOR.MATH; +exports.FLOORPRECISE = mathTrig.FLOOR.PRECISE; +exports.FTEST = statistical.F.TEST; +exports.GAMMADIST = statistical.GAMMA.DIST; +exports.GAMMAINV = statistical.GAMMA.INV; +exports.GAMMALNPRECISE = statistical.GAMMALN.PRECISE; +exports.HYPGEOMDIST = statistical.HYPGEOM.DIST; +exports.LOGINV = statistical.LOGNORM.INV; +exports.LOGNORMINV = statistical.LOGNORM.INV; +exports.LOGNORMDIST = statistical.LOGNORM.DIST; +exports.MODE = set(statistical.MODE.SNGL, statistical.MODE); +exports.MODEMULT = statistical.MODE.MULT; +exports.MODESNGL = statistical.MODE.SNGL; +exports.NEGBINOMDIST = statistical.NEGBINOM.DIST; +exports.NETWORKDAYSINTL = dateTime.NETWORKDAYS.INTL; +exports.NORMDIST = statistical.NORM.DIST; +exports.NORMINV = statistical.NORM.INV; +exports.NORMSDIST = statistical.NORM.S.DIST; +exports.NORMSINV = statistical.NORM.S.INV; +exports.PERCENTILE = set(statistical.PERCENTILE.EXC, statistical.PERCENTILE); +exports.PERCENTILEEXC = statistical.PERCENTILE.EXC; +exports.PERCENTILEINC = statistical.PERCENTILE.INC; +exports.PERCENTRANK = set(statistical.PERCENTRANK.INC, statistical.PERCENTRANK); +exports.PERCENTRANKEXC = statistical.PERCENTRANK.EXC; +exports.PERCENTRANKINC = statistical.PERCENTRANK.INC; +exports.POISSON = set(statistical.POISSON.DIST, statistical.POISSON); +exports.POISSONDIST = statistical.POISSON.DIST; +exports.QUARTILE = set(statistical.QUARTILE.INC, statistical.QUARTILE); +exports.QUARTILEEXC = statistical.QUARTILE.EXC; +exports.QUARTILEINC = statistical.QUARTILE.INC; +exports.RANK = set(statistical.RANK.EQ, statistical.RANK); +exports.RANKAVG = statistical.RANK.AVG; +exports.RANKEQ = statistical.RANK.EQ; +exports.SKEWP = statistical.SKEW.P; +exports.STDEV = set(statistical.STDEV.S, statistical.STDEV); +exports.STDEVP = statistical.STDEV.P; +exports.STDEVS = statistical.STDEV.S; +exports.TDIST = statistical.T.DIST; +exports.TDISTRT = statistical.T.DIST.RT; +exports.TINV = statistical.T.INV; +exports.TTEST = statistical.T.TEST; +exports.VAR = set(statistical.VAR.S, statistical.VAR); +exports.VARP = statistical.VAR.P; +exports.VARS = statistical.VAR.S; +exports.WEIBULL = set(statistical.WEIBULL.DIST, statistical.WEIBULL); +exports.WEIBULLDIST = statistical.WEIBULL.DIST; +exports.WORKDAYINTL = dateTime.WORKDAY.INTL; +exports.ZTEST = statistical.Z.TEST; -var _greaterThan = __webpack_require__(24); -var _greaterThan2 = _interopRequireDefault(_greaterThan); +/***/ }), +/* 27 */ +/***/ (function(module, exports, __webpack_require__) { -var _greaterThanOrEqual = __webpack_require__(23); +/* jshint sub: true */ +exports['bg'] = __webpack_require__(28); +exports['cs-CZ'] = __webpack_require__(29); +exports['da-DK'] = __webpack_require__(30); +exports['de-AT'] = __webpack_require__(31); +exports['de-CH'] = __webpack_require__(32); +exports['de-DE'] = __webpack_require__(33); +exports['de-LI'] = __webpack_require__(34); +exports['el'] = __webpack_require__(35); +exports['en-AU'] = __webpack_require__(36); +exports['en-GB'] = __webpack_require__(37); +exports['en-IE'] = __webpack_require__(38); +exports['en-NZ'] = __webpack_require__(39); +exports['en-ZA'] = __webpack_require__(40); +exports['es-AR'] = __webpack_require__(41); +exports['es-CL'] = __webpack_require__(42); +exports['es-CO'] = __webpack_require__(43); +exports['es-CR'] = __webpack_require__(44); +exports['es-ES'] = __webpack_require__(45); +exports['es-NI'] = __webpack_require__(46); +exports['es-PE'] = __webpack_require__(47); +exports['es-PR'] = __webpack_require__(48); +exports['es-SV'] = __webpack_require__(49); +exports['et-EE'] = __webpack_require__(50); +exports['fa-IR'] = __webpack_require__(51); +exports['fi-FI'] = __webpack_require__(52); +exports['fil-PH'] = __webpack_require__(53); +exports['fr-CA'] = __webpack_require__(54); +exports['fr-CH'] = __webpack_require__(55); +exports['fr-FR'] = __webpack_require__(56); +exports['he-IL'] = __webpack_require__(57); +exports['hu-HU'] = __webpack_require__(58); +exports['id'] = __webpack_require__(59); +exports['it-CH'] = __webpack_require__(60); +exports['it-IT'] = __webpack_require__(61); +exports['ja-JP'] = __webpack_require__(62); +exports['ko-KR'] = __webpack_require__(63); +exports['lv-LV'] = __webpack_require__(64); +exports['nb-NO'] = __webpack_require__(65); +exports['nb'] = __webpack_require__(66); +exports['nl-BE'] = __webpack_require__(67); +exports['nl-NL'] = __webpack_require__(68); +exports['nn'] = __webpack_require__(69); +exports['pl-PL'] = __webpack_require__(70); +exports['pt-BR'] = __webpack_require__(71); +exports['pt-PT'] = __webpack_require__(72); +exports['ro-RO'] = __webpack_require__(73); +exports['ro'] = __webpack_require__(74); +exports['ru-RU'] = __webpack_require__(75); +exports['ru-UA'] = __webpack_require__(76); +exports['sk-SK'] = __webpack_require__(77); +exports['sl'] = __webpack_require__(78); +exports['sr-Cyrl-RS'] = __webpack_require__(79); +exports['sv-SE'] = __webpack_require__(80); +exports['th-TH'] = __webpack_require__(81); +exports['tr-TR'] = __webpack_require__(82); +exports['uk-UA'] = __webpack_require__(83); +exports['zh-CN'] = __webpack_require__(84); +exports['zh-MO'] = __webpack_require__(85); +exports['zh-SG'] = __webpack_require__(86); +exports['zh-TW'] = __webpack_require__(87); -var _greaterThanOrEqual2 = _interopRequireDefault(_greaterThanOrEqual); +/***/ }), +/* 28 */ +/***/ (function(module, exports) { -var _lessThan = __webpack_require__(26); +/*! + * numbro.js language configuration + * language : Bulgarian + * author : Tim McIntosh (StayinFront NZ) + */ +(function () { + 'use strict'; -var _lessThan2 = _interopRequireDefault(_lessThan); + var language = { + langLocaleCode: 'bg', + cultureCode: 'bg', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 'И', + million: 'А', + billion: 'M', + trillion: 'T' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: 'лв.' + } + }; -var _lessThanOrEqual = __webpack_require__(25); + // Node + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + this.numbro.culture('bg', language); + } +}.call(typeof window === 'undefined' ? this : window)); -var _lessThanOrEqual2 = _interopRequireDefault(_lessThanOrEqual); -var _minus = __webpack_require__(27); +/***/ }), +/* 29 */ +/***/ (function(module, exports) { -var _minus2 = _interopRequireDefault(_minus); +/*! + * numbro.js language configuration + * language : Czech + * locale: Czech Republic + * author : Jan Pesa : https://github.com/smajl (based on work from Anatoli Papirovski : https://github.com/apapirovski) + */ +(function () { + 'use strict'; -var _multiply = __webpack_require__(28); + var language = { + langLocaleCode: 'cs-CZ', + cultureCode: 'cs-CZ', + delimiters: { + thousands: '\u00a0', + decimal: ',' + }, + abbreviations: { + thousand: 'tis.', + million: 'mil.', + billion: 'mld.', + trillion: 'bil.' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: 'Kč', + position: 'postfix', + spaceSeparated: true + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; -var _multiply2 = _interopRequireDefault(_multiply); + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -var _notEqual = __webpack_require__(29); -var _notEqual2 = _interopRequireDefault(_notEqual); +/***/ }), +/* 30 */ +/***/ (function(module, exports) { -var _power = __webpack_require__(30); +/*! + * numbro.js language configuration + * language : Danish + * locale: Denmark + * author : Michael Storgaard : https://github.com/mstorgaard + */ +(function () { + 'use strict'; -var _power2 = _interopRequireDefault(_power); + var language = { + langLocaleCode: 'da-DK', + cultureCode: 'da-DK', + delimiters: { + thousands: '.', + decimal: ',' + }, + abbreviations: { + thousand: 'k', + million: 'mio', + billion: 'mia', + trillion: 'b' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: 'kr', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; -var _error = __webpack_require__(1); + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } -/* eslint-disable import/no-named-as-default-member */ -var availableOperators = Object.create(null); +/***/ }), +/* 31 */ +/***/ (function(module, exports) { -/** - * Evaluate values by operator id.git - * - * @param {String} operator Operator id. - * @param {Array} [params=[]] Arguments to evaluate. - * @returns {*} +/*! + * numbro.js language configuration + * language : German + * locale: Austria + * author : Tim McIntosh (StayinFront NZ) */ -function evaluateByOperator(operator) { - var params = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : []; - - operator = operator.toUpperCase(); - - if (!availableOperators[operator]) { - throw Error(_error.ERROR_NAME); - } +(function () { + 'use strict'; - return availableOperators[operator].apply(availableOperators, params); -} + var language = { + langLocaleCode: 'de-AT', + cultureCode: 'de-AT', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: '€' + } + }; -/** - * Register operator. - * - * @param {String|Array} symbol Symbol to register. - * @param {Function} func Logic to register for this symbol. - */ -function registerOperation(symbol, func) { - if (!Array.isArray(symbol)) { - symbol = [symbol.toUpperCase()]; - } - symbol.forEach(function (s) { - if (func.isFactory) { - availableOperators[s] = func(s); - } else { - availableOperators[s] = func; + // Node + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; } - }); -} + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -registerOperation(_add2['default'].SYMBOL, _add2['default']); -registerOperation(_ampersand2['default'].SYMBOL, _ampersand2['default']); -registerOperation(_divide2['default'].SYMBOL, _divide2['default']); -registerOperation(_equal2['default'].SYMBOL, _equal2['default']); -registerOperation(_power2['default'].SYMBOL, _power2['default']); -registerOperation(_formulaFunction2['default'].SYMBOL, _formulaFunction2['default']); -registerOperation(_greaterThan2['default'].SYMBOL, _greaterThan2['default']); -registerOperation(_greaterThanOrEqual2['default'].SYMBOL, _greaterThanOrEqual2['default']); -registerOperation(_lessThan2['default'].SYMBOL, _lessThan2['default']); -registerOperation(_lessThanOrEqual2['default'].SYMBOL, _lessThanOrEqual2['default']); -registerOperation(_multiply2['default'].SYMBOL, _multiply2['default']); -registerOperation(_notEqual2['default'].SYMBOL, _notEqual2['default']); -registerOperation(_minus2['default'].SYMBOL, _minus2['default']); /***/ }), -/* 18 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - +/* 32 */ +/***/ (function(module, exports) { -exports.__esModule = true; -exports.SYMBOL = undefined; -exports['default'] = func; +/*! + * numbro.js language configuration + * language : German + * locale: Switzerland + * author : Michael Piefel : https://github.com/piefel (based on work from Marco Krage : https://github.com/sinky) + */ +(function () { + 'use strict'; -var _number = __webpack_require__(3); + var language = { + langLocaleCode: 'de-CH', + cultureCode: 'de-CH', + delimiters: { + thousands: '\'', + decimal: '.' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: 'CHF', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; -var _error = __webpack_require__(1); + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -var SYMBOL = exports.SYMBOL = '+'; -function func(first) { - for (var _len = arguments.length, rest = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - rest[_key - 1] = arguments[_key]; - } +/***/ }), +/* 33 */ +/***/ (function(module, exports) { - var result = rest.reduce(function (acc, value) { - return acc + (0, _number.toNumber)(value); - }, (0, _number.toNumber)(first)); +/*! + * numbro.js language configuration + * language : German + * locale: Germany + * author : Marco Krage : https://github.com/sinky + * + * Generally useful in Germany, Austria, Luxembourg, Belgium + */ +(function () { + 'use strict'; - if (isNaN(result)) { - throw Error(_error.ERROR_VALUE); - } + var language = { + langLocaleCode: 'de-DE', + cultureCode: 'de-DE', + delimiters: { + thousands: '.', + decimal: ',' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: '€', + position: 'postfix', + spaceSeparated: true + }, + defaults: { + currencyFormat: ',4' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - return result; -} + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -func.SYMBOL = SYMBOL; /***/ }), -/* 19 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - +/* 34 */ +/***/ (function(module, exports) { -exports.__esModule = true; -exports['default'] = func; -var SYMBOL = exports.SYMBOL = '&'; +/*! + * numbro.js language configuration + * language : German + * locale: Liechtenstein + * author : Michael Piefel : https://github.com/piefel (based on work from Marco Krage : https://github.com/sinky) + */ +(function () { + 'use strict'; -function func() { - for (var _len = arguments.length, params = Array(_len), _key = 0; _key < _len; _key++) { - params[_key] = arguments[_key]; - } + var language = { + langLocaleCode: 'de-LI', + cultureCode: 'de-LI', + delimiters: { + thousands: '\'', + decimal: '.' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: 'CHF', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - return params.reduce(function (acc, value) { - return acc + value.toString(); - }, ''); -} + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -func.SYMBOL = SYMBOL; /***/ }), -/* 20 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -exports.__esModule = true; -exports.SYMBOL = undefined; -exports['default'] = func; - -var _number = __webpack_require__(3); - -var _error = __webpack_require__(1); - -var SYMBOL = exports.SYMBOL = '/'; - -function func(first) { - for (var _len = arguments.length, rest = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - rest[_key - 1] = arguments[_key]; - } +/* 35 */ +/***/ (function(module, exports) { - var result = rest.reduce(function (acc, value) { - return acc / (0, _number.toNumber)(value); - }, (0, _number.toNumber)(first)); +/*! + * numbro.js language configuration + * language : Greek (el) + * author : Tim McIntosh (StayinFront NZ) + */ +(function () { + 'use strict'; - if (result === Infinity) { - throw Error(_error.ERROR_DIV_ZERO); - } - if (isNaN(result)) { - throw Error(_error.ERROR_VALUE); - } + var language = { + langLocaleCode: 'el', + cultureCode: 'el', + delimiters: { + thousands: '.', + decimal: ',' + }, + abbreviations: { + thousand: 'χ', + million: 'ε', + billion: 'δ', + trillion: 'τ' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: '€' + } + }; - return result; -} + // Node + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture('el', language); + } +}.call(typeof window === 'undefined' ? this : window)); -func.SYMBOL = SYMBOL; /***/ }), -/* 21 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; +/* 36 */ +/***/ (function(module, exports) { +/*! + * numbro.js language configuration + * language : English + * locale: Australia + * author : Benedikt Huss : https://github.com/ben305 + */ +(function () { + 'use strict'; -exports.__esModule = true; -exports['default'] = func; -var SYMBOL = exports.SYMBOL = '='; + var language = { + langLocaleCode: 'en-AU', + cultureCode: 'en-AU', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (~~ (number % 100 / 10) === 1) ? 'th' : + (b === 1) ? 'st' : + (b === 2) ? 'nd' : + (b === 3) ? 'rd' : 'th'; + }, + currency: { + symbol: '$', + position: 'prefix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: '$ ,0.00', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: '$ ,0' + } + }; -function func(exp1, exp2) { - return exp1 === exp2; -} + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -func.SYMBOL = SYMBOL; /***/ }), -/* 22 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -exports.__esModule = true; -exports.SYMBOL = undefined; -exports['default'] = func; - -var _formulajs = __webpack_require__(33); - -var formulajs = _interopRequireWildcard(_formulajs); - -var _supportedFormulas = __webpack_require__(10); - -var _supportedFormulas2 = _interopRequireDefault(_supportedFormulas); - -var _error = __webpack_require__(1); - -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } +/* 37 */ +/***/ (function(module, exports) { -function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj['default'] = obj; return newObj; } } +/*! + * numbro.js language configuration + * language : English + * locale: United Kingdom of Great Britain and Northern Ireland + * author : Dan Ristic : https://github.com/dristic + */ +(function () { + 'use strict'; -var SYMBOL = exports.SYMBOL = _supportedFormulas2['default']; + var language = { + langLocaleCode: 'en-GB', + cultureCode: 'en-GB', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (~~ (number % 100 / 10) === 1) ? 'th' : + (b === 1) ? 'st' : + (b === 2) ? 'nd' : + (b === 3) ? 'rd' : 'th'; + }, + currency: { + symbol: '£', + position: 'prefix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: '$ ,0.00', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: '$ ,0' + } + }; -function func(symbol) { - return function __formulaFunction() { - symbol = symbol.toUpperCase(); + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); - var symbolParts = symbol.split('.'); - var foundFormula = false; - var result = void 0; - if (symbolParts.length === 1) { - if (formulajs[symbolParts[0]]) { - foundFormula = true; - result = formulajs[symbolParts[0]].apply(formulajs, arguments); - } - } else { - var length = symbolParts.length; - var index = 0; - var nestedFormula = formulajs; +/***/ }), +/* 38 */ +/***/ (function(module, exports) { - while (index < length) { - nestedFormula = nestedFormula[symbolParts[index]]; - index++; +/*! ++ * numbro.js language configuration + * language : English + * locale: Ireland + * author : Tim McIntosh (StayinFront NZ) + */ +(function () { + 'use strict'; - if (!nestedFormula) { - nestedFormula = null; - break; + var language = { + langLocaleCode: 'en-IE', + cultureCode: 'en-IE', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (~~(number % 100 / 10) === 1) ? 'th' : + (b === 1) ? 'st' : + (b === 2) ? 'nd' : + (b === 3) ? 'rd' : 'th'; + }, + currency: { + symbol: '€' } - } - if (nestedFormula) { - foundFormula = true; - result = nestedFormula.apply(undefined, arguments); - } - } + }; - if (!foundFormula) { - throw Error(_error.ERROR_NAME); + // Node + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture('en-gb', language); + } +}.call(typeof window === 'undefined' ? this : window)); - return result; - }; -} - -func.isFactory = true; -func.SYMBOL = SYMBOL; /***/ }), -/* 23 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; +/* 39 */ +/***/ (function(module, exports) { +/*! + * numbro.js language configuration + * language : English + * locale: New Zealand + * author : Benedikt Huss : https://github.com/ben305 + */ +(function () { + 'use strict'; -exports.__esModule = true; -exports['default'] = func; -var SYMBOL = exports.SYMBOL = '>='; + var language = { + langLocaleCode: 'en-NZ', + cultureCode: 'en-NZ', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (~~ (number % 100 / 10) === 1) ? 'th' : + (b === 1) ? 'st' : + (b === 2) ? 'nd' : + (b === 3) ? 'rd' : 'th'; + }, + currency: { + symbol: '$', + position: 'prefix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: '$ ,0.00', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: '$ ,0' + } + }; -function func(exp1, exp2) { - return exp1 >= exp2; -} + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -func.SYMBOL = SYMBOL; /***/ }), -/* 24 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; +/* 40 */ +/***/ (function(module, exports) { +/*! + * numbro.js language configuration + * language : English + * locale: South Africa + * author : Stewart Scott https://github.com/stewart42 + */ +(function () { + 'use strict'; -exports.__esModule = true; -exports['default'] = func; -var SYMBOL = exports.SYMBOL = '>'; + var language = { + langLocaleCode: 'en-ZA', + cultureCode: 'en-ZA', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (~~ (number % 100 / 10) === 1) ? 'th' : + (b === 1) ? 'st' : + (b === 2) ? 'nd' : + (b === 3) ? 'rd' : 'th'; + }, + currency: { + symbol: 'R', + position: 'prefix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: '$ ,0.00', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: '$ ,0' + } + }; -function func(exp1, exp2) { - return exp1 > exp2; -} + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -func.SYMBOL = SYMBOL; /***/ }), -/* 25 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; +/* 41 */ +/***/ (function(module, exports) { +/*! + * numbro.js language configuration + * language : Spanish + * locale: Argentina + * author : Hernan Garcia : https://github.com/hgarcia + */ +(function () { + 'use strict'; -exports.__esModule = true; -exports['default'] = func; -var SYMBOL = exports.SYMBOL = '<='; + var language = { + langLocaleCode: 'es-AR', + cultureCode: 'es-AR', + delimiters: { + thousands: '.', + decimal: ',' + }, + abbreviations: { + thousand: 'k', + million: 'mm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (b === 1 || b === 3) ? 'er' : + (b === 2) ? 'do' : + (b === 7 || b === 0) ? 'mo' : + (b === 8) ? 'vo' : + (b === 9) ? 'no' : 'to'; + }, + currency: { + symbol: '$', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; -function func(exp1, exp2) { - return exp1 <= exp2; -} + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -func.SYMBOL = SYMBOL; /***/ }), -/* 26 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; +/* 42 */ +/***/ (function(module, exports) { +/*! + * numbro.js language configuration + * language : Spanish + * locale: Chile + * author : Gwyn Judd : https://github.com/gwynjudd + */ +(function () { + 'use strict'; -exports.__esModule = true; -exports['default'] = func; -var SYMBOL = exports.SYMBOL = '<'; + var language = { + langLocaleCode: 'es-CL', + cultureCode: 'es-CL', + delimiters: { + thousands: '.', + decimal: ',' + }, + abbreviations: { + thousand: 'k', + million: 'mm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (b === 1 || b === 3) ? 'er' : + (b === 2) ? 'do' : + (b === 7 || b === 0) ? 'mo' : + (b === 8) ? 'vo' : + (b === 9) ? 'no' : 'to'; + }, + currency: { + symbol: '$', + position: 'prefix' + }, + defaults: { + currencyFormat: '$0,0' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; -function func(exp1, exp2) { - return exp1 < exp2; -} + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -func.SYMBOL = SYMBOL; /***/ }), -/* 27 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -exports.__esModule = true; -exports.SYMBOL = undefined; -exports['default'] = func; - -var _number = __webpack_require__(3); - -var _error = __webpack_require__(1); - -var SYMBOL = exports.SYMBOL = '-'; - -function func(first) { - for (var _len = arguments.length, rest = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - rest[_key - 1] = arguments[_key]; - } +/* 43 */ +/***/ (function(module, exports) { - var result = rest.reduce(function (acc, value) { - return acc - (0, _number.toNumber)(value); - }, (0, _number.toNumber)(first)); +/*! + * numbro.js language configuration + * language : Spanish + * locale: Colombia + * author : Gwyn Judd : https://github.com/gwynjudd + */ +(function () { + 'use strict'; - if (isNaN(result)) { - throw Error(_error.ERROR_VALUE); - } + var language = { + langLocaleCode: 'es-CO', + cultureCode: 'es-CO', + delimiters: { + thousands: '.', + decimal: ',' + }, + abbreviations: { + thousand: 'k', + million: 'mm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (b === 1 || b === 3) ? 'er' : + (b === 2) ? 'do' : + (b === 7 || b === 0) ? 'mo' : + (b === 8) ? 'vo' : + (b === 9) ? 'no' : 'to'; + }, + currency: { + symbol: '€', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - return result; -} + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -func.SYMBOL = SYMBOL; /***/ }), -/* 28 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - +/* 44 */ +/***/ (function(module, exports) { -exports.__esModule = true; -exports.SYMBOL = undefined; -exports['default'] = func; +/*! + * numbro.js language configuration + * language : Spanish + * locale: Costa Rica + * author : Gwyn Judd : https://github.com/gwynjudd + */ +(function () { + 'use strict'; -var _number = __webpack_require__(3); + var language = { + langLocaleCode: 'es-CR', + cultureCode: 'es-CR', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 'k', + million: 'mm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (b === 1 || b === 3) ? 'er' : + (b === 2) ? 'do' : + (b === 7 || b === 0) ? 'mo' : + (b === 8) ? 'vo' : + (b === 9) ? 'no' : 'to'; + }, + currency: { + symbol: '₡', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; -var _error = __webpack_require__(1); + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -var SYMBOL = exports.SYMBOL = '*'; -function func(first) { - for (var _len = arguments.length, rest = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { - rest[_key - 1] = arguments[_key]; - } +/***/ }), +/* 45 */ +/***/ (function(module, exports) { - var result = rest.reduce(function (acc, value) { - return acc * (0, _number.toNumber)(value); - }, (0, _number.toNumber)(first)); +/*! + * numbro.js language configuration + * language : Spanish + * locale: Spain + * author : Hernan Garcia : https://github.com/hgarcia + */ +(function () { + 'use strict'; - if (isNaN(result)) { - throw Error(_error.ERROR_VALUE); - } + var language = { + langLocaleCode: 'es-ES', + cultureCode: 'es-ES', + delimiters: { + thousands: '.', + decimal: ',' + }, + abbreviations: { + thousand: 'k', + million: 'mm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (b === 1 || b === 3) ? 'er' : + (b === 2) ? 'do' : + (b === 7 || b === 0) ? 'mo' : + (b === 8) ? 'vo' : + (b === 9) ? 'no' : 'to'; + }, + currency: { + symbol: '€', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - return result; -} + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -func.SYMBOL = SYMBOL; /***/ }), -/* 29 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; +/* 46 */ +/***/ (function(module, exports) { +/*! + * numbro.js language configuration + * language : Spanish + * locale: Nicaragua + * author : Gwyn Judd : https://github.com/gwynjudd + */ +(function () { + 'use strict'; -exports.__esModule = true; -exports['default'] = func; -var SYMBOL = exports.SYMBOL = '<>'; + var language = { + langLocaleCode: 'es-NI', + cultureCode: 'es-NI', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: 'k', + million: 'mm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (b === 1 || b === 3) ? 'er' : + (b === 2) ? 'do' : + (b === 7 || b === 0) ? 'mo' : + (b === 8) ? 'vo' : + (b === 9) ? 'no' : 'to'; + }, + currency: { + symbol: 'C$', + position: 'prefix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; -function func(exp1, exp2) { - return exp1 !== exp2; -} + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -func.SYMBOL = SYMBOL; /***/ }), -/* 30 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; +/* 47 */ +/***/ (function(module, exports) { +/*! + * numbro.js language configuration + * language : Spanish + * locale: Peru + * author : Gwyn Judd : https://github.com/gwynjudd + */ +(function () { + 'use strict'; -exports.__esModule = true; -exports.SYMBOL = undefined; -exports['default'] = func; + var language = { + langLocaleCode: 'es-PE', + cultureCode: 'es-PE', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: 'k', + million: 'mm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (b === 1 || b === 3) ? 'er' : + (b === 2) ? 'do' : + (b === 7 || b === 0) ? 'mo' : + (b === 8) ? 'vo' : + (b === 9) ? 'no' : 'to'; + }, + currency: { + symbol: 'S/.', + position: 'prefix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; -var _number = __webpack_require__(3); + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -var _error = __webpack_require__(1); -var SYMBOL = exports.SYMBOL = '^'; +/***/ }), +/* 48 */ +/***/ (function(module, exports) { -function func(exp1, exp2) { - var result = Math.pow((0, _number.toNumber)(exp1), (0, _number.toNumber)(exp2)); +/*! + * numbro.js language configuration + * language : Spanish + * locale: Puerto Rico + * author : Gwyn Judd : https://github.com/gwynjudd + */ +(function () { + 'use strict'; - if (isNaN(result)) { - throw Error(_error.ERROR_VALUE); - } + var language = { + langLocaleCode: 'es-PR', + cultureCode: 'es-PR', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: 'k', + million: 'mm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (b === 1 || b === 3) ? 'er' : + (b === 2) ? 'do' : + (b === 7 || b === 0) ? 'mo' : + (b === 8) ? 'vo' : + (b === 9) ? 'no' : 'to'; + }, + currency: { + symbol: '$', + position: 'prefix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - return result; -} + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -func.SYMBOL = SYMBOL; /***/ }), -/* 31 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - +/* 49 */ +/***/ (function(module, exports) { -exports.__esModule = true; -exports.trimEdges = trimEdges; -/* eslint-disable import/prefer-default-export */ -/** - * Trim value by cutting character starting from the beginning and ending at the same time. - * - * @param {String} string String to trimming. - * @param {Number} [margin=1] Number of character to cut. - * @returns {String} +/*! + * numbro.js language configuration + * language : Spanish + * locale: El Salvador + * author : Gwyn Judd : https://github.com/gwynjudd */ -function trimEdges(string) { - var margin = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; +(function () { + 'use strict'; + + var language = { + langLocaleCode: 'es-SV', + cultureCode: 'es-SV', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: 'k', + million: 'mm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (b === 1 || b === 3) ? 'er' : + (b === 2) ? 'do' : + (b === 7 || b === 0) ? 'mo' : + (b === 8) ? 'vo' : + (b === 9) ? 'no' : 'to'; + }, + currency: { + symbol: '$', + position: 'prefix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - string = string.substring(margin, string.length - margin); + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); - return string; -} /***/ }), -/* 32 */ -/***/ (function(module, exports, __webpack_require__) { - -var M = Math; -function _horner(arr, v) { return arr.reduce(function(z,w){return v * z + w;},0); }; -function _bessel_iter(x, n, f0, f1, sign) { - if(!sign) sign = -1; - var tdx = 2 / x, f2; - if(n === 0) return f0; - if(n === 1) return f1; - for(var o = 1; o != n; ++o) { - f2 = f1 * o * tdx + sign * f0; - f0 = f1; f1 = f2; - } - return f1; -} -function _bessel_wrap(bessel0, bessel1, name, nonzero, sign) { - return function bessel(x,n) { - if(n === 0) return bessel0(x); - if(n === 1) return bessel1(x); - if(n < 0) throw name + ': Order (' + n + ') must be nonnegative'; - if(nonzero == 1 && x === 0) throw name + ': Undefined when x == 0'; - if(nonzero == 2 && x <= 0) throw name + ': Undefined when x <= 0'; - var b0 = bessel0(x), b1 = bessel1(x); - return _bessel_iter(x, n, b0, b1, sign); - }; -} -var besselj = (function() { - var b0_a1a = [57568490574.0,-13362590354.0,651619640.7,-11214424.18,77392.33017,-184.9052456].reverse(); - var b0_a2a = [57568490411.0,1029532985.0,9494680.718,59272.64853,267.8532712,1.0].reverse(); - var b0_a1b = [1.0, -0.1098628627e-2, 0.2734510407e-4, -0.2073370639e-5, 0.2093887211e-6].reverse(); - var b0_a2b = [-0.1562499995e-1, 0.1430488765e-3, -0.6911147651e-5, 0.7621095161e-6, -0.934935152e-7].reverse(); - var W = 0.636619772; // 2 / Math.PI +/* 50 */ +/***/ (function(module, exports) { - function bessel0(x) { - var a, a1, a2, y = x * x, xx = M.abs(x) - 0.785398164; - if(M.abs(x) < 8) { - a1 = _horner(b0_a1a, y); - a2 = _horner(b0_a2a, y); - a = a1/a2; - } - else { - y = 64 / y; - a1 = _horner(b0_a1b, y); - a2 = _horner(b0_a2b, y); - a = M.sqrt(W/M.abs(x))*(M.cos(xx)*a1-M.sin(xx)*a2*8/M.abs(x)); - } - return a; - } - var b1_a1a = [72362614232.0,-7895059235.0,242396853.1,-2972611.439, 15704.48260, -30.16036606].reverse(); - var b1_a2a = [144725228442.0, 2300535178.0, 18583304.74, 99447.43394, 376.9991397, 1.0].reverse(); - var b1_a1b = [1.0, 0.183105e-2, -0.3516396496e-4, 0.2457520174e-5, -0.240337019e-6].reverse(); - var b1_a2b = [0.04687499995, -0.2002690873e-3, 0.8449199096e-5, -0.88228987e-6, 0.105787412e-6].reverse(); - function bessel1(x) { - var a, a1, a2, y = x*x, xx = M.abs(x) - 2.356194491; - if(Math.abs(x)< 8) { - a1 = x*_horner(b1_a1a, y); - a2 = _horner(b1_a2a, y); - a = a1 / a2; - } else { - y = 64 / y; - a1=_horner(b1_a1b, y); - a2=_horner(b1_a2b, y); - a=M.sqrt(W/M.abs(x))*(M.cos(xx)*a1-M.sin(xx)*a2*8/M.abs(x)); - if(x < 0) a = -a; - } - return a; - } - return function besselj(x, n) { - n = Math.round(n); - if(n === 0) return bessel0(M.abs(x)); - if(n === 1) return bessel1(M.abs(x)); - if(n < 0) throw 'BESSELJ: Order (' + n + ') must be nonnegative'; - if(M.abs(x) === 0) return 0; +/*! + * numbro.js language configuration + * language : Estonian + * locale: Estonia + * author : Illimar Tambek : https://github.com/ragulka + * + * Note: in Estonian, abbreviations are always separated + * from numbers with a space + */ +(function () { + 'use strict'; - var ret, j, tox = 2 / M.abs(x), m, jsum, sum, bjp, bj, bjm; - if(M.abs(x) > n) { - ret = _bessel_iter(x, n, bessel0(M.abs(x)), bessel1(M.abs(x)),-1); - } else { - m=2*M.floor((n+M.floor(M.sqrt(40*n)))/2); - jsum=0; - bjp=ret=sum=0.0; - bj=1.0; - for (j=m;j>0;j--) { - bjm=j*tox*bj-bjp; - bjp=bj; - bj=bjm; - if (M.abs(bj) > 1E10) { - bj *= 1E-10; - bjp *= 1E-10; - ret *= 1E-10; - sum *= 1E-10; + var language = { + langLocaleCode: 'et-EE', + cultureCode: 'et-EE', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: ' tuh', + million: ' mln', + billion: ' mld', + trillion: ' trl' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: '€', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' } - if (jsum) sum += bj; - jsum=!jsum; - if (j == n) ret=bjp; - } - sum=2.0*sum-bj; - ret /= sum; - } - return x < 0 && (n%2) ? -ret : ret; - }; -})(); -var bessely = (function() { - var b0_a1a = [-2957821389.0, 7062834065.0, -512359803.6, 10879881.29, -86327.92757, 228.4622733].reverse(); - var b0_a2a = [40076544269.0, 745249964.8, 7189466.438, 47447.26470, 226.1030244, 1.0].reverse(); - var b0_a1b = [1.0, -0.1098628627e-2, 0.2734510407e-4, -0.2073370639e-5, 0.2093887211e-6].reverse(); - var b0_a2b = [-0.1562499995e-1, 0.1430488765e-3, -0.6911147651e-5, 0.7621095161e-6, -0.934945152e-7].reverse(); + }; - var W = 0.636619772; - function bessel0(x) { - var a, a1, a2, y = x * x, xx = x - 0.785398164; - if(x < 8) { - a1 = _horner(b0_a1a, y); - a2 = _horner(b0_a2a, y); - a = a1/a2 + W * besselj(x,0) * M.log(x); - } else { - y = 64 / y; - a1 = _horner(b0_a1b, y); - a2 = _horner(b0_a2b, y); - a = M.sqrt(W/x)*(M.sin(xx)*a1+M.cos(xx)*a2*8/x); + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; } - return a; - } - - var b1_a1a = [-0.4900604943e13, 0.1275274390e13, -0.5153438139e11, 0.7349264551e9, -0.4237922726e7, 0.8511937935e4].reverse(); - var b1_a2a = [0.2499580570e14, 0.4244419664e12, 0.3733650367e10, 0.2245904002e8, 0.1020426050e6, 0.3549632885e3, 1].reverse(); - var b1_a1b = [1.0, 0.183105e-2, -0.3516396496e-4, 0.2457520174e-5, -0.240337019e-6].reverse(); - var b1_a2b = [0.04687499995, -0.2002690873e-3, 0.8449199096e-5, -0.88228987e-6, 0.105787412e-6].reverse(); - function bessel1(x) { - var a, a1, a2, y = x*x, xx = x - 2.356194491; - if(x < 8) { - a1 = x*_horner(b1_a1a, y); - a2 = _horner(b1_a2a, y); - a = a1/a2 + W * (besselj(x,1) * M.log(x) - 1 / x); - } else { - y = 64 / y; - a1=_horner(b1_a1b, y); - a2=_horner(b1_a2b, y); - a=M.sqrt(W/x)*(M.sin(xx)*a1+M.cos(xx)*a2*8/x); + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); } - return a; - } +}.call(typeof window === 'undefined' ? this : window)); - return _bessel_wrap(bessel0, bessel1, 'BESSELY', 1, -1); -})(); -var besseli = (function() { - var b0_a = [1.0, 3.5156229, 3.0899424, 1.2067492, 0.2659732, 0.360768e-1, 0.45813e-2].reverse(); - var b0_b = [0.39894228, 0.1328592e-1, 0.225319e-2, -0.157565e-2, 0.916281e-2, -0.2057706e-1, 0.2635537e-1, -0.1647633e-1, 0.392377e-2].reverse(); - function bessel0(x) { - if(x <= 3.75) return _horner(b0_a, x*x/(3.75*3.75)); - return M.exp(M.abs(x))/M.sqrt(M.abs(x))*_horner(b0_b, 3.75/M.abs(x)); - } - var b1_a = [0.5, 0.87890594, 0.51498869, 0.15084934, 0.2658733e-1, 0.301532e-2, 0.32411e-3].reverse(); - var b1_b = [0.39894228, -0.3988024e-1, -0.362018e-2, 0.163801e-2, -0.1031555e-1, 0.2282967e-1, -0.2895312e-1, 0.1787654e-1, -0.420059e-2].reverse(); - function bessel1(x) { - if(x < 3.75) return x * _horner(b1_a, x*x/(3.75*3.75)); - return (x < 0 ? -1 : 1) * M.exp(M.abs(x))/M.sqrt(M.abs(x))*_horner(b1_b, 3.75/M.abs(x)); - } +/***/ }), +/* 51 */ +/***/ (function(module, exports) { - return function besseli(x, n) { - n = Math.round(n); - if(n === 0) return bessel0(x); - if(n == 1) return bessel1(x); - if(n < 0) throw 'BESSELI Order (' + n + ') must be nonnegative'; - if(M.abs(x) === 0) return 0; +/*! + * numbro.js language configuration + * language : Farsi + * locale: Iran + * author : neo13 : https://github.com/neo13 + */ +(function () { + 'use strict'; + + var language = { + langLocaleCode: 'fa-IR', + cultureCode: 'fa-IR', + delimiters: { + thousands: '،', + decimal: '.' + }, + abbreviations: { + thousand: 'هزار', + million: 'میلیون', + billion: 'میلیارد', + trillion: 'تریلیون' + }, + ordinal: function () { + return 'ام'; + }, + currency: { + symbol: '﷼' + } + }; - var ret, j, tox = 2 / M.abs(x), m, bip, bi, bim; - m=2*M.round((n+M.round(M.sqrt(40*n)))/2); - bip=ret=0.0; - bi=1.0; - for (j=m;j>0;j--) { - bim=j*tox*bi + bip; - bip=bi; bi=bim; - if (M.abs(bi) > 1E10) { - bi *= 1E-10; - bip *= 1E-10; - ret *= 1E-10; - } - if(j == n) ret = bip; + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; } - ret *= besseli(x, 0) / bi; - return x < 0 && (n%2) ? -ret : ret; - }; + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -})(); -var besselk = (function() { - var b0_a = [-0.57721566, 0.42278420, 0.23069756, 0.3488590e-1, 0.262698e-2, 0.10750e-3, 0.74e-5].reverse(); - var b0_b = [1.25331414, -0.7832358e-1, 0.2189568e-1, -0.1062446e-1, 0.587872e-2, -0.251540e-2, 0.53208e-3].reverse(); - function bessel0(x) { - if(x <= 2) return -M.log(x/2)*besseli(x,0) + _horner(b0_a, x*x/4); - return M.exp(-x)/M.sqrt(x)*_horner(b0_b, 2/x); - } +/***/ }), +/* 52 */ +/***/ (function(module, exports) { - var b1_a = [1.0, 0.15443144, -0.67278579, -0.18156897, -0.1919402e-1, -0.110404e-2, -0.4686e-4].reverse(); - var b1_b = [1.25331414, 0.23498619, -0.3655620e-1, 0.1504268e-1, -0.780353e-2, 0.325614e-2, -0.68245e-3].reverse(); - function bessel1(x) { - if(x <= 2) return M.log(x/2)*besseli(x,1) + (1/x)*_horner(b1_a, x*x/4); - return M.exp(-x)/M.sqrt(x)*_horner(b1_b, 2/x); - } +/*! + * numbro.js language configuration + * language : Finnish + * locale: Finland + * author : Sami Saada : https://github.com/samitheberber + */ +(function () { + 'use strict'; - return _bessel_wrap(bessel0, bessel1, 'BESSELK', 2, 1); -})(); -if(true) { - exports.besselj = besselj; - exports.bessely = bessely; - exports.besseli = besseli; - exports.besselk = besselk; -} + var language = { + langLocaleCode: 'fi-FI', + cultureCode: 'fi-FI', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 'k', + million: 'M', + billion: 'G', + trillion: 'T' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: '€', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); /***/ }), -/* 33 */ -/***/ (function(module, exports, __webpack_require__) { - -var categories = [ - __webpack_require__(34), - __webpack_require__(35), - __webpack_require__(11), - __webpack_require__(37), - __webpack_require__(4), - __webpack_require__(8), - __webpack_require__(6), - __webpack_require__(36), - __webpack_require__(7), - __webpack_require__(38), - __webpack_require__(5), - __webpack_require__(12) -]; +/* 53 */ +/***/ (function(module, exports) { -for (var c in categories) { - var category = categories[c]; - for (var f in category) { - exports[f] = exports[f] || category[f]; - } -} +/*! + * numbro.js language configuration + * language : Filipino (Pilipino) + * locale: Philippines + * author : Michael Abadilla : https://github.com/mjmaix + */ +(function () { + 'use strict'; + var language = { + langLocaleCode: 'fil-PH', + cultureCode: 'fil-PH', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal: function (number) { + var b = number % 10; + return (~~ (number % 100 / 10) === 1) ? 'th' : + (b === 1) ? 'st' : + (b === 2) ? 'nd' : + (b === 3) ? 'rd' : 'th'; + }, + currency: { + symbol: '₱' + } + }; -/***/ }), -/* 34 */ -/***/ (function(module, exports, __webpack_require__) { + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -var mathTrig = __webpack_require__(4); -var statistical = __webpack_require__(5); -var engineering = __webpack_require__(11); -var dateTime = __webpack_require__(6); -function set(fn, root) { - if (root) { - for (var i in root) { - fn[i] = root[i]; - } - } +/***/ }), +/* 54 */ +/***/ (function(module, exports) { - return fn; -} +/*! + * numbro.js language configuration + * language : French + * locale: Canada + * author : Léo Renaud-Allaire : https://github.com/renaudleo + */ +(function () { + 'use strict'; -exports.BETADIST = statistical.BETA.DIST; -exports.BETAINV = statistical.BETA.INV; -exports.BINOMDIST = statistical.BINOM.DIST; -exports.CEILING = exports.ISOCEILING = set(mathTrig.CEILING.MATH, mathTrig.CEILING); -exports.CEILINGMATH = mathTrig.CEILING.MATH; -exports.CEILINGPRECISE = mathTrig.CEILING.PRECISE; -exports.CHIDIST = statistical.CHISQ.DIST; -exports.CHIDISTRT = statistical.CHISQ.DIST.RT; -exports.CHIINV = statistical.CHISQ.INV; -exports.CHIINVRT = statistical.CHISQ.INV.RT; -exports.CHITEST = statistical.CHISQ.TEST; -exports.CONFIDENCE = set(statistical.CONFIDENCE.NORM, statistical.CONFIDENCE); -exports.COVAR = statistical.COVARIANCE.P; -exports.COVARIANCEP = statistical.COVARIANCE.P; -exports.COVARIANCES = statistical.COVARIANCE.S; -exports.CRITBINOM = statistical.BINOM.INV; -exports.EXPONDIST = statistical.EXPON.DIST; -exports.ERFCPRECISE = engineering.ERFC.PRECISE; -exports.ERFPRECISE = engineering.ERF.PRECISE; -exports.FDIST = statistical.F.DIST; -exports.FDISTRT = statistical.F.DIST.RT; -exports.FINVRT = statistical.F.INV.RT; -exports.FINV = statistical.F.INV; -exports.FLOOR = set(mathTrig.FLOOR.MATH, mathTrig.FLOOR); -exports.FLOORMATH = mathTrig.FLOOR.MATH; -exports.FLOORPRECISE = mathTrig.FLOOR.PRECISE; -exports.FTEST = statistical.F.TEST; -exports.GAMMADIST = statistical.GAMMA.DIST; -exports.GAMMAINV = statistical.GAMMA.INV; -exports.GAMMALNPRECISE = statistical.GAMMALN.PRECISE; -exports.HYPGEOMDIST = statistical.HYPGEOM.DIST; -exports.LOGINV = statistical.LOGNORM.INV; -exports.LOGNORMINV = statistical.LOGNORM.INV; -exports.LOGNORMDIST = statistical.LOGNORM.DIST; -exports.MODE = set(statistical.MODE.SNGL, statistical.MODE); -exports.MODEMULT = statistical.MODE.MULT; -exports.MODESNGL = statistical.MODE.SNGL; -exports.NEGBINOMDIST = statistical.NEGBINOM.DIST; -exports.NETWORKDAYSINTL = dateTime.NETWORKDAYS.INTL; -exports.NORMDIST = statistical.NORM.DIST; -exports.NORMINV = statistical.NORM.INV; -exports.NORMSDIST = statistical.NORM.S.DIST; -exports.NORMSINV = statistical.NORM.S.INV; -exports.PERCENTILE = set(statistical.PERCENTILE.EXC, statistical.PERCENTILE); -exports.PERCENTILEEXC = statistical.PERCENTILE.EXC; -exports.PERCENTILEINC = statistical.PERCENTILE.INC; -exports.PERCENTRANK = set(statistical.PERCENTRANK.INC, statistical.PERCENTRANK); -exports.PERCENTRANKEXC = statistical.PERCENTRANK.EXC; -exports.PERCENTRANKINC = statistical.PERCENTRANK.INC; -exports.POISSON = set(statistical.POISSON.DIST, statistical.POISSON); -exports.POISSONDIST = statistical.POISSON.DIST; -exports.QUARTILE = set(statistical.QUARTILE.INC, statistical.QUARTILE); -exports.QUARTILEEXC = statistical.QUARTILE.EXC; -exports.QUARTILEINC = statistical.QUARTILE.INC; -exports.RANK = set(statistical.RANK.EQ, statistical.RANK); -exports.RANKAVG = statistical.RANK.AVG; -exports.RANKEQ = statistical.RANK.EQ; -exports.SKEWP = statistical.SKEW.P; -exports.STDEV = set(statistical.STDEV.S, statistical.STDEV); -exports.STDEVP = statistical.STDEV.P; -exports.STDEVS = statistical.STDEV.S; -exports.TDIST = statistical.T.DIST; -exports.TDISTRT = statistical.T.DIST.RT; -exports.TINV = statistical.T.INV; -exports.TTEST = statistical.T.TEST; -exports.VAR = set(statistical.VAR.S, statistical.VAR); -exports.VARP = statistical.VAR.P; -exports.VARS = statistical.VAR.S; -exports.WEIBULL = set(statistical.WEIBULL.DIST, statistical.WEIBULL); -exports.WEIBULLDIST = statistical.WEIBULL.DIST; -exports.WORKDAYINTL = dateTime.WORKDAY.INTL; -exports.ZTEST = statistical.Z.TEST; + var language = { + langLocaleCode: 'fr-CA', + cultureCode: 'fr-CA', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 'k', + million: 'M', + billion: 'G', + trillion: 'T' + }, + ordinal : function (number) { + return number === 1 ? 'er' : 'ème'; + }, + currency: { + symbol: '$', + position: 'postfix', + spaceSeparated : true + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: '$ ,0.00', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: '$ ,0' + } + }; + + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); /***/ }), -/* 35 */ -/***/ (function(module, exports, __webpack_require__) { +/* 55 */ +/***/ (function(module, exports) { -var error = __webpack_require__(0); -var stats = __webpack_require__(5); -var maths = __webpack_require__(4); -var utils = __webpack_require__(2); +/*! + * numbro.js language configuration + * language : French + * locale: Switzerland + * author : Adam Draper : https://github.com/adamwdraper + */ +(function () { + 'use strict'; -function compact(array) { - var result = []; + var language = { + langLocaleCode: 'fr-CH', + cultureCode: 'fr-CH', + delimiters: { + thousands: ' ', + decimal: '.' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal : function (number) { + return number === 1 ? 'er' : 'ème'; + }, + currency: { + symbol: 'CHF', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - utils.arrayEach(array, function(value) { - if (value) { - result.push(value); + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; } - }); - - return result; -} - -exports.FINDFIELD = function(database, title) { - var index = null; - - utils.arrayEach(database, function(value, i) { - if (value[0] === title) { - index = i; - return false; + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); } - }); +}.call(typeof window === 'undefined' ? this : window)); - // Return error if the input field title is incorrect - if (index == null) { - return error.value; - } - return index; -}; +/***/ }), +/* 56 */ +/***/ (function(module, exports) { -function findResultIndex(database, criterias) { - var matches = {}; - for (var i = 1; i < database[0].length; ++i) { - matches[i] = true; - } - var maxCriteriaLength = criterias[0].length; - for (i = 1; i < criterias.length; ++i) { - if (criterias[i].length > maxCriteriaLength) { - maxCriteriaLength = criterias[i].length; - } - } +/*! + * numbro.js language configuration + * language : French + * locale: France + * author : Adam Draper : https://github.com/adamwdraper + */ +(function () { + 'use strict'; - for (var k = 1; k < database.length; ++k) { - for (var l = 1; l < database[k].length; ++l) { - var currentCriteriaResult = false; - var hasMatchingCriteria = false; - for (var j = 0; j < criterias.length; ++j) { - var criteria = criterias[j]; - if (criteria.length < maxCriteriaLength) { - continue; + var language = { + langLocaleCode: 'fr-FR', + cultureCode: 'fr-FR', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal : function (number) { + return number === 1 ? 'er' : 'ème'; + }, + currency: { + symbol: '€', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' } + }; - var criteriaField = criteria[0]; - if (database[k][0] !== criteriaField) { - continue; - } - hasMatchingCriteria = true; - for (var p = 1; p < criteria.length; ++p) { - currentCriteriaResult = currentCriteriaResult || eval(database[k][l] + criteria[p]); // jshint ignore:line - } - } - if (hasMatchingCriteria) { - matches[l] = matches[l] && currentCriteriaResult; - } + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; } - } - - var result = []; - for (var n = 0; n < database[0].length; ++n) { - if (matches[n]) { - result.push(n - 1); + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); } - } +}.call(typeof window === 'undefined' ? this : window)); - return result; -} -// Database functions -exports.DAVERAGE = function(database, field, criteria) { - // Return error if field is not a number and not a string - if (isNaN(field) && (typeof field !== "string")) { - return error.value; - } - var resultIndexes = findResultIndex(database, criteria); - var targetFields = []; +/***/ }), +/* 57 */ +/***/ (function(module, exports) { - if (typeof field === "string") { - var index = exports.FINDFIELD(database, field); - targetFields = utils.rest(database[index]); - } else { - targetFields = utils.rest(database[field]); - } - var sum = 0; +/*! + * numbro.js language configuration + * language : Hebrew + * locale : IL + * author : Eli Zehavi : https://github.com/eli-zehavi + */ +(function () { + 'use strict'; - utils.arrayEach(resultIndexes, function(value) { - sum += targetFields[value]; - }); + var language = { + langLocaleCode: 'he-IL', + cultureCode: 'he-IL', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: 'אלף', + million: 'מליון', + billion: 'בליון', + trillion: 'טריליון' + }, + currency: { + symbol: '₪', + position: 'prefix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: '₪ ,0.00', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: '₪ ,0' + } + }; - return resultIndexes.length === 0 ? error.div0 : sum / resultIndexes.length; -}; + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -exports.DCOUNT = function(database, field, criteria) { - // Return error if field is not a number and not a string - if (isNaN(field) && (typeof field !== "string")) { - return error.value; - } - var resultIndexes = findResultIndex(database, criteria); - var targetFields = []; - if (typeof field === "string") { - var index = exports.FINDFIELD(database, field); - targetFields = utils.rest(database[index]); - } else { - targetFields = utils.rest(database[field]); - } - var targetValues = []; +/***/ }), +/* 58 */ +/***/ (function(module, exports) { - utils.arrayEach(resultIndexes, function(value) { - targetValues.push(targetFields[value]); - }); +/*! + * numbro.js language configuration + * language : Hungarian + * locale: Hungary + * author : Peter Bakondy : https://github.com/pbakondy + */ +(function () { + 'use strict'; - return stats.COUNT(targetValues); -}; + var language = { + langLocaleCode: 'hu-HU', + cultureCode: 'hu-HU', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 'E', // ezer + million: 'M', // millió + billion: 'Mrd', // milliárd + trillion: 'T' // trillió + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: ' Ft', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; -exports.DCOUNTA = function(database, field, criteria) { - // Return error if field is not a number and not a string - if (isNaN(field) && (typeof field !== "string")) { - return error.value; - } + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); - var resultIndexes = findResultIndex(database, criteria); - var targetFields = []; - if (typeof field === "string") { - var index = exports.FINDFIELD(database, field); - targetFields = utils.rest(database[index]); - } else { - targetFields = utils.rest(database[field]); - } +/***/ }), +/* 59 */ +/***/ (function(module, exports) { - var targetValues = []; +/*! + * numbro.js language configuration + * language : Indonesian + * author : Tim McIntosh (StayinFront NZ) + */ +(function () { + 'use strict'; - utils.arrayEach(resultIndexes, function(value) { - targetValues.push(targetFields[value]); - }); + var language = { + langLocaleCode: 'id', + cultureCode: 'id', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: 'r', + million: 'j', + billion: 'm', + trillion: 't' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: 'Rp' + } + }; - return stats.COUNTA(targetValues); -}; + // Node + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture('id', language); + } +}.call(typeof window === 'undefined' ? this : window)); -exports.DGET = function(database, field, criteria) { - // Return error if field is not a number and not a string - if (isNaN(field) && (typeof field !== "string")) { - return error.value; - } - var resultIndexes = findResultIndex(database, criteria); - var targetFields = []; +/***/ }), +/* 60 */ +/***/ (function(module, exports) { - if (typeof field === "string") { - var index = exports.FINDFIELD(database, field); - targetFields = utils.rest(database[index]); - } else { - targetFields = utils.rest(database[field]); - } +/*! + * numbro.js language configuration + * language : Italian + * locale: Switzerland + * author : Tim McIntosh (StayinFront NZ) + */ +(function () { + 'use strict'; - // Return error if no record meets the criteria - if (resultIndexes.length === 0) { - return error.value; - } - // Returns the #NUM! error value because more than one record meets the - // criteria - if (resultIndexes.length > 1) { - return error.num; - } + var language = { + langLocaleCode: 'it-CH', + cultureCode: 'it-CH', + delimiters: { + thousands: '\'', + decimal: '.' + }, + abbreviations: { + thousand: 'mila', + million: 'mil', + billion: 'b', + trillion: 't' + }, + ordinal: function () { + return '°'; + }, + currency: { + symbol: 'CHF' + } + }; - return targetFields[resultIndexes[0]]; -}; + // Node + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture('it-CH', language); + } +}.call(typeof window === 'undefined' ? this : window)); -exports.DMAX = function(database, field, criteria) { - // Return error if field is not a number and not a string - if (isNaN(field) && (typeof field !== "string")) { - return error.value; - } - var resultIndexes = findResultIndex(database, criteria); - var targetFields = []; - if (typeof field === "string") { - var index = exports.FINDFIELD(database, field); - targetFields = utils.rest(database[index]); - } else { - targetFields = utils.rest(database[field]); - } +/***/ }), +/* 61 */ +/***/ (function(module, exports) { - var maxValue = targetFields[resultIndexes[0]]; +/*! + * numbro.js language configuration + * language : Italian + * locale: Italy + * author : Giacomo Trombi : http://cinquepunti.it + */ +(function () { + 'use strict'; - utils.arrayEach(resultIndexes, function(value) { - if (maxValue < targetFields[value]) { - maxValue = targetFields[value]; - } - }); + var language = { + langLocaleCode: 'it-IT', + cultureCode: 'it-IT', + delimiters: { + thousands: '.', + decimal: ',' + }, + abbreviations: { + thousand: 'mila', + million: 'mil', + billion: 'b', + trillion: 't' + }, + ordinal: function () { + return 'º'; + }, + currency: { + symbol: '€', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - return maxValue; -}; + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -exports.DMIN = function(database, field, criteria) { - // Return error if field is not a number and not a string - if (isNaN(field) && (typeof field !== "string")) { - return error.value; - } - var resultIndexes = findResultIndex(database, criteria); - var targetFields = []; +/***/ }), +/* 62 */ +/***/ (function(module, exports) { - if (typeof field === "string") { - var index = exports.FINDFIELD(database, field); - targetFields = utils.rest(database[index]); - } else { - targetFields = utils.rest(database[field]); - } +/*! + * numbro.js language configuration + * language : Japanese + * locale: Japan + * author : teppeis : https://github.com/teppeis + */ +(function () { + 'use strict'; - var minValue = targetFields[resultIndexes[0]]; + var language = { + langLocaleCode: 'ja-JP', + cultureCode: 'ja-JP', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: '千', + million: '百万', + billion: '十億', + trillion: '兆' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: '¥', + position: 'prefix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: '$ ,0.00', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: '$ ,0' + } + }; - utils.arrayEach(resultIndexes, function(value) { - if (minValue > targetFields[value]) { - minValue = targetFields[value]; + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; } - }); - - return minValue; -}; - -exports.DPRODUCT = function(database, field, criteria) { - // Return error if field is not a number and not a string - if (isNaN(field) && (typeof field !== "string")) { - return error.value; - } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); - var resultIndexes = findResultIndex(database, criteria); - var targetFields = []; - if (typeof field === "string") { - var index = exports.FINDFIELD(database, field); - targetFields = utils.rest(database[index]); - } else { - targetFields = utils.rest(database[field]); - } +/***/ }), +/* 63 */ +/***/ (function(module, exports) { - var targetValues = []; +/*! + * numbro.js language configuration + * language : Korean + * author (numbro.js Version): Randy Wilander : https://github.com/rocketedaway + * author (numeral.js Version) : Rich Daley : https://github.com/pedantic-git + */ +(function () { + 'use strict'; - utils.arrayEach(resultIndexes, function(value) { - targetValues.push(targetFields[value]); - }); - targetValues = compact(targetValues); + var language = { + langLocaleCode: 'ko-KR', + cultureCode: 'ko-KR', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: '천', + million: '백만', + billion: '십억', + trillion: '일조' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: '₩' + } + }; - var result = 1; + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); - utils.arrayEach(targetValues, function(value) { - result *= value; - }); - return result; -}; +/***/ }), +/* 64 */ +/***/ (function(module, exports) { -exports.DSTDEV = function(database, field, criteria) { - // Return error if field is not a number and not a string - if (isNaN(field) && (typeof field !== "string")) { - return error.value; - } - var resultIndexes = findResultIndex(database, criteria); - var targetFields = []; +/*! + * numbro.js language configuration + * language : Latvian + * locale: Latvia + * author : Lauris Bukšis-Haberkorns : https://github.com/Lafriks + */ +(function () { + 'use strict'; - if (typeof field === "string") { - var index = exports.FINDFIELD(database, field); - targetFields = utils.rest(database[index]); - } else { - targetFields = utils.rest(database[field]); - } - var targetValues = []; + var language = { + langLocaleCode: 'lv-LV', + cultureCode: 'lv-LV', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: ' tūkst.', + million: ' milj.', + billion: ' mljrd.', + trillion: ' trilj.' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: '€', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); - utils.arrayEach(resultIndexes, function(value) { - targetValues.push(targetFields[value]); - }); - targetValues = compact(targetValues); - return stats.STDEV.S(targetValues); -}; +/***/ }), +/* 65 */ +/***/ (function(module, exports) { -exports.DSTDEVP = function(database, field, criteria) { - // Return error if field is not a number and not a string - if (isNaN(field) && (typeof field !== "string")) { - return error.value; - } - var resultIndexes = findResultIndex(database, criteria); - var targetFields = []; +/*! + * numbro.js language configuration + * language: Norwegian Bokmål + * locale: Norway + * author : Benjamin Van Ryseghem + */ +(function() { + 'use strict'; - if (typeof field === "string") { - var index = exports.FINDFIELD(database, field); - targetFields = utils.rest(database[index]); - } else { - targetFields = utils.rest(database[field]); - } + var language = { + langLocaleCode: 'nb-NO', + cultureCode: 'nb-NO', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 't', + million: 'M', + billion: 'md', + trillion: 't' + }, + currency: { + symbol: 'kr', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - var targetValues = []; + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); - utils.arrayEach(resultIndexes, function(value) { - targetValues.push(targetFields[value]); - }); - targetValues = compact(targetValues); - return stats.STDEV.P(targetValues); -}; +/***/ }), +/* 66 */ +/***/ (function(module, exports) { -exports.DSUM = function(database, field, criteria) { - // Return error if field is not a number and not a string - if (isNaN(field) && (typeof field !== "string")) { - return error.value; - } - var resultIndexes = findResultIndex(database, criteria); - var targetFields = []; +/*! + * numbro.js language configuration + * language : Norwegian Bokmål (nb) + * author : Tim McIntosh (StayinFront NZ) + */ +(function () { + 'use strict'; - if (typeof field === "string") { - var index = exports.FINDFIELD(database, field); - targetFields = utils.rest(database[index]); - } else { - targetFields = utils.rest(database[field]); - } + var language = { + langLocaleCode: 'nb', + cultureCode: 'nb', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 't', + million: 'mil', + billion: 'mia', + trillion: 'b' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: 'kr' + } + }; - var targetValues = []; + // Node + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture('nb', language); + } +}.call(typeof window === 'undefined' ? this : window)); - utils.arrayEach(resultIndexes, function(value) { - targetValues.push(targetFields[value]); - }); - return maths.SUM(targetValues); -}; +/***/ }), +/* 67 */ +/***/ (function(module, exports) { -exports.DVAR = function(database, field, criteria) { - // Return error if field is not a number and not a string - if (isNaN(field) && (typeof field !== "string")) { - return error.value; - } - var resultIndexes = findResultIndex(database, criteria); - var targetFields = []; +/*! + * numbro.js language configuration + * language : Dutch + * locale: Belgium + * author : Dieter Luypaert : https://github.com/moeriki + */ +(function () { + 'use strict'; - if (typeof field === "string") { - var index = exports.FINDFIELD(database, field); - targetFields = utils.rest(database[index]); - } else { - targetFields = utils.rest(database[field]); - } - var targetValues = []; + var language = { + langLocaleCode: 'nl-BE', + cultureCode: 'nl-BE', + delimiters: { + thousands: ' ', + decimal : ',' + }, + abbreviations: { + thousand : 'k', + million : 'mln', + billion : 'mld', + trillion : 'bln' + }, + ordinal : function (number) { + var remainder = number % 100; + return (number !== 0 && remainder <= 1 || remainder === 8 || remainder >= 20) ? 'ste' : 'de'; + }, + currency: { + symbol: '€', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - utils.arrayEach(resultIndexes, function(value) { - targetValues.push(targetFields[value]); - }); + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); - return stats.VAR.S(targetValues); -}; -exports.DVARP = function(database, field, criteria) { - // Return error if field is not a number and not a string - if (isNaN(field) && (typeof field !== "string")) { - return error.value; - } - var resultIndexes = findResultIndex(database, criteria); - var targetFields = []; +/***/ }), +/* 68 */ +/***/ (function(module, exports) { - if (typeof field === "string") { - var index = exports.FINDFIELD(database, field); - targetFields = utils.rest(database[index]); - } else { - targetFields = utils.rest(database[field]); - } - var targetValues = []; +/*! + * numbro.js language configuration + * language : Dutch + * locale: Netherlands + * author : Dave Clayton : https://github.com/davedx + */ +(function () { + 'use strict'; - utils.arrayEach(resultIndexes, function(value) { - targetValues.push(targetFields[value]); - }); + var language = { + langLocaleCode: 'nl-NL', + cultureCode: 'nl-NL', + delimiters: { + thousands: '.', + decimal : ',' + }, + abbreviations: { + thousand : 'k', + million : 'mln', + billion : 'mrd', + trillion : 'bln' + }, + ordinal : function (number) { + var remainder = number % 100; + return (number !== 0 && remainder <= 1 || remainder === 8 || remainder >= 20) ? 'ste' : 'de'; + }, + currency: { + symbol: '€', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - return stats.VAR.P(targetValues); -}; + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); /***/ }), -/* 36 */ -/***/ (function(module, exports, __webpack_require__) { +/* 69 */ +/***/ (function(module, exports) { -var error = __webpack_require__(0); -var dateTime = __webpack_require__(6); -var utils = __webpack_require__(2); +/*! + * numbro.js language configuration + * language : Norwegian Nynorsk (nn) + * author : Tim McIntosh (StayinFront NZ) + */ +(function () { + 'use strict'; -function validDate(d) { - return d && d.getTime && !isNaN(d.getTime()); -} + var language = { + langLocaleCode: 'nn', + cultureCode: 'nn', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 't', + million: 'mil', + billion: 'mia', + trillion: 'b' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: 'kr' + } + }; -function ensureDate(d) { - return (d instanceof Date)?d:new Date(d); -} + // Node + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.language) { + window.numbro.language('nn', language); + } +}()); -exports.ACCRINT = function(issue, first, settlement, rate, par, frequency, basis) { - // Return error if either date is invalid - issue = ensureDate(issue); - first = ensureDate(first); - settlement = ensureDate(settlement); - if (!validDate(issue) || !validDate(first) || !validDate(settlement)) { - return error.value; - } - // Return error if either rate or par are lower than or equal to zero - if (rate <= 0 || par <= 0) { - return error.num - } +/***/ }), +/* 70 */ +/***/ (function(module, exports) { + +/*! + * numbro.js language configuration + * language : Polish + * locale : Poland + * author : Dominik Bulaj : https://github.com/dominikbulaj + */ +(function () { + 'use strict'; - // Return error if frequency is neither 1, 2, or 4 - if ([1, 2, 4].indexOf(frequency) === -1) { - return error.num; - } + var language = { + langLocaleCode: 'pl-PL', + cultureCode: 'pl-PL', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 'tys.', + million: 'mln', + billion: 'mld', + trillion: 'bln' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: ' zł', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - // Return error if basis is neither 0, 1, 2, 3, or 4 - if ([0, 1, 2, 3, 4].indexOf(basis) === -1) { - return error.num; - } + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); - // Return error if settlement is before or equal to issue - if (settlement <= issue) { - return error.num; - } - // Set default values - par = par || 0; - basis = basis || 0; +/***/ }), +/* 71 */ +/***/ (function(module, exports) { - // Compute accrued interest - return par * rate * dateTime.YEARFRAC(issue, settlement, basis); -}; +/*! + * numbro.js language configuration + * language : Portuguese + * locale : Brazil + * author : Ramiro Varandas Jr : https://github.com/ramirovjr + */ +(function () { + 'use strict'; -// TODO -exports.ACCRINTM = function() { - throw new Error('ACCRINTM is not implemented'); -}; + var language = { + langLocaleCode: 'pt-BR', + cultureCode: 'pt-BR', + delimiters: { + thousands: '.', + decimal: ',' + }, + abbreviations: { + thousand: 'mil', + million: 'milhões', + billion: 'b', + trillion: 't' + }, + ordinal: function () { + return 'º'; + }, + currency: { + symbol: 'R$', + position: 'prefix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; -// TODO -exports.AMORDEGRC = function() { - throw new Error('AMORDEGRC is not implemented'); -}; + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -// TODO -exports.AMORLINC = function() { - throw new Error('AMORLINC is not implemented'); -}; -// TODO -exports.COUPDAYBS = function() { - throw new Error('COUPDAYBS is not implemented'); -}; +/***/ }), +/* 72 */ +/***/ (function(module, exports) { -// TODO -exports.COUPDAYS = function() { - throw new Error('COUPDAYS is not implemented'); -}; +/*! + * numbro.js language configuration + * language : Portuguese + * locale : Portugal + * author : Diogo Resende : https://github.com/dresende + */ +(function () { + 'use strict'; -// TODO -exports.COUPDAYSNC = function() { - throw new Error('COUPDAYSNC is not implemented'); -}; + var language = { + langLocaleCode: 'pt-PT', + cultureCode: 'pt-PT', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 'k', + million: 'm', + billion: 'b', + trillion: 't' + }, + ordinal : function () { + return 'º'; + }, + currency: { + symbol: '€', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; -// TODO -exports.COUPNCD = function() { - throw new Error('COUPNCD is not implemented'); -}; + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -// TODO -exports.COUPNUM = function() { - throw new Error('COUPNUM is not implemented'); -}; -// TODO -exports.COUPPCD = function() { - throw new Error('COUPPCD is not implemented'); -}; +/***/ }), +/* 73 */ +/***/ (function(module, exports) { -exports.CUMIPMT = function(rate, periods, value, start, end, type) { - // Credits: algorithm inspired by Apache OpenOffice - // Credits: Hannes Stiebitzhofer for the translations of function and variable names - // Requires exports.FV() and exports.PMT() from exports.js [http://stoic.com/exports/] +/*! + * numeral.js language configuration + * language : Romanian + * author : Andrei Alecu https://github.com/andreialecu + */ +(function () { + 'use strict'; - rate = utils.parseNumber(rate); - periods = utils.parseNumber(periods); - value = utils.parseNumber(value); - if (utils.anyIsError(rate, periods, value)) { - return error.value; - } + var language = { + langLocaleCode: 'ro-RO', + cultureCode: 'ro-RO', + delimiters: { + thousands: '.', + decimal: ',' + }, + abbreviations: { + thousand: 'mii', + million: 'mil', + billion: 'mld', + trillion: 'bln' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: ' lei', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; + + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); - // Return error if either rate, periods, or value are lower than or equal to zero - if (rate <= 0 || periods <= 0 || value <= 0) { - return error.num; - } - // Return error if start < 1, end < 1, or start > end - if (start < 1 || end < 1 || start > end) { - return error.num; - } +/***/ }), +/* 74 */ +/***/ (function(module, exports) { - // Return error if type is neither 0 nor 1 - if (type !== 0 && type !== 1) { - return error.num; - } +/*! + * numbro.js language configuration + * language : Romanian (ro) + * author : Tim McIntosh (StayinFront NZ) + */ +(function () { + 'use strict'; - // Compute cumulative interest - var payment = exports.PMT(rate, periods, value, 0, type); - var interest = 0; + var language = { + langLocaleCode: 'ro', + cultureCode: 'ro', + delimiters: { + thousands: '.', + decimal: ',' + }, + abbreviations: { + thousand: 'mie', + million: 'mln', + billion: 'mld', + trillion: 't' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: 'RON' + } + }; - if (start === 1) { - if (type === 0) { - interest = -value; - start++; + // Node + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; } - } - - for (var i = start; i <= end; i++) { - if (type === 1) { - interest += exports.FV(rate, i - 2, payment, value, 1) - payment; - } else { - interest += exports.FV(rate, i - 1, payment, value, 0); + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture('ro', language); } - } - interest *= rate; +}.call(typeof window === 'undefined' ? this : window)); - // Return cumulative interest - return interest; -}; -exports.CUMPRINC = function(rate, periods, value, start, end, type) { - // Credits: algorithm inspired by Apache OpenOffice - // Credits: Hannes Stiebitzhofer for the translations of function and variable names +/***/ }), +/* 75 */ +/***/ (function(module, exports) { - rate = utils.parseNumber(rate); - periods = utils.parseNumber(periods); - value = utils.parseNumber(value); - if (utils.anyIsError(rate, periods, value)) { - return error.value; - } +/*! + * numbro.js language configuration + * language : Russian + * locale : Russsia + * author : Anatoli Papirovski : https://github.com/apapirovski + */ +(function () { + 'use strict'; - // Return error if either rate, periods, or value are lower than or equal to zero - if (rate <= 0 || periods <= 0 || value <= 0) { - return error.num; - } + var language = { + langLocaleCode: 'ru-RU', + cultureCode: 'ru-RU', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 'тыс.', + million: 'млн', + billion: 'b', + trillion: 't' + }, + ordinal: function () { + // not ideal, but since in Russian it can taken on + // different forms (masculine, feminine, neuter) + // this is all we can do + return '.'; + }, + currency: { + symbol: 'руб.', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - // Return error if start < 1, end < 1, or start > end - if (start < 1 || end < 1 || start > end) { - return error.num; - } + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); - // Return error if type is neither 0 nor 1 - if (type !== 0 && type !== 1) { - return error.num; - } - // Compute cumulative principal - var payment = exports.PMT(rate, periods, value, 0, type); - var principal = 0; - if (start === 1) { - if (type === 0) { - principal = payment + value * rate; - } else { - principal = payment; +/***/ }), +/* 76 */ +/***/ (function(module, exports) { + +/*! + * numbro.js language configuration + * language : Russian + * locale : Ukraine + * author : Anatoli Papirovski : https://github.com/apapirovski + */ +(function () { + 'use strict'; + + var language = { + langLocaleCode: 'ru-UA', + cultureCode: 'ru-UA', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 'тыс.', + million: 'млн', + billion: 'b', + trillion: 't' + }, + ordinal: function () { + // not ideal, but since in Russian it can taken on + // different forms (masculine, feminine, neuter) + // this is all we can do + return '.'; + }, + currency: { + symbol: '\u20B4', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; + + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; } - start++; - } - for (var i = start; i <= end; i++) { - if (type > 0) { - principal += payment - (exports.FV(rate, i - 2, payment, value, 1) - payment) * rate; - } else { - principal += payment - exports.FV(rate, i - 1, payment, value, 0) * rate; + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); } - } +}.call(typeof window === 'undefined' ? this : window)); - // Return cumulative principal - return principal; -}; -exports.DB = function(cost, salvage, life, period, month) { - // Initialize month - month = (month === undefined) ? 12 : month; +/***/ }), +/* 77 */ +/***/ (function(module, exports) { - cost = utils.parseNumber(cost); - salvage = utils.parseNumber(salvage); - life = utils.parseNumber(life); - period = utils.parseNumber(period); - month = utils.parseNumber(month); - if (utils.anyIsError(cost, salvage, life, period, month)) { - return error.value; - } +/*! + * numbro.js language configuration + * language : Slovak + * locale : Slovakia + * author : Jan Pesa : https://github.com/smajl (based on work from Ahmed Al Hafoudh : http://www.freevision.sk) + */ +(function () { + 'use strict'; + + var language = { + langLocaleCode: 'sk-SK', + cultureCode: 'sk-SK', + delimiters: { + thousands: '\u00a0', + decimal: ',' + }, + abbreviations: { + thousand: 'tis.', + million: 'mil.', + billion: 'mld.', + trillion: 'bil.' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: '€', + position: 'postfix', + spaceSeparated: true + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - // Return error if any of the parameters is negative - if (cost < 0 || salvage < 0 || life < 0 || period < 0) { - return error.num; - } + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); - // Return error if month is not an integer between 1 and 12 - if ([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12].indexOf(month) === -1) { - return error.num; - } - // Return error if period is greater than life - if (period > life) { - return error.num; - } +/***/ }), +/* 78 */ +/***/ (function(module, exports) { - // Return 0 (zero) if salvage is greater than or equal to cost - if (salvage >= cost) { - return 0; - } +/*! + * numbro.js language configuration + * language : Slovene + * locale: Slovenia + * author : Tim McIntosh (StayinFront NZ) + */ +(function () { + 'use strict'; - // Rate is rounded to three decimals places - var rate = (1 - Math.pow(salvage / cost, 1 / life)).toFixed(3); + var language = { + langLocaleCode: 'sl', + cultureCode: 'sl', + delimiters: { + thousands: '.', + decimal: ',' + }, + abbreviations: { + thousand: 'tis.', + million: 'mil.', + billion: 'b', + trillion: 't' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: '€' + } + }; - // Compute initial depreciation - var initial = cost * rate * month / 12; + // Node + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture('sl', language); + } +}()); - // Compute total depreciation - var total = initial; - var current = 0; - var ceiling = (period === life) ? life - 1 : period; - for (var i = 2; i <= ceiling; i++) { - current = (cost - total) * rate; - total += current; - } - // Depreciation for the first and last periods are special cases - if (period === 1) { - // First period - return initial; - } else if (period === life) { - // Last period - return (cost - total) * rate; - } else { - return current; - } -}; +/***/ }), +/* 79 */ +/***/ (function(module, exports) { -exports.DDB = function(cost, salvage, life, period, factor) { - // Initialize factor - factor = (factor === undefined) ? 2 : factor; +/*! + * numbro.js language configuration + * language : Serbian (sr) + * country : Serbia (Cyrillic) + * author : Tim McIntosh (StayinFront NZ) + */ +(function () { + 'use strict'; - cost = utils.parseNumber(cost); - salvage = utils.parseNumber(salvage); - life = utils.parseNumber(life); - period = utils.parseNumber(period); - factor = utils.parseNumber(factor); - if (utils.anyIsError(cost, salvage, life, period, factor)) { - return error.value; - } + var language = { + langLocaleCode: 'sr-Cyrl-RS', + cultureCode: 'sr-Cyrl-RS', + delimiters: { + thousands: '.', + decimal: ',' + }, + abbreviations: { + thousand: 'тыс.', + million: 'млн', + billion: 'b', + trillion: 't' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: 'RSD' + } + }; - // Return error if any of the parameters is negative or if factor is null - if (cost < 0 || salvage < 0 || life < 0 || period < 0 || factor <= 0) { - return error.num; - } + // Node + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture('sr-Cyrl-RS', language); + } +}()); - // Return error if period is greater than life - if (period > life) { - return error.num; - } - // Return 0 (zero) if salvage is greater than or equal to cost - if (salvage >= cost) { - return 0; - } +/***/ }), +/* 80 */ +/***/ (function(module, exports) { - // Compute depreciation - var total = 0; - var current = 0; - for (var i = 1; i <= period; i++) { - current = Math.min((cost - total) * (factor / life), (cost - salvage - total)); - total += current; - } +/*! + * numbro.js language configuration + * language : Swedish + * locale : Sweden + * author : Benjamin Van Ryseghem (benjamin.vanryseghem.com) + */ +(function() { + 'use strict'; - // Return depreciation - return current; -}; + var language = { + langLocaleCode: 'sv-SE', + cultureCode: 'sv-SE', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 't', + million: 'M', + billion: 'md', + trillion: 'tmd' + }, + currency: { + symbol: 'kr', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; -// TODO -exports.DISC = function() { - throw new Error('DISC is not implemented'); -}; + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -exports.DOLLARDE = function(dollar, fraction) { - // Credits: algorithm inspired by Apache OpenOffice - dollar = utils.parseNumber(dollar); - fraction = utils.parseNumber(fraction); - if (utils.anyIsError(dollar, fraction)) { - return error.value; - } +/***/ }), +/* 81 */ +/***/ (function(module, exports) { - // Return error if fraction is negative - if (fraction < 0) { - return error.num; - } +/*! + * numbro.js language configuration + * language : Thai + * locale : Thailand + * author : Sathit Jittanupat : https://github.com/jojosati + */ +(function () { + 'use strict'; - // Return error if fraction is greater than or equal to 0 and less than 1 - if (fraction >= 0 && fraction < 1) { - return error.div0; - } + var language = { + langLocaleCode: 'th-TH', + cultureCode: 'th-TH', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: 'พัน', + million: 'ล้าน', + billion: 'พันล้าน', + trillion: 'ล้านล้าน' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: '฿', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - // Truncate fraction if it is not an integer - fraction = parseInt(fraction, 10); + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); - // Compute integer part - var result = parseInt(dollar, 10); - // Add decimal part - result += (dollar % 1) * Math.pow(10, Math.ceil(Math.log(fraction) / Math.LN10)) / fraction; +/***/ }), +/* 82 */ +/***/ (function(module, exports) { - // Round result - var power = Math.pow(10, Math.ceil(Math.log(fraction) / Math.LN2) + 1); - result = Math.round(result * power) / power; +/*! + * numbro.js language configuration + * language : Turkish + * locale : Turkey + * author : Ecmel Ercan : https://github.com/ecmel, + * Erhan Gundogan : https://github.com/erhangundogan, + * Burak Yiğit Kaya: https://github.com/BYK + */ +(function() { + 'use strict'; - // Return converted dollar price - return result; -}; + var suffixes = { + 1: '\'inci', + 5: '\'inci', + 8: '\'inci', + 70: '\'inci', + 80: '\'inci', -exports.DOLLARFR = function(dollar, fraction) { - // Credits: algorithm inspired by Apache OpenOffice + 2: '\'nci', + 7: '\'nci', + 20: '\'nci', + 50: '\'nci', - dollar = utils.parseNumber(dollar); - fraction = utils.parseNumber(fraction); - if (utils.anyIsError(dollar, fraction)) { - return error.value; - } + 3: '\'üncü', + 4: '\'üncü', + 100: '\'üncü', - // Return error if fraction is negative - if (fraction < 0) { - return error.num; - } + 6: '\'ncı', - // Return error if fraction is greater than or equal to 0 and less than 1 - if (fraction >= 0 && fraction < 1) { - return error.div0; - } + 9: '\'uncu', + 10: '\'uncu', + 30: '\'uncu', - // Truncate fraction if it is not an integer - fraction = parseInt(fraction, 10); + 60: '\'ıncı', + 90: '\'ıncı' + }, + language = { + langLocaleCode: 'tr-TR', + cultureCode: 'tr-TR', + delimiters: { + thousands: '.', + decimal: ',' + }, + abbreviations: { + thousand: 'bin', + million: 'milyon', + billion: 'milyar', + trillion: 'trilyon' + }, + ordinal: function(number) { + if (number === 0) { // special case for zero + return '\'ıncı'; + } - // Compute integer part - var result = parseInt(dollar, 10); + var a = number % 10, + b = number % 100 - a, + c = number >= 100 ? 100 : null; - // Add decimal part - result += (dollar % 1) * Math.pow(10, -Math.ceil(Math.log(fraction) / Math.LN10)) * fraction; + return suffixes[a] || suffixes[b] || suffixes[c]; + }, + currency: { + symbol: '\u20BA', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - // Return converted dollar price - return result; -}; + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -// TODO -exports.DURATION = function() { - throw new Error('DURATION is not implemented'); -}; -exports.EFFECT = function(rate, periods) { - rate = utils.parseNumber(rate); - periods = utils.parseNumber(periods); - if (utils.anyIsError(rate, periods)) { - return error.value; - } +/***/ }), +/* 83 */ +/***/ (function(module, exports) { - // Return error if rate <=0 or periods < 1 - if (rate <= 0 || periods < 1) { - return error.num; - } +/*! + * numbro.js language configuration + * language : Ukrainian + * locale : Ukraine + * author : Michael Piefel : https://github.com/piefel (with help from Tetyana Kuzmenko) + */ +(function () { + 'use strict'; - // Truncate periods if it is not an integer - periods = parseInt(periods, 10); + var language = { + langLocaleCode: 'uk-UA', + cultureCode: 'uk-UA', + delimiters: { + thousands: ' ', + decimal: ',' + }, + abbreviations: { + thousand: 'тис.', + million: 'млн', + billion: 'млрд', + trillion: 'блн' + }, + ordinal: function () { + // not ideal, but since in Ukrainian it can taken on + // different forms (masculine, feminine, neuter) + // this is all we can do + return ''; + }, + currency: { + symbol: '\u20B4', + position: 'postfix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: ',0.00 $', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: ',0 $' + } + }; - // Return effective annual interest rate - return Math.pow(1 + rate / periods, periods) - 1; -}; + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -exports.FV = function(rate, periods, payment, value, type) { - // Credits: algorithm inspired by Apache OpenOffice - value = value || 0; - type = type || 0; +/***/ }), +/* 84 */ +/***/ (function(module, exports) { - rate = utils.parseNumber(rate); - periods = utils.parseNumber(periods); - payment = utils.parseNumber(payment); - value = utils.parseNumber(value); - type = utils.parseNumber(type); - if (utils.anyIsError(rate, periods, payment, value, type)) { - return error.value; - } +/*! + * numbro.js language configuration + * language : simplified chinese + * locale : China + * author : badplum : https://github.com/badplum + */ +(function () { + 'use strict'; - // Return future value - var result; - if (rate === 0) { - result = value + payment * periods; - } else { - var term = Math.pow(1 + rate, periods); - if (type === 1) { - result = value * term + payment * (1 + rate) * (term - 1) / rate; - } else { - result = value * term + payment * (term - 1) / rate; + var language = { + langLocaleCode: 'zh-CN', + cultureCode: 'zh-CN', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: '千', + million: '百万', + billion: '十亿', + trillion: '兆' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: '¥', + position: 'prefix' + }, + defaults: { + currencyFormat: ',4 a' + }, + formats: { + fourDigits: '4 a', + fullWithTwoDecimals: '$ ,0.00', + fullWithTwoDecimalsNoCurrency: ',0.00', + fullWithNoDecimals: '$ ,0' + } + }; + + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; } - } - return -result; -}; + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); -exports.FVSCHEDULE = function(principal, schedule) { - principal = utils.parseNumber(principal); - schedule = utils.parseNumberArray(utils.flatten(schedule)); - if (utils.anyIsError(principal, schedule)) { - return error.value; - } - var n = schedule.length; - var future = principal; +/***/ }), +/* 85 */ +/***/ (function(module, exports) { - // Apply all interests in schedule - for (var i = 0; i < n; i++) { - // Apply scheduled interest - future *= 1 + schedule[i]; - } +/*! + * numbro.js language configuration + * language : Chinese traditional + * locale: Macau + * author : Tim McIntosh (StayinFront NZ) + */ +(function () { + 'use strict'; - // Return future value - return future; -}; + var language = { + langLocaleCode: 'zh-MO', + cultureCode: 'zh-MO', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: '千', + million: '百萬', + billion: '十億', + trillion: '兆' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: 'MOP' + } + }; -// TODO -exports.INTRATE = function() { - throw new Error('INTRATE is not implemented'); -}; + // Node + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; + } + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture('zh-MO', language); + } +}()); -exports.IPMT = function(rate, period, periods, present, future, type) { - // Credits: algorithm inspired by Apache OpenOffice - future = future || 0; - type = type || 0; +/***/ }), +/* 86 */ +/***/ (function(module, exports) { - rate = utils.parseNumber(rate); - period = utils.parseNumber(period); - periods = utils.parseNumber(periods); - present = utils.parseNumber(present); - future = utils.parseNumber(future); - type = utils.parseNumber(type); - if (utils.anyIsError(rate, period, periods, present, future, type)) { - return error.value; - } +/*! + * numbro.js language configuration + * language : Chinese simplified + * locale: Singapore + * author : Tim McIntosh (StayinFront NZ) + */ +(function () { + 'use strict'; - // Compute payment - var payment = exports.PMT(rate, periods, present, future, type); + var language = { + langLocaleCode: 'zh-SG', + cultureCode: 'zh-SG', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: '千', + million: '百万', + billion: '十亿', + trillion: '兆' + }, + ordinal: function () { + return '.'; + }, + currency: { + symbol: '$' + } + }; - // Compute interest - var interest; - if (period === 1) { - if (type === 1) { - interest = 0; - } else { - interest = -present; + // Node + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; } - } else { - if (type === 1) { - interest = exports.FV(rate, period - 2, payment, present, 1) - payment; - } else { - interest = exports.FV(rate, period - 1, payment, present, 0); + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture('zh-SG', language); } - } +}.call(typeof window === 'undefined' ? this : window)); - // Return interest - return interest * rate; -}; -exports.IRR = function(values, guess) { - // Credits: algorithm inspired by Apache OpenOffice +/***/ }), +/* 87 */ +/***/ (function(module, exports) { - guess = guess || 0; +/*! + * numbro.js language configuration + * language : Chinese (Taiwan) + * author (numbro.js Version): Randy Wilander : https://github.com/rocketedaway + * author (numeral.js Version) : Rich Daley : https://github.com/pedantic-git + */ +(function () { + 'use strict'; - values = utils.parseNumberArray(utils.flatten(values)); - guess = utils.parseNumber(guess); - if (utils.anyIsError(values, guess)) { - return error.value; - } + var language = { + langLocaleCode: 'zh-TW', + cultureCode: 'zh-TW', + delimiters: { + thousands: ',', + decimal: '.' + }, + abbreviations: { + thousand: '千', + million: '百萬', + billion: '十億', + trillion: '兆' + }, + ordinal: function () { + return '第'; + }, + currency: { + symbol: 'NT$' + } + }; - // Calculates the resulting amount - var irrResult = function(values, dates, rate) { - var r = rate + 1; - var result = values[0]; - for (var i = 1; i < values.length; i++) { - result += values[i] / Math.pow(r, (dates[i] - dates[0]) / 365); + // CommonJS + if (typeof module !== 'undefined' && module.exports) { + module.exports = language; } - return result; + // Browser + if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { + window.numbro.culture(language.cultureCode, language); + } +}.call(typeof window === 'undefined' ? this : window)); + + +/***/ }), +/* 88 */ +/***/ (function(module, exports, __webpack_require__) { + +var M = Math; +function _horner(arr, v) { return arr.reduce(function(z,w){return v * z + w;},0); }; +function _bessel_iter(x, n, f0, f1, sign) { + if(!sign) sign = -1; + var tdx = 2 / x, f2; + if(n === 0) return f0; + if(n === 1) return f1; + for(var o = 1; o != n; ++o) { + f2 = f1 * o * tdx + sign * f0; + f0 = f1; f1 = f2; + } + return f1; +} +function _bessel_wrap(bessel0, bessel1, name, nonzero, sign) { + return function bessel(x,n) { + if(n === 0) return bessel0(x); + if(n === 1) return bessel1(x); + if(n < 0) throw name + ': Order (' + n + ') must be nonnegative'; + if(nonzero == 1 && x === 0) throw name + ': Undefined when x == 0'; + if(nonzero == 2 && x <= 0) throw name + ': Undefined when x <= 0'; + var b0 = bessel0(x), b1 = bessel1(x); + return _bessel_iter(x, n, b0, b1, sign); }; +} +var besselj = (function() { + var b0_a1a = [57568490574.0,-13362590354.0,651619640.7,-11214424.18,77392.33017,-184.9052456].reverse(); + var b0_a2a = [57568490411.0,1029532985.0,9494680.718,59272.64853,267.8532712,1.0].reverse(); + var b0_a1b = [1.0, -0.1098628627e-2, 0.2734510407e-4, -0.2073370639e-5, 0.2093887211e-6].reverse(); + var b0_a2b = [-0.1562499995e-1, 0.1430488765e-3, -0.6911147651e-5, 0.7621095161e-6, -0.934935152e-7].reverse(); + var W = 0.636619772; // 2 / Math.PI - // Calculates the first derivation - var irrResultDeriv = function(values, dates, rate) { - var r = rate + 1; - var result = 0; - for (var i = 1; i < values.length; i++) { - var frac = (dates[i] - dates[0]) / 365; - result -= frac * values[i] / Math.pow(r, frac + 1); + function bessel0(x) { + var a, a1, a2, y = x * x, xx = M.abs(x) - 0.785398164; + if(M.abs(x) < 8) { + a1 = _horner(b0_a1a, y); + a2 = _horner(b0_a2a, y); + a = a1/a2; + } + else { + y = 64 / y; + a1 = _horner(b0_a1b, y); + a2 = _horner(b0_a2b, y); + a = M.sqrt(W/M.abs(x))*(M.cos(xx)*a1-M.sin(xx)*a2*8/M.abs(x)); + } + return a; + } + var b1_a1a = [72362614232.0,-7895059235.0,242396853.1,-2972611.439, 15704.48260, -30.16036606].reverse(); + var b1_a2a = [144725228442.0, 2300535178.0, 18583304.74, 99447.43394, 376.9991397, 1.0].reverse(); + var b1_a1b = [1.0, 0.183105e-2, -0.3516396496e-4, 0.2457520174e-5, -0.240337019e-6].reverse(); + var b1_a2b = [0.04687499995, -0.2002690873e-3, 0.8449199096e-5, -0.88228987e-6, 0.105787412e-6].reverse(); + function bessel1(x) { + var a, a1, a2, y = x*x, xx = M.abs(x) - 2.356194491; + if(Math.abs(x)< 8) { + a1 = x*_horner(b1_a1a, y); + a2 = _horner(b1_a2a, y); + a = a1 / a2; + } else { + y = 64 / y; + a1=_horner(b1_a1b, y); + a2=_horner(b1_a2b, y); + a=M.sqrt(W/M.abs(x))*(M.cos(xx)*a1-M.sin(xx)*a2*8/M.abs(x)); + if(x < 0) a = -a; + } + return a; + } + return function besselj(x, n) { + n = Math.round(n); + if(n === 0) return bessel0(M.abs(x)); + if(n === 1) return bessel1(M.abs(x)); + if(n < 0) throw 'BESSELJ: Order (' + n + ') must be nonnegative'; + if(M.abs(x) === 0) return 0; + + var ret, j, tox = 2 / M.abs(x), m, jsum, sum, bjp, bj, bjm; + if(M.abs(x) > n) { + ret = _bessel_iter(x, n, bessel0(M.abs(x)), bessel1(M.abs(x)),-1); + } else { + m=2*M.floor((n+M.floor(M.sqrt(40*n)))/2); + jsum=0; + bjp=ret=sum=0.0; + bj=1.0; + for (j=m;j>0;j--) { + bjm=j*tox*bj-bjp; + bjp=bj; + bj=bjm; + if (M.abs(bj) > 1E10) { + bj *= 1E-10; + bjp *= 1E-10; + ret *= 1E-10; + sum *= 1E-10; + } + if (jsum) sum += bj; + jsum=!jsum; + if (j == n) ret=bjp; + } + sum=2.0*sum-bj; + ret /= sum; } - return result; + return x < 0 && (n%2) ? -ret : ret; }; +})(); +var bessely = (function() { + var b0_a1a = [-2957821389.0, 7062834065.0, -512359803.6, 10879881.29, -86327.92757, 228.4622733].reverse(); + var b0_a2a = [40076544269.0, 745249964.8, 7189466.438, 47447.26470, 226.1030244, 1.0].reverse(); + var b0_a1b = [1.0, -0.1098628627e-2, 0.2734510407e-4, -0.2073370639e-5, 0.2093887211e-6].reverse(); + var b0_a2b = [-0.1562499995e-1, 0.1430488765e-3, -0.6911147651e-5, 0.7621095161e-6, -0.934945152e-7].reverse(); - // Initialize dates and check that values contains at least one positive value and one negative value - var dates = []; - var positive = false; - var negative = false; - for (var i = 0; i < values.length; i++) { - dates[i] = (i === 0) ? 0 : dates[i - 1] + 365; - if (values[i] > 0) { - positive = true; - } - if (values[i] < 0) { - negative = true; + var W = 0.636619772; + function bessel0(x) { + var a, a1, a2, y = x * x, xx = x - 0.785398164; + if(x < 8) { + a1 = _horner(b0_a1a, y); + a2 = _horner(b0_a2a, y); + a = a1/a2 + W * besselj(x,0) * M.log(x); + } else { + y = 64 / y; + a1 = _horner(b0_a1b, y); + a2 = _horner(b0_a2b, y); + a = M.sqrt(W/x)*(M.sin(xx)*a1+M.cos(xx)*a2*8/x); } + return a; } - // Return error if values does not contain at least one positive value and one negative value - if (!positive || !negative) { - return error.num; + var b1_a1a = [-0.4900604943e13, 0.1275274390e13, -0.5153438139e11, 0.7349264551e9, -0.4237922726e7, 0.8511937935e4].reverse(); + var b1_a2a = [0.2499580570e14, 0.4244419664e12, 0.3733650367e10, 0.2245904002e8, 0.1020426050e6, 0.3549632885e3, 1].reverse(); + var b1_a1b = [1.0, 0.183105e-2, -0.3516396496e-4, 0.2457520174e-5, -0.240337019e-6].reverse(); + var b1_a2b = [0.04687499995, -0.2002690873e-3, 0.8449199096e-5, -0.88228987e-6, 0.105787412e-6].reverse(); + function bessel1(x) { + var a, a1, a2, y = x*x, xx = x - 2.356194491; + if(x < 8) { + a1 = x*_horner(b1_a1a, y); + a2 = _horner(b1_a2a, y); + a = a1/a2 + W * (besselj(x,1) * M.log(x) - 1 / x); + } else { + y = 64 / y; + a1=_horner(b1_a1b, y); + a2=_horner(b1_a2b, y); + a=M.sqrt(W/x)*(M.sin(xx)*a1+M.cos(xx)*a2*8/x); + } + return a; } - // Initialize guess and resultRate - guess = (guess === undefined) ? 0.1 : guess; - var resultRate = guess; - - // Set maximum epsilon for end of iteration - var epsMax = 1e-10; - - // Implement Newton's method - var newRate, epsRate, resultValue; - var contLoop = true; - do { - resultValue = irrResult(values, dates, resultRate); - newRate = resultRate - resultValue / irrResultDeriv(values, dates, resultRate); - epsRate = Math.abs(newRate - resultRate); - resultRate = newRate; - contLoop = (epsRate > epsMax) && (Math.abs(resultValue) > epsMax); - } while (contLoop); - - // Return internal rate of return - return resultRate; -}; - -exports.ISPMT = function(rate, period, periods, value) { - rate = utils.parseNumber(rate); - period = utils.parseNumber(period); - periods = utils.parseNumber(periods); - value = utils.parseNumber(value); - if (utils.anyIsError(rate, period, periods, value)) { - return error.value; + return _bessel_wrap(bessel0, bessel1, 'BESSELY', 1, -1); +})(); +var besseli = (function() { + var b0_a = [1.0, 3.5156229, 3.0899424, 1.2067492, 0.2659732, 0.360768e-1, 0.45813e-2].reverse(); + var b0_b = [0.39894228, 0.1328592e-1, 0.225319e-2, -0.157565e-2, 0.916281e-2, -0.2057706e-1, 0.2635537e-1, -0.1647633e-1, 0.392377e-2].reverse(); + function bessel0(x) { + if(x <= 3.75) return _horner(b0_a, x*x/(3.75*3.75)); + return M.exp(M.abs(x))/M.sqrt(M.abs(x))*_horner(b0_b, 3.75/M.abs(x)); } - // Return interest - return value * rate * (period / periods - 1); -}; - -// TODO -exports.MDURATION = function() { - throw new Error('MDURATION is not implemented'); -}; - -exports.MIRR = function(values, finance_rate, reinvest_rate) { - values = utils.parseNumberArray(utils.flatten(values)); - finance_rate = utils.parseNumber(finance_rate); - reinvest_rate = utils.parseNumber(reinvest_rate); - if (utils.anyIsError(values, finance_rate, reinvest_rate)) { - return error.value; + var b1_a = [0.5, 0.87890594, 0.51498869, 0.15084934, 0.2658733e-1, 0.301532e-2, 0.32411e-3].reverse(); + var b1_b = [0.39894228, -0.3988024e-1, -0.362018e-2, 0.163801e-2, -0.1031555e-1, 0.2282967e-1, -0.2895312e-1, 0.1787654e-1, -0.420059e-2].reverse(); + function bessel1(x) { + if(x < 3.75) return x * _horner(b1_a, x*x/(3.75*3.75)); + return (x < 0 ? -1 : 1) * M.exp(M.abs(x))/M.sqrt(M.abs(x))*_horner(b1_b, 3.75/M.abs(x)); } - // Initialize number of values - var n = values.length; + return function besseli(x, n) { + n = Math.round(n); + if(n === 0) return bessel0(x); + if(n == 1) return bessel1(x); + if(n < 0) throw 'BESSELI Order (' + n + ') must be nonnegative'; + if(M.abs(x) === 0) return 0; - // Lookup payments (negative values) and incomes (positive values) - var payments = []; - var incomes = []; - for (var i = 0; i < n; i++) { - if (values[i] < 0) { - payments.push(values[i]); - } else { - incomes.push(values[i]); + var ret, j, tox = 2 / M.abs(x), m, bip, bi, bim; + m=2*M.round((n+M.round(M.sqrt(40*n)))/2); + bip=ret=0.0; + bi=1.0; + for (j=m;j>0;j--) { + bim=j*tox*bi + bip; + bip=bi; bi=bim; + if (M.abs(bi) > 1E10) { + bi *= 1E-10; + bip *= 1E-10; + ret *= 1E-10; + } + if(j == n) ret = bip; } - } - - // Return modified internal rate of return - var num = -exports.NPV(reinvest_rate, incomes) * Math.pow(1 + reinvest_rate, n - 1); - var den = exports.NPV(finance_rate, payments) * (1 + finance_rate); - return Math.pow(num / den, 1 / (n - 1)) - 1; -}; + ret *= besseli(x, 0) / bi; + return x < 0 && (n%2) ? -ret : ret; + }; -exports.NOMINAL = function(rate, periods) { - rate = utils.parseNumber(rate); - periods = utils.parseNumber(periods); - if (utils.anyIsError(rate, periods)) { - return error.value; - } +})(); - // Return error if rate <=0 or periods < 1 - if (rate <= 0 || periods < 1) { - return error.num; +var besselk = (function() { + var b0_a = [-0.57721566, 0.42278420, 0.23069756, 0.3488590e-1, 0.262698e-2, 0.10750e-3, 0.74e-5].reverse(); + var b0_b = [1.25331414, -0.7832358e-1, 0.2189568e-1, -0.1062446e-1, 0.587872e-2, -0.251540e-2, 0.53208e-3].reverse(); + function bessel0(x) { + if(x <= 2) return -M.log(x/2)*besseli(x,0) + _horner(b0_a, x*x/4); + return M.exp(-x)/M.sqrt(x)*_horner(b0_b, 2/x); } - // Truncate periods if it is not an integer - periods = parseInt(periods, 10); - - // Return nominal annual interest rate - return (Math.pow(rate + 1, 1 / periods) - 1) * periods; -}; - -exports.NPER = function(rate, payment, present, future, type) { - type = (type === undefined) ? 0 : type; - future = (future === undefined) ? 0 : future; - - rate = utils.parseNumber(rate); - payment = utils.parseNumber(payment); - present = utils.parseNumber(present); - future = utils.parseNumber(future); - type = utils.parseNumber(type); - if (utils.anyIsError(rate, payment, present, future, type)) { - return error.value; + var b1_a = [1.0, 0.15443144, -0.67278579, -0.18156897, -0.1919402e-1, -0.110404e-2, -0.4686e-4].reverse(); + var b1_b = [1.25331414, 0.23498619, -0.3655620e-1, 0.1504268e-1, -0.780353e-2, 0.325614e-2, -0.68245e-3].reverse(); + function bessel1(x) { + if(x <= 2) return M.log(x/2)*besseli(x,1) + (1/x)*_horner(b1_a, x*x/4); + return M.exp(-x)/M.sqrt(x)*_horner(b1_b, 2/x); } - // Return number of periods - var num = payment * (1 + rate * type) - future * rate; - var den = (present * rate + payment * (1 + rate * type)); - return Math.log(num / den) / Math.log(1 + rate); -}; + return _bessel_wrap(bessel0, bessel1, 'BESSELK', 2, 1); +})(); +if(true) { + exports.besselj = besselj; + exports.bessely = bessely; + exports.besseli = besseli; + exports.besselk = besselk; +} -exports.NPV = function() { - var args = utils.parseNumberArray(utils.flatten(arguments)); - if (args instanceof Error) { - return args; - } - // Lookup rate - var rate = args[0]; - // Initialize net present value - var value = 0; +/***/ }), +/* 89 */ +/***/ (function(module, exports, __webpack_require__) { - // Loop on all values - for (var j = 1; j < args.length; j++) { - value += args[j] / Math.pow(1 + rate, j); - } +var error = __webpack_require__(0); +var stats = __webpack_require__(5); +var maths = __webpack_require__(4); +var utils = __webpack_require__(1); - // Return net present value - return value; -}; +function compact(array) { + var result = []; -// TODO -exports.ODDFPRICE = function() { - throw new Error('ODDFPRICE is not implemented'); -}; + utils.arrayEach(array, function(value) { + if (value) { + result.push(value); + } + }); -// TODO -exports.ODDFYIELD = function() { - throw new Error('ODDFYIELD is not implemented'); -}; + return result; +} -// TODO -exports.ODDLPRICE = function() { - throw new Error('ODDLPRICE is not implemented'); -}; +exports.FINDFIELD = function(database, title) { + var index = null; -// TODO -exports.ODDLYIELD = function() { - throw new Error('ODDLYIELD is not implemented'); -}; + utils.arrayEach(database, function(value, i) { + if (value[0] === title) { + index = i; + return false; + } + }); -exports.PDURATION = function(rate, present, future) { - rate = utils.parseNumber(rate); - present = utils.parseNumber(present); - future = utils.parseNumber(future); - if (utils.anyIsError(rate, present, future)) { + // Return error if the input field title is incorrect + if (index == null) { return error.value; } - // Return error if rate <=0 - if (rate <= 0) { - return error.num; - } - - // Return number of periods - return (Math.log(future) - Math.log(present)) / Math.log(1 + rate); + return index; }; -exports.PMT = function(rate, periods, present, future, type) { - // Credits: algorithm inspired by Apache OpenOffice +function findResultIndex(database, criterias) { + var matches = {}; + for (var i = 1; i < database[0].length; ++i) { + matches[i] = true; + } + var maxCriteriaLength = criterias[0].length; + for (i = 1; i < criterias.length; ++i) { + if (criterias[i].length > maxCriteriaLength) { + maxCriteriaLength = criterias[i].length; + } + } - future = future || 0; - type = type || 0; + for (var k = 1; k < database.length; ++k) { + for (var l = 1; l < database[k].length; ++l) { + var currentCriteriaResult = false; + var hasMatchingCriteria = false; + for (var j = 0; j < criterias.length; ++j) { + var criteria = criterias[j]; + if (criteria.length < maxCriteriaLength) { + continue; + } - rate = utils.parseNumber(rate); - periods = utils.parseNumber(periods); - present = utils.parseNumber(present); - future = utils.parseNumber(future); - type = utils.parseNumber(type); - if (utils.anyIsError(rate, periods, present, future, type)) { - return error.value; + var criteriaField = criteria[0]; + if (database[k][0] !== criteriaField) { + continue; + } + hasMatchingCriteria = true; + for (var p = 1; p < criteria.length; ++p) { + currentCriteriaResult = currentCriteriaResult || eval(database[k][l] + criteria[p]); // jshint ignore:line + } + } + if (hasMatchingCriteria) { + matches[l] = matches[l] && currentCriteriaResult; + } + } } - // Return payment - var result; - if (rate === 0) { - result = (present + future) / periods; - } else { - var term = Math.pow(1 + rate, periods); - if (type === 1) { - result = (future * rate / (term - 1) + present * rate / (1 - 1 / term)) / (1 + rate); - } else { - result = future * rate / (term - 1) + present * rate / (1 - 1 / term); + var result = []; + for (var n = 0; n < database[0].length; ++n) { + if (matches[n]) { + result.push(n - 1); } } - return -result; -}; -exports.PPMT = function(rate, period, periods, present, future, type) { - future = future || 0; - type = type || 0; + return result; +} - rate = utils.parseNumber(rate); - periods = utils.parseNumber(periods); - present = utils.parseNumber(present); - future = utils.parseNumber(future); - type = utils.parseNumber(type); - if (utils.anyIsError(rate, periods, present, future, type)) { +// Database functions +exports.DAVERAGE = function(database, field, criteria) { + // Return error if field is not a number and not a string + if (isNaN(field) && (typeof field !== "string")) { return error.value; } + var resultIndexes = findResultIndex(database, criteria); + var targetFields = []; - return exports.PMT(rate, periods, present, future, type) - exports.IPMT(rate, period, periods, present, future, type); -}; - -// TODO -exports.PRICE = function() { - throw new Error('PRICE is not implemented'); -}; + if (typeof field === "string") { + var index = exports.FINDFIELD(database, field); + targetFields = utils.rest(database[index]); + } else { + targetFields = utils.rest(database[field]); + } + var sum = 0; -// TODO -exports.PRICEDISC = function() { - throw new Error('PRICEDISC is not implemented'); -}; + utils.arrayEach(resultIndexes, function(value) { + sum += targetFields[value]; + }); -// TODO -exports.PRICEMAT = function() { - throw new Error('PRICEMAT is not implemented'); + return resultIndexes.length === 0 ? error.div0 : sum / resultIndexes.length; }; -exports.PV = function(rate, periods, payment, future, type) { - future = future || 0; - type = type || 0; - - rate = utils.parseNumber(rate); - periods = utils.parseNumber(periods); - payment = utils.parseNumber(payment); - future = utils.parseNumber(future); - type = utils.parseNumber(type); - if (utils.anyIsError(rate, periods, payment, future, type)) { +exports.DCOUNT = function(database, field, criteria) { + // Return error if field is not a number and not a string + if (isNaN(field) && (typeof field !== "string")) { return error.value; } + var resultIndexes = findResultIndex(database, criteria); + var targetFields = []; - // Return present value - if (rate === 0) { - return -payment * periods - future; + if (typeof field === "string") { + var index = exports.FINDFIELD(database, field); + targetFields = utils.rest(database[index]); } else { - return (((1 - Math.pow(1 + rate, periods)) / rate) * payment * (1 + rate * type) - future) / Math.pow(1 + rate, periods); + targetFields = utils.rest(database[field]); } -}; -exports.RATE = function(periods, payment, present, future, type, guess) { - // Credits: rabugento + var targetValues = []; - guess = (guess === undefined) ? 0.01 : guess; - future = (future === undefined) ? 0 : future; - type = (type === undefined) ? 0 : type; + utils.arrayEach(resultIndexes, function(value) { + targetValues.push(targetFields[value]); + }); - periods = utils.parseNumber(periods); - payment = utils.parseNumber(payment); - present = utils.parseNumber(present); - future = utils.parseNumber(future); - type = utils.parseNumber(type); - guess = utils.parseNumber(guess); - if (utils.anyIsError(periods, payment, present, future, type, guess)) { + return stats.COUNT(targetValues); +}; + +exports.DCOUNTA = function(database, field, criteria) { + // Return error if field is not a number and not a string + if (isNaN(field) && (typeof field !== "string")) { return error.value; } - // Set maximum epsilon for end of iteration - var epsMax = 1e-10; - - // Set maximum number of iterations - var iterMax = 50; + var resultIndexes = findResultIndex(database, criteria); + var targetFields = []; - // Implement Newton's method - var y, y0, y1, x0, x1 = 0, - f = 0, - i = 0; - var rate = guess; - if (Math.abs(rate) < epsMax) { - y = present * (1 + periods * rate) + payment * (1 + rate * type) * periods + future; + if (typeof field === "string") { + var index = exports.FINDFIELD(database, field); + targetFields = utils.rest(database[index]); } else { - f = Math.exp(periods * Math.log(1 + rate)); - y = present * f + payment * (1 / rate + type) * (f - 1) + future; - } - y0 = present + payment * periods + future; - y1 = present * f + payment * (1 / rate + type) * (f - 1) + future; - i = x0 = 0; - x1 = rate; - while ((Math.abs(y0 - y1) > epsMax) && (i < iterMax)) { - rate = (y1 * x0 - y0 * x1) / (y1 - y0); - x0 = x1; - x1 = rate; - if (Math.abs(rate) < epsMax) { - y = present * (1 + periods * rate) + payment * (1 + rate * type) * periods + future; - } else { - f = Math.exp(periods * Math.log(1 + rate)); - y = present * f + payment * (1 / rate + type) * (f - 1) + future; - } - y0 = y1; - y1 = y; - ++i; + targetFields = utils.rest(database[field]); } - return rate; -}; -// TODO -exports.RECEIVED = function() { - throw new Error('RECEIVED is not implemented'); + var targetValues = []; + + utils.arrayEach(resultIndexes, function(value) { + targetValues.push(targetFields[value]); + }); + + return stats.COUNTA(targetValues); }; -exports.RRI = function(periods, present, future) { - periods = utils.parseNumber(periods); - present = utils.parseNumber(present); - future = utils.parseNumber(future); - if (utils.anyIsError(periods, present, future)) { +exports.DGET = function(database, field, criteria) { + // Return error if field is not a number and not a string + if (isNaN(field) && (typeof field !== "string")) { return error.value; } - // Return error if periods or present is equal to 0 (zero) - if (periods === 0 || present === 0) { - return error.num; - } + var resultIndexes = findResultIndex(database, criteria); + var targetFields = []; - // Return equivalent interest rate - return Math.pow(future / present, 1 / periods) - 1; -}; + if (typeof field === "string") { + var index = exports.FINDFIELD(database, field); + targetFields = utils.rest(database[index]); + } else { + targetFields = utils.rest(database[field]); + } -exports.SLN = function(cost, salvage, life) { - cost = utils.parseNumber(cost); - salvage = utils.parseNumber(salvage); - life = utils.parseNumber(life); - if (utils.anyIsError(cost, salvage, life)) { + // Return error if no record meets the criteria + if (resultIndexes.length === 0) { return error.value; } - - // Return error if life equal to 0 (zero) - if (life === 0) { + // Returns the #NUM! error value because more than one record meets the + // criteria + if (resultIndexes.length > 1) { return error.num; } - // Return straight-line depreciation - return (cost - salvage) / life; + return targetFields[resultIndexes[0]]; }; -exports.SYD = function(cost, salvage, life, period) { - // Return error if any of the parameters is not a number - cost = utils.parseNumber(cost); - salvage = utils.parseNumber(salvage); - life = utils.parseNumber(life); - period = utils.parseNumber(period); - if (utils.anyIsError(cost, salvage, life, period)) { +exports.DMAX = function(database, field, criteria) { + // Return error if field is not a number and not a string + if (isNaN(field) && (typeof field !== "string")) { return error.value; } + var resultIndexes = findResultIndex(database, criteria); + var targetFields = []; - // Return error if life equal to 0 (zero) - if (life === 0) { - return error.num; + if (typeof field === "string") { + var index = exports.FINDFIELD(database, field); + targetFields = utils.rest(database[index]); + } else { + targetFields = utils.rest(database[field]); } - // Return error if period is lower than 1 or greater than life - if (period < 1 || period > life) { - return error.num; - } + var maxValue = targetFields[resultIndexes[0]]; - // Truncate period if it is not an integer - period = parseInt(period, 10); + utils.arrayEach(resultIndexes, function(value) { + if (maxValue < targetFields[value]) { + maxValue = targetFields[value]; + } + }); - // Return straight-line depreciation - return ((cost - salvage) * (life - period + 1) * 2) / (life * (life + 1)); + return maxValue; }; -exports.TBILLEQ = function(settlement, maturity, discount) { - settlement = utils.parseDate(settlement); - maturity = utils.parseDate(maturity); - discount = utils.parseNumber(discount); - if (utils.anyIsError(settlement, maturity, discount)) { +exports.DMIN = function(database, field, criteria) { + // Return error if field is not a number and not a string + if (isNaN(field) && (typeof field !== "string")) { return error.value; } - // Return error if discount is lower than or equal to zero - if (discount <= 0) { - return error.num; - } + var resultIndexes = findResultIndex(database, criteria); + var targetFields = []; - // Return error if settlement is greater than maturity - if (settlement > maturity) { - return error.num; + if (typeof field === "string") { + var index = exports.FINDFIELD(database, field); + targetFields = utils.rest(database[index]); + } else { + targetFields = utils.rest(database[field]); } - // Return error if maturity is more than one year after settlement - if (maturity - settlement > 365 * 24 * 60 * 60 * 1000) { - return error.num; - } + var minValue = targetFields[resultIndexes[0]]; - // Return bond-equivalent yield - return (365 * discount) / (360 - discount * dateTime.DAYS360(settlement, maturity, false)); + utils.arrayEach(resultIndexes, function(value) { + if (minValue > targetFields[value]) { + minValue = targetFields[value]; + } + }); + + return minValue; }; -exports.TBILLPRICE = function(settlement, maturity, discount) { - settlement = utils.parseDate(settlement); - maturity = utils.parseDate(maturity); - discount = utils.parseNumber(discount); - if (utils.anyIsError(settlement, maturity, discount)) { +exports.DPRODUCT = function(database, field, criteria) { + // Return error if field is not a number and not a string + if (isNaN(field) && (typeof field !== "string")) { return error.value; } - // Return error if discount is lower than or equal to zero - if (discount <= 0) { - return error.num; - } + var resultIndexes = findResultIndex(database, criteria); + var targetFields = []; - // Return error if settlement is greater than maturity - if (settlement > maturity) { - return error.num; + if (typeof field === "string") { + var index = exports.FINDFIELD(database, field); + targetFields = utils.rest(database[index]); + } else { + targetFields = utils.rest(database[field]); } - // Return error if maturity is more than one year after settlement - if (maturity - settlement > 365 * 24 * 60 * 60 * 1000) { - return error.num; - } + var targetValues = []; - // Return bond-equivalent yield - return 100 * (1 - discount * dateTime.DAYS360(settlement, maturity, false) / 360); + utils.arrayEach(resultIndexes, function(value) { + targetValues.push(targetFields[value]); + }); + targetValues = compact(targetValues); + + var result = 1; + + utils.arrayEach(targetValues, function(value) { + result *= value; + }); + + return result; }; -exports.TBILLYIELD = function(settlement, maturity, price) { - settlement = utils.parseDate(settlement); - maturity = utils.parseDate(maturity); - price = utils.parseNumber(price); - if (utils.anyIsError(settlement, maturity, price)) { +exports.DSTDEV = function(database, field, criteria) { + // Return error if field is not a number and not a string + if (isNaN(field) && (typeof field !== "string")) { return error.value; } + var resultIndexes = findResultIndex(database, criteria); + var targetFields = []; - // Return error if price is lower than or equal to zero - if (price <= 0) { - return error.num; + if (typeof field === "string") { + var index = exports.FINDFIELD(database, field); + targetFields = utils.rest(database[index]); + } else { + targetFields = utils.rest(database[field]); } + var targetValues = []; - // Return error if settlement is greater than maturity - if (settlement > maturity) { - return error.num; - } + utils.arrayEach(resultIndexes, function(value) { + targetValues.push(targetFields[value]); + }); + targetValues = compact(targetValues); - // Return error if maturity is more than one year after settlement - if (maturity - settlement > 365 * 24 * 60 * 60 * 1000) { - return error.num; + return stats.STDEV.S(targetValues); +}; + +exports.DSTDEVP = function(database, field, criteria) { + // Return error if field is not a number and not a string + if (isNaN(field) && (typeof field !== "string")) { + return error.value; } + var resultIndexes = findResultIndex(database, criteria); + var targetFields = []; - // Return bond-equivalent yield - return (100 - price) * 360 / (price * dateTime.DAYS360(settlement, maturity, false)); -}; + if (typeof field === "string") { + var index = exports.FINDFIELD(database, field); + targetFields = utils.rest(database[index]); + } else { + targetFields = utils.rest(database[field]); + } -// TODO -exports.VDB = function() { - throw new Error('VDB is not implemented'); -}; + var targetValues = []; -// TODO needs better support for date -// exports.XIRR = function(values, dates, guess) { -// // Credits: algorithm inspired by Apache OpenOffice -// -// values = utils.parseNumberArray(utils.flatten(values)); -// dates = utils.parseDateArray(utils.flatten(dates)); -// guess = utils.parseNumber(guess); -// -// if (utils.anyIsError(values, dates, guess)) { -// return error.value; -// } -// -// // Calculates the resulting amount -// var irrResult = function(values, dates, rate) { -// var r = rate + 1; -// var result = values[0]; -// for (var i = 1; i < values.length; i++) { -// result += values[i] / Math.pow(r, dateTime.DAYS(dates[i], dates[0]) / 365); -// } -// return result; -// }; -// -// // Calculates the first derivation -// var irrResultDeriv = function(values, dates, rate) { -// var r = rate + 1; -// var result = 0; -// for (var i = 1; i < values.length; i++) { -// var frac = dateTime.DAYS(dates[i], dates[0]) / 365; -// result -= frac * values[i] / Math.pow(r, frac + 1); -// } -// return result; -// }; -// -// // Check that values contains at least one positive value and one negative value -// var positive = false; -// var negative = false; -// for (var i = 0; i < values.length; i++) { -// if (values[i] > 0) { -// positive = true; -// } -// if (values[i] < 0) { -// negative = true; -// } -// } -// -// // Return error if values does not contain at least one positive value and one negative value -// if (!positive || !negative) { -// return error.num; -// } -// -// // Initialize guess and resultRate -// guess = guess || 0.1; -// var resultRate = guess; -// -// // Set maximum epsilon for end of iteration -// var epsMax = 1e-10; -// -// // Implement Newton's method -// var newRate, epsRate, resultValue; -// var contLoop = true; -// do { -// resultValue = irrResult(values, dates, resultRate); -// newRate = resultRate - resultValue / irrResultDeriv(values, dates, resultRate); -// epsRate = Math.abs(newRate - resultRate); -// resultRate = newRate; -// contLoop = (epsRate > epsMax) && (Math.abs(resultValue) > epsMax); -// } while (contLoop); -// -// // Return internal rate of return -// return resultRate; -// }; + utils.arrayEach(resultIndexes, function(value) { + targetValues.push(targetFields[value]); + }); + targetValues = compact(targetValues); -exports.XNPV = function(rate, values, dates) { - rate = utils.parseNumber(rate); - values = utils.parseNumberArray(utils.flatten(values)); - dates = utils.parseDateArray(utils.flatten(dates)); - if (utils.anyIsError(rate, values, dates)) { + return stats.STDEV.P(targetValues); +}; + +exports.DSUM = function(database, field, criteria) { + // Return error if field is not a number and not a string + if (isNaN(field) && (typeof field !== "string")) { return error.value; } + var resultIndexes = findResultIndex(database, criteria); + var targetFields = []; - var result = 0; - for (var i = 0; i < values.length; i++) { - result += values[i] / Math.pow(1 + rate, dateTime.DAYS(dates[i], dates[0]) / 365); + if (typeof field === "string") { + var index = exports.FINDFIELD(database, field); + targetFields = utils.rest(database[index]); + } else { + targetFields = utils.rest(database[field]); } - return result; -}; -// TODO -exports.YIELD = function() { - throw new Error('YIELD is not implemented'); + var targetValues = []; + + utils.arrayEach(resultIndexes, function(value) { + targetValues.push(targetFields[value]); + }); + + return maths.SUM(targetValues); }; -// TODO -exports.YIELDDISC = function() { - throw new Error('YIELDDISC is not implemented'); +exports.DVAR = function(database, field, criteria) { + // Return error if field is not a number and not a string + if (isNaN(field) && (typeof field !== "string")) { + return error.value; + } + var resultIndexes = findResultIndex(database, criteria); + var targetFields = []; + + if (typeof field === "string") { + var index = exports.FINDFIELD(database, field); + targetFields = utils.rest(database[index]); + } else { + targetFields = utils.rest(database[field]); + } + var targetValues = []; + + utils.arrayEach(resultIndexes, function(value) { + targetValues.push(targetFields[value]); + }); + + return stats.VAR.S(targetValues); }; -// TODO -exports.YIELDMAT = function() { - throw new Error('YIELDMAT is not implemented'); +exports.DVARP = function(database, field, criteria) { + // Return error if field is not a number and not a string + if (isNaN(field) && (typeof field !== "string")) { + return error.value; + } + var resultIndexes = findResultIndex(database, criteria); + var targetFields = []; + + if (typeof field === "string") { + var index = exports.FINDFIELD(database, field); + targetFields = utils.rest(database[index]); + } else { + targetFields = utils.rest(database[field]); + } + var targetValues = []; + + utils.arrayEach(resultIndexes, function(value) { + targetValues.push(targetFields[value]); + }); + + return stats.VAR.P(targetValues); }; /***/ }), -/* 37 */ +/* 90 */ /***/ (function(module, exports, __webpack_require__) { var error = __webpack_require__(0); -var utils = __webpack_require__(2); +var utils = __webpack_require__(1); var information = __webpack_require__(7); exports.AND = function() { @@ -14598,2339 +17285,1393 @@ exports.SWITCH = function () { /***/ }), -/* 38 */ +/* 91 */ /***/ (function(module, exports, __webpack_require__) { var error = __webpack_require__(0); +var dateTime = __webpack_require__(8); +var utils = __webpack_require__(1); -exports.MATCH = function(lookupValue, lookupArray, matchType) { - if (!lookupValue && !lookupArray) { - return error.na; - } +function validDate(d) { + return d && d.getTime && !isNaN(d.getTime()); +} - if (arguments.length === 2) { - matchType = 1; - } - if (!(lookupArray instanceof Array)) { - return error.na; - } +function ensureDate(d) { + return (d instanceof Date)?d:new Date(d); +} - if (matchType !== -1 && matchType !== 0 && matchType !== 1) { - return error.na; - } - var index; - var indexValue; - for (var idx = 0; idx < lookupArray.length; idx++) { - if (matchType === 1) { - if (lookupArray[idx] === lookupValue) { - return idx + 1; - } else if (lookupArray[idx] < lookupValue) { - if (!indexValue) { - index = idx + 1; - indexValue = lookupArray[idx]; - } else if (lookupArray[idx] > indexValue) { - index = idx + 1; - indexValue = lookupArray[idx]; - } - } - } else if (matchType === 0) { - if (typeof lookupValue === 'string') { - lookupValue = lookupValue.replace(/\?/g, '.'); - if (lookupArray[idx].toLowerCase().match(lookupValue.toLowerCase())) { - return idx + 1; - } - } else { - if (lookupArray[idx] === lookupValue) { - return idx + 1; - } - } - } else if (matchType === -1) { - if (lookupArray[idx] === lookupValue) { - return idx + 1; - } else if (lookupArray[idx] > lookupValue) { - if (!indexValue) { - index = idx + 1; - indexValue = lookupArray[idx]; - } else if (lookupArray[idx] < indexValue) { - index = idx + 1; - indexValue = lookupArray[idx]; - } - } - } +exports.ACCRINT = function(issue, first, settlement, rate, par, frequency, basis) { + // Return error if either date is invalid + issue = ensureDate(issue); + first = ensureDate(first); + settlement = ensureDate(settlement); + if (!validDate(issue) || !validDate(first) || !validDate(settlement)) { + return error.value; } - return index ? index : error.na; -}; - -/***/ }), -/* 39 */ -/***/ (function(module, exports) { - -/*! - * numbro.js language configuration - * language : Czech - * locale: Czech Republic - * author : Anatoli Papirovski : https://github.com/apapirovski - */ -(function () { - 'use strict'; - - var language = { - langLocaleCode: 'cs-CZ', - cultureCode: 'cs-CZ', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: 'tis.', - million: 'mil.', - billion: 'b', - trillion: 't' - }, - ordinal: function () { - return '.'; - }, - currency: { - symbol: 'Kč', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; - - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); - - -/***/ }), -/* 40 */ -/***/ (function(module, exports) { - -/*! - * numbro.js language configuration - * language : Danish - * locale: Denmark - * author : Michael Storgaard : https://github.com/mstorgaard - */ -(function () { - 'use strict'; - - var language = { - langLocaleCode: 'da-DK', - cultureCode: 'da-DK', - delimiters: { - thousands: '.', - decimal: ',' - }, - abbreviations: { - thousand: 'k', - million: 'mio', - billion: 'mia', - trillion: 'b' - }, - ordinal: function () { - return '.'; - }, - currency: { - symbol: 'kr', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + // Return error if either rate or par are lower than or equal to zero + if (rate <= 0 || par <= 0) { + return error.num; + } - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); + // Return error if frequency is neither 1, 2, or 4 + if ([1, 2, 4].indexOf(frequency) === -1) { + return error.num; + } + // Return error if basis is neither 0, 1, 2, 3, or 4 + if ([0, 1, 2, 3, 4].indexOf(basis) === -1) { + return error.num; + } -/***/ }), -/* 41 */ -/***/ (function(module, exports) { + // Return error if settlement is before or equal to issue + if (settlement <= issue) { + return error.num; + } -/*! - * numbro.js language configuration - * language : German - * locale: Switzerland - * author : Michael Piefel : https://github.com/piefel (based on work from Marco Krage : https://github.com/sinky) - */ -(function () { - 'use strict'; + // Set default values + par = par || 0; + basis = basis || 0; - var language = { - langLocaleCode: 'de-CH', - cultureCode: 'de-CH', - delimiters: { - thousands: '\'', - decimal: '.' - }, - abbreviations: { - thousand: 'k', - million: 'm', - billion: 'b', - trillion: 't' - }, - ordinal: function () { - return '.'; - }, - currency: { - symbol: 'CHF', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + // Compute accrued interest + return par * rate * dateTime.YEARFRAC(issue, settlement, basis); +}; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +// TODO +exports.ACCRINTM = function() { + throw new Error('ACCRINTM is not implemented'); +}; +// TODO +exports.AMORDEGRC = function() { + throw new Error('AMORDEGRC is not implemented'); +}; -/***/ }), -/* 42 */ -/***/ (function(module, exports) { +// TODO +exports.AMORLINC = function() { + throw new Error('AMORLINC is not implemented'); +}; -/*! - * numbro.js language configuration - * language : German - * locale: Germany - * author : Marco Krage : https://github.com/sinky - * - * Generally useful in Germany, Austria, Luxembourg, Belgium - */ -(function () { - 'use strict'; +// TODO +exports.COUPDAYBS = function() { + throw new Error('COUPDAYBS is not implemented'); +}; - var language = { - langLocaleCode: 'de-DE', - cultureCode: 'de-DE', - delimiters: { - thousands: '.', - decimal: ',' - }, - abbreviations: { - thousand: 'k', - million: 'm', - billion: 'b', - trillion: 't' - }, - ordinal: function () { - return '.'; - }, - currency: { - symbol: '€', - position: 'postfix', - spaceSeparated: true - }, - defaults: { - currencyFormat: ',4' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; +// TODO +exports.COUPDAYS = function() { + throw new Error('COUPDAYS is not implemented'); +}; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +// TODO +exports.COUPDAYSNC = function() { + throw new Error('COUPDAYSNC is not implemented'); +}; +// TODO +exports.COUPNCD = function() { + throw new Error('COUPNCD is not implemented'); +}; -/***/ }), -/* 43 */ -/***/ (function(module, exports) { +// TODO +exports.COUPNUM = function() { + throw new Error('COUPNUM is not implemented'); +}; -/*! - * numbro.js language configuration - * language : English - * locale: Australia - * author : Benedikt Huss : https://github.com/ben305 - */ -(function () { - 'use strict'; +// TODO +exports.COUPPCD = function() { + throw new Error('COUPPCD is not implemented'); +}; - var language = { - langLocaleCode: 'en-AU', - cultureCode: 'en-AU', - delimiters: { - thousands: ',', - decimal: '.' - }, - abbreviations: { - thousand: 'k', - million: 'm', - billion: 'b', - trillion: 't' - }, - ordinal: function (number) { - var b = number % 10; - return (~~ (number % 100 / 10) === 1) ? 'th' : - (b === 1) ? 'st' : - (b === 2) ? 'nd' : - (b === 3) ? 'rd' : 'th'; - }, - currency: { - symbol: '$', - position: 'prefix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: '$ ,0.00', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: '$ ,0' - } - }; +exports.CUMIPMT = function(rate, periods, value, start, end, type) { + // Credits: algorithm inspired by Apache OpenOffice + // Credits: Hannes Stiebitzhofer for the translations of function and variable names + // Requires exports.FV() and exports.PMT() from exports.js [http://stoic.com/exports/] - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; + rate = utils.parseNumber(rate); + periods = utils.parseNumber(periods); + value = utils.parseNumber(value); + if (utils.anyIsError(rate, periods, value)) { + return error.value; + } + + // Return error if either rate, periods, or value are lower than or equal to zero + if (rate <= 0 || periods <= 0 || value <= 0) { + return error.num; + } + + // Return error if start < 1, end < 1, or start > end + if (start < 1 || end < 1 || start > end) { + return error.num; + } + + // Return error if type is neither 0 nor 1 + if (type !== 0 && type !== 1) { + return error.num; + } + + // Compute cumulative interest + var payment = exports.PMT(rate, periods, value, 0, type); + var interest = 0; + + if (start === 1) { + if (type === 0) { + interest = -value; + start++; } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); + } + + for (var i = start; i <= end; i++) { + if (type === 1) { + interest += exports.FV(rate, i - 2, payment, value, 1) - payment; + } else { + interest += exports.FV(rate, i - 1, payment, value, 0); } -}.call(typeof window === 'undefined' ? this : window)); + } + interest *= rate; + // Return cumulative interest + return interest; +}; -/***/ }), -/* 44 */ -/***/ (function(module, exports) { +exports.CUMPRINC = function(rate, periods, value, start, end, type) { + // Credits: algorithm inspired by Apache OpenOffice + // Credits: Hannes Stiebitzhofer for the translations of function and variable names -/*! - * numbro.js language configuration - * language : English - * locale: United Kingdom of Great Britain and Northern Ireland - * author : Dan Ristic : https://github.com/dristic - */ -(function () { - 'use strict'; + rate = utils.parseNumber(rate); + periods = utils.parseNumber(periods); + value = utils.parseNumber(value); + if (utils.anyIsError(rate, periods, value)) { + return error.value; + } - var language = { - langLocaleCode: 'en-GB', - cultureCode: 'en-GB', - delimiters: { - thousands: ',', - decimal: '.' - }, - abbreviations: { - thousand: 'k', - million: 'm', - billion: 'b', - trillion: 't' - }, - ordinal: function (number) { - var b = number % 10; - return (~~ (number % 100 / 10) === 1) ? 'th' : - (b === 1) ? 'st' : - (b === 2) ? 'nd' : - (b === 3) ? 'rd' : 'th'; - }, - currency: { - symbol: '£', - position: 'prefix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: '$ ,0.00', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: '$ ,0' - } - }; + // Return error if either rate, periods, or value are lower than or equal to zero + if (rate <= 0 || periods <= 0 || value <= 0) { + return error.num; + } - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; + // Return error if start < 1, end < 1, or start > end + if (start < 1 || end < 1 || start > end) { + return error.num; + } + + // Return error if type is neither 0 nor 1 + if (type !== 0 && type !== 1) { + return error.num; + } + + // Compute cumulative principal + var payment = exports.PMT(rate, periods, value, 0, type); + var principal = 0; + if (start === 1) { + if (type === 0) { + principal = payment + value * rate; + } else { + principal = payment; } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); + start++; + } + for (var i = start; i <= end; i++) { + if (type > 0) { + principal += payment - (exports.FV(rate, i - 2, payment, value, 1) - payment) * rate; + } else { + principal += payment - exports.FV(rate, i - 1, payment, value, 0) * rate; } -}.call(typeof window === 'undefined' ? this : window)); + } + // Return cumulative principal + return principal; +}; -/***/ }), -/* 45 */ -/***/ (function(module, exports) { +exports.DB = function(cost, salvage, life, period, month) { + // Initialize month + month = (month === undefined) ? 12 : month; -/*! - * numbro.js language configuration - * language : English - * locale: New Zealand - * author : Benedikt Huss : https://github.com/ben305 - */ -(function () { - 'use strict'; + cost = utils.parseNumber(cost); + salvage = utils.parseNumber(salvage); + life = utils.parseNumber(life); + period = utils.parseNumber(period); + month = utils.parseNumber(month); + if (utils.anyIsError(cost, salvage, life, period, month)) { + return error.value; + } - var language = { - langLocaleCode: 'en-NZ', - cultureCode: 'en-NZ', - delimiters: { - thousands: ',', - decimal: '.' - }, - abbreviations: { - thousand: 'k', - million: 'm', - billion: 'b', - trillion: 't' - }, - ordinal: function (number) { - var b = number % 10; - return (~~ (number % 100 / 10) === 1) ? 'th' : - (b === 1) ? 'st' : - (b === 2) ? 'nd' : - (b === 3) ? 'rd' : 'th'; - }, - currency: { - symbol: '$', - position: 'prefix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: '$ ,0.00', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: '$ ,0' - } - }; + // Return error if any of the parameters is negative + if (cost < 0 || salvage < 0 || life < 0 || period < 0) { + return error.num; + } - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); + // Return error if month is not an integer between 1 and 12 + if ([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12].indexOf(month) === -1) { + return error.num; + } + // Return error if period is greater than life + if (period > life) { + return error.num; + } -/***/ }), -/* 46 */ -/***/ (function(module, exports) { + // Return 0 (zero) if salvage is greater than or equal to cost + if (salvage >= cost) { + return 0; + } -/*! - * numbro.js language configuration - * language : English - * locale: South Africa - * author : Stewart Scott https://github.com/stewart42 - */ -(function () { - 'use strict'; + // Rate is rounded to three decimals places + var rate = (1 - Math.pow(salvage / cost, 1 / life)).toFixed(3); - var language = { - langLocaleCode: 'en-ZA', - cultureCode: 'en-ZA', - delimiters: { - thousands: ',', - decimal: '.' - }, - abbreviations: { - thousand: 'k', - million: 'm', - billion: 'b', - trillion: 't' - }, - ordinal: function (number) { - var b = number % 10; - return (~~ (number % 100 / 10) === 1) ? 'th' : - (b === 1) ? 'st' : - (b === 2) ? 'nd' : - (b === 3) ? 'rd' : 'th'; - }, - currency: { - symbol: 'R', - position: 'prefix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: '$ ,0.00', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: '$ ,0' - } - }; + // Compute initial depreciation + var initial = cost * rate * month / 12; + + // Compute total depreciation + var total = initial; + var current = 0; + var ceiling = (period === life) ? life - 1 : period; + for (var i = 2; i <= ceiling; i++) { + current = (cost - total) * rate; + total += current; + } + + // Depreciation for the first and last periods are special cases + if (period === 1) { + // First period + return initial; + } else if (period === life) { + // Last period + return (cost - total) * rate; + } else { + return current; + } +}; + +exports.DDB = function(cost, salvage, life, period, factor) { + // Initialize factor + factor = (factor === undefined) ? 2 : factor; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); + cost = utils.parseNumber(cost); + salvage = utils.parseNumber(salvage); + life = utils.parseNumber(life); + period = utils.parseNumber(period); + factor = utils.parseNumber(factor); + if (utils.anyIsError(cost, salvage, life, period, factor)) { + return error.value; + } + // Return error if any of the parameters is negative or if factor is null + if (cost < 0 || salvage < 0 || life < 0 || period < 0 || factor <= 0) { + return error.num; + } -/***/ }), -/* 47 */ -/***/ (function(module, exports) { + // Return error if period is greater than life + if (period > life) { + return error.num; + } -/*! - * numbro.js language configuration - * language : Spanish - * locale: Argentina - * author : Hernan Garcia : https://github.com/hgarcia - */ -(function () { - 'use strict'; + // Return 0 (zero) if salvage is greater than or equal to cost + if (salvage >= cost) { + return 0; + } - var language = { - langLocaleCode: 'es-AR', - cultureCode: 'es-AR', - delimiters: { - thousands: '.', - decimal: ',' - }, - abbreviations: { - thousand: 'k', - million: 'mm', - billion: 'b', - trillion: 't' - }, - ordinal: function (number) { - var b = number % 10; - return (b === 1 || b === 3) ? 'er' : - (b === 2) ? 'do' : - (b === 7 || b === 0) ? 'mo' : - (b === 8) ? 'vo' : - (b === 9) ? 'no' : 'to'; - }, - currency: { - symbol: '$', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + // Compute depreciation + var total = 0; + var current = 0; + for (var i = 1; i <= period; i++) { + current = Math.min((cost - total) * (factor / life), (cost - salvage - total)); + total += current; + } - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); + // Return depreciation + return current; +}; +// TODO +exports.DISC = function() { + throw new Error('DISC is not implemented'); +}; -/***/ }), -/* 48 */ -/***/ (function(module, exports) { +exports.DOLLARDE = function(dollar, fraction) { + // Credits: algorithm inspired by Apache OpenOffice -/*! - * numbro.js language configuration - * language : Spanish - * locale: Spain - * author : Hernan Garcia : https://github.com/hgarcia - */ -(function () { - 'use strict'; + dollar = utils.parseNumber(dollar); + fraction = utils.parseNumber(fraction); + if (utils.anyIsError(dollar, fraction)) { + return error.value; + } - var language = { - langLocaleCode: 'es-ES', - cultureCode: 'es-ES', - delimiters: { - thousands: '.', - decimal: ',' - }, - abbreviations: { - thousand: 'k', - million: 'mm', - billion: 'b', - trillion: 't' - }, - ordinal: function (number) { - var b = number % 10; - return (b === 1 || b === 3) ? 'er' : - (b === 2) ? 'do' : - (b === 7 || b === 0) ? 'mo' : - (b === 8) ? 'vo' : - (b === 9) ? 'no' : 'to'; - }, - currency: { - symbol: '€', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + // Return error if fraction is negative + if (fraction < 0) { + return error.num; + } - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); + // Return error if fraction is greater than or equal to 0 and less than 1 + if (fraction >= 0 && fraction < 1) { + return error.div0; + } + // Truncate fraction if it is not an integer + fraction = parseInt(fraction, 10); -/***/ }), -/* 49 */ -/***/ (function(module, exports) { + // Compute integer part + var result = parseInt(dollar, 10); -/*! - * numbro.js language configuration - * language : Estonian - * locale: Estonia - * author : Illimar Tambek : https://github.com/ragulka - * - * Note: in Estonian, abbreviations are always separated - * from numbers with a space - */ -(function () { - 'use strict'; + // Add decimal part + result += (dollar % 1) * Math.pow(10, Math.ceil(Math.log(fraction) / Math.LN10)) / fraction; - var language = { - langLocaleCode: 'et-EE', - cultureCode: 'et-EE', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: ' tuh', - million: ' mln', - billion: ' mld', - trillion: ' trl' - }, - ordinal: function () { - return '.'; - }, - currency: { - symbol: '€', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + // Round result + var power = Math.pow(10, Math.ceil(Math.log(fraction) / Math.LN2) + 1); + result = Math.round(result * power) / power; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); + // Return converted dollar price + return result; +}; + +exports.DOLLARFR = function(dollar, fraction) { + // Credits: algorithm inspired by Apache OpenOffice + + dollar = utils.parseNumber(dollar); + fraction = utils.parseNumber(fraction); + if (utils.anyIsError(dollar, fraction)) { + return error.value; + } + + // Return error if fraction is negative + if (fraction < 0) { + return error.num; + } + + // Return error if fraction is greater than or equal to 0 and less than 1 + if (fraction >= 0 && fraction < 1) { + return error.div0; + } + + // Truncate fraction if it is not an integer + fraction = parseInt(fraction, 10); + // Compute integer part + var result = parseInt(dollar, 10); -/***/ }), -/* 50 */ -/***/ (function(module, exports) { + // Add decimal part + result += (dollar % 1) * Math.pow(10, -Math.ceil(Math.log(fraction) / Math.LN10)) * fraction; -/*! - * numbro.js language configuration - * language : Farsi - * locale: Iran - * author : neo13 : https://github.com/neo13 - */ -(function () { - 'use strict'; + // Return converted dollar price + return result; +}; - var language = { - langLocaleCode: 'fa-IR', - cultureCode: 'fa-IR', - delimiters: { - thousands: '،', - decimal: '.' - }, - abbreviations: { - thousand: 'هزار', - million: 'میلیون', - billion: 'میلیارد', - trillion: 'تریلیون' - }, - ordinal: function () { - return 'ام'; - }, - currency: { - symbol: '﷼' - } - }; +// TODO +exports.DURATION = function() { + throw new Error('DURATION is not implemented'); +}; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +exports.EFFECT = function(rate, periods) { + rate = utils.parseNumber(rate); + periods = utils.parseNumber(periods); + if (utils.anyIsError(rate, periods)) { + return error.value; + } + // Return error if rate <=0 or periods < 1 + if (rate <= 0 || periods < 1) { + return error.num; + } -/***/ }), -/* 51 */ -/***/ (function(module, exports) { + // Truncate periods if it is not an integer + periods = parseInt(periods, 10); -/*! - * numbro.js language configuration - * language : Finnish - * locale: Finland - * author : Sami Saada : https://github.com/samitheberber - */ -(function () { - 'use strict'; + // Return effective annual interest rate + return Math.pow(1 + rate / periods, periods) - 1; +}; - var language = { - langLocaleCode: 'fi-FI', - cultureCode: 'fi-FI', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: 'k', - million: 'M', - billion: 'G', - trillion: 'T' - }, - ordinal: function () { - return '.'; - }, - currency: { - symbol: '€', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; +exports.FV = function(rate, periods, payment, value, type) { + // Credits: algorithm inspired by Apache OpenOffice - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); + value = value || 0; + type = type || 0; + + rate = utils.parseNumber(rate); + periods = utils.parseNumber(periods); + payment = utils.parseNumber(payment); + value = utils.parseNumber(value); + type = utils.parseNumber(type); + if (utils.anyIsError(rate, periods, payment, value, type)) { + return error.value; + } + // Return future value + var result; + if (rate === 0) { + result = value + payment * periods; + } else { + var term = Math.pow(1 + rate, periods); + if (type === 1) { + result = value * term + payment * (1 + rate) * (term - 1) / rate; + } else { + result = value * term + payment * (term - 1) / rate; + } + } + return -result; +}; -/***/ }), -/* 52 */ -/***/ (function(module, exports) { +exports.FVSCHEDULE = function(principal, schedule) { + principal = utils.parseNumber(principal); + schedule = utils.parseNumberArray(utils.flatten(schedule)); + if (utils.anyIsError(principal, schedule)) { + return error.value; + } -/*! - * numbro.js language configuration - * language : Filipino (Pilipino) - * locale: Philippines - * author : Michael Abadilla : https://github.com/mjmaix - */ -(function () { - 'use strict'; + var n = schedule.length; + var future = principal; - var language = { - langLocaleCode: 'fil-PH', - cultureCode: 'fil-PH', - delimiters: { - thousands: ',', - decimal: '.' - }, - abbreviations: { - thousand: 'k', - million: 'm', - billion: 'b', - trillion: 't' - }, - ordinal: function (number) { - var b = number % 10; - return (~~ (number % 100 / 10) === 1) ? 'th' : - (b === 1) ? 'st' : - (b === 2) ? 'nd' : - (b === 3) ? 'rd' : 'th'; - }, - currency: { - symbol: '₱' - } - }; + // Apply all interests in schedule + for (var i = 0; i < n; i++) { + // Apply scheduled interest + future *= 1 + schedule[i]; + } - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); + // Return future value + return future; +}; +// TODO +exports.INTRATE = function() { + throw new Error('INTRATE is not implemented'); +}; -/***/ }), -/* 53 */ -/***/ (function(module, exports) { +exports.IPMT = function(rate, period, periods, present, future, type) { + // Credits: algorithm inspired by Apache OpenOffice -/*! - * numbro.js language configuration - * language : French - * locale: Canada - * author : Léo Renaud-Allaire : https://github.com/renaudleo - */ -(function () { - 'use strict'; + future = future || 0; + type = type || 0; - var language = { - langLocaleCode: 'fr-CA', - cultureCode: 'fr-CA', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: 'k', - million: 'M', - billion: 'G', - trillion: 'T' - }, - ordinal : function (number) { - return number === 1 ? 'er' : 'ème'; - }, - currency: { - symbol: '$', - position: 'postfix', - spaceSeparated : true - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: '$ ,0.00', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: '$ ,0' - } - }; + rate = utils.parseNumber(rate); + period = utils.parseNumber(period); + periods = utils.parseNumber(periods); + present = utils.parseNumber(present); + future = utils.parseNumber(future); + type = utils.parseNumber(type); + if (utils.anyIsError(rate, period, periods, present, future, type)) { + return error.value; + } - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; + // Compute payment + var payment = exports.PMT(rate, periods, present, future, type); + + // Compute interest + var interest; + if (period === 1) { + if (type === 1) { + interest = 0; + } else { + interest = -present; } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); + } else { + if (type === 1) { + interest = exports.FV(rate, period - 2, payment, present, 1) - payment; + } else { + interest = exports.FV(rate, period - 1, payment, present, 0); } -}.call(typeof window === 'undefined' ? this : window)); + } + // Return interest + return interest * rate; +}; -/***/ }), -/* 54 */ -/***/ (function(module, exports) { +exports.IRR = function(values, guess) { + // Credits: algorithm inspired by Apache OpenOffice -/*! - * numbro.js language configuration - * language : French - * locale: Switzerland - * author : Adam Draper : https://github.com/adamwdraper - */ -(function () { - 'use strict'; + guess = guess || 0; - var language = { - langLocaleCode: 'fr-CH', - cultureCode: 'fr-CH', - delimiters: { - thousands: '\'', - decimal: '.' - }, - abbreviations: { - thousand: 'k', - million: 'm', - billion: 'b', - trillion: 't' - }, - ordinal : function (number) { - return number === 1 ? 'er' : 'ème'; - }, - currency: { - symbol: 'CHF', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + values = utils.parseNumberArray(utils.flatten(values)); + guess = utils.parseNumber(guess); + if (utils.anyIsError(values, guess)) { + return error.value; + } - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; + // Calculates the resulting amount + var irrResult = function(values, dates, rate) { + var r = rate + 1; + var result = values[0]; + for (var i = 1; i < values.length; i++) { + result += values[i] / Math.pow(r, (dates[i] - dates[0]) / 365); } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); + return result; + }; + + // Calculates the first derivation + var irrResultDeriv = function(values, dates, rate) { + var r = rate + 1; + var result = 0; + for (var i = 1; i < values.length; i++) { + var frac = (dates[i] - dates[0]) / 365; + result -= frac * values[i] / Math.pow(r, frac + 1); } -}.call(typeof window === 'undefined' ? this : window)); + return result; + }; + // Initialize dates and check that values contains at least one positive value and one negative value + var dates = []; + var positive = false; + var negative = false; + for (var i = 0; i < values.length; i++) { + dates[i] = (i === 0) ? 0 : dates[i - 1] + 365; + if (values[i] > 0) { + positive = true; + } + if (values[i] < 0) { + negative = true; + } + } -/***/ }), -/* 55 */ -/***/ (function(module, exports) { + // Return error if values does not contain at least one positive value and one negative value + if (!positive || !negative) { + return error.num; + } -/*! - * numbro.js language configuration - * language : French - * locale: France - * author : Adam Draper : https://github.com/adamwdraper - */ -(function () { - 'use strict'; + // Initialize guess and resultRate + guess = (guess === undefined) ? 0.1 : guess; + var resultRate = guess; - var language = { - langLocaleCode: 'fr-FR', - cultureCode: 'fr-FR', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: 'k', - million: 'm', - billion: 'b', - trillion: 't' - }, - ordinal : function (number) { - return number === 1 ? 'er' : 'ème'; - }, - currency: { - symbol: '€', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + // Set maximum epsilon for end of iteration + var epsMax = 1e-10; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); + // Implement Newton's method + var newRate, epsRate, resultValue; + var contLoop = true; + do { + resultValue = irrResult(values, dates, resultRate); + newRate = resultRate - resultValue / irrResultDeriv(values, dates, resultRate); + epsRate = Math.abs(newRate - resultRate); + resultRate = newRate; + contLoop = (epsRate > epsMax) && (Math.abs(resultValue) > epsMax); + } while (contLoop); + // Return internal rate of return + return resultRate; +}; -/***/ }), -/* 56 */ -/***/ (function(module, exports) { +exports.ISPMT = function(rate, period, periods, value) { + rate = utils.parseNumber(rate); + period = utils.parseNumber(period); + periods = utils.parseNumber(periods); + value = utils.parseNumber(value); + if (utils.anyIsError(rate, period, periods, value)) { + return error.value; + } -/*! - * numbro.js language configuration - * language : Hebrew - * locale : IL - * author : Eli Zehavi : https://github.com/eli-zehavi - */ -(function () { - 'use strict'; + // Return interest + return value * rate * (period / periods - 1); +}; - var language = { - langLocaleCode: 'he-IL', - cultureCode: 'he-IL', - delimiters: { - thousands: ',', - decimal: '.' - }, - abbreviations: { - thousand: 'אלף', - million: 'מליון', - billion: 'בליון', - trillion: 'טריליון' - }, - currency: { - symbol: '₪', - position: 'prefix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: '₪ ,0.00', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: '₪ ,0' - } - }; +// TODO +exports.MDURATION = function() { + throw new Error('MDURATION is not implemented'); +}; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); +exports.MIRR = function(values, finance_rate, reinvest_rate) { + values = utils.parseNumberArray(utils.flatten(values)); + finance_rate = utils.parseNumber(finance_rate); + reinvest_rate = utils.parseNumber(reinvest_rate); + if (utils.anyIsError(values, finance_rate, reinvest_rate)) { + return error.value; + } + + // Initialize number of values + var n = values.length; + + // Lookup payments (negative values) and incomes (positive values) + var payments = []; + var incomes = []; + for (var i = 0; i < n; i++) { + if (values[i] < 0) { + payments.push(values[i]); + } else { + incomes.push(values[i]); } -}.call(typeof window === 'undefined' ? this : window)); + } + // Return modified internal rate of return + var num = -exports.NPV(reinvest_rate, incomes) * Math.pow(1 + reinvest_rate, n - 1); + var den = exports.NPV(finance_rate, payments) * (1 + finance_rate); + return Math.pow(num / den, 1 / (n - 1)) - 1; +}; +exports.NOMINAL = function(rate, periods) { + rate = utils.parseNumber(rate); + periods = utils.parseNumber(periods); + if (utils.anyIsError(rate, periods)) { + return error.value; + } -/***/ }), -/* 57 */ -/***/ (function(module, exports) { + // Return error if rate <=0 or periods < 1 + if (rate <= 0 || periods < 1) { + return error.num; + } -/*! - * numbro.js language configuration - * language : Hungarian - * locale: Hungary - * author : Peter Bakondy : https://github.com/pbakondy - */ -(function () { - 'use strict'; + // Truncate periods if it is not an integer + periods = parseInt(periods, 10); - var language = { - langLocaleCode: 'hu-HU', - cultureCode: 'hu-HU', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: 'E', // ezer - million: 'M', // millió - billion: 'Mrd', // milliárd - trillion: 'T' // trillió - }, - ordinal: function () { - return '.'; - }, - currency: { - symbol: ' Ft', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + // Return nominal annual interest rate + return (Math.pow(rate + 1, 1 / periods) - 1) * periods; +}; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +exports.NPER = function(rate, payment, present, future, type) { + type = (type === undefined) ? 0 : type; + future = (future === undefined) ? 0 : future; + rate = utils.parseNumber(rate); + payment = utils.parseNumber(payment); + present = utils.parseNumber(present); + future = utils.parseNumber(future); + type = utils.parseNumber(type); + if (utils.anyIsError(rate, payment, present, future, type)) { + return error.value; + } -/***/ }), -/* 58 */ -/***/ (function(module, exports, __webpack_require__) { + // Return number of periods + var num = payment * (1 + rate * type) - future * rate; + var den = (present * rate + payment * (1 + rate * type)); + return Math.log(num / den) / Math.log(1 + rate); +}; -exports['cs-CZ'] = __webpack_require__(39); -exports['da-DK'] = __webpack_require__(40); -exports['de-CH'] = __webpack_require__(41); -exports['de-DE'] = __webpack_require__(42); -exports['en-AU'] = __webpack_require__(43); -exports['en-GB'] = __webpack_require__(44); -exports['en-NZ'] = __webpack_require__(45); -exports['en-ZA'] = __webpack_require__(46); -exports['es-AR'] = __webpack_require__(47); -exports['es-ES'] = __webpack_require__(48); -exports['et-EE'] = __webpack_require__(49); -exports['fa-IR'] = __webpack_require__(50); -exports['fi-FI'] = __webpack_require__(51); -exports['fil-PH'] = __webpack_require__(52); -exports['fr-CA'] = __webpack_require__(53); -exports['fr-CH'] = __webpack_require__(54); -exports['fr-FR'] = __webpack_require__(55); -exports['he-IL'] = __webpack_require__(56); -exports['hu-HU'] = __webpack_require__(57); -exports['it-IT'] = __webpack_require__(59); -exports['ja-JP'] = __webpack_require__(60); -exports['ko-KR'] = __webpack_require__(61); -exports['lv-LV'] = __webpack_require__(62); -exports['nb-NO'] = __webpack_require__(63); -exports['nl-BE'] = __webpack_require__(64); -exports['nl-NL'] = __webpack_require__(65); -exports['pl-PL'] = __webpack_require__(66); -exports['pt-BR'] = __webpack_require__(67); -exports['pt-PT'] = __webpack_require__(68); -exports['ru-RU'] = __webpack_require__(69); -exports['ru-UA'] = __webpack_require__(70); -exports['sk-SK'] = __webpack_require__(71); -exports['sv-SE'] = __webpack_require__(72); -exports['th-TH'] = __webpack_require__(73); -exports['tr-TR'] = __webpack_require__(74); -exports['uk-UA'] = __webpack_require__(75); -exports['zh-CN'] = __webpack_require__(76); -exports['zh-TW'] = __webpack_require__(77); +exports.NPV = function() { + var args = utils.parseNumberArray(utils.flatten(arguments)); + if (args instanceof Error) { + return args; + } -/***/ }), -/* 59 */ -/***/ (function(module, exports) { + // Lookup rate + var rate = args[0]; -/*! - * numbro.js language configuration - * language : Italian - * locale: Italy - * author : Giacomo Trombi : http://cinquepunti.it - */ -(function () { - 'use strict'; + // Initialize net present value + var value = 0; - var language = { - langLocaleCode: 'it-IT', - cultureCode: 'it-IT', - delimiters: { - thousands: '.', - decimal: ',' - }, - abbreviations: { - thousand: 'mila', - million: 'mil', - billion: 'b', - trillion: 't' - }, - ordinal: function () { - return 'º'; - }, - currency: { - symbol: '€', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + // Loop on all values + for (var j = 1; j < args.length; j++) { + value += args[j] / Math.pow(1 + rate, j); + } - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); + // Return net present value + return value; +}; +// TODO +exports.ODDFPRICE = function() { + throw new Error('ODDFPRICE is not implemented'); +}; -/***/ }), -/* 60 */ -/***/ (function(module, exports) { +// TODO +exports.ODDFYIELD = function() { + throw new Error('ODDFYIELD is not implemented'); +}; -/*! - * numbro.js language configuration - * language : Japanese - * locale: Japan - * author : teppeis : https://github.com/teppeis - */ -(function () { - 'use strict'; +// TODO +exports.ODDLPRICE = function() { + throw new Error('ODDLPRICE is not implemented'); +}; - var language = { - langLocaleCode: 'ja-JP', - cultureCode: 'ja-JP', - delimiters: { - thousands: ',', - decimal: '.' - }, - abbreviations: { - thousand: '千', - million: '百万', - billion: '十億', - trillion: '兆' - }, - ordinal: function () { - return '.'; - }, - currency: { - symbol: '¥', - position: 'prefix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: '$ ,0.00', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: '$ ,0' - } - }; +// TODO +exports.ODDLYIELD = function() { + throw new Error('ODDLYIELD is not implemented'); +}; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +exports.PDURATION = function(rate, present, future) { + rate = utils.parseNumber(rate); + present = utils.parseNumber(present); + future = utils.parseNumber(future); + if (utils.anyIsError(rate, present, future)) { + return error.value; + } + + // Return error if rate <=0 + if (rate <= 0) { + return error.num; + } + // Return number of periods + return (Math.log(future) - Math.log(present)) / Math.log(1 + rate); +}; -/***/ }), -/* 61 */ -/***/ (function(module, exports) { +exports.PMT = function(rate, periods, present, future, type) { + // Credits: algorithm inspired by Apache OpenOffice -/*! - * numbro.js language configuration - * language : Korean - * author (numbro.js Version): Randy Wilander : https://github.com/rocketedaway - * author (numeral.js Version) : Rich Daley : https://github.com/pedantic-git - */ -(function () { - 'use strict'; + future = future || 0; + type = type || 0; - var language = { - langLocaleCode: 'ko-KR', - cultureCode: 'ko-KR', - delimiters: { - thousands: ',', - decimal: '.' - }, - abbreviations: { - thousand: '천', - million: '백만', - billion: '십억', - trillion: '일조' - }, - ordinal: function () { - return '.'; - }, - currency: { - symbol: '₩' - } - }; + rate = utils.parseNumber(rate); + periods = utils.parseNumber(periods); + present = utils.parseNumber(present); + future = utils.parseNumber(future); + type = utils.parseNumber(type); + if (utils.anyIsError(rate, periods, present, future, type)) { + return error.value; + } - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); + // Return payment + var result; + if (rate === 0) { + result = (present + future) / periods; + } else { + var term = Math.pow(1 + rate, periods); + if (type === 1) { + result = (future * rate / (term - 1) + present * rate / (1 - 1 / term)) / (1 + rate); + } else { + result = future * rate / (term - 1) + present * rate / (1 - 1 / term); } -}.call(typeof window === 'undefined' ? this : window)); - + } + return -result; +}; -/***/ }), -/* 62 */ -/***/ (function(module, exports) { +exports.PPMT = function(rate, period, periods, present, future, type) { + future = future || 0; + type = type || 0; -/*! - * numbro.js language configuration - * language : Latvian - * locale: Latvia - * author : Lauris Bukšis-Haberkorns : https://github.com/Lafriks - */ -(function () { - 'use strict'; + rate = utils.parseNumber(rate); + periods = utils.parseNumber(periods); + present = utils.parseNumber(present); + future = utils.parseNumber(future); + type = utils.parseNumber(type); + if (utils.anyIsError(rate, periods, present, future, type)) { + return error.value; + } - var language = { - langLocaleCode: 'lv-LV', - cultureCode: 'lv-LV', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: ' tūkst.', - million: ' milj.', - billion: ' mljrd.', - trillion: ' trilj.' - }, - ordinal: function () { - return '.'; - }, - currency: { - symbol: '€', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); + return exports.PMT(rate, periods, present, future, type) - exports.IPMT(rate, period, periods, present, future, type); +}; +// TODO +exports.PRICE = function() { + throw new Error('PRICE is not implemented'); +}; -/***/ }), -/* 63 */ -/***/ (function(module, exports) { +// TODO +exports.PRICEDISC = function() { + throw new Error('PRICEDISC is not implemented'); +}; -/*! - * numbro.js language configuration - * language: Norwegian Bokmål - * locale: Norway - * author : Benjamin Van Ryseghem - */ -(function() { - 'use strict'; +// TODO +exports.PRICEMAT = function() { + throw new Error('PRICEMAT is not implemented'); +}; - var language = { - langLocaleCode: 'nb-NO', - cultureCode: 'nb-NO', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: 't', - million: 'M', - billion: 'md', - trillion: 't' - }, - currency: { - symbol: 'kr', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; +exports.PV = function(rate, periods, payment, future, type) { + future = future || 0; + type = type || 0; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); + rate = utils.parseNumber(rate); + periods = utils.parseNumber(periods); + payment = utils.parseNumber(payment); + future = utils.parseNumber(future); + type = utils.parseNumber(type); + if (utils.anyIsError(rate, periods, payment, future, type)) { + return error.value; + } + // Return present value + if (rate === 0) { + return -payment * periods - future; + } else { + return (((1 - Math.pow(1 + rate, periods)) / rate) * payment * (1 + rate * type) - future) / Math.pow(1 + rate, periods); + } +}; -/***/ }), -/* 64 */ -/***/ (function(module, exports) { +exports.RATE = function(periods, payment, present, future, type, guess) { + // Credits: rabugento -/*! - * numbro.js language configuration - * language : Dutch - * locale: Belgium - * author : Dieter Luypaert : https://github.com/moeriki - */ -(function () { - 'use strict'; + guess = (guess === undefined) ? 0.01 : guess; + future = (future === undefined) ? 0 : future; + type = (type === undefined) ? 0 : type; - var language = { - langLocaleCode: 'nl-BE', - cultureCode: 'nl-BE', - delimiters: { - thousands: ' ', - decimal : ',' - }, - abbreviations: { - thousand : 'k', - million : 'mln', - billion : 'mld', - trillion : 'bln' - }, - ordinal : function (number) { - var remainder = number % 100; - return (number !== 0 && remainder <= 1 || remainder === 8 || remainder >= 20) ? 'ste' : 'de'; - }, - currency: { - symbol: '€', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + periods = utils.parseNumber(periods); + payment = utils.parseNumber(payment); + present = utils.parseNumber(present); + future = utils.parseNumber(future); + type = utils.parseNumber(type); + guess = utils.parseNumber(guess); + if (utils.anyIsError(periods, payment, present, future, type, guess)) { + return error.value; + } - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); + // Set maximum epsilon for end of iteration + var epsMax = 1e-10; + // Set maximum number of iterations + var iterMax = 50; -/***/ }), -/* 65 */ -/***/ (function(module, exports) { + // Implement Newton's method + var y, y0, y1, x0, x1 = 0, + f = 0, + i = 0; + var rate = guess; + if (Math.abs(rate) < epsMax) { + y = present * (1 + periods * rate) + payment * (1 + rate * type) * periods + future; + } else { + f = Math.exp(periods * Math.log(1 + rate)); + y = present * f + payment * (1 / rate + type) * (f - 1) + future; + } + y0 = present + payment * periods + future; + y1 = present * f + payment * (1 / rate + type) * (f - 1) + future; + i = x0 = 0; + x1 = rate; + while ((Math.abs(y0 - y1) > epsMax) && (i < iterMax)) { + rate = (y1 * x0 - y0 * x1) / (y1 - y0); + x0 = x1; + x1 = rate; + if (Math.abs(rate) < epsMax) { + y = present * (1 + periods * rate) + payment * (1 + rate * type) * periods + future; + } else { + f = Math.exp(periods * Math.log(1 + rate)); + y = present * f + payment * (1 / rate + type) * (f - 1) + future; + } + y0 = y1; + y1 = y; + ++i; + } + return rate; +}; -/*! - * numbro.js language configuration - * language : Dutch - * locale: Netherlands - * author : Dave Clayton : https://github.com/davedx - */ -(function () { - 'use strict'; +// TODO +exports.RECEIVED = function() { + throw new Error('RECEIVED is not implemented'); +}; - var language = { - langLocaleCode: 'nl-NL', - cultureCode: 'nl-NL', - delimiters: { - thousands: '.', - decimal : ',' - }, - abbreviations: { - thousand : 'k', - million : 'mln', - billion : 'mrd', - trillion : 'bln' - }, - ordinal : function (number) { - var remainder = number % 100; - return (number !== 0 && remainder <= 1 || remainder === 8 || remainder >= 20) ? 'ste' : 'de'; - }, - currency: { - symbol: '€', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; +exports.RRI = function(periods, present, future) { + periods = utils.parseNumber(periods); + present = utils.parseNumber(present); + future = utils.parseNumber(future); + if (utils.anyIsError(periods, present, future)) { + return error.value; + } - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); + // Return error if periods or present is equal to 0 (zero) + if (periods === 0 || present === 0) { + return error.num; + } + // Return equivalent interest rate + return Math.pow(future / present, 1 / periods) - 1; +}; -/***/ }), -/* 66 */ -/***/ (function(module, exports) { +exports.SLN = function(cost, salvage, life) { + cost = utils.parseNumber(cost); + salvage = utils.parseNumber(salvage); + life = utils.parseNumber(life); + if (utils.anyIsError(cost, salvage, life)) { + return error.value; + } -/*! - * numbro.js language configuration - * language : Polish - * locale : Poland - * author : Dominik Bulaj : https://github.com/dominikbulaj - */ -(function () { - 'use strict'; + // Return error if life equal to 0 (zero) + if (life === 0) { + return error.num; + } - var language = { - langLocaleCode: 'pl-PL', - cultureCode: 'pl-PL', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: 'tys.', - million: 'mln', - billion: 'mld', - trillion: 'bln' - }, - ordinal: function () { - return '.'; - }, - currency: { - symbol: ' zł', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + // Return straight-line depreciation + return (cost - salvage) / life; +}; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +exports.SYD = function(cost, salvage, life, period) { + // Return error if any of the parameters is not a number + cost = utils.parseNumber(cost); + salvage = utils.parseNumber(salvage); + life = utils.parseNumber(life); + period = utils.parseNumber(period); + if (utils.anyIsError(cost, salvage, life, period)) { + return error.value; + } + // Return error if life equal to 0 (zero) + if (life === 0) { + return error.num; + } -/***/ }), -/* 67 */ -/***/ (function(module, exports) { + // Return error if period is lower than 1 or greater than life + if (period < 1 || period > life) { + return error.num; + } -/*! - * numbro.js language configuration - * language : Portuguese - * locale : Brazil - * author : Ramiro Varandas Jr : https://github.com/ramirovjr - */ -(function () { - 'use strict'; + // Truncate period if it is not an integer + period = parseInt(period, 10); - var language = { - langLocaleCode: 'pt-BR', - cultureCode: 'pt-BR', - delimiters: { - thousands: '.', - decimal: ',' - }, - abbreviations: { - thousand: 'mil', - million: 'milhões', - billion: 'b', - trillion: 't' - }, - ordinal: function () { - return 'º'; - }, - currency: { - symbol: 'R$', - position: 'prefix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + // Return straight-line depreciation + return ((cost - salvage) * (life - period + 1) * 2) / (life * (life + 1)); +}; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +exports.TBILLEQ = function(settlement, maturity, discount) { + settlement = utils.parseDate(settlement); + maturity = utils.parseDate(maturity); + discount = utils.parseNumber(discount); + if (utils.anyIsError(settlement, maturity, discount)) { + return error.value; + } + // Return error if discount is lower than or equal to zero + if (discount <= 0) { + return error.num; + } -/***/ }), -/* 68 */ -/***/ (function(module, exports) { + // Return error if settlement is greater than maturity + if (settlement > maturity) { + return error.num; + } -/*! - * numbro.js language configuration - * language : Portuguese - * locale : Portugal - * author : Diogo Resende : https://github.com/dresende - */ -(function () { - 'use strict'; + // Return error if maturity is more than one year after settlement + if (maturity - settlement > 365 * 24 * 60 * 60 * 1000) { + return error.num; + } - var language = { - langLocaleCode: 'pt-PT', - cultureCode: 'pt-PT', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: 'k', - million: 'm', - billion: 'b', - trillion: 't' - }, - ordinal : function () { - return 'º'; - }, - currency: { - symbol: '€', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + // Return bond-equivalent yield + return (365 * discount) / (360 - discount * dateTime.DAYS360(settlement, maturity, false)); +}; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +exports.TBILLPRICE = function(settlement, maturity, discount) { + settlement = utils.parseDate(settlement); + maturity = utils.parseDate(maturity); + discount = utils.parseNumber(discount); + if (utils.anyIsError(settlement, maturity, discount)) { + return error.value; + } + // Return error if discount is lower than or equal to zero + if (discount <= 0) { + return error.num; + } -/***/ }), -/* 69 */ -/***/ (function(module, exports) { + // Return error if settlement is greater than maturity + if (settlement > maturity) { + return error.num; + } -/*! - * numbro.js language configuration - * language : Russian - * locale : Russsia - * author : Anatoli Papirovski : https://github.com/apapirovski - */ -(function () { - 'use strict'; + // Return error if maturity is more than one year after settlement + if (maturity - settlement > 365 * 24 * 60 * 60 * 1000) { + return error.num; + } - var language = { - langLocaleCode: 'ru-RU', - cultureCode: 'ru-RU', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: 'тыс.', - million: 'млн', - billion: 'b', - trillion: 't' - }, - ordinal: function () { - // not ideal, but since in Russian it can taken on - // different forms (masculine, feminine, neuter) - // this is all we can do - return '.'; - }, - currency: { - symbol: 'руб.', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + // Return bond-equivalent yield + return 100 * (1 - discount * dateTime.DAYS360(settlement, maturity, false) / 360); +}; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +exports.TBILLYIELD = function(settlement, maturity, price) { + settlement = utils.parseDate(settlement); + maturity = utils.parseDate(maturity); + price = utils.parseNumber(price); + if (utils.anyIsError(settlement, maturity, price)) { + return error.value; + } + // Return error if price is lower than or equal to zero + if (price <= 0) { + return error.num; + } -/***/ }), -/* 70 */ -/***/ (function(module, exports) { + // Return error if settlement is greater than maturity + if (settlement > maturity) { + return error.num; + } -/*! - * numbro.js language configuration - * language : Russian - * locale : Ukraine - * author : Anatoli Papirovski : https://github.com/apapirovski - */ -(function () { - 'use strict'; + // Return error if maturity is more than one year after settlement + if (maturity - settlement > 365 * 24 * 60 * 60 * 1000) { + return error.num; + } - var language = { - langLocaleCode: 'ru-UA', - cultureCode: 'ru-UA', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: 'тыс.', - million: 'млн', - billion: 'b', - trillion: 't' - }, - ordinal: function () { - // not ideal, but since in Russian it can taken on - // different forms (masculine, feminine, neuter) - // this is all we can do - return '.'; - }, - currency: { - symbol: '\u20B4', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; + // Return bond-equivalent yield + return (100 - price) * 360 / (price * dateTime.DAYS360(settlement, maturity, false)); +}; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +// TODO +exports.VDB = function() { + throw new Error('VDB is not implemented'); +}; + +// TODO needs better support for date +// exports.XIRR = function(values, dates, guess) { +// // Credits: algorithm inspired by Apache OpenOffice +// +// values = utils.parseNumberArray(utils.flatten(values)); +// dates = utils.parseDateArray(utils.flatten(dates)); +// guess = utils.parseNumber(guess); +// +// if (utils.anyIsError(values, dates, guess)) { +// return error.value; +// } +// +// // Calculates the resulting amount +// var irrResult = function(values, dates, rate) { +// var r = rate + 1; +// var result = values[0]; +// for (var i = 1; i < values.length; i++) { +// result += values[i] / Math.pow(r, dateTime.DAYS(dates[i], dates[0]) / 365); +// } +// return result; +// }; +// +// // Calculates the first derivation +// var irrResultDeriv = function(values, dates, rate) { +// var r = rate + 1; +// var result = 0; +// for (var i = 1; i < values.length; i++) { +// var frac = dateTime.DAYS(dates[i], dates[0]) / 365; +// result -= frac * values[i] / Math.pow(r, frac + 1); +// } +// return result; +// }; +// +// // Check that values contains at least one positive value and one negative value +// var positive = false; +// var negative = false; +// for (var i = 0; i < values.length; i++) { +// if (values[i] > 0) { +// positive = true; +// } +// if (values[i] < 0) { +// negative = true; +// } +// } +// +// // Return error if values does not contain at least one positive value and one negative value +// if (!positive || !negative) { +// return error.num; +// } +// +// // Initialize guess and resultRate +// guess = guess || 0.1; +// var resultRate = guess; +// +// // Set maximum epsilon for end of iteration +// var epsMax = 1e-10; +// +// // Implement Newton's method +// var newRate, epsRate, resultValue; +// var contLoop = true; +// do { +// resultValue = irrResult(values, dates, resultRate); +// newRate = resultRate - resultValue / irrResultDeriv(values, dates, resultRate); +// epsRate = Math.abs(newRate - resultRate); +// resultRate = newRate; +// contLoop = (epsRate > epsMax) && (Math.abs(resultValue) > epsMax); +// } while (contLoop); +// +// // Return internal rate of return +// return resultRate; +// }; +exports.XNPV = function(rate, values, dates) { + rate = utils.parseNumber(rate); + values = utils.parseNumberArray(utils.flatten(values)); + dates = utils.parseDateArray(utils.flatten(dates)); + if (utils.anyIsError(rate, values, dates)) { + return error.value; + } -/***/ }), -/* 71 */ -/***/ (function(module, exports) { + var result = 0; + for (var i = 0; i < values.length; i++) { + result += values[i] / Math.pow(1 + rate, dateTime.DAYS(dates[i], dates[0]) / 365); + } + return result; +}; -/*! - * numbro.js language configuration - * language : Slovak - * locale : Slovakia - * author : Ahmed Al Hafoudh : http://www.freevision.sk - */ -(function () { - 'use strict'; +// TODO +exports.YIELD = function() { + throw new Error('YIELD is not implemented'); +}; - var language = { - langLocaleCode: 'sk-SK', - cultureCode: 'sk-SK', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: 'tis.', - million: 'mil.', - billion: 'b', - trillion: 't' - }, - ordinal: function () { - return '.'; - }, - currency: { - symbol: '€', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; +// TODO +exports.YIELDDISC = function() { + throw new Error('YIELDDISC is not implemented'); +}; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +// TODO +exports.YIELDMAT = function() { + throw new Error('YIELDMAT is not implemented'); +}; /***/ }), -/* 72 */ -/***/ (function(module, exports) { - -/*! - * numbro.js language configuration - * language : Swedish - * locale : Sweden - * author : Benjamin Van Ryseghem (benjamin.vanryseghem.com) - */ -(function() { - 'use strict'; - - var language = { - langLocaleCode: 'sv-SE', - cultureCode: 'sv-SE', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: 't', - million: 'M', - billion: 'md', - trillion: 'tmd' - }, - currency: { - symbol: 'kr', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; - - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +/* 92 */ +/***/ (function(module, exports, __webpack_require__) { +var error = __webpack_require__(0); +var utils = __webpack_require__(1); -/***/ }), -/* 73 */ -/***/ (function(module, exports) { +exports.MATCH = function(lookupValue, lookupArray, matchType) { + if (!lookupValue && !lookupArray) { + return error.na; + } -/*! - * numbro.js language configuration - * language : Thai - * locale : Thailand - * author : Sathit Jittanupat : https://github.com/jojosati - */ -(function () { - 'use strict'; + if (arguments.length === 2) { + matchType = 1; + } + if (!(lookupArray instanceof Array)) { + return error.na; + } - var language = { - langLocaleCode: 'th-TH', - cultureCode: 'th-TH', - delimiters: { - thousands: ',', - decimal: '.' - }, - abbreviations: { - thousand: 'พัน', - million: 'ล้าน', - billion: 'พันล้าน', - trillion: 'ล้านล้าน' - }, - ordinal: function () { - return '.'; - }, - currency: { - symbol: '฿', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' + if (matchType !== -1 && matchType !== 0 && matchType !== 1) { + return error.na; + } + var index; + var indexValue; + for (var idx = 0; idx < lookupArray.length; idx++) { + if (matchType === 1) { + if (lookupArray[idx] === lookupValue) { + return idx + 1; + } else if (lookupArray[idx] < lookupValue) { + if (!indexValue) { + index = idx + 1; + indexValue = lookupArray[idx]; + } else if (lookupArray[idx] > indexValue) { + index = idx + 1; + indexValue = lookupArray[idx]; } - }; + } + } else if (matchType === 0) { + if (typeof lookupValue === 'string') { + lookupValue = lookupValue.replace(/\?/g, '.'); + if (lookupArray[idx].toLowerCase().match(lookupValue.toLowerCase())) { + return idx + 1; + } + } else { + if (lookupArray[idx] === lookupValue) { + return idx + 1; + } + } + } else if (matchType === -1) { + if (lookupArray[idx] === lookupValue) { + return idx + 1; + } else if (lookupArray[idx] > lookupValue) { + if (!indexValue) { + index = idx + 1; + indexValue = lookupArray[idx]; + } else if (lookupArray[idx] < indexValue) { + index = idx + 1; + indexValue = lookupArray[idx]; + } + } + } + } + + return index ? index : error.na; +}; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; +exports.VLOOKUP = function (needle, table, index, rangeLookup) { + if (!needle || !table || !index) { + return error.na; + } + + rangeLookup = rangeLookup || false; + for (var i = 0; i < table.length; i++) { + var row = table[i]; + if ((!rangeLookup && row[0] === needle) || + ((row[0] === needle) || + (rangeLookup && typeof row[0] === "string" && row[0].toLowerCase().indexOf(needle.toLowerCase()) !== -1))) { + return (index < (row.length + 1) ? row[index - 1] : error.ref); } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); + } + + return error.na; +}; + +exports.HLOOKUP = function (needle, table, index, rangeLookup) { + if (!needle || !table || !index) { + return error.na; + } + + rangeLookup = rangeLookup || false; + + var transposedTable = utils.transpose(table); + + for (var i = 0; i < transposedTable.length; i++) { + var row = transposedTable[i]; + if ((!rangeLookup && row[0] === needle) || + ((row[0] === needle) || + (rangeLookup && typeof row[0] === "string" && row[0].toLowerCase().indexOf(needle.toLowerCase()) !== -1))) { + return (index < (row.length + 1) ? row[index - 1] : error.ref); } -}.call(typeof window === 'undefined' ? this : window)); + } + + return error.na; +}; /***/ }), -/* 74 */ -/***/ (function(module, exports) { +/* 93 */ +/***/ (function(module, exports, __webpack_require__) { -/*! - * numbro.js language configuration - * language : Turkish - * locale : Turkey - * author : Ecmel Ercan : https://github.com/ecmel, - * Erhan Gundogan : https://github.com/erhangundogan, - * Burak Yiğit Kaya: https://github.com/BYK - */ -(function() { - 'use strict'; +"use strict"; - var suffixes = { - 1: '\'inci', - 5: '\'inci', - 8: '\'inci', - 70: '\'inci', - 80: '\'inci', - 2: '\'nci', - 7: '\'nci', - 20: '\'nci', - 50: '\'nci', +exports.__esModule = true; +exports['default'] = func; +var SYMBOL = exports.SYMBOL = '>'; - 3: '\'üncü', - 4: '\'üncü', - 100: '\'üncü', +function func(exp1, exp2) { + return exp1 > exp2; +} - 6: '\'ncı', +func.SYMBOL = SYMBOL; - 9: '\'uncu', - 10: '\'uncu', - 30: '\'uncu', +/***/ }), +/* 94 */ +/***/ (function(module, exports, __webpack_require__) { - 60: '\'ıncı', - 90: '\'ıncı' - }, - language = { - langLocaleCode: 'tr-TR', - cultureCode: 'tr-TR', - delimiters: { - thousands: '.', - decimal: ',' - }, - abbreviations: { - thousand: 'bin', - million: 'milyon', - billion: 'milyar', - trillion: 'trilyon' - }, - ordinal: function(number) { - if (number === 0) { // special case for zero - return '\'ıncı'; - } +"use strict"; - var a = number % 10, - b = number % 100 - a, - c = number >= 100 ? 100 : null; - return suffixes[a] || suffixes[b] || suffixes[c]; - }, - currency: { - symbol: '\u20BA', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; +exports.__esModule = true; +exports['default'] = func; +var SYMBOL = exports.SYMBOL = '>='; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +function func(exp1, exp2) { + return exp1 >= exp2; +} +func.SYMBOL = SYMBOL; /***/ }), -/* 75 */ -/***/ (function(module, exports) { +/* 95 */ +/***/ (function(module, exports, __webpack_require__) { -/*! - * numbro.js language configuration - * language : Ukrainian - * locale : Ukraine - * author : Michael Piefel : https://github.com/piefel (with help from Tetyana Kuzmenko) - */ -(function () { - 'use strict'; +"use strict"; - var language = { - langLocaleCode: 'uk-UA', - cultureCode: 'uk-UA', - delimiters: { - thousands: ' ', - decimal: ',' - }, - abbreviations: { - thousand: 'тис.', - million: 'млн', - billion: 'млрд', - trillion: 'блн' - }, - ordinal: function () { - // not ideal, but since in Ukrainian it can taken on - // different forms (masculine, feminine, neuter) - // this is all we can do - return ''; - }, - currency: { - symbol: '\u20B4', - position: 'postfix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: ',0.00 $', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: ',0 $' - } - }; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +exports.__esModule = true; +exports['default'] = func; +var SYMBOL = exports.SYMBOL = '<'; +function func(exp1, exp2) { + return exp1 < exp2; +} + +func.SYMBOL = SYMBOL; /***/ }), -/* 76 */ -/***/ (function(module, exports) { +/* 96 */ +/***/ (function(module, exports, __webpack_require__) { -/*! - * numbro.js language configuration - * language : simplified chinese - * locale : China - * author : badplum : https://github.com/badplum - */ -(function () { - 'use strict'; +"use strict"; - var language = { - langLocaleCode: 'zh-CN', - cultureCode: 'zh-CN', - delimiters: { - thousands: ',', - decimal: '.' - }, - abbreviations: { - thousand: '千', - million: '百万', - billion: '十亿', - trillion: '兆' - }, - ordinal: function () { - return '.'; - }, - currency: { - symbol: '¥', - position: 'prefix' - }, - defaults: { - currencyFormat: ',4 a' - }, - formats: { - fourDigits: '4 a', - fullWithTwoDecimals: '$ ,0.00', - fullWithTwoDecimalsNoCurrency: ',0.00', - fullWithNoDecimals: '$ ,0' - } - }; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +exports.__esModule = true; +exports['default'] = func; +var SYMBOL = exports.SYMBOL = '<='; + +function func(exp1, exp2) { + return exp1 <= exp2; +} + +func.SYMBOL = SYMBOL; + +/***/ }), +/* 97 */ +/***/ (function(module, exports, __webpack_require__) { + +"use strict"; + + +exports.__esModule = true; +exports.SYMBOL = undefined; +exports['default'] = func; + +var _number = __webpack_require__(3); + +var _error = __webpack_require__(2); + +var SYMBOL = exports.SYMBOL = '-'; + +function func(first) { + for (var _len = arguments.length, rest = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + rest[_key - 1] = arguments[_key]; + } + + var result = rest.reduce(function (acc, value) { + return acc - (0, _number.toNumber)(value); + }, (0, _number.toNumber)(first)); + + if (isNaN(result)) { + throw Error(_error.ERROR_VALUE); + } + + return result; +} +func.SYMBOL = SYMBOL; /***/ }), -/* 77 */ -/***/ (function(module, exports) { +/* 98 */ +/***/ (function(module, exports, __webpack_require__) { -/*! - * numbro.js language configuration - * language : Chinese (Taiwan) - * author (numbro.js Version): Randy Wilander : https://github.com/rocketedaway - * author (numeral.js Version) : Rich Daley : https://github.com/pedantic-git - */ -(function () { - 'use strict'; +"use strict"; - var language = { - langLocaleCode: 'zh-TW', - cultureCode: 'zh-TW', - delimiters: { - thousands: ',', - decimal: '.' - }, - abbreviations: { - thousand: '千', - million: '百萬', - billion: '十億', - trillion: '兆' - }, - ordinal: function () { - return '第'; - }, - currency: { - symbol: 'NT$' - } - }; - // CommonJS - if (typeof module !== 'undefined' && module.exports) { - module.exports = language; - } - // Browser - if (typeof window !== 'undefined' && window.numbro && window.numbro.culture) { - window.numbro.culture(language.cultureCode, language); - } -}.call(typeof window === 'undefined' ? this : window)); +exports.__esModule = true; +exports.SYMBOL = undefined; +exports['default'] = func; +var _number = __webpack_require__(3); -/***/ }), -/* 78 */ -/***/ (function(module, exports) { +var _error = __webpack_require__(2); -function E () { - // Keep this empty so it's easier to inherit from - // (via https://github.com/lipsmack from https://github.com/scottcorgan/tiny-emitter/issues/3) +var SYMBOL = exports.SYMBOL = '*'; + +function func(first) { + for (var _len = arguments.length, rest = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { + rest[_key - 1] = arguments[_key]; + } + + var result = rest.reduce(function (acc, value) { + return acc * (0, _number.toNumber)(value); + }, (0, _number.toNumber)(first)); + + if (isNaN(result)) { + throw Error(_error.ERROR_VALUE); + } + + return result; } -E.prototype = { - on: function (name, callback, ctx) { - var e = this.e || (this.e = {}); +func.SYMBOL = SYMBOL; - (e[name] || (e[name] = [])).push({ - fn: callback, - ctx: ctx - }); +/***/ }), +/* 99 */ +/***/ (function(module, exports, __webpack_require__) { - return this; - }, +"use strict"; - once: function (name, callback, ctx) { - var self = this; - function listener () { - self.off(name, listener); - callback.apply(ctx, arguments); - }; - listener._ = callback - return this.on(name, listener, ctx); - }, +exports.__esModule = true; +exports['default'] = func; +var SYMBOL = exports.SYMBOL = '<>'; - emit: function (name) { - var data = [].slice.call(arguments, 1); - var evtArr = ((this.e || (this.e = {}))[name] || []).slice(); - var i = 0; - var len = evtArr.length; +function func(exp1, exp2) { + return exp1 !== exp2; +} - for (i; i < len; i++) { - evtArr[i].fn.apply(evtArr[i].ctx, data); - } +func.SYMBOL = SYMBOL; - return this; - }, +/***/ }), +/* 100 */ +/***/ (function(module, exports, __webpack_require__) { - off: function (name, callback) { - var e = this.e || (this.e = {}); - var evts = e[name]; - var liveEvents = []; +"use strict"; - if (evts && callback) { - for (var i = 0, len = evts.length; i < len; i++) { - if (evts[i].fn !== callback && evts[i].fn._ !== callback) - liveEvents.push(evts[i]); - } - } - // Remove event from queue to prevent memory leak - // Suggested by https://github.com/lazd - // Ref: https://github.com/scottcorgan/tiny-emitter/commit/c6ebfaa9bc973b33d110a84a307742b7cf94c953#commitcomment-5024910 +exports.__esModule = true; +exports.SYMBOL = undefined; +exports['default'] = func; - (liveEvents.length) - ? e[name] = liveEvents - : delete e[name]; +var _number = __webpack_require__(3); - return this; - } -}; +var _error = __webpack_require__(2); -module.exports = E; +var SYMBOL = exports.SYMBOL = '^'; +function func(exp1, exp2) { + var result = Math.pow((0, _number.toNumber)(exp1), (0, _number.toNumber)(exp2)); -/***/ }), -/* 79 */ -/***/ (function(module, exports) { + if (isNaN(result)) { + throw Error(_error.ERROR_VALUE); + } -module.exports = function(module) { - if(!module.webpackPolyfill) { - module.deprecate = function() {}; - module.paths = []; - // module.parent = undefined by default - if(!module.children) module.children = []; - Object.defineProperty(module, "loaded", { - enumerable: true, - get: function() { - return module.l; - } - }); - Object.defineProperty(module, "id", { - enumerable: true, - get: function() { - return module.i; - } - }); - module.webpackPolyfill = 1; - } - return module; -}; + return result; +} +func.SYMBOL = SYMBOL; /***/ }), -/* 80 */ +/* 101 */ /***/ (function(module, exports, __webpack_require__) { /* WEBPACK VAR INJECTION */(function(module, process) {/* parser generated by jison 0.4.17 */ @@ -17880,51 +19621,60 @@ if (typeof module !== 'undefined' && __webpack_require__.c[__webpack_require__.s } } -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(79)(module), __webpack_require__(15))) +/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(102)(module), __webpack_require__(10))) /***/ }), -/* 81 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -exports.__esModule = true; -exports.rowLabelToIndex = exports.rowIndexToLabel = exports.columnLabelToIndex = exports.columnIndexToLabel = exports.toLabel = exports.extractLabel = exports.error = exports.Parser = exports.ERROR_VALUE = exports.ERROR_REF = exports.ERROR_NUM = exports.ERROR_NULL = exports.ERROR_NOT_AVAILABLE = exports.ERROR_NAME = exports.ERROR_DIV_ZERO = exports.ERROR = exports.SUPPORTED_FORMULAS = undefined; - -var _parser = __webpack_require__(16); +/* 102 */ +/***/ (function(module, exports) { -var _parser2 = _interopRequireDefault(_parser); +module.exports = function(module) { + if(!module.webpackPolyfill) { + module.deprecate = function() {}; + module.paths = []; + // module.parent = undefined by default + if(!module.children) module.children = []; + Object.defineProperty(module, "loaded", { + enumerable: true, + get: function() { + return module.l; + } + }); + Object.defineProperty(module, "id", { + enumerable: true, + get: function() { + return module.i; + } + }); + module.webpackPolyfill = 1; + } + return module; +}; -var _supportedFormulas = __webpack_require__(10); -var _supportedFormulas2 = _interopRequireDefault(_supportedFormulas); +/***/ }), +/* 103 */ +/***/ (function(module, exports, __webpack_require__) { -var _error = __webpack_require__(1); +"use strict"; -var _error2 = _interopRequireDefault(_error); -var _cell = __webpack_require__(9); +exports.__esModule = true; +exports.trimEdges = trimEdges; +/* eslint-disable import/prefer-default-export */ +/** + * Trim value by cutting character starting from the beginning and ending at the same time. + * + * @param {String} string String to trimming. + * @param {Number} [margin=1] Number of character to cut. + * @returns {String} + */ +function trimEdges(string) { + var margin = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } + string = string.substring(margin, string.length - margin); -exports.SUPPORTED_FORMULAS = _supportedFormulas2['default']; -exports.ERROR = _error.ERROR; -exports.ERROR_DIV_ZERO = _error.ERROR_DIV_ZERO; -exports.ERROR_NAME = _error.ERROR_NAME; -exports.ERROR_NOT_AVAILABLE = _error.ERROR_NOT_AVAILABLE; -exports.ERROR_NULL = _error.ERROR_NULL; -exports.ERROR_NUM = _error.ERROR_NUM; -exports.ERROR_REF = _error.ERROR_REF; -exports.ERROR_VALUE = _error.ERROR_VALUE; -exports.Parser = _parser2['default']; -exports.error = _error2['default']; -exports.extractLabel = _cell.extractLabel; -exports.toLabel = _cell.toLabel; -exports.columnIndexToLabel = _cell.columnIndexToLabel; -exports.columnLabelToIndex = _cell.columnLabelToIndex; -exports.rowIndexToLabel = _cell.rowIndexToLabel; -exports.rowLabelToIndex = _cell.rowLabelToIndex; + return string; +} /***/ }) /******/ ]); diff --git a/dist/formula-parser.min.js b/dist/formula-parser.min.js index e8c0df3c..b8068e1b 100644 --- a/dist/formula-parser.min.js +++ b/dist/formula-parser.min.js @@ -1,29 +1,40 @@ -!function(r,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.formulaParser=t():r.formulaParser=t()}(this,function(){return function(r){function t(n){if(e[n])return e[n].exports;var u=e[n]={i:n,l:!1,exports:{}};return r[n].call(u.exports,u,u.exports,t),u.l=!0,u.exports}var e={};return t.m=r,t.c=e,t.i=function(r){return r},t.d=function(r,e,n){t.o(r,e)||Object.defineProperty(r,e,{configurable:!1,enumerable:!0,get:n})},t.n=function(r){var e=r&&r.__esModule?function(){return r["default"]}:function(){return r};return t.d(e,"a",e),e},t.o=function(r,t){return Object.prototype.hasOwnProperty.call(r,t)},t.p="",t(t.s=81)}([function(r,t){t.nil=Error("#NULL!"),t.div0=Error("#DIV/0!"),t.value=Error("#VALUE!"),t.ref=Error("#REF!"),t.name=Error("#NAME?"),t.num=Error("#NUM!"),t.na=Error("#N/A"),t.error=Error("#ERROR!"),t.data=Error("#GETTING_DATA")},function(r,t,e){"use strict";function n(r){var t=void 0;return r=(r+"").replace(/#|!|\?/g,""),d[r]&&(t=d[r]),t?t:null}function u(r){var t=!1;for(var e in d)if(Object.prototype.hasOwnProperty.call(d,e)&&d[e]===r){t=!0;break}return t}t.__esModule=!0;var i;t["default"]=n,t.isValidStrict=u;var o=t.ERROR="ERROR",a=t.ERROR_DIV_ZERO="DIV/0",s=t.ERROR_NAME="NAME",l=t.ERROR_NOT_AVAILABLE="N/A",f=t.ERROR_NULL="NULL",c=t.ERROR_NUM="NUM",p=t.ERROR_REF="REF",m=t.ERROR_VALUE="VALUE",d=(i={},i[o]="#ERROR!",i[a]="#DIV/0!",i[s]="#NAME?",i[l]="#N/A",i[f]="#NULL!",i[c]="#NUM!",i[p]="#REF!",i[m]="#VALUE!",i)},function(r,t,e){var n=e(0);t.flattenShallow=function(r){return r&&r.reduce?r.reduce(function(r,t){var e=Array.isArray(r),n=Array.isArray(t);return e&&n?r.concat(t):e?(r.push(t),r):n?[r].concat(t):[r,t]}):r},t.isFlat=function(r){if(!r)return!1;for(var t=0;r.length>t;++t)if(Array.isArray(r[t]))return!1;return!0},t.flatten=function(){for(var r=t.argsToArray.apply(null,arguments);!t.isFlat(r);)r=t.flattenShallow(r);return r},t.argsToArray=function(r){var e=[];return t.arrayEach(r,function(r){e.push(r)}),e},t.numbers=function(){return this.flatten.apply(null,arguments).filter(function(r){return"number"==typeof r})},t.cleanFloat=function(r){var t=1e14;return Math.round(r*t)/t},t.parseBool=function(r){if("boolean"==typeof r)return r;if(r instanceof Error)return r;if("number"==typeof r)return 0!==r;if("string"==typeof r){var t=r.toUpperCase();if("TRUE"===t)return!0;if("FALSE"===t)return!1}return r instanceof Date&&!isNaN(r)||n.value},t.parseNumber=function(r){return r===undefined||""===r?n.value:isNaN(r)?n.value:parseFloat(r)},t.parseNumberArray=function(r){var e;if(!r||0===(e=r.length))return n.value;for(var u;e--;){if((u=t.parseNumber(r[e]))===n.value)return u;r[e]=u}return r},t.parseMatrix=function(r){if(!r||0===r.length)return n.value;for(var e,u=0;r.length>u;u++)if(e=t.parseNumberArray(r[u]),r[u]=e,e instanceof Error)return e;return r};var u=new Date(1900,0,1);t.parseDate=function(r){if(!isNaN(r)){if(r instanceof Date)return new Date(r);var t=parseInt(r,10);return 0>t?n.num:t>60?new Date(u.getTime()+864e5*(t-2)):new Date(u.getTime()+864e5*(t-1))}return"string"!=typeof r||(r=new Date(r),isNaN(r))?n.value:r},t.parseDateArray=function(r){for(var t,e=r.length;e--;){if((t=this.parseDate(r[e]))===n.value)return t;r[e]=t}return r},t.anyIsError=function(){for(var r=arguments.length;r--;)if(arguments[r]instanceof Error)return!0;return!1},t.arrayValuesToNumbers=function(r){for(var t,e=r.length;e--;)if("number"!=typeof(t=r[e]))if(t!==!0)if(t!==!1){if("string"==typeof t){var n=this.parseNumber(t);r[e]=n instanceof Error?0:n}}else r[e]=0;else r[e]=1;return r},t.rest=function(r,t){return t=t||1,r&&"function"==typeof r.slice?r.slice(t):r},t.initial=function(r,t){return t=t||1,r&&"function"==typeof r.slice?r.slice(0,r.length-t):r},t.arrayEach=function(r,t){for(var e=-1,n=r.length;++e-1?parseFloat(r):parseInt(r,10)),t}function u(r){return-1*n(r)}t.__esModule=!0,t.toNumber=n,t.invertNumber=u},function(module,exports,__webpack_require__){var utils=__webpack_require__(2),error=__webpack_require__(0),statistical=__webpack_require__(5),information=__webpack_require__(7);exports.ABS=function(r){return(r=utils.parseNumber(r))instanceof Error?r:Math.abs(r)},exports.ACOS=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var t=Math.acos(r);return isNaN(t)&&(t=error.num),t},exports.ACOSH=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var t=Math.log(r+Math.sqrt(r*r-1));return isNaN(t)&&(t=error.num),t},exports.ACOT=function(r){return(r=utils.parseNumber(r))instanceof Error?r:Math.atan(1/r)},exports.ACOTH=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var t=.5*Math.log((r+1)/(r-1));return isNaN(t)&&(t=error.num),t},exports.AGGREGATE=function(r,t,e,n){if(r=utils.parseNumber(r),t=utils.parseNumber(r),utils.anyIsError(r,t))return error.value;switch(r){case 1:return statistical.AVERAGE(e);case 2:return statistical.COUNT(e);case 3:return statistical.COUNTA(e);case 4:return statistical.MAX(e);case 5:return statistical.MIN(e);case 6:return exports.PRODUCT(e);case 7:return statistical.STDEV.S(e);case 8:return statistical.STDEV.P(e);case 9:return exports.SUM(e);case 10:return statistical.VAR.S(e);case 11:return statistical.VAR.P(e);case 12:return statistical.MEDIAN(e);case 13:return statistical.MODE.SNGL(e);case 14:return statistical.LARGE(e,n);case 15:return statistical.SMALL(e,n);case 16:return statistical.PERCENTILE.INC(e,n);case 17:return statistical.QUARTILE.INC(e,n);case 18:return statistical.PERCENTILE.EXC(e,n);case 19:return statistical.QUARTILE.EXC(e,n)}},exports.ARABIC=function(r){if(!/^M*(?:D?C{0,3}|C[MD])(?:L?X{0,3}|X[CL])(?:V?I{0,3}|I[XV])$/.test(r))return error.value;var t=0;return r.replace(/[MDLV]|C[MD]?|X[CL]?|I[XV]?/g,function(r){t+={M:1e3,CM:900,D:500,CD:400,C:100,XC:90,L:50,XL:40,X:10,IX:9,V:5,IV:4,I:1}[r]}),t},exports.ASIN=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var t=Math.asin(r);return isNaN(t)&&(t=error.num),t},exports.ASINH=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.log(r+Math.sqrt(r*r+1))},exports.ATAN=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.atan(r)},exports.ATAN2=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:Math.atan2(r,t)},exports.ATANH=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var t=Math.log((1+r)/(1-r))/2;return isNaN(t)&&(t=error.num),t},exports.BASE=function(r,t,e){if(e=e||0,r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e))return error.value;e=e===undefined?0:e;var n=r.toString(t);return Array(Math.max(e+1-n.length,0)).join("0")+n},exports.CEILING=function(r,t,e){if(t=t===undefined?1:Math.abs(t),e=e||0,r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e))return error.value;if(0===t)return 0;var n=-Math.floor(Math.log(t)/Math.log(10));return 0>r?0===e?-exports.ROUND(Math.floor(Math.abs(r)/t)*t,n):-exports.ROUND(Math.ceil(Math.abs(r)/t)*t,n):exports.ROUND(Math.ceil(r/t)*t,n)},exports.CEILING.MATH=exports.CEILING,exports.CEILING.PRECISE=exports.CEILING,exports.COMBIN=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:exports.FACT(r)/(exports.FACT(t)*exports.FACT(r-t))},exports.COMBINA=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:0===r&&0===t?1:exports.COMBIN(r+t-1,r-1)},exports.COS=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.cos(r)},exports.COSH=function(r){return r=utils.parseNumber(r),r instanceof Error?r:(Math.exp(r)+Math.exp(-r))/2},exports.COT=function(r){return r=utils.parseNumber(r),r instanceof Error?r:1/Math.tan(r)},exports.COTH=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var t=Math.exp(2*r);return(t+1)/(t-1)},exports.CSC=function(r){return r=utils.parseNumber(r),r instanceof Error?r:1/Math.sin(r)},exports.CSCH=function(r){return r=utils.parseNumber(r),r instanceof Error?r:2/(Math.exp(r)-Math.exp(-r))},exports.DECIMAL=function(r,t){return 1>arguments.length?error.value:parseInt(r,t)},exports.DEGREES=function(r){return r=utils.parseNumber(r),r instanceof Error?r:180*r/Math.PI},exports.EVEN=function(r){return r=utils.parseNumber(r),r instanceof Error?r:exports.CEILING(r,-2,-1)},exports.EXP=Math.exp;var MEMOIZED_FACT=[];exports.FACT=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var t=Math.floor(r);return 0===t||1===t?1:MEMOIZED_FACT[t]>0?MEMOIZED_FACT[t]:MEMOIZED_FACT[t]=exports.FACT(t-1)*t},exports.FACTDOUBLE=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var t=Math.floor(r);return t>0?t*exports.FACTDOUBLE(t-2):1},exports.FLOOR=function(r,t){if(r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t))return error.value;if(0===t)return 0;if(!(r>0&&t>0||0>r&&0>t))return error.num;t=Math.abs(t);var e=-Math.floor(Math.log(t)/Math.log(10));return 0>r?-exports.ROUND(Math.ceil(Math.abs(r)/t),e):exports.ROUND(Math.floor(r/t)*t,e)},exports.FLOOR.MATH=function(r,t,e){if(t=t===undefined?1:t,e=e===undefined?0:e,r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e))return error.value;if(0===t)return 0;t=t?Math.abs(t):1;var n=-Math.floor(Math.log(t)/Math.log(10));return 0>r?0===e||e===undefined?-exports.ROUND(Math.ceil(Math.abs(r)/t)*t,n):-exports.ROUND(Math.floor(Math.abs(r)/t)*t,n):exports.ROUND(Math.floor(r/t)*t,n)},exports.FLOOR.PRECISE=exports.FLOOR.MATH,exports.GCD=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var t=r.length,e=r[0],n=0>e?-e:e,u=1;t>u;u++){for(var i=r[u],o=0>i?-i:i;n&&o;)n>o?n%=o:o%=n;n+=o}return n},exports.INT=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.floor(r)},exports.ISO={CEILING:exports.CEILING},exports.LCM=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var t,e,n,u,i=1;(n=r.pop())!==undefined;)for(;n>1;){if(n%2){for(t=3,e=Math.floor(Math.sqrt(n));e>=t&&n%t;t+=2);u=t>e?n:t}else u=2;for(n/=u,i*=u,t=r.length;t;r[--t]%u==0&&1==(r[t]/=u)&&r.splice(t,1));}return i},exports.LN=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.log(r)},exports.LN10=function(){return Math.log(10)},exports.LN2=function(){return Math.log(2)},exports.LOG10E=function(){return Math.LOG10E},exports.LOG2E=function(){return Math.LOG2E},exports.LOG=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:(t=t===undefined?10:t,Math.log(r)/Math.log(t))},exports.LOG10=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.log(r)/Math.log(10)},exports.MOD=function(r,t){if(r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t))return error.value;if(0===t)return error.div0;var e=Math.abs(r%t);return t>0?e:-e},exports.MROUND=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:0>r*t?error.num:Math.round(r/t)*t},exports.MULTINOMIAL=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var t=0,e=1,n=0;r.length>n;n++)t+=r[n],e*=exports.FACT(r[n]);return exports.FACT(t)/e},exports.ODD=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var t=Math.ceil(Math.abs(r));return t=1&t?t:t+1,r>0?t:-t},exports.PI=function(){return Math.PI},exports.E=function(){return Math.E},exports.POWER=function(r,t){if(r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t))return error.value;var e=Math.pow(r,t);return isNaN(e)?error.num:e},exports.PRODUCT=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var t=1,e=0;r.length>e;e++)t*=r[e];return t},exports.QUOTIENT=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:parseInt(r/t,10)},exports.RADIANS=function(r){return r=utils.parseNumber(r),r instanceof Error?r:r*Math.PI/180},exports.RAND=function(){return Math.random()},exports.RANDBETWEEN=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:r+Math.ceil((t-r+1)*Math.random())-1},exports.ROMAN=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;for(var t=(r+"").split(""),e=["","C","CC","CCC","CD","D","DC","DCC","DCCC","CM","","X","XX","XXX","XL","L","LX","LXX","LXXX","XC","","I","II","III","IV","V","VI","VII","VIII","IX"],n="",u=3;u--;)n=(e[+t.pop()+10*u]||"")+n;return Array(+t.join("")+1).join("M")+n},exports.ROUND=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:Math.round(r*Math.pow(10,t))/Math.pow(10,t)},exports.ROUNDDOWN=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:(r>0?1:-1)*Math.floor(Math.abs(r)*Math.pow(10,t))/Math.pow(10,t)},exports.ROUNDUP=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:(r>0?1:-1)*Math.ceil(Math.abs(r)*Math.pow(10,t))/Math.pow(10,t)},exports.SEC=function(r){return r=utils.parseNumber(r),r instanceof Error?r:1/Math.cos(r)},exports.SECH=function(r){return r=utils.parseNumber(r),r instanceof Error?r:2/(Math.exp(r)+Math.exp(-r))},exports.SERIESSUM=function(r,t,e,n){if(r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),n=utils.parseNumberArray(n),utils.anyIsError(r,t,e,n))return error.value;for(var u=n[0]*Math.pow(r,t),i=1;n.length>i;i++)u+=n[i]*Math.pow(r,t+i*e);return u},exports.SIGN=function(r){return r=utils.parseNumber(r),r instanceof Error?r:0>r?-1:0===r?0:1},exports.SIN=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.sin(r)},exports.SINH=function(r){return r=utils.parseNumber(r),r instanceof Error?r:(Math.exp(r)-Math.exp(-r))/2},exports.SQRT=function(r){return r=utils.parseNumber(r),r instanceof Error?r:0>r?error.num:Math.sqrt(r)},exports.SQRTPI=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.sqrt(r*Math.PI)},exports.SQRT1_2=function(){return 1/Math.sqrt(2)},exports.SQRT2=function(){return Math.sqrt(2)},exports.SUBTOTAL=function(r,t){if((r=utils.parseNumber(r))instanceof Error)return r;switch(r){case 1:return statistical.AVERAGE(t);case 2:return statistical.COUNT(t);case 3:return statistical.COUNTA(t);case 4:return statistical.MAX(t);case 5:return statistical.MIN(t);case 6:return exports.PRODUCT(t);case 7:return statistical.STDEV.S(t);case 8:return statistical.STDEV.P(t);case 9:return exports.SUM(t);case 10:return statistical.VAR.S(t);case 11:return statistical.VAR.P(t);case 101:return statistical.AVERAGE(t);case 102:return statistical.COUNT(t);case 103:return statistical.COUNTA(t);case 104:return statistical.MAX(t);case 105:return statistical.MIN(t);case 106:return exports.PRODUCT(t);case 107:return statistical.STDEV.S(t);case 108:return statistical.STDEV.P(t);case 109:return exports.SUM(t);case 110:return statistical.VAR.S(t);case 111:return statistical.VAR.P(t)}},exports.ADD=function(r,t){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:r+t)},exports.MINUS=function(r,t){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:r-t)},exports.DIVIDE=function(r,t){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:0===t?error.div0:r/t)},exports.MULTIPLY=function(r,t){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:r*t)},exports.GTE=function(r,t){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.error:r>=t)},exports.LT=function(r,t){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.error:t>r)},exports.LTE=function(r,t){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.error:t>=r)},exports.EQ=function(r,t){return 2!==arguments.length?error.na:r===t},exports.NE=function(r,t){return 2!==arguments.length?error.na:r!==t},exports.POW=function(r,t){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.error:exports.POWER(r,t))},exports.SUM=function(){var r=0;return utils.arrayEach(utils.argsToArray(arguments),function(t){if("number"==typeof t)r+=t;else if("string"==typeof t){var e=parseFloat(t);!isNaN(e)&&(r+=e)}else Array.isArray(t)&&(r+=exports.SUM.apply(null,t))}),r},exports.SUMIF=function(range,criteria){if((range=utils.parseNumberArray(utils.flatten(range)))instanceof Error)return range;for(var result=0,i=0;range.length>i;i++)result+=eval(range[i]+criteria)?range[i]:0;return result},exports.SUMIFS=function(){var args=utils.argsToArray(arguments),range=utils.parseNumberArray(utils.flatten(args.shift()));if(range instanceof Error)return range;for(var criteria=args,n_range_elements=range.length,n_criterias=criteria.length,result=0,i=0;n_range_elements>i;i++){for(var el=range[i],condition="",c=0;n_criterias>c;c++)condition+=el+criteria[c],c!==n_criterias-1&&(condition+="&&");eval(condition)&&(result+=el)}return result},exports.SUMPRODUCT=function(){if(!arguments||0===arguments.length)return error.value;for(var r,t,e,n,u=arguments.length+1,i=0,o=0;arguments[0].length>o;o++)if(arguments[0][o]instanceof Array)for(var a=0;arguments[0][o].length>a;a++){for(r=1,t=1;u>t;t++){if((n=utils.parseNumber(arguments[t-1][o][a]))instanceof Error)return n;r*=n}i+=r}else{for(r=1,t=1;u>t;t++){if((e=utils.parseNumber(arguments[t-1][o]))instanceof Error)return e;r*=e}i+=r}return i},exports.SUMSQ=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var t=0,e=r.length,n=0;e>n;n++)t+=information.ISNUMBER(r[n])?r[n]*r[n]:0;return t},exports.SUMX2MY2=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t))return error.value;for(var e=0,n=0;r.length>n;n++)e+=r[n]*r[n]-t[n]*t[n];return e},exports.SUMX2PY2=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t))return error.value;var e=0;r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t));for(var n=0;r.length>n;n++)e+=r[n]*r[n]+t[n]*t[n];return e},exports.SUMXMY2=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t))return error.value;var e=0;r=utils.flatten(r),t=utils.flatten(t);for(var n=0;r.length>n;n++)e+=Math.pow(r[n]-t[n],2);return e},exports.TAN=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.tan(r)},exports.TANH=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var t=Math.exp(2*r);return(t-1)/(t+1)},exports.TRUNC=function(r,t){return t=t===undefined?0:t,r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:(r>0?1:-1)*Math.floor(Math.abs(r)*Math.pow(10,t))/Math.pow(10,t)}},function(module,exports,__webpack_require__){var mathTrig=__webpack_require__(4),text=__webpack_require__(8),jStat=__webpack_require__(13).jStat,utils=__webpack_require__(2),error=__webpack_require__(0),misc=__webpack_require__(12);exports.AVEDEV=function(){var r=utils.parseNumberArray(utils.flatten(arguments));return r instanceof Error?r:jStat.sum(jStat(r).subtract(jStat.mean(r)).abs()[0])/r.length},exports.AVERAGE=function(){for(var r,t=utils.numbers(utils.flatten(arguments)),e=t.length,n=0,u=0,i=0;e>i;i++)n+=t[i],u+=1;return r=n/u,isNaN(r)&&(r=error.num),r},exports.AVERAGEA=function(){for(var r,t=utils.flatten(arguments),e=t.length,n=0,u=0,i=0;e>i;i++){var o=t[i];"number"==typeof o&&(n+=o),o===!0&&n++,null!==o&&u++}return r=n/u,isNaN(r)&&(r=error.num),r},exports.AVERAGEIF=function(range,criteria,average_range){if(1>=arguments.length)return error.na;if(average_range=average_range||range,range=utils.flatten(range),(average_range=utils.parseNumberArray(utils.flatten(average_range)))instanceof Error)return average_range;for(var average_count=0,result=0,i=0;range.length>i;i++)eval(range[i]+criteria)&&(result+=average_range[i],average_count++);return result/average_count},exports.AVERAGEIFS=function(){for(var args=utils.argsToArray(arguments),criteria=(args.length-1)/2,range=utils.flatten(args[0]),count=0,result=0,i=0;range.length>i;i++){for(var condition="",j=0;criteria>j;j++)condition+=args[2*j+1][i]+args[2*j+2],j!==criteria-1&&(condition+="&&");eval(condition)&&(result+=range[i],count++)}var average=result/count;return isNaN(average)?0:average},exports.BETA={},exports.BETA.DIST=function(r,t,e,n,u,i){return 4>arguments.length?error.value:(u=u===undefined?0:u,i=i===undefined?1:i,r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),u=utils.parseNumber(u),i=utils.parseNumber(i),utils.anyIsError(r,t,e,u,i)?error.value:(r=(r-u)/(i-u),n?jStat.beta.cdf(r,t,e):jStat.beta.pdf(r,t,e)))},exports.BETA.INV=function(r,t,e,n,u){return n=n===undefined?0:n,u=u===undefined?1:u,r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),n=utils.parseNumber(n),u=utils.parseNumber(u),utils.anyIsError(r,t,e,n,u)?error.value:jStat.beta.inv(r,t,e)*(u-n)+n},exports.BINOM={},exports.BINOM.DIST=function(r,t,e,n){return r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),n=utils.parseNumber(n),utils.anyIsError(r,t,e,n)?error.value:n?jStat.binomial.cdf(r,t,e):jStat.binomial.pdf(r,t,e)},exports.BINOM.DIST.RANGE=function(r,t,e,n){if(n=n===undefined?e:n,r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),n=utils.parseNumber(n),utils.anyIsError(r,t,e,n))return error.value;for(var u=0,i=e;n>=i;i++)u+=mathTrig.COMBIN(r,i)*Math.pow(t,i)*Math.pow(1-t,r-i);return u},exports.BINOM.INV=function(r,t,e){if(r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e))return error.value;for(var n=0;r>=n;){if(jStat.binomial.cdf(n,r,t)>=e)return n;n++}},exports.CHISQ={},exports.CHISQ.DIST=function(r,t,e){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:e?jStat.chisquare.cdf(r,t):jStat.chisquare.pdf(r,t)},exports.CHISQ.DIST.RT=function(r,t){return!r|!t?error.na:1>r||t>Math.pow(10,10)?error.num:"number"!=typeof r||"number"!=typeof t?error.value:1-jStat.chisquare.cdf(r,t)},exports.CHISQ.INV=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:jStat.chisquare.inv(r,t)},exports.CHISQ.INV.RT=function(r,t){return!r|!t?error.na:0>r||r>1||1>t||t>Math.pow(10,10)?error.num:"number"!=typeof r||"number"!=typeof t?error.value:jStat.chisquare.inv(1-r,t)},exports.CHISQ.TEST=function(r,t){function e(r,t){var e=Math.exp(-.5*r);t%2==1&&(e*=Math.sqrt(2*r/f));for(var n=t;n>=2;)e=e*r/n,n-=2;for(var u=e,i=t;u>1e-10*e;)i+=2,u=u*r/i,e+=u;return 1-e}if(2!==arguments.length)return error.na;if(!(r instanceof Array&&t instanceof Array))return error.value;if(r.length!==t.length)return error.value;if(r[0]&&t[0]&&r[0].length!==t[0].length)return error.value;var n,u,i,o=r.length;for(u=0;o>u;u++)r[u]instanceof Array||(n=r[u],r[u]=[],r[u].push(n)),t[u]instanceof Array||(n=t[u],t[u]=[],t[u].push(n));var a=r[0].length,s=1===a?o-1:(o-1)*(a-1),l=0,f=Math.PI;for(u=0;o>u;u++)for(i=0;a>i;i++)l+=Math.pow(r[u][i]-t[u][i],2)/t[u][i];return Math.round(1e6*e(l,s))/1e6},exports.COLUMN=function(r,t){return 2!==arguments.length?error.na:0>t?error.num:r instanceof Array&&"number"==typeof t?0===r.length?undefined:jStat.col(r,t):error.value},exports.COLUMNS=function(r){return 1!==arguments.length?error.na:r instanceof Array?0===r.length?0:jStat.cols(r):error.value},exports.CONFIDENCE={},exports.CONFIDENCE.NORM=function(r,t,e){return r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e)?error.value:jStat.normalci(1,r,t,e)[1]-1},exports.CONFIDENCE.T=function(r,t,e){return r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e)?error.value:jStat.tci(1,r,t,e)[1]-1},exports.CORREL=function(r,t){return r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t)?error.value:jStat.corrcoeff(r,t)},exports.COUNT=function(){return utils.numbers(utils.flatten(arguments)).length},exports.COUNTA=function(){var r=utils.flatten(arguments);return r.length-exports.COUNTBLANK(r)},exports.COUNTIN=function(r,t){var e=0;r=utils.flatten(r);for(var n=0;r.length>n;n++)r[n]===t&&e++;return e},exports.COUNTBLANK=function(){for(var r,t=utils.flatten(arguments),e=0,n=0;t.length>n;n++)null!==(r=t[n])&&""!==r||e++;return e},exports.COUNTIF=function(range,criteria){range=utils.flatten(range),/[<>=!]/.test(criteria)||(criteria='=="'+criteria+'"');for(var matches=0,i=0;range.length>i;i++)"string"!=typeof range[i]?eval(range[i]+criteria)&&matches++:eval('"'+range[i]+'"'+criteria)&&matches++;return matches},exports.COUNTIFS=function(){for(var args=utils.argsToArray(arguments),results=Array(utils.flatten(args[0]).length),i=0;results.length>i;i++)results[i]=!0;for(i=0;args.length>i;i+=2){var range=utils.flatten(args[i]),criteria=args[i+1];/[<>=!]/.test(criteria)||(criteria='=="'+criteria+'"');for(var j=0;range.length>j;j++)results[j]="string"!=typeof range[j]?results[j]&&eval(range[j]+criteria):results[j]&&eval('"'+range[j]+'"'+criteria)}var result=0;for(i=0;results.length>i;i++)results[i]&&result++;return result},exports.COUNTUNIQUE=function(){return misc.UNIQUE.apply(null,utils.flatten(arguments)).length},exports.COVARIANCE={},exports.COVARIANCE.P=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t))return error.value;for(var e=jStat.mean(r),n=jStat.mean(t),u=0,i=r.length,o=0;i>o;o++)u+=(r[o]-e)*(t[o]-n);return u/i},exports.COVARIANCE.S=function(r,t){return r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t)?error.value:jStat.covariance(r,t)},exports.DEVSQ=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var t=jStat.mean(r),e=0,n=0;r.length>n;n++)e+=Math.pow(r[n]-t,2);return e},exports.EXPON={},exports.EXPON.DIST=function(r,t,e){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:e?jStat.exponential.cdf(r,t):jStat.exponential.pdf(r,t)},exports.F={},exports.F.DIST=function(r,t,e,n){return r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e)?error.value:n?jStat.centralF.cdf(r,t,e):jStat.centralF.pdf(r,t,e)},exports.F.DIST.RT=function(r,t,e){return 3!==arguments.length?error.na:0>r||1>t||1>e?error.num:"number"!=typeof r||"number"!=typeof t||"number"!=typeof e?error.value:1-jStat.centralF.cdf(r,t,e)},exports.F.INV=function(r,t,e){return r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e)?error.value:0>=r||r>1?error.num:jStat.centralF.inv(r,t,e)},exports.F.INV.RT=function(r,t,e){return 3!==arguments.length?error.na:0>r||r>1||1>t||t>Math.pow(10,10)||1>e||e>Math.pow(10,10)?error.num:"number"!=typeof r||"number"!=typeof t||"number"!=typeof e?error.value:jStat.centralF.inv(1-r,t,e)},exports.F.TEST=function(r,t){if(!r||!t)return error.na;if(!(r instanceof Array&&t instanceof Array))return error.na;if(2>r.length||2>t.length)return error.div0;var e=function(r,t){for(var e=0,n=0;r.length>n;n++)e+=Math.pow(r[n]-t,2);return e},n=mathTrig.SUM(r)/r.length,u=mathTrig.SUM(t)/t.length;return e(r,n)/(r.length-1)/(e(t,u)/(t.length-1))},exports.FISHER=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.log((1+r)/(1-r))/2},exports.FISHERINV=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var t=Math.exp(2*r);return(t-1)/(t+1)},exports.FORECAST=function(r,t,e){if(r=utils.parseNumber(r),t=utils.parseNumberArray(utils.flatten(t)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,t,e))return error.value;for(var n=jStat.mean(e),u=jStat.mean(t),i=e.length,o=0,a=0,s=0;i>s;s++)o+=(e[s]-n)*(t[s]-u),a+=Math.pow(e[s]-n,2);var l=o/a;return u-l*n+l*r},exports.FREQUENCY=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t))return error.value;for(var e=r.length,n=t.length,u=[],i=0;n>=i;i++){u[i]=0;for(var o=0;e>o;o++)0===i?r[o]>t[0]||(u[0]+=1):n>i?r[o]>t[i-1]&&t[i]>=r[o]&&(u[i]+=1):i===n&&r[o]>t[n-1]&&(u[n]+=1)}return u},exports.GAMMA=function(r){return r=utils.parseNumber(r),r instanceof Error?r:0===r?error.num:parseInt(r,10)===r&&0>r?error.num:jStat.gammafn(r)},exports.GAMMA.DIST=function(r,t,e,n){return 4!==arguments.length?error.na:r>=0&&t>0&&e>0?"number"!=typeof r||"number"!=typeof t||"number"!=typeof e?error.value:n?jStat.gamma.cdf(r,t,e,!0):jStat.gamma.pdf(r,t,e,!1):error.value},exports.GAMMA.INV=function(r,t,e){return 3!==arguments.length?error.na:0>r||r>1||0>=t||0>=e?error.num:"number"!=typeof r||"number"!=typeof t||"number"!=typeof e?error.value:jStat.gamma.inv(r,t,e)},exports.GAMMALN=function(r){return r=utils.parseNumber(r),r instanceof Error?r:jStat.gammaln(r)},exports.GAMMALN.PRECISE=function(r){return 1!==arguments.length?error.na:r>0?"number"!=typeof r?error.value:jStat.gammaln(r):error.num},exports.GAUSS=function(r){return r=utils.parseNumber(r),r instanceof Error?r:jStat.normal.cdf(r,0,1)-.5},exports.GEOMEAN=function(){var r=utils.parseNumberArray(utils.flatten(arguments));return r instanceof Error?r:jStat.geomean(r)},exports.GROWTH=function(r,t,e,n){if((r=utils.parseNumberArray(r))instanceof Error)return r;var u;if(t===undefined)for(t=[],u=1;r.length>=u;u++)t.push(u);if(e===undefined)for(e=[],u=1;r.length>=u;u++)e.push(u);if(t=utils.parseNumberArray(t),e=utils.parseNumberArray(e),utils.anyIsError(t,e))return error.value;n===undefined&&(n=!0);var i=r.length,o=0,a=0,s=0,l=0;for(u=0;i>u;u++){var f=t[u],c=Math.log(r[u]);o+=f,a+=c,s+=f*c,l+=f*f}o/=i,a/=i,s/=i,l/=i;var p,m;n?(p=(s-o*a)/(l-o*o),m=a-p*o):(p=s/l,m=0);var d=[];for(u=0;e.length>u;u++)d.push(Math.exp(m+p*e[u]));return d},exports.HARMEAN=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var t=r.length,e=0,n=0;t>n;n++)e+=1/r[n];return t/e},exports.HYPGEOM={},exports.HYPGEOM.DIST=function(r,t,e,n,u){function i(r,t,e,n){return mathTrig.COMBIN(e,r)*mathTrig.COMBIN(n-e,t-r)/mathTrig.COMBIN(n,t)}function o(r,t,e,n){for(var u=0,o=0;r>=o;o++)u+=i(o,t,e,n);return u}return r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),n=utils.parseNumber(n),utils.anyIsError(r,t,e,n)?error.value:u?o(r,t,e,n):i(r,t,e,n)},exports.INTERCEPT=function(r,t){return r=utils.parseNumberArray(r),t=utils.parseNumberArray(t),utils.anyIsError(r,t)?error.value:r.length!==t.length?error.na:exports.FORECAST(0,r,t)},exports.KURT=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var t=jStat.mean(r),e=r.length,n=0,u=0;e>u;u++)n+=Math.pow(r[u]-t,4);return n/=Math.pow(jStat.stdev(r,!0),4),e*(e+1)/((e-1)*(e-2)*(e-3))*n-3*(e-1)*(e-1)/((e-2)*(e-3))},exports.LARGE=function(r,t){return r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumber(t),utils.anyIsError(r,t)?r:r.sort(function(r,t){return t-r})[t-1]},exports.LINEST=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t))return error.value;for(var e=jStat.mean(r),n=jStat.mean(t),u=t.length,i=0,o=0,a=0;u>a;a++)i+=(t[a]-n)*(r[a]-e),o+=Math.pow(t[a]-n,2);var s=i/o;return[s,e-s*n]},exports.LOGEST=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t))return error.value;for(var e=0;r.length>e;e++)r[e]=Math.log(r[e]);var n=exports.LINEST(r,t);return n[0]=Math.round(1e6*Math.exp(n[0]))/1e6,n[1]=Math.round(1e6*Math.exp(n[1]))/1e6,n},exports.LOGNORM={},exports.LOGNORM.DIST=function(r,t,e,n){return r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e)?error.value:n?jStat.lognormal.cdf(r,t,e):jStat.lognormal.pdf(r,t,e)},exports.LOGNORM.INV=function(r,t,e){return r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e)?error.value:jStat.lognormal.inv(r,t,e)},exports.MAX=function(){var r=utils.numbers(utils.flatten(arguments));return 0===r.length?0:Math.max.apply(Math,r)},exports.MAXA=function(){var r=utils.arrayValuesToNumbers(utils.flatten(arguments));return 0===r.length?0:Math.max.apply(Math,r)},exports.MEDIAN=function(){var r=utils.arrayValuesToNumbers(utils.flatten(arguments)),t=jStat.median(r);return isNaN(t)&&(t=error.num),t},exports.MIN=function(){var r=utils.numbers(utils.flatten(arguments));return 0===r.length?0:Math.min.apply(Math,r)},exports.MINA=function(){var r=utils.arrayValuesToNumbers(utils.flatten(arguments));return 0===r.length?0:Math.min.apply(Math,r)},exports.MODE={},exports.MODE.MULT=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var t,e=r.length,n={},u=[],i=0,o=0;e>o;o++)t=r[o],n[t]=n[t]?n[t]+1:1,n[t]>i&&(i=n[t],u=[]),n[t]===i&&(u[u.length]=t);return u},exports.MODE.SNGL=function(){var r=utils.parseNumberArray(utils.flatten(arguments));return r instanceof Error?r:exports.MODE.MULT(r).sort(function(r,t){return r-t})[0]},exports.NEGBINOM={},exports.NEGBINOM.DIST=function(r,t,e,n){return r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e)?error.value:n?jStat.negbin.cdf(r,t,e):jStat.negbin.pdf(r,t,e)},exports.NORM={},exports.NORM.DIST=function(r,t,e,n){return r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e)?error.value:e>0?n?jStat.normal.cdf(r,t,e):jStat.normal.pdf(r,t,e):error.num},exports.NORM.INV=function(r,t,e){return r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e)?error.value:jStat.normal.inv(r,t,e)},exports.NORM.S={},exports.NORM.S.DIST=function(r,t){return r=utils.parseNumber(r),r instanceof Error?error.value:t?jStat.normal.cdf(r,0,1):jStat.normal.pdf(r,0,1)},exports.NORM.S.INV=function(r){return r=utils.parseNumber(r),r instanceof Error?error.value:jStat.normal.inv(r,0,1)},exports.PEARSON=function(r,t){if(t=utils.parseNumberArray(utils.flatten(t)),r=utils.parseNumberArray(utils.flatten(r)),utils.anyIsError(t,r))return error.value;for(var e=jStat.mean(r),n=jStat.mean(t),u=r.length,i=0,o=0,a=0,s=0;u>s;s++)i+=(r[s]-e)*(t[s]-n),o+=Math.pow(r[s]-e,2),a+=Math.pow(t[s]-n,2);return i/Math.sqrt(o*a)},exports.PERCENTILE={},exports.PERCENTILE.EXC=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumber(t),utils.anyIsError(r,t))return error.value;r=r.sort(function(r,t){return r-t});var e=r.length;if(1/(e+1)>t||t>1-1/(e+1))return error.num;var n=t*(e+1)-1,u=Math.floor(n);return utils.cleanFloat(n===u?r[n]:r[u]+(n-u)*(r[u+1]-r[u]))},exports.PERCENTILE.INC=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumber(t),utils.anyIsError(r,t))return error.value;r=r.sort(function(r,t){return r-t});var e=r.length,n=t*(e-1),u=Math.floor(n);return utils.cleanFloat(n===u?r[n]:r[u]+(n-u)*(r[u+1]-r[u]))},exports.PERCENTRANK={},exports.PERCENTRANK.EXC=function(r,t,e){if(e=e===undefined?3:e,r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e))return error.value;r=r.sort(function(r,t){return r-t});for(var n=misc.UNIQUE.apply(null,r),u=r.length,i=n.length,o=Math.pow(10,e),a=0,s=!1,l=0;!s&&i>l;)t===n[l]?(a=(r.indexOf(n[l])+1)/(u+1),s=!0):n[l]>t||t>=n[l+1]&&l!==i-1||(a=(r.indexOf(n[l])+1+(t-n[l])/(n[l+1]-n[l]))/(u+1),s=!0),l++;return Math.floor(a*o)/o},exports.PERCENTRANK.INC=function(r,t,e){if(e=e===undefined?3:e,r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e))return error.value;r=r.sort(function(r,t){return r-t});for(var n=misc.UNIQUE.apply(null,r),u=r.length,i=n.length,o=Math.pow(10,e),a=0,s=!1,l=0;!s&&i>l;)t===n[l]?(a=r.indexOf(n[l])/(u-1),s=!0):n[l]>t||t>=n[l+1]&&l!==i-1||(a=(r.indexOf(n[l])+(t-n[l])/(n[l+1]-n[l]))/(u-1),s=!0),l++;return Math.floor(a*o)/o},exports.PERMUT=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:mathTrig.FACT(r)/mathTrig.FACT(r-t)},exports.PERMUTATIONA=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:Math.pow(r,t)},exports.PHI=function(r){return r=utils.parseNumber(r),r instanceof Error?error.value:Math.exp(-.5*r*r)/2.5066282746310002},exports.POISSON={},exports.POISSON.DIST=function(r,t,e){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:e?jStat.poisson.cdf(r,t):jStat.poisson.pdf(r,t)},exports.PROB=function(r,t,e,n){if(e===undefined)return 0;if(n=n===undefined?e:n,r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),e=utils.parseNumber(e),n=utils.parseNumber(n),utils.anyIsError(r,t,e,n))return error.value;if(e===n)return 0>r.indexOf(e)?0:t[r.indexOf(e)];for(var u=r.sort(function(r,t){return r-t}),i=u.length,o=0,a=0;i>a;a++)e>u[a]||u[a]>n||(o+=t[r.indexOf(u[a])]);return o},exports.QUARTILE={},exports.QUARTILE.EXC=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumber(t),utils.anyIsError(r,t))return error.value;switch(t){case 1:return exports.PERCENTILE.EXC(r,.25);case 2:return exports.PERCENTILE.EXC(r,.5);case 3:return exports.PERCENTILE.EXC(r,.75);default:return error.num}},exports.QUARTILE.INC=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumber(t),utils.anyIsError(r,t))return error.value;switch(t){case 1:return exports.PERCENTILE.INC(r,.25);case 2:return exports.PERCENTILE.INC(r,.5);case 3:return exports.PERCENTILE.INC(r,.75);default:return error.num}},exports.RANK={},exports.RANK.AVG=function(r,t,e){if(r=utils.parseNumber(r),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t))return error.value;t=utils.flatten(t),e=e||!1,t=t.sort(e?function(r,t){return r-t}:function(r,t){return t-r});for(var n=t.length,u=0,i=0;n>i;i++)t[i]===r&&u++;return u>1?(2*t.indexOf(r)+u+1)/2:t.indexOf(r)+1},exports.RANK.EQ=function(r,t,e){return r=utils.parseNumber(r),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t)?error.value:(e=e||!1,t=t.sort(e?function(r,t){return r-t}:function(r,t){return t-r}),t.indexOf(r)+1)},exports.ROW=function(r,t){return 2!==arguments.length?error.na:0>t?error.num:r instanceof Array&&"number"==typeof t?0===r.length?undefined:jStat.row(r,t):error.value},exports.ROWS=function(r){return 1!==arguments.length?error.na:r instanceof Array?0===r.length?0:jStat.rows(r):error.value},exports.RSQ=function(r,t){return r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t)?error.value:Math.pow(exports.PEARSON(r,t),2)},exports.SKEW=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var t=jStat.mean(r),e=r.length,n=0,u=0;e>u;u++)n+=Math.pow(r[u]-t,3);return e*n/((e-1)*(e-2)*Math.pow(jStat.stdev(r,!0),3))},exports.SKEW.P=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var t=jStat.mean(r),e=r.length,n=0,u=0,i=0;e>i;i++)u+=Math.pow(r[i]-t,3),n+=Math.pow(r[i]-t,2);return u/=e,n/=e,u/Math.pow(n,1.5)},exports.SLOPE=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t))return error.value;for(var e=jStat.mean(t),n=jStat.mean(r),u=t.length,i=0,o=0,a=0;u>a;a++)i+=(t[a]-e)*(r[a]-n),o+=Math.pow(t[a]-e,2);return i/o},exports.SMALL=function(r,t){return r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumber(t),utils.anyIsError(r,t)?r:r.sort(function(r,t){return r-t})[t-1]},exports.STANDARDIZE=function(r,t,e){return r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e)?error.value:(r-t)/e},exports.STDEV={},exports.STDEV.P=function(){var r=exports.VAR.P.apply(this,arguments),t=Math.sqrt(r);return isNaN(t)&&(t=error.num),t},exports.STDEV.S=function(){var r=exports.VAR.S.apply(this,arguments);return Math.sqrt(r)},exports.STDEVA=function(){var r=exports.VARA.apply(this,arguments);return Math.sqrt(r)},exports.STDEVPA=function(){var r=exports.VARPA.apply(this,arguments),t=Math.sqrt(r);return isNaN(t)&&(t=error.num),t},exports.STEYX=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t))return error.value;for(var e=jStat.mean(t),n=jStat.mean(r),u=t.length,i=0,o=0,a=0,s=0;u>s;s++)i+=Math.pow(r[s]-n,2),o+=(t[s]-e)*(r[s]-n),a+=Math.pow(t[s]-e,2);return Math.sqrt((i-o*o/a)/(u-2))},exports.TRANSPOSE=function(r){return r?jStat.transpose(r):error.na},exports.T=text.T,exports.T.DIST=function(r,t,e){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:e?jStat.studentt.cdf(r,t):jStat.studentt.pdf(r,t)},exports.T.DIST["2T"]=function(r,t){return 2!==arguments.length?error.na:0>r||1>t?error.num:"number"!=typeof r||"number"!=typeof t?error.value:2*(1-jStat.studentt.cdf(r,t))},exports.T.DIST.RT=function(r,t){return 2!==arguments.length?error.na:0>r||1>t?error.num:"number"!=typeof r||"number"!=typeof t?error.value:1-jStat.studentt.cdf(r,t)},exports.T.INV=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),utils.anyIsError(r,t)?error.value:jStat.studentt.inv(r,t)},exports.T.INV["2T"]=function(r,t){return r=utils.parseNumber(r),t=utils.parseNumber(t),0>=r||r>1||1>t?error.num:utils.anyIsError(r,t)?error.value:Math.abs(jStat.studentt.inv(r/2,t))},exports.T.TEST=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,t))return error.value;var e,n=jStat.mean(r),u=jStat.mean(t),i=0,o=0;for(e=0;r.length>e;e++)i+=Math.pow(r[e]-n,2);for(e=0;t.length>e;e++)o+=Math.pow(t[e]-u,2);return i/=r.length-1,o/=t.length-1,exports.T.DIST["2T"](Math.abs(n-u)/Math.sqrt(i/r.length+o/t.length),r.length+t.length-2)},exports.TREND=function(r,t,e){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumberArray(utils.flatten(t)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,t,e))return error.value;var n=exports.LINEST(r,t),u=n[0],i=n[1],o=[];return e.forEach(function(r){o.push(u*r+i)}),o},exports.TRIMMEAN=function(r,t){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumber(t),utils.anyIsError(r,t))return error.value;var e=mathTrig.FLOOR(r.length*t,2)/2;return jStat.mean(utils.initial(utils.rest(r.sort(function(r,t){return r-t}),e),e))},exports.VAR={},exports.VAR.P=function(){for(var r,t=utils.numbers(utils.flatten(arguments)),e=t.length,n=0,u=exports.AVERAGE(t),i=0;e>i;i++)n+=Math.pow(t[i]-u,2);return r=n/e,isNaN(r)&&(r=error.num),r},exports.VAR.S=function(){for(var r=utils.numbers(utils.flatten(arguments)),t=r.length,e=0,n=exports.AVERAGE(r),u=0;t>u;u++)e+=Math.pow(r[u]-n,2);return e/(t-1)},exports.VARA=function(){for(var r=utils.flatten(arguments),t=r.length,e=0,n=0,u=exports.AVERAGEA(r),i=0;t>i;i++){var o=r[i];e+="number"==typeof o?Math.pow(o-u,2):o===!0?Math.pow(1-u,2):Math.pow(0-u,2),null!==o&&n++}return e/(n-1)},exports.VARPA=function(){for(var r,t=utils.flatten(arguments),e=t.length,n=0,u=0,i=exports.AVERAGEA(t),o=0;e>o;o++){var a=t[o];n+="number"==typeof a?Math.pow(a-i,2):a===!0?Math.pow(1-i,2):Math.pow(0-i,2),null!==a&&u++}return r=n/u,isNaN(r)&&(r=error.num),r},exports.WEIBULL={},exports.WEIBULL.DIST=function(r,t,e,n){return r=utils.parseNumber(r),t=utils.parseNumber(t),e=utils.parseNumber(e),utils.anyIsError(r,t,e)?error.value:n?1-Math.exp(-Math.pow(r/e,t)):Math.pow(r,t-1)*Math.exp(-Math.pow(r/e,t))*t/Math.pow(e,t)},exports.Z={},exports.Z.TEST=function(r,t,e){if(r=utils.parseNumberArray(utils.flatten(r)),t=utils.parseNumber(t),utils.anyIsError(r,t))return error.value;e=e||exports.STDEV.S(r);var n=r.length;return 1-exports.NORM.S.DIST((exports.AVERAGE(r)-t)/(e/Math.sqrt(n)),!0)}},function(r,t,e){function n(r){return 1===new Date(r,1,29).getMonth()}function u(r,t){return Math.ceil((t-r)/1e3/60/60/24)}function i(r){return(r-s)/864e5+(r>-22038912e5?2:1)}var o=e(0),a=e(2),s=new Date(1900,0,1),l=[undefined,0,1,undefined,undefined,undefined,undefined,undefined,undefined,undefined,undefined,undefined,1,2,3,4,5,6,0],f=[[],[1,2,3,4,5,6,7],[7,1,2,3,4,5,6],[6,0,1,2,3,4,5],[],[],[],[],[],[],[],[7,1,2,3,4,5,6],[6,7,1,2,3,4,5],[5,6,7,1,2,3,4],[4,5,6,7,1,2,3],[3,4,5,6,7,1,2],[2,3,4,5,6,7,1],[1,2,3,4,5,6,7]],c=[[],[6,0],[0,1],[1,2],[2,3],[3,4],[4,5],[5,6],undefined,undefined,undefined,[0,0],[1,1],[2,2],[3,3],[4,4],[5,5],[6,6]];t.DATE=function(r,t,e){return r=a.parseNumber(r),t=a.parseNumber(t),e=a.parseNumber(e),a.anyIsError(r,t,e)?o.value:0>r||0>t||0>e?o.num:new Date(r,t-1,e)},t.DATEVALUE=function(r){if("string"!=typeof r)return o.value;var t=Date.parse(r);return isNaN(t)?o.value:t>-22038912e5?(t-s)/864e5+2:(t-s)/864e5+1},t.DAY=function(r){var t=a.parseDate(r);return t instanceof Error?t:t.getDate()},t.DAYS=function(r,t){return r=a.parseDate(r),t=a.parseDate(t),r instanceof Error?r:t instanceof Error?t:i(r)-i(t)},t.DAYS360=function(r,t,e){if(e=a.parseBool(e),r=a.parseDate(r),t=a.parseDate(t),r instanceof Error)return r;if(t instanceof Error)return t;if(e instanceof Error)return e;var n,u,i=r.getMonth(),o=t.getMonth();if(e)n=31===r.getDate()?30:r.getDate(),u=31===t.getDate()?30:t.getDate();else{var s=new Date(r.getFullYear(),i+1,0).getDate(),l=new Date(t.getFullYear(),o+1,0).getDate();n=r.getDate()===s?30:r.getDate(),t.getDate()===l?30>n?(o++,u=1):u=30:u=t.getDate()}return 360*(t.getFullYear()-r.getFullYear())+30*(o-i)+(u-n)},t.EDATE=function(r,t){return(r=a.parseDate(r))instanceof Error?r:isNaN(t)?o.value:(t=parseInt(t,10),r.setMonth(r.getMonth()+t),i(r))},t.EOMONTH=function(r,t){return(r=a.parseDate(r))instanceof Error?r:isNaN(t)?o.value:(t=parseInt(t,10),i(new Date(r.getFullYear(),r.getMonth()+t+1,0)))},t.HOUR=function(r){return r=a.parseDate(r),r instanceof Error?r:r.getHours()},t.INTERVAL=function(r){if("number"!=typeof r&&"string"!=typeof r)return o.value;r=parseInt(r,10);var t=Math.floor(r/94608e4);r%=94608e4;var e=Math.floor(r/2592e3);r%=2592e3;var n=Math.floor(r/86400);r%=86400;var u=Math.floor(r/3600);r%=3600;var i=Math.floor(r/60);r%=60;var a=r;return t=t>0?t+"Y":"",e=e>0?e+"M":"",n=n>0?n+"D":"",u=u>0?u+"H":"",i=i>0?i+"M":"",a=a>0?a+"S":"","P"+t+e+n+"T"+u+i+a},t.ISOWEEKNUM=function(r){if((r=a.parseDate(r))instanceof Error)return r;r.setHours(0,0,0),r.setDate(r.getDate()+4-(r.getDay()||7));var t=new Date(r.getFullYear(),0,1);return Math.ceil(((r-t)/864e5+1)/7)},t.MINUTE=function(r){return r=a.parseDate(r),r instanceof Error?r:r.getMinutes()},t.MONTH=function(r){return r=a.parseDate(r),r instanceof Error?r:r.getMonth()+1},t.NETWORKDAYS=function(r,t,e){return this.NETWORKDAYS.INTL(r,t,1,e)},t.NETWORKDAYS.INTL=function(r,t,e,n){if((r=a.parseDate(r))instanceof Error)return r;if((t=a.parseDate(t))instanceof Error)return t;if(!((e=e===undefined?c[1]:c[e])instanceof Array))return o.value;n===undefined?n=[]:n instanceof Array||(n=[n]);for(var u=0;n.length>u;u++){var i=a.parseDate(n[u]);if(i instanceof Error)return i;n[u]=i}var s=(t-r)/864e5+1,l=s,f=r;for(u=0;s>u;u++){var p=(new Date).getTimezoneOffset()>0?f.getUTCDay():f.getDay(),m=!1;p!==e[0]&&p!==e[1]||(m=!0);for(var d=0;n.length>d;d++){var h=n[d];if(h.getDate()===f.getDate()&&h.getMonth()===f.getMonth()&&h.getFullYear()===f.getFullYear()){m=!0;break}}m&&l--,f.setDate(f.getDate()+1)}return l},t.NOW=function(){return new Date},t.SECOND=function(r){return r=a.parseDate(r),r instanceof Error?r:r.getSeconds()},t.TIME=function(r,t,e){return r=a.parseNumber(r),t=a.parseNumber(t),e=a.parseNumber(e),a.anyIsError(r,t,e)?o.value:0>r||0>t||0>e?o.num:(3600*r+60*t+e)/86400},t.TIMEVALUE=function(r){return r=a.parseDate(r),r instanceof Error?r:(3600*r.getHours()+60*r.getMinutes()+r.getSeconds())/86400},t.TODAY=function(){return new Date},t.WEEKDAY=function(r,t){return(r=a.parseDate(r))instanceof Error?r:(t===undefined&&(t=1),f[t][r.getDay()])},t.WEEKNUM=function(r,t){if((r=a.parseDate(r))instanceof Error)return r;if(t===undefined&&(t=1),21===t)return this.ISOWEEKNUM(r);var e=l[t],n=new Date(r.getFullYear(),0,1),u=n.getDay()t)return o.num;if(!((e=e===undefined?c[1]:c[e])instanceof Array))return o.value;n===undefined?n=[]:n instanceof Array||(n=[n]);for(var u=0;n.length>u;u++){var i=a.parseDate(n[u]);if(i instanceof Error)return i;n[u]=i}for(var s=0;t>s;){r.setDate(r.getDate()+1);var l=r.getDay();if(l!==e[0]&&l!==e[1]){for(var f=0;n.length>f;f++){var p=n[f];if(p.getDate()===r.getDate()&&p.getMonth()===r.getMonth()&&p.getFullYear()===r.getFullYear()){s--;break}}s++}}return r},t.YEAR=function(r){return r=a.parseDate(r),r instanceof Error?r:r.getFullYear()},t.YEARFRAC=function(r,t,e){if((r=a.parseDate(r))instanceof Error)return r;if((t=a.parseDate(t))instanceof Error)return t;e=e||0;var i=r.getDate(),o=r.getMonth()+1,s=r.getFullYear(),l=t.getDate(),f=t.getMonth()+1,c=t.getFullYear();switch(e){case 0:return 31===i&&31===l?(i=30,l=30):31===i?i=30:30===i&&31===l&&(l=30),(l+30*f+360*c-(i+30*o+360*s))/360;case 1:var p=function(r,t){var e=r.getFullYear(),u=new Date(e,2,1);if(n(e)&&u>r&&t>=u)return!0;var i=t.getFullYear(),o=new Date(i,2,1);return n(i)&&t>=o&&o>r},m=365;if(s===c||s+1===c&&(o>f||o===f&&i>=l))return(s===c&&n(s)||p(r,t)||1===f&&29===l)&&(m=366),u(r,t)/m;var d=c-s+1,h=(new Date(c+1,0,1)-new Date(s,0,1))/1e3/60/60/24,E=h/d;return u(r,t)/E;case 2:return u(r,t)/360;case 3:return u(r,t)/365;case 4:return(l+30*f+360*c-(i+30*o+360*s))/360}}},function(r,t,e){var n=e(0);t.CELL=function(){throw Error("CELL is not implemented")},t.ERROR={},t.ERROR.TYPE=function(r){switch(r){case n.nil:return 1;case n.div0:return 2;case n.value:return 3;case n.ref:return 4;case n.name:return 5;case n.num:return 6;case n.na:return 7;case n.data:return 8}return n.na},t.INFO=function(){throw Error("INFO is not implemented")},t.ISBLANK=function(r){return null===r},t.ISBINARY=function(r){return/^[01]{1,10}$/.test(r)},t.ISERR=function(r){return[n.value,n.ref,n.div0,n.num,n.name,n.nil].indexOf(r)>=0||"number"==typeof r&&(isNaN(r)||!isFinite(r))},t.ISERROR=function(r){return t.ISERR(r)||r===n.na},t.ISEVEN=function(r){return!(1&Math.floor(Math.abs(r)))},t.ISFORMULA=function(){throw Error("ISFORMULA is not implemented")},t.ISLOGICAL=function(r){return r===!0||r===!1},t.ISNA=function(r){return r===n.na},t.ISNONTEXT=function(r){return"string"!=typeof r},t.ISNUMBER=function(r){return"number"==typeof r&&!isNaN(r)&&isFinite(r)},t.ISODD=function(r){return!!(1&Math.floor(Math.abs(r)))},t.ISREF=function(){throw Error("ISREF is not implemented")},t.ISTEXT=function(r){return"string"==typeof r},t.N=function(r){return this.ISNUMBER(r)?r:r instanceof Date?r.getTime():r===!0?1:r===!1?0:this.ISERROR(r)?r:0},t.NA=function(){return n.na},t.SHEET=function(){throw Error("SHEET is not implemented")},t.SHEETS=function(){throw Error("SHEETS is not implemented")},t.TYPE=function(r){return this.ISNUMBER(r)?1:this.ISTEXT(r)?2:this.ISLOGICAL(r)?4:this.ISERROR(r)?16:Array.isArray(r)?64:void 0}},function(r,t,e){var n=e(2),u=e(0),i=e(14);t.ASC=function(){throw Error("ASC is not implemented")},t.BAHTTEXT=function(){throw Error("BAHTTEXT is not implemented")},t.CHAR=function(r){return r=n.parseNumber(r),r instanceof Error?r:String.fromCharCode(r)},t.CLEAN=function(r){return r=r||"",r.replace(/[\0-\x1F]/g,"")},t.CODE=function(r){r=r||"";var t=r.charCodeAt(0);return isNaN(t)&&(t=u.na),t},t.CONCATENATE=function(){for(var r=n.flatten(arguments),t=0;(t=r.indexOf(!0))>-1;)r[t]="TRUE";for(var e=0;(e=r.indexOf(!1))>-1;)r[e]="FALSE";return r.join("")},t.DBCS=function(){throw Error("DBCS is not implemented")},t.DOLLAR=function(r,t){if(t=t===undefined?2:t,r=n.parseNumber(r),t=n.parseNumber(t),n.anyIsError(r,t))return u.value;var e="";return t>0?t>0&&(e="($0,0."+Array(t+1).join("0")+")"):(r=Math.round(r*Math.pow(10,t))/Math.pow(10,t),e="($0,0)"),i(r).format(e)},t.EXACT=function(r,t){return 2!==arguments.length?u.na:r===t},t.FIND=function(r,t,e){return 2>arguments.length?u.na:(e=e===undefined?0:e,t?t.indexOf(r,e-1)+1:null)},t.FIXED=function(r,t,e){if(t=t===undefined?2:t,e=e!==undefined&&e,r=n.parseNumber(r),t=n.parseNumber(t),n.anyIsError(r,t))return u.value;var o=e?"0":"0,0";return t>0?t>0&&(o+="."+Array(t+1).join("0")):r=Math.round(r*Math.pow(10,t))/Math.pow(10,t),i(r).format(o)},t.HTML2TEXT=function(r){var t="";return r&&(r instanceof Array?r.forEach(function(r){""!==t&&(t+="\n"),t+=r.replace(/<(?:.|\n)*?>/gm,"")}):t=r.replace(/<(?:.|\n)*?>/gm,"")),t},t.LEFT=function(r,t){return t=t===undefined?1:t,t=n.parseNumber(t),t instanceof Error||"string"!=typeof r?u.value:r?r.substring(0,t):null},t.LEN=function(r){return 0===arguments.length?u.error:"string"==typeof r?r?r.length:0:r.length?r.length:u.value},t.LOWER=function(r){return"string"!=typeof r?u.value:r?r.toLowerCase():r},t.MID=function(r,t,e){if(t=n.parseNumber(t),e=n.parseNumber(e),n.anyIsError(t,e)||"string"!=typeof r)return e;var u=t-1;return r.substring(u,u+e)},t.NUMBERVALUE=function(r,t,e){return t=void 0===t?".":t,e=void 0===e?",":e,+r.replace(t,".").replace(e,"")},t.PRONETIC=function(){throw Error("PRONETIC is not implemented")},t.PROPER=function(r){return r===undefined||0===r.length?u.value:(r===!0&&(r="TRUE"),r===!1&&(r="FALSE"),isNaN(r)&&"number"==typeof r?u.value:("number"==typeof r&&(r=""+r),r.replace(/\w\S*/g,function(r){return r.charAt(0).toUpperCase()+r.substr(1).toLowerCase()})))},t.REGEXEXTRACT=function(r,t){if(2>arguments.length)return u.na;var e=r.match(RegExp(t));return e?e[e.length>1?e.length-1:0]:null},t.REGEXMATCH=function(r,t,e){if(2>arguments.length)return u.na;var n=r.match(RegExp(t));return e?n:!!n},t.REGEXREPLACE=function(r,t,e){return 3>arguments.length?u.na:r.replace(RegExp(t),e)},t.REPLACE=function(r,t,e,i){return t=n.parseNumber(t),e=n.parseNumber(e),n.anyIsError(t,e)||"string"!=typeof r||"string"!=typeof i?u.value:r.substr(0,t-1)+i+r.substr(t-1+e)},t.REPT=function(r,t){return t=n.parseNumber(t),t instanceof Error?t:Array(t+1).join(r)},t.RIGHT=function(r,t){return t=t===undefined?1:t,t=n.parseNumber(t),t instanceof Error?t:r?r.substring(r.length-t):u.na},t.SEARCH=function(r,t,e){var n;return"string"!=typeof r||"string"!=typeof t?u.value:(e=e===undefined?0:e,n=t.toLowerCase().indexOf(r.toLowerCase(),e-1)+1,0===n?u.value:n)},t.SPLIT=function(r,t){return r.split(t)},t.SUBSTITUTE=function(r,t,e,n){if(2>arguments.length)return u.na;if(!(r&&t&&e))return r;if(n===undefined)return r.replace(RegExp(t,"g"),e);for(var i=0,o=0;r.indexOf(t,i)>0;)if(i=r.indexOf(t,i+1),++o===n)return r.substring(0,i)+e+r.substring(i+t.length)},t.T=function(r){return"string"==typeof r?r:""},t.TEXT=function(r,t){return r=n.parseNumber(r),n.anyIsError(r)?u.na:i(r).format(t)},t.TRIM=function(r){return"string"!=typeof r?u.value:r.replace(/ +/g," ").trim()},t.UNICHAR=t.CHAR,t.UNICODE=t.CODE,t.UPPER=function(r){return"string"!=typeof r?u.value:r.toUpperCase()},t.VALUE=function(r){if("string"!=typeof r)return u.value;var t=i().unformat(r);return void 0===t?0:t}},function(r,t,e){"use strict";function n(r){var t=parseInt(r,10);return t=isNaN(t)?-1:Math.max(t-1,-1)}function u(r){var t="";return 0>r||(t=""+(r+1)),t}function i(r){var t=0;if("string"==typeof r){r=r.toUpperCase();for(var e=0,n=r.length-1;r.length>e;e+=1,n-=1)t+=Math.pow(f,n)*(l.indexOf(r[e])+1)}return--t}function o(r){for(var t="";r>=0;)t=String.fromCharCode(r%f+97)+t,r=Math.floor(r/f)-1;return t.toUpperCase()}function a(r){if("string"!=typeof r||!c.test(r))return[];var t=r.toUpperCase().match(c),e=t[1],u=t[2],o=t[3],a=t[4];return[{index:n(a),label:a,isAbsolute:"$"===o},{index:i(u),label:u,isAbsolute:"$"===e}]}function s(r,t){var e=(r.isAbsolute?"$":"")+u(r.index);return(t.isAbsolute?"$":"")+o(t.index)+e}t.__esModule=!0,t.rowLabelToIndex=n,t.rowIndexToLabel=u,t.columnLabelToIndex=i,t.columnIndexToLabel=o,t.extractLabel=a,t.toLabel=s;var l="ABCDEFGHIJKLMNOPQRSTUVWXYZ",f=l.length,c=/^([$])?([A-Za-z]+)([$])?([0-9]+)$/},function(r,t,e){"use strict";t.__esModule=!0,t["default"]=["ABS","ACCRINT","ACOS","ACOSH","ACOT","ACOTH","ADD","AGGREGATE","AND","ARABIC","ARGS2ARRAY","ASIN","ASINH","ATAN","ATAN2","ATANH","AVEDEV","AVERAGE","AVERAGEA","AVERAGEIF","AVERAGEIFS","BASE","BESSELI","BESSELJ","BESSELK","BESSELY","BETA.DIST","BETA.INV","BETADIST","BETAINV","BIN2DEC","BIN2HEX","BIN2OCT","BINOM.DIST","BINOM.DIST.RANGE","BINOM.INV","BINOMDIST","BITAND","BITLSHIFT","BITOR","BITRSHIFT","BITXOR","CEILING","CEILINGMATH","CEILINGPRECISE","CHAR","CHISQ.DIST","CHISQ.DIST.RT","CHISQ.INV","CHISQ.INV.RT","CHOOSE","CHOOSE","CLEAN","CODE","COLUMN","COLUMNS","COMBIN","COMBINA","COMPLEX","CONCATENATE","CONFIDENCE","CONFIDENCE.NORM","CONFIDENCE.T","CONVERT","CORREL","COS","COSH","COT","COTH","COUNT","COUNTA","COUNTBLANK","COUNTIF","COUNTIFS","COUNTIN","COUNTUNIQUE","COVARIANCE.P","COVARIANCE.S","CSC","CSCH","CUMIPMT","CUMPRINC","DATE","DATEVALUE","DAY","DAYS","DAYS360","DB","DDB","DEC2BIN","DEC2HEX","DEC2OCT","DECIMAL","DEGREES","DELTA","DEVSQ","DIVIDE","DOLLAR","DOLLARDE","DOLLARFR","E","EDATE","EFFECT","EOMONTH","EQ","ERF","ERFC","EVEN","EXACT","EXPON.DIST","EXPONDIST","F.DIST","F.DIST.RT","F.INV","F.INV.RT","FACT","FACTDOUBLE","FALSE","FDIST","FDISTRT","FIND","FINV","FINVRT","FISHER","FISHERINV","FIXED","FLATTEN","FLOOR","FORECAST","FREQUENCY","FV","FVSCHEDULE","GAMMA","GAMMA.DIST","GAMMA.INV","GAMMADIST","GAMMAINV","GAMMALN","GAMMALN.PRECISE","GAUSS","GCD","GEOMEAN","GESTEP","GROWTH","GTE","HARMEAN","HEX2BIN","HEX2DEC","HEX2OCT","HOUR","HTML2TEXT","HYPGEOM.DIST","HYPGEOMDIST","IF","IMABS","IMAGINARY","IMARGUMENT","IMCONJUGATE","IMCOS","IMCOSH","IMCOT","IMCSC","IMCSCH","IMDIV","IMEXP","IMLN","IMLOG10","IMLOG2","IMPOWER","IMPRODUCT","IMREAL","IMSEC","IMSECH","IMSIN","IMSINH","IMSQRT","IMSUB","IMSUM","IMTAN","INT","INTERCEPT","INTERVAL","IPMT","IRR","ISBINARY","ISBLANK","ISEVEN","ISLOGICAL","ISNONTEXT","ISNUMBER","ISODD","ISODD","ISOWEEKNUM","ISPMT","ISTEXT","JOIN","KURT","LARGE","LCM","LEFT","LEN","LINEST","LN","LOG","LOG10","LOGEST","LOGNORM.DIST","LOGNORM.INV","LOGNORMDIST","LOGNORMINV","LOWER","LT","LTE","MATCH","MAX","MAXA","MEDIAN","MID","MIN","MINA","MINUS","MINUTE","MIRR","MOD","MODE.MULT","MODE.SNGL","MODEMULT","MODESNGL","MONTH","MROUND","MULTINOMIAL","MULTIPLY","NE","NEGBINOM.DIST","NEGBINOMDIST","NETWORKDAYS","NOMINAL","NORM.DIST","NORM.INV","NORM.S.DIST","NORM.S.INV","NORMDIST","NORMINV","NORMSDIST","NORMSINV","NOT","NOW","NPER","NPV","NUMBERS","NUMERAL","OCT2BIN","OCT2DEC","OCT2HEX","ODD","OR","PDURATION","PEARSON","PERCENTILEEXC","PERCENTILEINC","PERCENTRANKEXC","PERCENTRANKINC","PERMUT","PERMUTATIONA","PHI","PI","PMT","POISSON.DIST","POISSONDIST","POW","POWER","PPMT","PROB","PRODUCT","PROPER","PV","QUARTILE.EXC","QUARTILE.INC","QUARTILEEXC","QUARTILEINC","QUOTIENT","RADIANS","RAND","RANDBETWEEN","RANK.AVG","RANK.EQ","RANKAVG","RANKEQ","RATE","REFERENCE","REGEXEXTRACT","REGEXMATCH","REGEXREPLACE","REPLACE","REPT","RIGHT","ROMAN","ROUND","ROUNDDOWN","ROUNDUP","ROW","ROWS","RRI","RSQ","SEARCH","SEC","SECH","SECOND","SERIESSUM","SIGN","SIN","SINH","SKEW","SKEW.P","SKEWP","SLN","SLOPE","SMALL","SPLIT","SPLIT","SQRT","SQRTPI","STANDARDIZE","STDEV.P","STDEV.S","STDEVA","STDEVP","STDEVPA","STDEVS","STEYX","SUBSTITUTE","SUBTOTAL","SUM","SUMIF","SUMIFS","SUMPRODUCT","SUMSQ","SUMX2MY2","SUMX2PY2","SUMXMY2","SWITCH","SYD","T","T.DIST","T.DIST.2T","T.DIST.RT","T.INV","T.INV.2T","TAN","TANH","TBILLEQ","TBILLPRICE","TBILLYIELD","TDIST","TDIST2T","TDISTRT","TEXT","TIME","TIMEVALUE","TINV","TINV2T","TODAY","TRANSPOSE","TREND","TRIM","TRIMMEAN","TRUE","TRUNC","UNICHAR","UNICODE","UNIQUE","UPPER","VALUE","VAR.P","VAR.S","VARA","VARP","VARPA","VARS","WEEKDAY","WEEKNUM","WEIBULL.DIST","WEIBULLDIST","WORKDAY","XIRR","XNPV","XOR","YEAR","YEARFRAC"]},function(r,t,e){function n(r){return/^[01]{1,10}$/.test(r)}var u=e(0),i=e(13).jStat,o=e(8),a=e(2),s=e(32);t.BESSELI=function(r,t){return r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t)?u.value:s.besseli(r,t)},t.BESSELJ=function(r,t){return r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t)?u.value:s.besselj(r,t)},t.BESSELK=function(r,t){return r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t)?u.value:s.besselk(r,t)},t.BESSELY=function(r,t){return r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t)?u.value:s.bessely(r,t)},t.BIN2DEC=function(r){if(!n(r))return u.num;var t=parseInt(r,2),e=""+r;return 10===e.length&&"1"===e.substring(0,1)?parseInt(e.substring(1),2)-512:t},t.BIN2HEX=function(r,t){if(!n(r))return u.num;var e=""+r;if(10===e.length&&"1"===e.substring(0,1))return(0xfffffffe00+parseInt(e.substring(1),2)).toString(16);var i=parseInt(r,2).toString(16);return t===undefined?i:isNaN(t)?u.value:0>t?u.num:(t=Math.floor(t),i.length>t?u.num:o.REPT("0",t-i.length)+i)},t.BIN2OCT=function(r,t){if(!n(r))return u.num;var e=""+r;if(10===e.length&&"1"===e.substring(0,1))return(1073741312+parseInt(e.substring(1),2)).toString(8);var i=parseInt(r,2).toString(8);return t===undefined?i:isNaN(t)?u.value:0>t?u.num:(t=Math.floor(t),i.length>t?u.num:o.REPT("0",t-i.length)+i)},t.BITAND=function(r,t){return r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t)?u.value:0>r||0>t?u.num:Math.floor(r)!==r||Math.floor(t)!==t?u.num:r>0xffffffffffff||t>0xffffffffffff?u.num:r&t},t.BITLSHIFT=function(r,t){return r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t)?u.value:0>r?u.num:Math.floor(r)!==r?u.num:r>0xffffffffffff?u.num:Math.abs(t)>53?u.num:0>t?r>>-t:r<r||0>t?u.num:Math.floor(r)!==r||Math.floor(t)!==t?u.num:r>0xffffffffffff||t>0xffffffffffff?u.num:r|t},t.BITRSHIFT=function(r,t){return r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t)?u.value:0>r?u.num:Math.floor(r)!==r?u.num:r>0xffffffffffff?u.num:Math.abs(t)>53?u.num:0>t?r<<-t:r>>t},t.BITXOR=function(r,t){return r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t)?u.value:0>r||0>t?u.num:Math.floor(r)!==r||Math.floor(t)!==t?u.num:r>0xffffffffffff||t>0xffffffffffff?u.num:r^t},t.COMPLEX=function(r,t,e){return r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t)?r:"i"!==(e=e===undefined?"i":e)&&"j"!==e?u.value:0===r&&0===t?0:0===r?1===t?e:""+t+e:0===t?""+r:r+(t>0?"+":"")+(1===t?e:""+t+e)},t.CONVERT=function(r,t,e){if((r=a.parseNumber(r))instanceof Error)return r;for(var n,i=[["a.u. of action","?",null,"action",!1,!1,1.05457168181818e-34],["a.u. of charge","e",null,"electric_charge",!1,!1,1.60217653141414e-19],["a.u. of energy","Eh",null,"energy",!1,!1,4.35974417757576e-18],["a.u. of length","a?",null,"length",!1,!1,5.29177210818182e-11],["a.u. of mass","m?",null,"mass",!1,!1,9.10938261616162e-31],["a.u. of time","?/Eh",null,"time",!1,!1,2.41888432650516e-17],["admiralty knot","admkn",null,"speed",!1,!0,.514773333],["ampere","A",null,"electric_current",!0,!1,1],["ampere per meter","A/m",null,"magnetic_field_intensity",!0,!1,1],["ångström","Å",["ang"],"length",!1,!0,1e-10],["are","ar",null,"area",!1,!0,100],["astronomical unit","ua",null,"length",!1,!1,1.49597870691667e-11],["bar","bar",null,"pressure",!1,!1,1e5],["barn","b",null,"area",!1,!1,1e-28],["becquerel","Bq",null,"radioactivity",!0,!1,1],["bit","bit",["b"],"information",!1,!0,1],["btu","BTU",["btu"],"energy",!1,!0,1055.05585262],["byte","byte",null,"information",!1,!0,8],["candela","cd",null,"luminous_intensity",!0,!1,1],["candela per square metre","cd/m?",null,"luminance",!0,!1,1],["coulomb","C",null,"electric_charge",!0,!1,1],["cubic ångström","ang3",["ang^3"],"volume",!1,!0,1e-30],["cubic foot","ft3",["ft^3"],"volume",!1,!0,.028316846592],["cubic inch","in3",["in^3"],"volume",!1,!0,16387064e-12],["cubic light-year","ly3",["ly^3"],"volume",!1,!0,8.46786664623715e-47],["cubic metre","m?",null,"volume",!0,!0,1],["cubic mile","mi3",["mi^3"],"volume",!1,!0,4168181825.44058],["cubic nautical mile","Nmi3",["Nmi^3"],"volume",!1,!0,6352182208],["cubic Pica","Pica3",["Picapt3","Pica^3","Picapt^3"],"volume",!1,!0,7.58660370370369e-8],["cubic yard","yd3",["yd^3"],"volume",!1,!0,.764554857984],["cup","cup",null,"volume",!1,!0,.0002365882365],["dalton","Da",["u"],"mass",!1,!1,1.66053886282828e-27],["day","d",["day"],"time",!1,!0,86400],["degree","°",null,"angle",!1,!1,.0174532925199433],["degrees Rankine","Rank",null,"temperature",!1,!0,.555555555555556],["dyne","dyn",["dy"],"force",!1,!0,1e-5],["electronvolt","eV",["ev"],"energy",!1,!0,1.60217656514141],["ell","ell",null,"length",!1,!0,1.143],["erg","erg",["e"],"energy",!1,!0,1e-7],["farad","F",null,"electric_capacitance",!0,!1,1],["fluid ounce","oz",null,"volume",!1,!0,295735295625e-16],["foot","ft",null,"length",!1,!0,.3048],["foot-pound","flb",null,"energy",!1,!0,1.3558179483314],["gal","Gal",null,"acceleration",!1,!1,.01],["gallon","gal",null,"volume",!1,!0,.003785411784],["gauss","G",["ga"],"magnetic_flux_density",!1,!0,1],["grain","grain",null,"mass",!1,!0,647989e-10],["gram","g",null,"mass",!1,!0,.001],["gray","Gy",null,"absorbed_dose",!0,!1,1],["gross registered ton","GRT",["regton"],"volume",!1,!0,2.8316846592],["hectare","ha",null,"area",!1,!0,1e4],["henry","H",null,"inductance",!0,!1,1],["hertz","Hz",null,"frequency",!0,!1,1],["horsepower","HP",["h"],"power",!1,!0,745.69987158227],["horsepower-hour","HPh",["hh","hph"],"energy",!1,!0,2684519.538],["hour","h",["hr"],"time",!1,!0,3600],["imperial gallon (U.K.)","uk_gal",null,"volume",!1,!0,.00454609],["imperial hundredweight","lcwt",["uk_cwt","hweight"],"mass",!1,!0,50.802345],["imperial quart (U.K)","uk_qt",null,"volume",!1,!0,.0011365225],["imperial ton","brton",["uk_ton","LTON"],"mass",!1,!0,1016.046909],["inch","in",null,"length",!1,!0,.0254],["international acre","uk_acre",null,"area",!1,!0,4046.8564224],["IT calorie","cal",null,"energy",!1,!0,4.1868],["joule","J",null,"energy",!0,!0,1],["katal","kat",null,"catalytic_activity",!0,!1,1],["kelvin","K",["kel"],"temperature",!0,!0,1],["kilogram","kg",null,"mass",!0,!0,1],["knot","kn",null,"speed",!1,!0,.514444444444444],["light-year","ly",null,"length",!1,!0,9460730472580800],["litre","L",["l","lt"],"volume",!1,!0,.001],["lumen","lm",null,"luminous_flux",!0,!1,1],["lux","lx",null,"illuminance",!0,!1,1],["maxwell","Mx",null,"magnetic_flux",!1,!1,1e-18],["measurement ton","MTON",null,"volume",!1,!0,1.13267386368],["meter per hour","m/h",["m/hr"],"speed",!1,!0,.00027777777777778],["meter per second","m/s",["m/sec"],"speed",!0,!0,1],["meter per second squared","m?s??",null,"acceleration",!0,!1,1],["parsec","pc",["parsec"],"length",!1,!0,0x6da012f958ee1c],["meter squared per second","m?/s",null,"kinematic_viscosity",!0,!1,1],["metre","m",null,"length",!0,!0,1],["miles per hour","mph",null,"speed",!1,!0,.44704],["millimetre of mercury","mmHg",null,"pressure",!1,!1,133.322],["minute","?",null,"angle",!1,!1,.000290888208665722],["minute","min",["mn"],"time",!1,!0,60],["modern teaspoon","tspm",null,"volume",!1,!0,5e-6],["mole","mol",null,"amount_of_substance",!0,!1,1],["morgen","Morgen",null,"area",!1,!0,2500],["n.u. of action","?",null,"action",!1,!1,1.05457168181818e-34],["n.u. of mass","m?",null,"mass",!1,!1,9.10938261616162e-31],["n.u. of speed","c?",null,"speed",!1,!1,299792458],["n.u. of time","?/(me?c??)",null,"time",!1,!1,1.28808866778687e-21],["nautical mile","M",["Nmi"],"length",!1,!0,1852],["newton","N",null,"force",!0,!0,1],["œrsted","Oe ",null,"magnetic_field_intensity",!1,!1,79.5774715459477],["ohm","Ω",null,"electric_resistance",!0,!1,1],["ounce mass","ozm",null,"mass",!1,!0,.028349523125],["pascal","Pa",null,"pressure",!0,!1,1],["pascal second","Pa?s",null,"dynamic_viscosity",!0,!1,1],["pferdestärke","PS",null,"power",!1,!0,735.49875],["phot","ph",null,"illuminance",!1,!1,1e-4],["pica (1/6 inch)","pica",null,"length",!1,!0,.00035277777777778],["pica (1/72 inch)","Pica",["Picapt"],"length",!1,!0,.00423333333333333],["poise","P",null,"dynamic_viscosity",!1,!1,.1],["pond","pond",null,"force",!1,!0,.00980665],["pound force","lbf",null,"force",!1,!0,4.4482216152605],["pound mass","lbm",null,"mass",!1,!0,.45359237],["quart","qt",null,"volume",!1,!0,.000946352946],["radian","rad",null,"angle",!0,!1,1],["second","?",null,"angle",!1,!1,484813681109536e-20],["second","s",["sec"],"time",!0,!0,1],["short hundredweight","cwt",["shweight"],"mass",!1,!0,45.359237],["siemens","S",null,"electrical_conductance",!0,!1,1],["sievert","Sv",null,"equivalent_dose",!0,!1,1],["slug","sg",null,"mass",!1,!0,14.59390294],["square ångström","ang2",["ang^2"],"area",!1,!0,1e-20],["square foot","ft2",["ft^2"],"area",!1,!0,.09290304],["square inch","in2",["in^2"],"area",!1,!0,64516e-8],["square light-year","ly2",["ly^2"],"area",!1,!0,8.95054210748189e31],["square meter","m?",null,"area",!0,!0,1],["square mile","mi2",["mi^2"],"area",!1,!0,2589988.110336],["square nautical mile","Nmi2",["Nmi^2"],"area",!1,!0,3429904],["square Pica","Pica2",["Picapt2","Pica^2","Picapt^2"],"area",!1,!0,1792111111111e-17],["square yard","yd2",["yd^2"],"area",!1,!0,.83612736],["statute mile","mi",null,"length",!1,!0,1609.344],["steradian","sr",null,"solid_angle",!0,!1,1],["stilb","sb",null,"luminance",!1,!1,1e-4],["stokes","St",null,"kinematic_viscosity",!1,!1,1e-4],["stone","stone",null,"mass",!1,!0,6.35029318],["tablespoon","tbs",null,"volume",!1,!0,147868e-10],["teaspoon","tsp",null,"volume",!1,!0,492892e-11],["tesla","T",null,"magnetic_flux_density",!0,!0,1],["thermodynamic calorie","c",null,"energy",!1,!0,4.184],["ton","ton",null,"mass",!1,!0,907.18474],["tonne","t",null,"mass",!1,!1,1e3],["U.K. pint","uk_pt",null,"volume",!1,!0,.00056826125],["U.S. bushel","bushel",null,"volume",!1,!0,.03523907],["U.S. oil barrel","barrel",null,"volume",!1,!0,.158987295],["U.S. pint","pt",["us_pt"],"volume",!1,!0,.000473176473],["U.S. survey mile","survey_mi",null,"length",!1,!0,1609.347219],["U.S. survey/statute acre","us_acre",null,"area",!1,!0,4046.87261],["volt","V",null,"voltage",!0,!1,1],["watt","W",null,"power",!0,!0,1],["watt-hour","Wh",["wh"],"energy",!1,!0,3600],["weber","Wb",null,"magnetic_flux",!0,!1,1],["yard","yd",null,"length",!1,!0,.9144],["year","yr",null,"time",!1,!0,31557600]],o={Yi:["yobi",80,1.2089258196146292e24,"Yi","yotta"],Zi:["zebi",70,0x400000000000000000,"Zi","zetta"],Ei:["exbi",60,0x1000000000000000,"Ei","exa"],Pi:["pebi",50,0x4000000000000,"Pi","peta"],Ti:["tebi",40,1099511627776,"Ti","tera"],Gi:["gibi",30,1073741824,"Gi","giga"],Mi:["mebi",20,1048576,"Mi","mega"],ki:["kibi",10,1024,"ki","kilo"]},s={Y:["yotta",1e24,"Y"],Z:["zetta",1e21,"Z"],E:["exa",1e18,"E"],P:["peta",1e15,"P"],T:["tera",1e12,"T"],G:["giga",1e9,"G"],M:["mega",1e6,"M"],k:["kilo",1e3,"k"],h:["hecto",100,"h"],e:["dekao",10,"e"],d:["deci",.1,"d"],c:["centi",.01,"c"],m:["milli",.001,"m"],u:["micro",1e-6,"u"],n:["nano",1e-9,"n"],p:["pico",1e-12,"p"],f:["femto",1e-15,"f"],a:["atto",1e-18,"a"],z:["zepto",1e-21,"z"],y:["yocto",1e-24,"y"]},l=null,f=null,c=t,p=e,m=1,d=1,h=0;i.length>h;h++)n=null===i[h][2]?[]:i[h][2],i[h][1]!==c&&0>n.indexOf(c)||(l=i[h]),i[h][1]!==p&&0>n.indexOf(p)||(f=i[h]);if(null===l){var E=o[t.substring(0,2)],g=s[t.substring(0,1)];"da"===t.substring(0,2)&&(g=["dekao",10,"da"]),E?(m=E[2],c=t.substring(2)):g&&(m=g[1],c=t.substring(g[2].length));for(var v=0;i.length>v;v++)n=null===i[v][2]?[]:i[v][2],i[v][1]!==c&&0>n.indexOf(c)||(l=i[v])}if(null===f){var N=o[e.substring(0,2)],b=s[e.substring(0,1)];"da"===e.substring(0,2)&&(b=["dekao",10,"da"]),N?(d=N[2],p=e.substring(2)):b&&(d=b[1],p=e.substring(b[2].length));for(var y=0;i.length>y;y++)n=null===i[y][2]?[]:i[y][2],i[y][1]!==p&&0>n.indexOf(p)||(f=i[y])}return null===l||null===f?u.na:l[3]!==f[3]?u.na:r*l[6]*m/(f[6]*d)},t.DEC2BIN=function(r,t){if((r=a.parseNumber(r))instanceof Error)return r;if(!/^-?[0-9]{1,3}$/.test(r)||-512>r||r>511)return u.num;if(0>r)return"1"+o.REPT("0",9-(512+r).toString(2).length)+(512+r).toString(2);var e=parseInt(r,10).toString(2);return void 0===t?e:isNaN(t)?u.value:0>t?u.num:(t=Math.floor(t),e.length>t?u.num:o.REPT("0",t-e.length)+e)},t.DEC2HEX=function(r,t){if((r=a.parseNumber(r))instanceof Error)return r;if(!/^-?[0-9]{1,12}$/.test(r)||-549755813888>r||r>549755813887)return u.num;if(0>r)return(1099511627776+r).toString(16);var e=parseInt(r,10).toString(16);return void 0===t?e:isNaN(t)?u.value:0>t?u.num:(t=Math.floor(t),e.length>t?u.num:o.REPT("0",t-e.length)+e)},t.DEC2OCT=function(r,t){if((r=a.parseNumber(r))instanceof Error)return r;if(!/^-?[0-9]{1,9}$/.test(r)||-536870912>r||r>536870911)return u.num;if(0>r)return(1073741824+r).toString(8);var e=parseInt(r,10).toString(8);return void 0===t?e:isNaN(t)?u.value:0>t?u.num:(t=Math.floor(t),e.length>t?u.num:o.REPT("0",t-e.length)+e)},t.DELTA=function(r,t){return t=t===undefined?0:t,r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t)?u.value:r===t?1:0},t.ERF=function(r,t){return t=t===undefined?0:t,r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t)?u.value:i.erf(r)},t.ERF.PRECISE=function(){throw Error("ERF.PRECISE is not implemented")},t.ERFC=function(r){return isNaN(r)?u.value:i.erfc(r)},t.ERFC.PRECISE=function(){throw Error("ERFC.PRECISE is not implemented")},t.GESTEP=function(r,t){return t=t||0,r=a.parseNumber(r),a.anyIsError(t,r)?r:t>r?0:1},t.HEX2BIN=function(r,t){if(!/^[0-9A-Fa-f]{1,10}$/.test(r))return u.num;var e=10===r.length&&"f"===r.substring(0,1).toLowerCase(),n=e?parseInt(r,16)-1099511627776:parseInt(r,16);if(-512>n||n>511)return u.num;if(e)return"1"+o.REPT("0",9-(512+n).toString(2).length)+(512+n).toString(2);var i=n.toString(2);return t===undefined?i:isNaN(t)?u.value:0>t?u.num:(t=Math.floor(t),i.length>t?u.num:o.REPT("0",t-i.length)+i)},t.HEX2DEC=function(r){if(!/^[0-9A-Fa-f]{1,10}$/.test(r))return u.num;var t=parseInt(r,16);return 549755813888>t?t:t-1099511627776},t.HEX2OCT=function(r,t){if(!/^[0-9A-Fa-f]{1,10}$/.test(r))return u.num;var e=parseInt(r,16);if(e>536870911&&0xffe0000000>e)return u.num;if(e>=0xffe0000000)return(e-0xffc0000000).toString(8);var n=e.toString(8);return t===undefined?n:isNaN(t)?u.value:0>t?u.num:(t=Math.floor(t),n.length>t?u.num:o.REPT("0",t-n.length)+n)},t.IMABS=function(r){var e=t.IMREAL(r),n=t.IMAGINARY(r);return a.anyIsError(e,n)?u.value:Math.sqrt(Math.pow(e,2)+Math.pow(n,2))},t.IMAGINARY=function(r){if(r===undefined||r===!0||r===!1)return u.value;if(0===r||"0"===r)return 0;if(["i","j"].indexOf(r)>=0)return 1;r=r.replace("+i","+1i").replace("-i","-1i").replace("+j","+1j").replace("-j","-1j");var t=r.indexOf("+"),e=r.indexOf("-");0===t&&(t=r.indexOf("+",1)),0===e&&(e=r.indexOf("-",1));var n=r.substring(r.length-1,r.length),i="i"===n||"j"===n;return 0>t&&0>e?i?isNaN(r.substring(0,r.length-1))?u.num:r.substring(0,r.length-1):isNaN(r)?u.num:0:i?0>t?isNaN(r.substring(0,e))||isNaN(r.substring(e+1,r.length-1))?u.num:-+r.substring(e+1,r.length-1):isNaN(r.substring(0,t))||isNaN(r.substring(t+1,r.length-1))?u.num:+r.substring(t+1,r.length-1):u.num},t.IMARGUMENT=function(r){var e=t.IMREAL(r),n=t.IMAGINARY(r);return a.anyIsError(e,n)?u.value:0===e&&0===n?u.div0:0===e&&n>0?Math.PI/2:0===e&&0>n?-Math.PI/2:0===n&&e>0?0:0===n&&0>e?-Math.PI:e>0?Math.atan(n/e):0>e&&n>=0?Math.atan(n/e)+Math.PI:Math.atan(n/e)-Math.PI},t.IMCONJUGATE=function(r){var e=t.IMREAL(r),n=t.IMAGINARY(r);if(a.anyIsError(e,n))return u.value;var i=r.substring(r.length-1);return i="i"===i||"j"===i?i:"i",0!==n?t.COMPLEX(e,-n,i):r},t.IMCOS=function(r){var e=t.IMREAL(r),n=t.IMAGINARY(r);if(a.anyIsError(e,n))return u.value;var i=r.substring(r.length-1);return i="i"===i||"j"===i?i:"i",t.COMPLEX(Math.cos(e)*(Math.exp(n)+Math.exp(-n))/2,-Math.sin(e)*(Math.exp(n)-Math.exp(-n))/2,i)},t.IMCOSH=function(r){var e=t.IMREAL(r),n=t.IMAGINARY(r);if(a.anyIsError(e,n))return u.value;var i=r.substring(r.length-1);return i="i"===i||"j"===i?i:"i",t.COMPLEX(Math.cos(n)*(Math.exp(e)+Math.exp(-e))/2,Math.sin(n)*(Math.exp(e)-Math.exp(-e))/2,i)},t.IMCOT=function(r){return a.anyIsError(t.IMREAL(r),t.IMAGINARY(r))?u.value:t.IMDIV(t.IMCOS(r),t.IMSIN(r))},t.IMDIV=function(r,e){var n=t.IMREAL(r),i=t.IMAGINARY(r),o=t.IMREAL(e),s=t.IMAGINARY(e);if(a.anyIsError(n,i,o,s))return u.value;var l=r.substring(r.length-1),f=e.substring(e.length-1),c="i";if("j"===l?c="j":"j"===f&&(c="j"),0===o&&0===s)return u.num;var p=o*o+s*s;return t.COMPLEX((n*o+i*s)/p,(i*o-n*s)/p,c)},t.IMEXP=function(r){var e=t.IMREAL(r),n=t.IMAGINARY(r);if(a.anyIsError(e,n))return u.value;var i=r.substring(r.length-1);i="i"===i||"j"===i?i:"i";var o=Math.exp(e);return t.COMPLEX(o*Math.cos(n),o*Math.sin(n),i)},t.IMLN=function(r){var e=t.IMREAL(r),n=t.IMAGINARY(r);if(a.anyIsError(e,n))return u.value;var i=r.substring(r.length-1);return i="i"===i||"j"===i?i:"i",t.COMPLEX(Math.log(Math.sqrt(e*e+n*n)),Math.atan(n/e),i)},t.IMLOG10=function(r){var e=t.IMREAL(r),n=t.IMAGINARY(r);if(a.anyIsError(e,n))return u.value;var i=r.substring(r.length-1);return i="i"===i||"j"===i?i:"i",t.COMPLEX(Math.log(Math.sqrt(e*e+n*n))/Math.log(10),Math.atan(n/e)/Math.log(10),i)},t.IMLOG2=function(r){var e=t.IMREAL(r),n=t.IMAGINARY(r);if(a.anyIsError(e,n))return u.value;var i=r.substring(r.length-1);return i="i"===i||"j"===i?i:"i",t.COMPLEX(Math.log(Math.sqrt(e*e+n*n))/Math.log(2),Math.atan(n/e)/Math.log(2),i)},t.IMPOWER=function(r,e){if(e=a.parseNumber(e),a.anyIsError(e,t.IMREAL(r),t.IMAGINARY(r)))return u.value;var n=r.substring(r.length-1);n="i"===n||"j"===n?n:"i";var i=Math.pow(t.IMABS(r),e),o=t.IMARGUMENT(r);return t.COMPLEX(i*Math.cos(e*o),i*Math.sin(e*o),n)},t.IMPRODUCT=function(){var r=arguments[0];if(!arguments.length)return u.value;for(var e=1;arguments.length>e;e++){var n=t.IMREAL(r),i=t.IMAGINARY(r),o=t.IMREAL(arguments[e]),s=t.IMAGINARY(arguments[e]);if(a.anyIsError(n,i,o,s))return u.value;r=t.COMPLEX(n*o-i*s,n*s+i*o)}return r},t.IMREAL=function(r){if(r===undefined||r===!0||r===!1)return u.value;if(0===r||"0"===r)return 0;if(["i","+i","1i","+1i","-i","-1i","j","+j","1j","+1j","-j","-1j"].indexOf(r)>=0)return 0;var t=r.indexOf("+"),e=r.indexOf("-");0===t&&(t=r.indexOf("+",1)),0===e&&(e=r.indexOf("-",1));var n=r.substring(r.length-1,r.length),i="i"===n||"j"===n;return 0>t&&0>e?i?isNaN(r.substring(0,r.length-1))?u.num:0:isNaN(r)?u.num:r:i?0>t?isNaN(r.substring(0,e))||isNaN(r.substring(e+1,r.length-1))?u.num:+r.substring(0,e):isNaN(r.substring(0,t))||isNaN(r.substring(t+1,r.length-1))?u.num:+r.substring(0,t):u.num},t.IMSEC=function(r){return r===!0||r===!1?u.value:a.anyIsError(t.IMREAL(r),t.IMAGINARY(r))?u.value:t.IMDIV("1",t.IMCOS(r))},t.IMSECH=function(r){return a.anyIsError(t.IMREAL(r),t.IMAGINARY(r))?u.value:t.IMDIV("1",t.IMCOSH(r))},t.IMSIN=function(r){var e=t.IMREAL(r),n=t.IMAGINARY(r);if(a.anyIsError(e,n))return u.value;var i=r.substring(r.length-1);return i="i"===i||"j"===i?i:"i",t.COMPLEX(Math.sin(e)*(Math.exp(n)+Math.exp(-n))/2,Math.cos(e)*(Math.exp(n)-Math.exp(-n))/2,i)},t.IMSINH=function(r){var e=t.IMREAL(r),n=t.IMAGINARY(r);if(a.anyIsError(e,n))return u.value;var i=r.substring(r.length-1);return i="i"===i||"j"===i?i:"i",t.COMPLEX(Math.cos(n)*(Math.exp(e)-Math.exp(-e))/2,Math.sin(n)*(Math.exp(e)+Math.exp(-e))/2,i)},t.IMSQRT=function(r){if(a.anyIsError(t.IMREAL(r),t.IMAGINARY(r)))return u.value;var e=r.substring(r.length-1);e="i"===e||"j"===e?e:"i";var n=Math.sqrt(t.IMABS(r)),i=t.IMARGUMENT(r);return t.COMPLEX(n*Math.cos(i/2),n*Math.sin(i/2),e)},t.IMCSC=function(r){return r===!0||r===!1?u.value:a.anyIsError(t.IMREAL(r),t.IMAGINARY(r))?u.num:t.IMDIV("1",t.IMSIN(r))},t.IMCSCH=function(r){return r===!0||r===!1?u.value:a.anyIsError(t.IMREAL(r),t.IMAGINARY(r))?u.num:t.IMDIV("1",t.IMSINH(r))},t.IMSUB=function(r,t){var e=this.IMREAL(r),n=this.IMAGINARY(r),i=this.IMREAL(t),o=this.IMAGINARY(t);if(a.anyIsError(e,n,i,o))return u.value;var s=r.substring(r.length-1),l=t.substring(t.length-1),f="i";return"j"===s?f="j":"j"===l&&(f="j"),this.COMPLEX(e-i,n-o,f)},t.IMSUM=function(){if(!arguments.length)return u.value;for(var r=a.flatten(arguments),t=r[0],e=1;r.length>e;e++){var n=this.IMREAL(t),i=this.IMAGINARY(t),o=this.IMREAL(r[e]),s=this.IMAGINARY(r[e]);if(a.anyIsError(n,i,o,s))return u.value;t=this.COMPLEX(n+o,i+s)}return t},t.IMTAN=function(r){return r===!0||r===!1?u.value:a.anyIsError(t.IMREAL(r),t.IMAGINARY(r))?u.value:this.IMDIV(this.IMSIN(r),this.IMCOS(r))},t.OCT2BIN=function(r,t){if(!/^[0-7]{1,10}$/.test(r))return u.num;var e=10===r.length&&"7"===r.substring(0,1),n=e?parseInt(r,8)-1073741824:parseInt(r,8);if(-512>n||n>511)return u.num;if(e)return"1"+o.REPT("0",9-(512+n).toString(2).length)+(512+n).toString(2);var i=n.toString(2);return void 0===t?i:isNaN(t)?u.value:0>t?u.num:(t=Math.floor(t),i.length>t?u.num:o.REPT("0",t-i.length)+i)},t.OCT2DEC=function(r){if(!/^[0-7]{1,10}$/.test(r))return u.num;var t=parseInt(r,8);return 536870912>t?t:t-1073741824},t.OCT2HEX=function(r,t){if(!/^[0-7]{1,10}$/.test(r))return u.num;var e=parseInt(r,8);if(e>=536870912)return"ff"+(e+3221225472).toString(16);var n=e.toString(16);return t===undefined?n:isNaN(t)?u.value:0>t?u.num:(t=Math.floor(t),n.length>t?u.num:o.REPT("0",t-n.length)+n)}},function(r,t,e){var n=e(2),u=e(14),i=e(0);t.UNIQUE=function(){for(var r=[],t=0;arguments.length>t;++t){for(var e=!1,n=arguments[t],u=0;r.length>u&&!(e=r[u]===n);++u);e||r.push(n)}return r},t.FLATTEN=n.flatten,t.ARGS2ARRAY=function(){return Array.prototype.slice.call(arguments,0)},t.REFERENCE=function(r,t){if(!arguments.length)return i.error;try{for(var e=t.split("."),n=r,u=0;e.length>u;++u){var o=e[u];if("]"===o[o.length-1]){var a=o.indexOf("["),s=o.substring(a+1,o.length-1);n=n[o.substring(0,a)][s]}else n=n[o]}return n}catch(i){}},t.JOIN=function(r,t){return r.join(t)},t.NUMBERS=function(){return n.flatten(arguments).filter(function(r){return"number"==typeof r})},t.NUMERAL=function(r,t){return u(r).format(t)}},function(r,t){this.j$=this.jStat=function(r,t){function e(t,e){var n=t>e?t:e;return r.pow(10,17-~~(r.log(n>0?n:-n)*r.LOG10E))}function n(r){return"[object Function]"===m.call(r)}function u(r){return"number"==typeof r&&r===r}function o(r){return c.apply([],r)}function a(){return new a._init(arguments)}function s(){return 0}function l(){return 1}function f(r,t){return r===t?1:0}var c=Array.prototype.concat,p=Array.prototype.slice,m=Object.prototype.toString,d=Array.isArray||function(r){return"[object Array]"===m.call(r)};a.fn=a.prototype,a._init=function(r){var t;if(d(r[0]))if(d(r[0][0])){n(r[1])&&(r[0]=a.map(r[0],r[1]));for(var t=0;r[0].length>t;t++)this[t]=r[0][t];this.length=r[0].length}else this[0]=n(r[1])?a.map(r[0],r[1]):r[0],this.length=1;else if(u(r[0]))this[0]=a.seq.apply(null,r),this.length=1;else{if(r[0]instanceof a)return a(r[0].toArray());this[0]=[],this.length=1}return this},a._init.prototype=a.prototype,a._init.constructor=a,a.utils={calcRdx:e,isArray:d,isFunction:n,isNumber:u,toVector:o},a.extend=function(r){var t,e;if(1===arguments.length){for(e in r)a[e]=r[e];return this}for(var t=1;arguments.length>t;t++)for(e in arguments[t])r[e]=arguments[t][e];return r},a.rows=function(r){return r.length||1},a.cols=function(r){return r[0].length||1},a.dimensions=function(r){return{rows:a.rows(r),cols:a.cols(r)}},a.row=function(r,t){return d(t)?t.map(function(t){return a.row(r,t)}):r[t]},a.rowa=function(r,t){return a.row(r,t)},a.col=function(r,t){if(d(t)){var e=a.arange(r.length).map(function(r){return Array(t.length)});return t.forEach(function(t,n){a.arange(r.length).forEach(function(u){e[u][n]=r[u][t]})}),e}for(var n=Array(r.length),u=0;r.length>u;u++)n[u]=[r[u][t]];return n},a.cola=function(r,t){return a.col(r,t).map(function(r){return r[0]})},a.diag=function(r){for(var t=a.rows(r),e=Array(t),n=0;t>n;n++)e[n]=[r[n][n]];return e},a.antidiag=function(r){for(var t=a.rows(r)-1,e=Array(t),n=0;t>=0;t--,n++)e[n]=[r[n][t]];return e},a.transpose=function(r){var t,e,n,u,i,o=[];d(r[0])||(r=[r]),e=r.length,n=r[0].length;for(var i=0;n>i;i++){for(t=Array(e),u=0;e>u;u++)t[u]=r[u][i];o.push(t)}return 1===o.length?o[0]:o},a.map=function(r,t,e){var n,u,i,o,a;for(d(r[0])||(r=[r]),u=r.length,i=r[0].length,o=e?r:Array(u),n=0;u>n;n++)for(o[n]||(o[n]=Array(i)),a=0;i>a;a++)o[n][a]=t(r[n][a],n,a);return 1===o.length?o[0]:o},a.cumreduce=function(r,t,e){var n,u,i,o,a;for(d(r[0])||(r=[r]),u=r.length,i=r[0].length,o=e?r:Array(u),n=0;u>n;n++)for(o[n]||(o[n]=Array(i)),i>0&&(o[n][0]=r[n][0]),a=1;i>a;a++)o[n][a]=t(o[n][a-1],r[n][a]);return 1===o.length?o[0]:o},a.alter=function(r,t){return a.map(r,t,!0)},a.create=function(r,t,e){var u,i,o=Array(r);n(t)&&(e=t,t=r);for(var u=0;r>u;u++)for(o[u]=Array(t),i=0;t>i;i++)o[u][i]=e(u,i);return o},a.zeros=function(r,t){return u(t)||(t=r),a.create(r,t,s)},a.ones=function(r,t){return u(t)||(t=r),a.create(r,t,l)},a.rand=function(t,e){return u(e)||(e=t),a.create(t,e,r.random)},a.identity=function(r,t){return u(t)||(t=r),a.create(r,t,f)},a.symmetric=function(r){var t,e,n=r.length;if(r.length!==r[0].length)return!1;for(t=0;n>t;t++)for(e=0;n>e;e++)if(r[e][t]!==r[t][e])return!1;return!0},a.clear=function(r){return a.alter(r,s)},a.seq=function(r,t,u,i){n(i)||(i=!1);var o,a=[],s=e(r,t),l=(t*s-r*s)/((u-1)*s),f=r;for(o=0;t>=f;o++,f=(r*s+l*s*o)/s)a.push(i?i(f,o):f);return a},a.arange=function(r,e,n){var u=[];if(n=n||1,e===t&&(e=r,r=0),r===e||0===n)return[];if(e>r&&0>n)return[];if(r>e&&n>0)return[];if(n>0)for(i=r;ie;i+=n)u.push(i);return u},a.slice=function(){function r(r,e,n,u){var i,o=[],s=r.length;if(e===t&&n===t&&u===t)return a.copy(r);if(e=e||0,n=n||r.length,e=0>e?s+e:e,n=0>n?s+n:n,u=u||1,e===n||0===u)return[];if(n>e&&0>u)return[];if(e>n&&u>0)return[];if(u>0)for(i=e;n>i;i+=u)o.push(r[i]);else for(i=e;i>n;i+=u)o.push(r[i]);return o}function e(t,e){if(e=e||{},u(e.row)){if(u(e.col))return t[e.row][e.col];var n=a.rowa(t,e.row),i=e.col||{};return r(n,i.start,i.end,i.step)}if(u(e.col)){var o=a.cola(t,e.col),s=e.row||{};return r(o,s.start,s.end,s.step)}var s=e.row||{},i=e.col||{};return r(t,s.start,s.end,s.step).map(function(t){return r(t,i.start,i.end,i.step)})}return e}(),a.sliceAssign=function(e,n,i){if(u(n.row)){if(u(n.col))return e[n.row][n.col]=i;n.col=n.col||{},n.col.start=n.col.start||0,n.col.end=n.col.end||e[0].length,n.col.step=n.col.step||1;var o=a.arange(n.col.start,r.min(e.length,n.col.end),n.col.step),s=n.row;return o.forEach(function(r,t){e[s][r]=i[t]}),e}if(u(n.col)){n.row=n.row||{},n.row.start=n.row.start||0,n.row.end=n.row.end||e.length,n.row.step=n.row.step||1;var l=a.arange(n.row.start,r.min(e[0].length,n.row.end),n.row.step),f=n.col;return l.forEach(function(r,t){e[r][f]=i[t]}),e}i[0].length===t&&(i=[i]),n.row.start=n.row.start||0,n.row.end=n.row.end||e.length,n.row.step=n.row.step||1,n.col.start=n.col.start||0,n.col.end=n.col.end||e[0].length,n.col.step=n.col.step||1;var l=a.arange(n.row.start,r.min(e.length,n.row.end),n.row.step),o=a.arange(n.col.start,r.min(e[0].length,n.col.end),n.col.step);return l.forEach(function(r,t){o.forEach(function(n,u){e[r][n]=i[t][u]})}),e},a.diagonal=function(r){var t=a.zeros(r.length,r.length);return r.forEach(function(r,e){t[e][e]=r}),t},a.copy=function(r){return r.map(function(r){return u(r)?r:r.map(function(r){return r})})};var h=a.prototype;return h.length=0,h.push=Array.prototype.push,h.sort=Array.prototype.sort,h.splice=Array.prototype.splice,h.slice=Array.prototype.slice,h.toArray=function(){return this.length>1?p.call(this):p.call(this)[0]},h.map=function(r,t){return a(a.map(this,r,t))},h.cumreduce=function(r,t){return a(a.cumreduce(this,r,t))},h.alter=function(r){return a.alter(this,r),this},function(r){for(var t=0;r.length>t;t++)!function(r){h[r]=function(t){var e,n=this;return t?(setTimeout(function(){t.call(n,h[r].call(n))}),this):(e=a[r](this),d(e)?a(e):e)}}(r[t])}("transpose clear symmetric rows cols dimensions diag antidiag".split(" ")),function(r){for(var t=0;r.length>t;t++)!function(r){h[r]=function(t,e){var n=this;return e?(setTimeout(function(){e.call(n,h[r].call(n,t))}),this):a(a[r](this,t))}}(r[t])}("row col".split(" ")),function(r){for(var t=0;r.length>t;t++)!function(r){h[r]=Function("return jStat(jStat."+r+".apply(null, arguments));")}(r[t])}("create zeros ones rand identity".split(" ")),a}(Math),function(r,t){function e(r,t){return r-t}function n(r,e,n){return t.max(e,t.min(r,n))}var u=r.utils.isFunction;r.sum=function o(r){for(var o=0,t=r.length;--t>=0;)o+=r[t];return o},r.sumsqrd=function(r){for(var t=0,e=r.length;--e>=0;)t+=r[e]*r[e];return t},r.sumsqerr=function(t){for(var e,n=r.mean(t),u=0,i=t.length;--i>=0;)e=t[i]-n,u+=e*e;return u},r.sumrow=function(r){for(var t=0,e=r.length;--e>=0;)t+=r[e];return t},r.product=function(r){for(var t=1,e=r.length;--e>=0;)t*=r[e];return t},r.min=function(r){for(var t=r[0],e=0;++er[e]&&(t=r[e]);return t},r.max=function(r){for(var t=r[0],e=0;++et&&(t=r[e]);return t},r.unique=function(r){for(var t={},e=[],n=0;r.length>n;n++)t[r[n]]||(t[r[n]]=!0,e.push(r[n]));return e},r.mean=function(t){return r.sum(t)/t.length},r.meansqerr=function(t){return r.sumsqerr(t)/t.length},r.geomean=function(e){return t.pow(r.product(e),1/e.length)},r.median=function(r){var t=r.length,n=r.slice().sort(e);return 1&t?n[t/2|0]:(n[t/2-1]+n[t/2])/2},r.cumsum=function(t){return r.cumreduce(t,function(r,t){return r+t})},r.cumprod=function(t){return r.cumreduce(t,function(r,t){return r*t})},r.diff=function(r){for(var t,e=[],n=r.length,t=1;n>t;t++)e.push(r[t]-r[t-1]);return e},r.rank=function(r){for(var t=r.length,n=r.slice().sort(e),u=Array(t),i=0;t>i;i++){var o=n.indexOf(r[i]),a=n.lastIndexOf(r[i]);if(o===a)var s=o;else var s=(o+a)/2;u[i]=s+1}return u},r.mode=function(r){for(var t,n=r.length,u=r.slice().sort(e),i=1,o=0,a=0,s=[],t=0;n>t;t++)u[t]===u[t+1]?i++:(i>o?(s=[u[t]],o=i,a=0):i===o&&(s.push(u[t]),a++),i=1);return 0===a?s[0]:s},r.range=function(t){return r.max(t)-r.min(t)},r.variance=function(t,e){return r.sumsqerr(t)/(t.length-(e?1:0))},r.deviation=function(t){for(var e=r.mean(t),n=t.length,u=Array(n),i=0;n>i;i++)u[i]=t[i]-e;return u},r.stdev=function(e,n){return t.sqrt(r.variance(e,n))},r.meandev=function(e){for(var n,u=0,i=r.mean(e),n=e.length-1;n>=0;n--)u+=t.abs(e[n]-i);return u/e.length},r.meddev=function(e){for(var n,u=0,i=r.median(e),n=e.length-1;n>=0;n--)u+=t.abs(e[n]-i);return u/e.length},r.coeffvar=function(t){return r.stdev(t)/r.mean(t)},r.quartiles=function(r){var n=r.length,u=r.slice().sort(e);return[u[t.round(n/4)-1],u[t.round(n/2)-1],u[t.round(3*n/4)-1]]},r.quantiles=function(r,u,i,o){var a,s,l,f,c,p,m=r.slice().sort(e),d=[u.length],h=r.length;void 0===i&&(i=3/8),void 0===o&&(o=3/8);for(var a=0;u.length>a;a++)s=u[a],l=i+s*(1-i-o),f=h*s+l,c=t.floor(n(f,1,h-1)),p=n(f-c,0,1),d[a]=(1-p)*m[c-1]+p*m[c];return d},r.percentile=function(r,t){var n=r.slice().sort(e),u=t*(n.length-1),i=parseInt(u),o=u-i;return n.length>i+1?n[i]*(1-o)+n[i+1]*o:n[i]},r.percentileOfScore=function(r,t,e){var n,u,i=0,o=r.length,a=!1;"strict"===e&&(a=!0);for(var u=0;o>u;u++)n=r[u],(a&&t>n||!a&&t>=n)&&i++;return i/o},r.histogram=function(e,n){for(var u,i=r.min(e),o=n||4,a=(r.max(e)-i)/o,s=e.length,n=[],u=0;o>u;u++)n[u]=0;for(var u=0;s>u;u++)n[t.min(t.floor((e[u]-i)/a),o-1)]+=1;return n},r.covariance=function(t,e){for(var n,u=r.mean(t),i=r.mean(e),o=t.length,a=Array(o),n=0;o>n;n++)a[n]=(t[n]-u)*(e[n]-i);return r.sum(a)/(o-1)},r.corrcoeff=function(t,e){return r.covariance(t,e)/r.stdev(t,1)/r.stdev(e,1)},r.spearmancoeff=function(e,n){e=r.rank(e),n=r.rank(n);var u=r.deviation(e),i=r.deviation(n);return r.sum(u.map(function(r,t){return r*i[t]}))/t.sqrt(r.sum(u.map(function(r){return t.pow(r,2)}))*r.sum(i.map(function(r){return t.pow(r,2)})))},r.stanMoment=function(e,n){for(var u=r.mean(e),i=r.stdev(e),o=e.length,a=0,s=0;o>s;s++)a+=t.pow((e[s]-u)/i,n);return a/e.length},r.skewness=function(t){return r.stanMoment(t,3)},r.kurtosis=function(t){return r.stanMoment(t,4)-3};var i=r.prototype;!function(t){for(var e=0;t.length>e;e++)!function(t){i[t]=function(e,n){var o=[],a=0,s=this;if(u(e)&&(n=e,e=!1),n)return setTimeout(function(){n.call(s,i[t].call(s,e))}),this;if(this.length>1){for(s=e===!0?this:this.transpose();s.length>a;a++)o[a]=r[t](s[a]);return o}return r[t](this[0],e)}}(t[e])}("cumsum cumprod".split(" ")),function(t){for(var e=0;t.length>e;e++)!function(t){i[t]=function(e,n){var o=[],a=0,s=this;if(u(e)&&(n=e,e=!1),n)return setTimeout(function(){n.call(s,i[t].call(s,e))}),this;if(this.length>1){for("sumrow"!==t&&(s=e===!0?this:this.transpose());s.length>a;a++)o[a]=r[t](s[a]);return e===!0?r[t](r.utils.toVector(o)):o}return r[t](this[0],e)}}(t[e])}("sum sumsqrd sumsqerr sumrow product min max unique mean meansqerr geomean median diff rank mode range variance deviation stdev meandev meddev coeffvar quartiles histogram skewness kurtosis".split(" ")),function(t){for(var e=0;t.length>e;e++)!function(t){i[t]=function(){var e=[],n=0,o=this,a=Array.prototype.slice.call(arguments);if(u(a[a.length-1])){var s=a[a.length-1],l=a.slice(0,a.length-1);return setTimeout(function(){s.call(o,i[t].apply(o,l))}),this}var s=undefined,f=function(e){return r[t].apply(o,[e].concat(a))};if(this.length>1){for(o=o.transpose();o.length>n;n++)e[n]=f(o[n]);return e}return f(this[0])}}(t[e])}("quantiles percentileOfScore".split(" "))}(this.jStat,Math),function(r,t){r.gammaln=function(r){var e,n,u,i=0,o=[76.18009172947146,-86.50532032941678,24.01409824083091,-1.231739572450155,.001208650973866179,-5395239384953e-18],a=1.000000000190015;for(u=(n=e=r)+5.5,u-=(e+.5)*t.log(u);6>i;i++)a+=o[i]/++n;return t.log(2.5066282746310007*a/e)-u},r.gammafn=function(r){var e,n,u,i,o=[-1.716185138865495,24.76565080557592,-379.80425647094563,629.3311553128184,866.9662027904133,-31451.272968848367,-36144.413418691176,66456.14382024054],a=[-30.8402300119739,315.35062697960416,-1015.1563674902192,-3107.771671572311,22538.11842098015,4755.846277527881,-134659.9598649693,-115132.2596755535],s=!1,l=0,f=0,c=0,p=r;if(0>=p){if(!(i=p%1+3.6e-16))return Infinity;s=(1&p?-1:1)*t.PI/t.sin(t.PI*i),p=1-p}u=p,n=1>p?p++:(p-=l=(0|p)-1)-1;for(var e=0;8>e;++e)c=(c+o[e])*n,f=f*n+a[e];if(i=c/f+1,p>u)i/=u;else if(u>p)for(var e=0;l>e;++e)i*=p,p++;return s&&(i=s/i),i},r.gammap=function(t,e){return r.lowRegGamma(t,e)*r.gammafn(t)},r.lowRegGamma=function(e,n){var u,i=r.gammaln(e),o=e,a=1/e,s=a,l=n+1-e,f=1/1e-30,c=1/l,p=c,m=1,d=-~(8.5*t.log(1>e?1/e:e)+.4*e+17);if(0>n||0>=e)return NaN;if(e+1>n){for(;d>=m;m++)a+=s*=n/++o;return a*t.exp(-n+e*t.log(n)-i)}for(;d>=m;m++)u=-m*(m-e),l+=2,c=u*c+l,f=l+u/f,c=1/c,p*=c*f;return 1-p*t.exp(-n+e*t.log(n)-i)},r.factorialln=function(t){return 0>t?NaN:r.gammaln(t+1)},r.factorial=function(t){return 0>t?NaN:r.gammafn(t+1)},r.combination=function(e,n){return e>170||n>170?t.exp(r.combinationln(e,n)):r.factorial(e)/r.factorial(n)/r.factorial(e-n)},r.combinationln=function(t,e){return r.factorialln(t)-r.factorialln(e)-r.factorialln(t-e)},r.permutation=function(t,e){return r.factorial(t)/r.factorial(t-e)},r.betafn=function(e,n){return e>0&&n>0?e+n>170?t.exp(r.betaln(e,n)):r.gammafn(e)*r.gammafn(n)/r.gammafn(e+n):undefined},r.betaln=function(t,e){return r.gammaln(t)+r.gammaln(e)-r.gammaln(t+e)},r.betacf=function(r,e,n){var u,i,o,a,s=1e-30,l=1,f=e+n,c=e+1,p=e-1,m=1,d=1-f*r/c;for(t.abs(d)=l&&(u=2*l,i=l*(n-l)*r/((p+u)*(e+u)),d=1+i*d,t.abs(d)=1)return t.max(100,n+100*t.sqrt(n));if(0>=e)return 0;for(n>1?(l=t.log(p),f=t.exp(p*(l-1)-d),s=.5>e?e:1-e,o=t.sqrt(-2*t.log(s)),u=(2.30753+.27061*o)/(1+o*(.99229+.04481*o))-o,.5>e&&(u=-u),u=t.max(.001,n*t.pow(1-1/(9*n)-u/(3*t.sqrt(n)),3))):(o=1-n*(.253+.12*n),u=o>e?t.pow(e/o,1/n):1-t.log(1-(e-o)/(1-o)));12>c;c++){if(0>=u)return 0;if(i=r.lowRegGamma(n,u)-e,o=n>1?f*t.exp(-(u-p)+p*(t.log(u)-l)):t.exp(-u+p*t.log(u)-d),a=i/o,u-=o=a/(1-.5*t.min(1,a*((n-1)/u-1))),u>0||(u=.5*(u+o)),t.abs(o)r&&(r=-r,s=!0),e=2/(2+r),n=4*e-2;a>0;a--)u=l,l=n*l-f+o[a],f=u;return i=e*t.exp(-r*r+.5*(o[0]+n*l)-f),s?i-1:1-i},r.erfc=function(t){return 1-r.erf(t)},r.erfcinv=function(e){var n,u,i,o,a=0;if(e>=2)return-100;if(0>=e)return 100;for(o=1>e?e:2-e,i=t.sqrt(-2*t.log(o/2)),n=-.70711*((2.30753+.27061*i)/(1+i*(.99229+.04481*i))-i);2>a;a++)u=r.erfc(n)-o,n+=u/(1.1283791670955126*t.exp(-n*n)-n*u);return 1>e?n:-n},r.ibetainv=function(e,n,u){var i,o,a,s,l,f,c,p,m,d,h,E=1e-8,g=n-1,v=u-1,N=0;if(0>=e)return 0;if(e>=1)return 1;for(1>n||1>u?(i=t.log(n/(n+u)),o=t.log(u/(n+u)),s=t.exp(n*i)/n,l=t.exp(u*o)/u,d=s+l,c=s/d>e?t.pow(n*d*e,1/n):1-t.pow(u*d*(1-e),1/u)):(a=.5>e?e:1-e,s=t.sqrt(-2*t.log(a)),c=(2.30753+.27061*s)/(1+s*(.99229+.04481*s))-s,.5>e&&(c=-c),p=(c*c-3)/6,m=2/(1/(2*n-1)+1/(2*u-1)),d=c*t.sqrt(p+m)/m-(1/(2*u-1)-1/(2*n-1))*(p+5/6-2/(3*m)),c=n/(n+u*t.exp(2*d))),h=-r.gammaln(n)-r.gammaln(u)+r.gammaln(n+u);10>N;N++){if(0===c||1===c)return c;if(f=r.ibeta(c,n,u)-e,s=t.exp(g*t.log(c)+v*t.log(1-c)+h),l=f/s,c-=s=l/(1-.5*t.min(1,l*(g/c-v/(1-c)))),c>0||(c=.5*(c+s)),1>c||(c=.5*(c+s+1)),t.abs(s)0)break}return c},r.ibeta=function(e,n,u){var i=0===e||1===e?0:t.exp(r.gammaln(n+u)-r.gammaln(n)-r.gammaln(u)+n*t.log(e)+u*t.log(1-e));return e>=0&&1>=e&&((n+1)/(n+u+2)>e?i*r.betacf(e,n,u)/n:1-i*r.betacf(1-e,u,n)/u)},r.randn=function(e,n){var u,i,o,a,s;if(n||(n=e),e)return r.create(e,n,function(){return r.randn()});do{u=t.random(),i=1.7156*(t.random()-.5),o=u-.449871,a=t.abs(i)+.386595,s=o*o+a*(.196*a-.25472*o)}while(s>.27597&&(s>.27846||i*i>-4*t.log(u)*u*u));return i/u},r.randg=function(e,n,u){var i,o,a,s,l,f,c=e;if(u||(u=n),e||(e=1),n)return f=r.zeros(n,u),f.alter(function(){return r.randg(e)}),f;1>e&&(e+=1),i=e-1/3,o=1/t.sqrt(9*i);do{do{l=r.randn(),s=1+o*l}while(0>=s);s*=s*s,a=t.random()}while(a>1-.331*t.pow(l,4)&&t.log(a)>.5*l*l+i*(1-s+t.log(s)));if(e==c)return i*s;do{a=t.random()}while(0===a);return t.pow(a,1/c)*i*s},function(t){for(var e=0;t.length>e;e++)!function(t){r.fn[t]=function(){return r(r.map(this,function(e){return r[t](e)}))}}(t[e])}("gammaln gammafn factorial factorialln".split(" ")),function(t){for(var e=0;t.length>e;e++)!function(t){r.fn[t]=function(){return r(r[t].apply(null,arguments))}}(t[e])}("randn".split(" "))}(this.jStat,Math),function(r,t){function e(r){return r/t.abs(r)}!function(t){for(var e=0;t.length>e;e++)!function(t){r[t]=function(r,t,e){return this instanceof arguments.callee?(this._a=r,this._b=t,this._c=e,this):new arguments.callee(r,t,e)},r.fn[t]=function(e,n,u){var i=r[t](e,n,u);return i.data=this,i},r[t].prototype.sample=function(e){var n=this._a,u=this._b,i=this._c;return e?r.alter(e,function(){return r[t].sample(n,u,i)}):r[t].sample(n,u,i)},function(e){for(var n=0;e.length>n;n++)!function(e){r[t].prototype[e]=function(n){var u=this._a,i=this._b,o=this._c;return n||0===n||(n=this.data),"number"!=typeof n?r.fn.map.call(n,function(n){return r[t][e](n,u,i,o)}):r[t][e](n,u,i,o)}}(e[n])}("pdf cdf inv".split(" ")),function(e){for(var n=0;e.length>n;n++)!function(e){r[t].prototype[e]=function(){return r[t][e](this._a,this._b,this._c)}}(e[n])}("mean median mode variance".split(" "))}(t[e])}("beta centralF cauchy chisquare exponential gamma invgamma kumaraswamy laplace lognormal noncentralt normal pareto studentt weibull uniform binomial negbin hypgeom poisson triangular".split(" ")),r.extend(r.beta,{pdf:function(e,n,u){return e>1||0>e?0:1==n&&1==u?1:512>n&&512>u?t.pow(e,n-1)*t.pow(1-e,u-1)/r.betafn(n,u):t.exp((n-1)*t.log(e)+(u-1)*t.log(1-e)-r.betaln(n,u))},cdf:function(t,e,n){return t>1||0>t?1*(t>1):r.ibeta(t,e,n)},inv:function(t,e,n){return r.ibetainv(t,e,n)},mean:function(r,t){return r/(r+t)},median:function(t,e){return r.ibetainv(.5,t,e)},mode:function(r,t){return(r-1)/(r+t-2)},sample:function(t,e){var n=r.randg(t);return n/(n+r.randg(e))},variance:function(r,e){return r*e/(t.pow(r+e,2)*(r+e+1))}}),r.extend(r.centralF,{pdf:function(e,n,u){var i,o;return 0>e?0:n>2?(i=n*e/(u+e*n),o=u/(u+e*n),n*o/2*r.binomial.pdf((n-2)/2,(n+u-2)/2,i)):0===e&&2>n?Infinity:0===e&&2===n?1:t.sqrt(t.pow(n*e,n)*t.pow(u,u)/t.pow(n*e+u,n+u))/(e*r.betafn(n/2,u/2))},cdf:function(t,e,n){return 0>t?0:r.ibeta(e*t/(e*t+n),e/2,n/2)},inv:function(t,e,n){return n/(e*(1/r.ibetainv(t,e/2,n/2)-1))},mean:function(r,t){return t>2?t/(t-2):undefined},mode:function(r,t){return r>2?t*(r-2)/(r*(t+2)):undefined},sample:function(t,e){return 2*r.randg(t/2)/t/(2*r.randg(e/2)/e)},variance:function(r,t){return t>4?2*t*t*(r+t-2)/(r*(t-2)*(t-2)*(t-4)):undefined}}),r.extend(r.cauchy,{pdf:function(r,e,n){return 0>n?0:n/(t.pow(r-e,2)+t.pow(n,2))/t.PI},cdf:function(r,e,n){return t.atan((r-e)/n)/t.PI+.5},inv:function(r,e,n){return e+n*t.tan(t.PI*(r-.5))},median:function(r,t){return r},mode:function(r,t){return r},sample:function(e,n){return r.randn()*t.sqrt(1/(2*r.randg(.5)))*n+e}}),r.extend(r.chisquare,{pdf:function(e,n){return 0>e?0:0===e&&2===n?.5:t.exp((n/2-1)*t.log(e)-e/2-n/2*t.log(2)-r.gammaln(n/2))},cdf:function(t,e){return 0>t?0:r.lowRegGamma(e/2,t/2)},inv:function(t,e){return 2*r.gammapinv(t,.5*e)},mean:function(r){return r},median:function(r){return r*t.pow(1-2/(9*r),3)},mode:function(r){return r-2>0?r-2:0},sample:function(t){return 2*r.randg(t/2)},variance:function(r){return 2*r}}),r.extend(r.exponential,{pdf:function(r,e){return 0>r?0:e*t.exp(-e*r)},cdf:function(r,e){return 0>r?0:1-t.exp(-e*r)},inv:function(r,e){return-t.log(1-r)/e},mean:function(r){return 1/r},median:function(r){return 1/r*t.log(2)},mode:function(r){return 0},sample:function(r){return-1/r*t.log(t.random())},variance:function(r){return t.pow(r,-2)}}),r.extend(r.gamma,{pdf:function(e,n,u){return 0>e?0:0===e&&1===n?1/u:t.exp((n-1)*t.log(e)-e/u-r.gammaln(n)-n*t.log(u))},cdf:function(t,e,n){return 0>t?0:r.lowRegGamma(e,t/n)},inv:function(t,e,n){return r.gammapinv(t,e)*n},mean:function(r,t){return r*t},mode:function(r,t){return r>1?(r-1)*t:undefined},sample:function(t,e){return r.randg(t)*e},variance:function(r,t){return r*t*t}}),r.extend(r.invgamma,{pdf:function(e,n,u){return e>0?t.exp(-(n+1)*t.log(e)-u/e-r.gammaln(n)+n*t.log(u)):0},cdf:function(t,e,n){return t>0?1-r.lowRegGamma(e,n/t):0},inv:function(t,e,n){return n/r.gammapinv(1-t,e)},mean:function(r,t){return r>1?t/(r-1):undefined},mode:function(r,t){return t/(r+1)},sample:function(t,e){return e/r.randg(t)},variance:function(r,t){return r>2?t*t/((r-1)*(r-1)*(r-2)):undefined}}),r.extend(r.kumaraswamy,{pdf:function(r,e,n){return 0===r&&1===e?n:1===r&&1===n?e:t.exp(t.log(e)+t.log(n)+(e-1)*t.log(r)+(n-1)*t.log(1-t.pow(r,e)))},cdf:function(r,e,n){return 0>r?0:r>1?1:1-t.pow(1-t.pow(r,e),n)},inv:function(r,e,n){return t.pow(1-t.pow(1-r,1/n),1/e)},mean:function(t,e){return e*r.gammafn(1+1/t)*r.gammafn(e)/r.gammafn(1+1/t+e)},median:function(r,e){return t.pow(1-t.pow(2,-1/e),1/r)},mode:function(r,e){return 1>r||1>e||1===r||1===e?undefined:t.pow((r-1)/(r*e-1),1/r)},variance:function(r,t){throw Error("variance not yet implemented")}}),r.extend(r.lognormal,{pdf:function(r,e,n){return r>0?t.exp(-t.log(r)-.5*t.log(2*t.PI)-t.log(n)-t.pow(t.log(r)-e,2)/(2*n*n)):0},cdf:function(e,n,u){return 0>e?0:.5+.5*r.erf((t.log(e)-n)/t.sqrt(2*u*u))},inv:function(e,n,u){return t.exp(-1.4142135623730951*u*r.erfcinv(2*e)+n)},mean:function(r,e){return t.exp(r+e*e/2)},median:function(r,e){return t.exp(r)},mode:function(r,e){return t.exp(r-e*e)},sample:function(e,n){return t.exp(r.randn()*n+e)},variance:function(r,e){return(t.exp(e*e)-1)*t.exp(2*r+e*e)}}),r.extend(r.noncentralt,{pdf:function(e,n,u){var i=1e-14;return t.abs(u)e&&(a=!0,u=-u);for(var s=r.normal.cdf(-u,0,1),l=i+1,f=l,c=e*e/(e*e+n),p=0,m=t.exp(-u*u/2),d=t.exp(-u*u/2-.5*t.log(2)-r.gammaln(1.5))*u;o>p||f>i||l>i;)f=l,p>0&&(m*=u*u/(2*p),d*=u*u/(2*(p+.5))),l=m*r.beta.cdf(c,p+.5,n/2)+d*r.beta.cdf(c,p+1,n/2),s+=.5*l,p++;return a?1-s:s}}),r.extend(r.normal,{pdf:function(r,e,n){return t.exp(-.5*t.log(2*t.PI)-t.log(n)-t.pow(r-e,2)/(2*n*n))},cdf:function(e,n,u){return.5*(1+r.erf((e-n)/t.sqrt(2*u*u)))},inv:function(t,e,n){return-1.4142135623730951*n*r.erfcinv(2*t)+e},mean:function(r,t){return r},median:function(r,t){return r},mode:function(r,t){return r},sample:function(t,e){return r.randn()*e+t},variance:function(r,t){return t*t}}),r.extend(r.pareto,{pdf:function(r,e,n){return e>r?0:n*t.pow(e,n)/t.pow(r,n+1)},cdf:function(r,e,n){return e>r?0:1-t.pow(e/r,n)},inv:function(r,e,n){return e/t.pow(1-r,1/n)},mean:function(r,e){return e>1?e*t.pow(r,e)/(e-1):undefined},median:function(r,e){return r*(e*t.SQRT2)},mode:function(r,t){return r},variance:function(r,e){return e>2?r*r*e/(t.pow(e-1,2)*(e-2)):undefined}}),r.extend(r.studentt,{pdf:function(e,n){return n=n>1e100?1e100:n,1/(t.sqrt(n)*r.betafn(.5,n/2))*t.pow(1+e*e/n,-((n+1)/2))},cdf:function(e,n){var u=n/2;return r.ibeta((e+t.sqrt(e*e+n))/(2*t.sqrt(e*e+n)),u,u)},inv:function(e,n){var u=r.ibetainv(2*t.min(e,1-e),.5*n,.5);return u=t.sqrt(n*(1-u)/u),e>.5?u:-u},mean:function(r){return r>1?0:undefined},median:function(r){return 0},mode:function(r){return 0},sample:function(e){return r.randn()*t.sqrt(e/(2*r.randg(e/2)))},variance:function(r){return r>2?r/(r-2):r>1?Infinity:undefined}}),r.extend(r.weibull,{pdf:function(r,e,n){return 0>r||0>e||0>n?0:n/e*t.pow(r/e,n-1)*t.exp(-t.pow(r/e,n))},cdf:function(r,e,n){return 0>r?0:1-t.exp(-t.pow(r/e,n))},inv:function(r,e,n){return e*t.pow(-t.log(1-r),1/n)},mean:function(t,e){return t*r.gammafn(1+1/e)},median:function(r,e){return r*t.pow(t.log(2),1/e)},mode:function(r,e){return e>1?r*t.pow((e-1)/e,1/e):0},sample:function(r,e){return r*t.pow(-t.log(t.random()),1/e)},variance:function(e,n){return e*e*r.gammafn(1+2/n)-t.pow(r.weibull.mean(e,n),2)}}),r.extend(r.uniform,{pdf:function(r,t,e){return t>r||r>e?0:1/(e-t)},cdf:function(r,t,e){return t>r?0:e>r?(r-t)/(e-t):1},inv:function(r,t,e){return t+r*(e-t)},mean:function(r,t){return.5*(r+t)},median:function(t,e){return r.mean(t,e)},mode:function(r,t){throw Error("mode is not yet implemented")},sample:function(r,e){return r/2+e/2+(e/2-r/2)*(2*t.random()-1)},variance:function(r,e){return t.pow(e-r,2)/12}}),r.extend(r.binomial,{pdf:function(e,n,u){return 0===u||1===u?n*u===e?1:0:r.combination(n,e)*t.pow(u,e)*t.pow(1-u,n-e)},cdf:function(t,e,n){var u=[],i=0;if(0>t)return 0;if(e>t){for(;t>=i;i++)u[i]=r.binomial.pdf(i,e,n);return r.sum(u)}return 1}}),r.extend(r.negbin,{pdf:function(e,n,u){return e===e>>>0&&(0>e?0:r.combination(e+n-1,n-1)*t.pow(1-u,e)*t.pow(u,n))},cdf:function(t,e,n){var u=0,i=0;if(0>t)return 0;for(;t>=i;i++)u+=r.negbin.pdf(i,e,n);return u}}),r.extend(r.hypgeom,{pdf:function(e,n,u,i){if(e!==e|0)return!1;if(0>e||u-(n-i)>e)return 0;if(e>i||e>u)return 0;if(2*u>n)return 2*i>n?r.hypgeom.pdf(n-u-i+e,n,n-u,n-i):r.hypgeom.pdf(i-e,n,n-u,i);if(2*i>n)return r.hypgeom.pdf(u-e,n,u,n-i);if(i>u)return r.hypgeom.pdf(e,n,i,u);for(var o=1,a=0,s=0;e>s;s++){for(;o>1&&i>a;)o*=1-u/(n-a),a++;o*=(i-s)*(u-s)/((s+1)*(n-u-i+s+1))}for(;i>a;a++)o*=1-u/(n-a);return t.min(1,t.max(0,o))},cdf:function(e,n,u,i){if(0>e||u-(n-i)>e)return 0;if(i>e&&u>e){if(2*u>n)return 2*i>n?r.hypgeom.cdf(n-u-i+e,n,n-u,n-i):1-r.hypgeom.cdf(i-e-1,n,n-u,i);if(2*i>n)return 1-r.hypgeom.cdf(u-e-1,n,u,n-i);if(i>u)return r.hypgeom.cdf(e,n,i,u);for(var o=1,a=1,s=0,l=0;e>l;l++){for(;o>1&&i>s;){var f=1-u/(n-s);a*=f,o*=f,s++}a*=(i-l)*(u-l)/((l+1)*(n-u-i+l+1)),o+=a}for(;i>s;s++)o*=1-u/(n-s);return t.min(1,t.max(0,o))}return 1}}),r.extend(r.poisson,{pdf:function(e,n){return 0>n||e%1!=0||0>e?0:t.pow(n,e)*t.exp(-n)/r.factorial(e)},cdf:function(t,e){var n=[],u=0;if(0>t)return 0;for(;t>=u;u++)n.push(r.poisson.pdf(u,e));return r.sum(n)},mean:function(r){return r},variance:function(r){return r},sample:function(r){var e=1,n=0,u=t.exp(-r);do{n++,e*=t.random()}while(e>u);return n-1}}),r.extend(r.triangular,{pdf:function(r,t,e,n){return t>=e||t>n||n>e?NaN:t>r||r>e?0:n>r?2*(r-t)/((e-t)*(n-t)):r===n?2/(e-t):2*(e-r)/((e-t)*(e-n))},cdf:function(r,e,n,u){return e>=n||e>u||u>n?NaN:r>e?n>r?r>u?1-t.pow(n-r,2)/((n-e)*(n-u)):t.pow(r-e,2)/((n-e)*(u-e)):1:0},inv:function(r,e,n,u){return e>=n||e>u||u>n?NaN:r>(u-e)/(n-e)?e+(n-e)*(1-t.sqrt((1-r)*(1-(u-e)/(n-e)))):e+(n-e)*t.sqrt(r*((u-e)/(n-e)))},mean:function(r,t,e){return(r+t+e)/3},median:function(r,e,n){return n>(r+e)/2?n>(r+e)/2?r+t.sqrt((e-r)*(n-r))/t.sqrt(2):void 0:e-t.sqrt((e-r)*(e-n))/t.sqrt(2)},mode:function(r,t,e){return e},sample:function(r,e,n){var u=t.random();return(n-r)/(e-r)>u?r+t.sqrt(u*(e-r)*(n-r)):e-t.sqrt((1-u)*(e-r)*(e-n))},variance:function(r,t,e){return(r*r+t*t+e*e-r*t-r*e-t*e)/18}}),r.extend(r.laplace,{pdf:function(r,e,n){return n>0?t.exp(-t.abs(r-e)/n)/(2*n):0},cdf:function(r,e,n){return n>0?e>r?.5*t.exp((r-e)/n):1-.5*t.exp(-(r-e)/n):0},mean:function(r,t){return r},median:function(r,t){return r},mode:function(r,t){return r},variance:function(r,t){return 2*t*t},sample:function(r,n){var u=t.random()-.5;return r-n*e(u)*t.log(1-2*t.abs(u))}})}(this.jStat,Math),function(r,t){function e(t){return u(t)||t instanceof r}var n=Array.prototype.push,u=r.utils.isArray;r.extend({add:function(t,n){return e(n)?(e(n[0])||(n=[n]),r.map(t,function(r,t,e){return r+n[t][e]})):r.map(t,function(r){return r+n})},subtract:function(t,n){return e(n)?(e(n[0])||(n=[n]),r.map(t,function(r,t,e){return r-n[t][e]||0})):r.map(t,function(r){return r-n})},divide:function(t,n){return e(n)?(e(n[0])||(n=[n]),r.multiply(t,r.inv(n))):r.map(t,function(r){return r/n})},multiply:function(t,n){var u,i,o,a,s,l,f,c;if(t.length===undefined&&n.length===undefined)return t*n;if(s=t.length,l=t[0].length,f=r.zeros(s,o=e(n)?n[0].length:l),c=0,e(n)){for(;o>c;c++)for(u=0;s>u;u++){for(a=0,i=0;l>i;i++)a+=t[u][i]*n[i][c];f[u][c]=a}return 1===s&&1===c?f[0][0]:f}return r.map(t,function(r){return r*n})},outer:function(t,e){return r.multiply(t.map(function(r){return[r]}),[e])},dot:function(t,n){e(t[0])||(t=[t]),e(n[0])||(n=[n]);for(var u,i,o=1===t[0].length&&1!==t.length?r.transpose(t):t,a=1===n[0].length&&1!==n.length?r.transpose(n):n,s=[],l=0,f=o.length,c=o[0].length;f>l;l++){for(s[l]=[],u=0,i=0;c>i;i++)u+=o[l][i]*a[l][i];s[l]=u}return 1===s.length?s[0]:s},pow:function(e,n){return r.map(e,function(r){return t.pow(r,n)})},exp:function(e){return r.map(e,function(r){return t.exp(r)})},log:function(e){return r.map(e,function(r){return t.log(r)})},abs:function(e){return r.map(e,function(r){return t.abs(r)})},norm:function(r,n){var u=0,i=0;for(isNaN(n)&&(n=2),e(r[0])&&(r=r[0]);r.length>i;i++)u+=t.pow(t.abs(r[i]),n);return t.pow(u,1/n)},angle:function(e,n){return t.acos(r.dot(e,n)/(r.norm(e)*r.norm(n)))},aug:function(r,t){for(var e=[],u=0;r.length>u;u++)e.push(r[u].slice());for(var u=0;e.length>u;u++)n.apply(e[u],t[u]);return e},inv:function(t){for(var e,n=t.length,u=t[0].length,i=r.identity(n,u),o=r.gauss_jordan(t,i),a=[],s=0;n>s;s++)for(a[s]=[],e=u;o[0].length>e;e++)a[s][e-u]=o[s][e];return a},det:function(r){var t,e=r.length,n=2*e,u=Array(n),i=e-1,o=n-1,a=i-e+1,s=o,l=0,f=0;if(2===e)return r[0][0]*r[1][1]-r[0][1]*r[1][0];for(;n>l;l++)u[l]=1;for(var l=0;e>l;l++){for(t=0;e>t;t++)u[0>a?a+e:a]*=r[l][t],u[e>s?s+e:s]*=r[l][t],a++,s--;a=--i-e+1,s=--o}for(var l=0;e>l;l++)f+=u[l];for(;n>l;l++)f-=u[l];return f},gauss_elimination:function(e,n){var u,i,o,a,s=0,l=0,f=e.length,c=e[0].length,p=1,m=0,d=[];e=r.aug(e,n),u=e[0].length;for(var s=0;f>s;s++){for(i=e[s][s],l=s,a=s+1;c>a;a++)ia;a++)o=e[s][a],e[s][a]=e[l][a],e[l][a]=o;for(l=s+1;f>l;l++)for(p=e[l][s]/e[s][s],a=s;u>a;a++)e[l][a]=e[l][a]-p*e[s][a]}for(var s=f-1;s>=0;s--){for(m=0,l=s+1;f-1>=l;l++)m+=d[l]*e[s][l];d[s]=(e[s][u-1]-m)/e[s][s]}return d},gauss_jordan:function(e,n){for(var u=r.aug(e,n),i=u.length,o=u[0].length,a=0;i>a;a++){for(var s=a,l=a+1;i>l;l++)t.abs(u[l][a])>t.abs(u[s][a])&&(s=l);var f=u[a];u[a]=u[s],u[s]=f;for(var l=a+1;i>l;l++){c=u[l][a]/u[a][a];for(var p=a;o>p;p++)u[l][p]-=u[a][p]*c}}for(var a=i-1;a>=0;a--){c=u[a][a];for(var l=0;a>l;l++)for(var p=o-1;p>a-1;p--)u[l][p]-=u[a][p]*u[l][a]/c;u[a][a]/=c;for(var p=i;o>p;p++)u[a][p]/=c}return u},triaUpSolve:function(t,e){var n,u=t[0].length,i=r.zeros(1,u)[0],o=!1;return e[0].length!=undefined&&(e=e.map(function(r){return r[0]}),o=!0),r.arange(u-1,-1,-1).forEach(function(o){n=r.arange(o+1,u).map(function(r){return i[r]*t[o][r]}),i[o]=(e[o]-r.sum(n))/t[o][o]}),o?i.map(function(r){return[r]}):i},triaLowSolve:function(t,e){var n,u=t[0].length,i=r.zeros(1,u)[0],o=!1;return e[0].length!=undefined&&(e=e.map(function(r){return r[0]}),o=!0),r.arange(u).forEach(function(u){n=r.arange(u).map(function(r){return t[u][r]*i[r]}),i[u]=(e[u]-r.sum(n))/t[u][u]}),o?i.map(function(r){return[r]}):i},lu:function(t){var e,n=t.length,u=r.identity(n),o=r.zeros(t.length,t[0].length);return r.arange(n).forEach(function(r){o[0][r]=t[0][r]}),r.arange(1,n).forEach(function(a){r.arange(a).forEach(function(n){e=r.arange(n).map(function(r){return u[a][r]*o[r][n]}),u[a][n]=(t[a][n]-r.sum(e))/o[n][n]}),r.arange(a,n).forEach(function(n){e=r.arange(a).map(function(r){return u[a][r]*o[r][n]}),o[a][n]=t[i][n]-r.sum(e)})}),[u,o]},cholesky:function(e){var n,u=e.length,i=r.zeros(e.length,e[0].length);return r.arange(u).forEach(function(o){n=r.arange(o).map(function(r){return t.pow(i[o][r],2)}),i[o][o]=t.sqrt(e[o][o]-r.sum(n)),r.arange(o+1,u).forEach(function(t){n=r.arange(o).map(function(r){return i[o][r]*i[t][r]}),i[t][o]=(e[o][t]-r.sum(n))/i[o][o]})}),i},gauss_jacobi:function(e,n,u,i){for(var o,a,s,l,f=0,c=0,p=e.length,m=[],d=[],h=[];p>f;f++)for(m[f]=[],d[f]=[],h[f]=[],c=0;p>c;c++)f>c?(m[f][c]=e[f][c],d[f][c]=h[f][c]=0):c>f?(d[f][c]=e[f][c],m[f][c]=h[f][c]=0):(h[f][c]=e[f][c],m[f][c]=d[f][c]=0);for(s=r.multiply(r.multiply(r.inv(h),r.add(m,d)),-1),a=r.multiply(r.inv(h),n),o=u,l=r.add(r.multiply(s,u),a),f=2;t.abs(r.norm(r.subtract(l,o)))>i;)o=l,l=r.add(r.multiply(s,o),a),f++;return l},gauss_seidel:function(e,n,u,i){for(var o,a,s,l,f,c=0,p=e.length,m=[],d=[],h=[];p>c;c++)for(m[c]=[],d[c]=[],h[c]=[],o=0;p>o;o++)c>o?(m[c][o]=e[c][o],d[c][o]=h[c][o]=0):o>c?(d[c][o]=e[c][o],m[c][o]=h[c][o]=0):(h[c][o]=e[c][o],m[c][o]=d[c][o]=0);for(l=r.multiply(r.multiply(r.inv(r.add(h,m)),d),-1),s=r.multiply(r.inv(r.add(h,m)),n),a=u,f=r.add(r.multiply(l,u),s),c=2;t.abs(r.norm(r.subtract(f,a)))>i;)a=f,f=r.add(r.multiply(l,a),s),c+=1;return f},SOR:function(e,n,u,i,o){for(var a,s,l,f,c,p=0,m=e.length,d=[],h=[],E=[];m>p;p++)for(d[p]=[],h[p]=[],E[p]=[],a=0;m>a;a++)p>a?(d[p][a]=e[p][a],h[p][a]=E[p][a]=0):a>p?(h[p][a]=e[p][a],d[p][a]=E[p][a]=0):(E[p][a]=e[p][a],d[p][a]=h[p][a]=0);for(f=r.multiply(r.inv(r.add(E,r.multiply(d,o))),r.subtract(r.multiply(E,1-o),r.multiply(h,o))),l=r.multiply(r.multiply(r.inv(r.add(E,r.multiply(d,o))),n),o),s=u,c=r.add(r.multiply(f,u),l),p=2;t.abs(r.norm(r.subtract(c,s)))>i;)s=c,c=r.add(r.multiply(f,s),l),p++;return c},householder:function(e){for(var n,u,i,o,a,s=e.length,l=e[0].length,f=0,c=[],p=[];s-1>f;f++){for(n=0,o=f+1;l>o;o++)n+=e[o][f]*e[o][f];for(a=e[f+1][f]>0?-1:1,n=a*t.sqrt(n),u=t.sqrt((n*n-e[f+1][f]*n)/2),c=r.zeros(s,1),c[f+1][0]=(e[f+1][f]-n)/(2*u),i=f+2;s>i;i++)c[i][0]=e[i][f]/(2*u);p=r.subtract(r.identity(s,l),r.multiply(r.multiply(c,r.transpose(c)),2)),e=r.multiply(p,r.multiply(e,p))}return e},QR:function(){function t(t){var e=t.length,n=r.norm(t,2),u=r.zeros(1,e)[0];u[0]=1;var i=r.add(r.multiply(r.multiply(u,n),-1),t),o=r.norm(i,2),a=r.divide(i,o);return r.subtract(r.identity(e),r.multiply(r.outer(a,a),2))}function e(e){var n=e[0].length,u=[];return r.arange(n).forEach(function(n){var i=r.slice(e,{row:{start:n},col:n}),o=t(i),a=r.identity(e.length);a=r.sliceAssign(a,{row:{start:n},col:{start:n}},o),e=r.multiply(a,e),u.push(a)}),[u.reduce(function(t,e){return r.multiply(t,e)}),e]}return e}(),lstsq:function(t,e){function n(t){t=r.copy(t);var e=t.length,n=r.identity(e);return r.arange(e-1,-1,-1).forEach(function(e){r.sliceAssign(n,{row:e},r.divide(r.slice(n,{row:e}),t[e][e])),r.sliceAssign(t,{row:e},r.divide(r.slice(t,{row:e}),t[e][e])),r.arange(e).forEach(function(u){var i=r.multiply(t[u][e],-1);r.sliceAssign(t,{row:u},r.add(r.slice(t,{row:u}),r.multiply(r.slice(t,{row:e}),i))),r.sliceAssign(n,{row:u},r.add(r.slice(n,{row:u}),r.multiply(r.slice(n,{row:e}),i)))})}),n}function u(t,e){var u=!1;e[0].length===undefined&&(e=e.map(function(r){return[r]}),u=!0);var i=r.QR(t),o=i[0],a=i[1],s=t[0].length,l=r.slice(o,{col:{end:s}}),f=r.slice(a,{row:{end:s}}),c=n(f),p=r.multiply(r.multiply(c,r.transpose(l)),e);return u?p.map(function(r){return r[0]}):p}return u}(),jacobi:function(e){for(var n,u,i,o,a,s,l,f,c=1,p=0,m=e.length,d=r.identity(m,m),h=[];1===c;){p++,s=e[0][1],o=0,a=1;for(var u=0;m>u;u++)for(i=0;m>i;i++)u!=i&&s0?t.PI/4:-t.PI/4:t.atan(2*e[o][a]/(e[o][o]-e[a][a]))/2,f=r.identity(m,m),f[o][o]=t.cos(l),f[o][a]=-t.sin(l),f[a][o]=t.sin(l),f[a][a]=t.cos(l),d=r.multiply(d,f),n=r.multiply(r.multiply(r.inv(f),e),f),e=n,c=0;for(var u=1;m>u;u++)for(i=1;m>i;i++)u!=i&&t.abs(e[u][i])>.001&&(c=1)}for(var u=0;m>u;u++)h.push(e[u][u]);return[d,h]},rungekutta:function(r,t,e,n,u,i){var o,a,s,l,f;if(2===i)for(;e>=n;)o=t*r(n,u),a=t*r(n+t,u+o),s=u+(o+a)/2,u=s,n+=t;if(4===i)for(;e>=n;)o=t*r(n,u),a=t*r(n+t/2,u+o/2),l=t*r(n+t/2,u+a/2),f=t*r(n+t,u+l),s=u+(o+2*a+2*l+f)/6,u=s,n+=t;return u},romberg:function(r,e,n,u){for(var i,o,a,s,l,f=0,c=(n-e)/2,p=[],m=[],d=[];u/2>f;){for(l=r(e),a=e,s=0;n>=a;a+=c,s++)p[s]=a;for(i=p.length,a=1;i-1>a;a++)l+=(a%2!=0?4:2)*r(p[a]);l=c/3*(l+r(n)),d[f]=l,c/=2,f++}for(o=d.length,i=1;1!==o;){for(a=0;o-1>a;a++)m[a]=(t.pow(4,i)*d[a+1]-d[a])/(t.pow(4,i)-1);o=m.length,d=m,m=[],i++}return d},richardson:function(r,e,n,u){function i(r,t){for(var e,n=0,u=r.length;u>n;n++)r[n]===t&&(e=n);return e}for(var o,a,s,l,f,c=t.abs(n-r[i(r,n)+1]),p=0,m=[],d=[];u>=c;)o=i(r,n+u),a=i(r,n),m[p]=(e[o]-2*e[a]+e[2*a-o])/(u*u),u/=2,p++;for(l=m.length,s=1;1!=l;){for(f=0;l-1>f;f++)d[f]=(t.pow(4,s)*m[f+1]-m[f])/(t.pow(4,s)-1);l=d.length,m=d,d=[],s++}return m},simpson:function(r,t,e,n){for(var u,i=(e-t)/n,o=r(t),a=[],s=t,l=0,f=1;e>=s;s+=i,l++)a[l]=s;for(u=a.length;u-1>f;f++)o+=(f%2!=0?4:2)*r(a[f]);return i/3*(o+r(e))},hermite:function(r,t,e,n){for(var u,i=r.length,o=0,a=0,s=[],l=[],f=[],c=[];i>a;a++){for(s[a]=1,u=0;i>u;u++)a!=u&&(s[a]*=(n-r[u])/(r[a]-r[u]));for(l[a]=0,u=0;i>u;u++)a!=u&&(l[a]+=1/(r[a]-r[u]));f[a]=s[a]*s[a]*(1-2*(n-r[a])*l[a]),c[a]=s[a]*s[a]*(n-r[a]),o+=f[a]*t[a]+c[a]*e[a]}return o},lagrange:function(r,t,e){for(var n,u,i=0,o=0,a=r.length;a>o;o++){for(u=t[o],n=0;a>n;n++)o!=n&&(u*=(e-r[n])/(r[o]-r[n]));i+=u}return i},cubic_spline:function(t,e,n){for(var u,i=t.length,o=0,a=[],s=[],l=[],f=[],c=[],p=[],m=[];i-1>o;o++)c[o]=t[o+1]-t[o];l[0]=0;for(var o=1;i-1>o;o++)l[o]=3/c[o]*(e[o+1]-e[o])-3/c[o-1]*(e[o]-e[o-1]);for(var o=1;i-1>o;o++)a[o]=[],s[o]=[],a[o][o-1]=c[o-1],a[o][o]=2*(c[o-1]+c[o]),a[o][o+1]=c[o],s[o][0]=l[o];for(f=r.multiply(r.inv(a),s),u=0;i-1>u;u++)p[u]=(e[u+1]-e[u])/c[u]-c[u]*(f[u+1][0]+2*f[u][0])/3,m[u]=(f[u+1][0]-f[u][0])/(3*c[u]);for(u=0;i>u&&t[u]<=n;u++);return u-=1,e[u]+(n-t[u])*p[u]+r.sq(n-t[u])*f[u]+(n-t[u])*r.sq(n-t[u])*m[u]},gauss_quadrature:function(){throw Error("gauss_quadrature not yet implemented")},PCA:function(t){for(var e,n,u=t.length,i=t[0].length,o=0,a=[],s=[],l=[],f=[],c=[],p=[],m=[],d=[],h=[],E=[],o=0;u>o;o++)a[o]=r.sum(t[o])/i;for(var o=0;i>o;o++)for(m[o]=[],e=0;u>e;e++)m[o][e]=t[e][o]-a[e];m=r.transpose(m);for(var o=0;u>o;o++)for(d[o]=[],e=0;u>e;e++)d[o][e]=r.dot([m[o]],[m[e]])/(i-1);l=r.jacobi(d),h=l[0],s=l[1],E=r.transpose(h);for(var o=0;s.length>o;o++)for(e=o;s.length>e;e++)s[e]>s[o]&&(n=s[o],s[o]=s[e],s[e]=n,f=E[o],E[o]=E[e],E[e]=f);p=r.transpose(m);for(var o=0;u>o;o++)for(c[o]=[],e=0;p.length>e;e++)c[o][e]=r.dot([E[o]],[p[e]]);return[t,s,E,c]}}),function(t){for(var e=0;t.length>e;e++)!function(t){r.fn[t]=function(e,n){var u=this;return n?(setTimeout(function(){n.call(u,r.fn[t].call(u,e))},15),this):"number"==typeof r[t](this,e)?r[t](this,e):r(r[t](this,e))}}(t[e])}("add divide multiply subtract dot pow exp log abs norm angle".split(" "))}(this.jStat,Math),function(r,t){function e(r,e,n,u){if(r>1||n>1||0>=r||0>=n)throw Error("Proportions should be greater than 0 and less than 1");var i=(r*e+n*u)/(e+u);return(r-n)/t.sqrt(i*(1-i)*(1/e+1/u))}var n=[].slice,u=r.utils.isNumber,i=r.utils.isArray;r.extend({zscore:function(){var t=n.call(arguments);return u(t[1])?(t[0]-t[1])/t[2]:(t[0]-r.mean(t[1]))/r.stdev(t[1],t[2])},ztest:function(){var e,u=n.call(arguments);return i(u[1])?(e=r.zscore(u[0],u[1],u[3]),1===u[2]?r.normal.cdf(-t.abs(e),0,1):2*r.normal.cdf(-t.abs(e),0,1)):u.length>2?(e=r.zscore(u[0],u[1],u[2]),1===u[3]?r.normal.cdf(-t.abs(e),0,1):2*r.normal.cdf(-t.abs(e),0,1)):(e=u[0],1===u[1]?r.normal.cdf(-t.abs(e),0,1):2*r.normal.cdf(-t.abs(e),0,1))}}),r.extend(r.fn,{zscore:function(r,t){return(r-this.mean())/this.stdev(t)},ztest:function(e,n,u){var i=t.abs(this.zscore(e,u));return 1===n?r.normal.cdf(-i,0,1):2*r.normal.cdf(-i,0,1)}}),r.extend({tscore:function(){var e=n.call(arguments);return 4===e.length?(e[0]-e[1])/(e[2]/t.sqrt(e[3])):(e[0]-r.mean(e[1]))/(r.stdev(e[1],!0)/t.sqrt(e[1].length))},ttest:function(){var e,i=n.call(arguments);return 5===i.length?(e=t.abs(r.tscore(i[0],i[1],i[2],i[3])),1===i[4]?r.studentt.cdf(-e,i[3]-1):2*r.studentt.cdf(-e,i[3]-1)):u(i[1])?(e=t.abs(i[0]),1==i[2]?r.studentt.cdf(-e,i[1]-1):2*r.studentt.cdf(-e,i[1]-1)):(e=t.abs(r.tscore(i[0],i[1])),1==i[2]?r.studentt.cdf(-e,i[1].length-1):2*r.studentt.cdf(-e,i[1].length-1))}}),r.extend(r.fn,{tscore:function(r){return(r-this.mean())/(this.stdev(!0)/t.sqrt(this.cols()))},ttest:function(e,n){return 1===n?1-r.studentt.cdf(t.abs(this.tscore(e)),this.cols()-1):2*r.studentt.cdf(-t.abs(this.tscore(e)),this.cols()-1)}}),r.extend({anovafscore:function(){var e,u,i,o,a,s,l,f,c=n.call(arguments);if(1===c.length){a=Array(c[0].length);for(var l=0;c[0].length>l;l++)a[l]=c[0][l];c=a}if(2===c.length)return r.variance(c[0])/r.variance(c[1]);u=[];for(var l=0;c.length>l;l++)u=u.concat(c[l]);i=r.mean(u),e=0;for(var l=0;c.length>l;l++)e+=c[l].length*t.pow(r.mean(c[l])-i,2);e/=c.length-1,s=0;for(var l=0;c.length>l;l++)for(o=r.mean(c[l]),f=0;c[l].length>f;f++)s+=t.pow(c[l][f]-o,2);return s/=u.length-c.length,e/s},anovaftest:function(){var t,e,i,o,a=n.call(arguments);if(u(a[0]))return 1-r.centralF.cdf(a[0],a[1],a[2]);anovafscore=r.anovafscore(a),t=a.length-1,i=0;for(var o=0;a.length>o;o++)i+=a[o].length;return e=i-t-1,1-r.centralF.cdf(anovafscore,t,e)},ftest:function(t,e,n){return 1-r.centralF.cdf(t,e,n)}}),r.extend(r.fn,{anovafscore:function(){return r.anovafscore(this.toArray())},anovaftes:function(){for(var t,e=0,t=0;this.length>t;t++)e+=this[t].length;return r.ftest(this.anovafscore(),this.length-1,e-this.length)}}),r.extend({normalci:function(){var e,u=n.call(arguments),i=Array(2);return e=t.abs(4===u.length?r.normal.inv(u[1]/2,0,1)*u[2]/t.sqrt(u[3]):r.normal.inv(u[1]/2,0,1)*r.stdev(u[2])/t.sqrt(u[2].length)),i[0]=u[0]-e,i[1]=u[0]+e,i},tci:function(){var e,u=n.call(arguments),i=Array(2);return e=t.abs(4===u.length?r.studentt.inv(u[1]/2,u[3]-1)*u[2]/t.sqrt(u[3]):r.studentt.inv(u[1]/2,u[2].length-1)*r.stdev(u[2],!0)/t.sqrt(u[2].length)),i[0]=u[0]-e,i[1]=u[0]+e,i},significant:function(r,t){return t>r}}),r.extend(r.fn,{normalci:function(t,e){return r.normalci(t,e,this.toArray())},tci:function(t,e){return r.tci(t,e,this.toArray())}}),r.extend(r.fn,{oneSidedDifferenceOfProportions:function(t,n,u,i){return r.ztest(e(t,n,u,i),1)},twoSidedDifferenceOfProportions:function(t,n,u,i){return r.ztest(e(t,n,u,i),2)}})}(this.jStat,Math),this.jStat.models=function(){function r(r,e){return t(r,e)}function r(r){var e=r[0].length;return jStat.arange(e).map(function(n){var u=jStat.arange(e).filter(function(r){return r!==n});return t(jStat.col(r,n).map(function(r){return r[0]}),jStat.col(r,u))})}function t(r,t){var e=r.length,n=t[0].length-1,u=e-n-1,i=jStat.lstsq(t,r),o=jStat.multiply(t,i.map(function(r){return[r]})).map(function(r){return r[0]}),a=jStat.subtract(r,o),s=jStat.mean(r),l=jStat.sum(o.map(function(r){return Math.pow(r-s,2)})),f=jStat.sum(r.map(function(r,t){return Math.pow(r-o[t],2)})),c=l+f;return{exog:t,endog:r,nobs:e,df_model:n,df_resid:u,coef:i,predict:o,resid:a,ybar:s,SST:c,SSE:l,SSR:f,R2:l/c}}function e(t){var e=r(t.exog),n=Math.sqrt(t.SSR/t.df_resid),u=e.map(function(r){var t=r.SST,e=r.R2;return n/Math.sqrt(t*(1-e))}),i=t.coef.map(function(r,t){return(r-0)/u[t]}),o=i.map(function(r){var e=jStat.studentt.cdf(r,t.df_resid);return 2*(e>.5?1-e:e)}),a=jStat.studentt.inv(.975,t.df_resid);return{se:u,t:i,p:o,sigmaHat:n,interval95:t.coef.map(function(r,t){var e=a*u[t];return[r-e,r+e]})}}function n(r){var t=r.R2/r.df_model/((1-r.R2)/r.df_resid);return{F_statistic:t,pvalue:1-function(r,t,e){return jStat.beta.cdf(r/(e/t+r),t/2,e/2)}(t,r.df_model,r.df_resid)}}function u(r,u){var i=t(r,u),o=e(i),a=n(i),s=1-(i.nobs-1)/i.df_resid*(1-i.rsquared);return i.t=o,i.f=a,i.adjust_R2=s,i}return{ols:u}}()},function(r,t,e){(function(n){var u,i;/*! +!function(r,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.formulaParser=e():r.formulaParser=e()}(this,function(){return function(r){function e(n){if(t[n])return t[n].exports;var i=t[n]={i:n,l:!1,exports:{}};return r[n].call(i.exports,i,i.exports,e),i.l=!0,i.exports}var t={};return e.m=r,e.c=t,e.d=function(r,t,n){e.o(r,t)||Object.defineProperty(r,t,{configurable:!1,enumerable:!0,get:n})},e.n=function(r){var t=r&&r.__esModule?function(){return r["default"]}:function(){return r};return e.d(t,"a",t),t},e.o=function(r,e){return Object.prototype.hasOwnProperty.call(r,e)},e.p="",e(e.s=16)}([function(r,e){e.nil=Error("#NULL!"),e.div0=Error("#DIV/0!"),e.value=Error("#VALUE!"),e.ref=Error("#REF!"),e.name=Error("#NAME?"),e.num=Error("#NUM!"),e.na=Error("#N/A"),e.error=Error("#ERROR!"),e.data=Error("#GETTING_DATA")},function(r,e,t){var n=t(0);e.flattenShallow=function(r){return r&&r.reduce?r.reduce(function(r,e){var t=Array.isArray(r),n=Array.isArray(e);return t&&n?r.concat(e):t?(r.push(e),r):n?[r].concat(e):[r,e]}):r},e.isFlat=function(r){if(!r)return!1;for(var e=0;r.length>e;++e)if(Array.isArray(r[e]))return!1;return!0},e.flatten=function(){for(var r=e.argsToArray.apply(null,arguments);!e.isFlat(r);)r=e.flattenShallow(r);return r},e.argsToArray=function(r){var t=[];return e.arrayEach(r,function(r){t.push(r)}),t},e.numbers=function(){return this.flatten.apply(null,arguments).filter(function(r){return"number"==typeof r})},e.cleanFloat=function(r){return Math.round(1e14*r)/1e14},e.parseBool=function(r){if("boolean"==typeof r)return r;if(r instanceof Error)return r;if("number"==typeof r)return 0!==r;if("string"==typeof r){var e=r.toUpperCase();if("TRUE"===e)return!0;if("FALSE"===e)return!1}return r instanceof Date&&!isNaN(r)||n.value},e.parseNumber=function(r){return r===undefined||""===r?n.value:isNaN(r)?n.value:parseFloat(r)},e.parseNumberArray=function(r){var t;if(!r||0===(t=r.length))return n.value;for(var i;t--;){if((i=e.parseNumber(r[t]))===n.value)return i;r[t]=i}return r},e.parseMatrix=function(r){if(!r||0===r.length)return n.value;for(var t,i=0;r.length>i;i++)if(t=e.parseNumberArray(r[i]),r[i]=t,t instanceof Error)return t;return r};var i=new Date(1900,0,1);e.parseDate=function(r){if(!isNaN(r)){if(r instanceof Date)return new Date(r);var e=parseInt(r,10);return 0>e?n.num:e>60?new Date(i.getTime()+864e5*(e-2)):new Date(i.getTime()+864e5*(e-1))}return"string"!=typeof r||(r=new Date(r),isNaN(r))?n.value:r},e.parseDateArray=function(r){for(var e,t=r.length;t--;){if((e=this.parseDate(r[t]))===n.value)return e;r[t]=e}return r},e.anyIsError=function(){for(var r=arguments.length;r--;)if(arguments[r]instanceof Error)return!0;return!1},e.arrayValuesToNumbers=function(r){for(var e,t=r.length;t--;)if("number"!=typeof(e=r[t]))if(!0!==e)if(!1!==e){if("string"==typeof e){var n=this.parseNumber(e);r[t]=n instanceof Error?0:n}}else r[t]=0;else r[t]=1;return r},e.rest=function(r,e){return e=e||1,r&&"function"==typeof r.slice?r.slice(e):r},e.initial=function(r,e){return e=e||1,r&&"function"==typeof r.slice?r.slice(0,r.length-e):r},e.arrayEach=function(r,e){for(var t=-1,n=r.length;++t-1?parseFloat(r):parseInt(r,10)),e}function i(r){return-1*n(r)}e.__esModule=!0,e.toNumber=n,e.invertNumber=i},function(module,exports,__webpack_require__){var utils=__webpack_require__(1),error=__webpack_require__(0),statistical=__webpack_require__(5),information=__webpack_require__(7);exports.ABS=function(r){return(r=utils.parseNumber(r))instanceof Error?r:Math.abs(r)},exports.ACOS=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var e=Math.acos(r);return isNaN(e)&&(e=error.num),e},exports.ACOSH=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var e=Math.log(r+Math.sqrt(r*r-1));return isNaN(e)&&(e=error.num),e},exports.ACOT=function(r){return(r=utils.parseNumber(r))instanceof Error?r:Math.atan(1/r)},exports.ACOTH=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var e=.5*Math.log((r+1)/(r-1));return isNaN(e)&&(e=error.num),e},exports.AGGREGATE=function(r,e,t,n){if(r=utils.parseNumber(r),e=utils.parseNumber(r),utils.anyIsError(r,e))return error.value;switch(r){case 1:return statistical.AVERAGE(t);case 2:return statistical.COUNT(t);case 3:return statistical.COUNTA(t);case 4:return statistical.MAX(t);case 5:return statistical.MIN(t);case 6:return exports.PRODUCT(t);case 7:return statistical.STDEV.S(t);case 8:return statistical.STDEV.P(t);case 9:return exports.SUM(t);case 10:return statistical.VAR.S(t);case 11:return statistical.VAR.P(t);case 12:return statistical.MEDIAN(t);case 13:return statistical.MODE.SNGL(t);case 14:return statistical.LARGE(t,n);case 15:return statistical.SMALL(t,n);case 16:return statistical.PERCENTILE.INC(t,n);case 17:return statistical.QUARTILE.INC(t,n);case 18:return statistical.PERCENTILE.EXC(t,n);case 19:return statistical.QUARTILE.EXC(t,n)}},exports.ARABIC=function(r){if(!/^M*(?:D?C{0,3}|C[MD])(?:L?X{0,3}|X[CL])(?:V?I{0,3}|I[XV])$/.test(r))return error.value;var e=0;return r.replace(/[MDLV]|C[MD]?|X[CL]?|I[XV]?/g,function(r){e+={M:1e3,CM:900,D:500,CD:400,C:100,XC:90,L:50,XL:40,X:10,IX:9,V:5,IV:4,I:1}[r]}),e},exports.ASIN=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var e=Math.asin(r);return isNaN(e)&&(e=error.num),e},exports.ASINH=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.log(r+Math.sqrt(r*r+1))},exports.ATAN=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.atan(r)},exports.ATAN2=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:Math.atan2(r,e)},exports.ATANH=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var e=Math.log((1+r)/(1-r))/2;return isNaN(e)&&(e=error.num),e},exports.BASE=function(r,e,t){if(t=t||0,r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t))return error.value;t=t===undefined?0:t;var n=r.toString(e);return Array(Math.max(t+1-n.length,0)).join("0")+n},exports.CEILING=function(r,e,t){if(e=e===undefined?1:Math.abs(e),t=t||0,r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t))return error.value;if(0===e)return 0;var n=-Math.floor(Math.log(e)/Math.log(10));return 0>r?0===t?-exports.ROUND(Math.floor(Math.abs(r)/e)*e,n):-exports.ROUND(Math.ceil(Math.abs(r)/e)*e,n):exports.ROUND(Math.ceil(r/e)*e,n)},exports.CEILING.MATH=exports.CEILING,exports.CEILING.PRECISE=exports.CEILING,exports.COMBIN=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:exports.FACT(r)/(exports.FACT(e)*exports.FACT(r-e))},exports.COMBINA=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:0===r&&0===e?1:exports.COMBIN(r+e-1,r-1)},exports.COS=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.cos(r)},exports.COSH=function(r){return r=utils.parseNumber(r),r instanceof Error?r:(Math.exp(r)+Math.exp(-r))/2},exports.COT=function(r){return r=utils.parseNumber(r),r instanceof Error?r:1/Math.tan(r)},exports.COTH=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var e=Math.exp(2*r);return(e+1)/(e-1)},exports.CSC=function(r){return r=utils.parseNumber(r),r instanceof Error?r:1/Math.sin(r)},exports.CSCH=function(r){return r=utils.parseNumber(r),r instanceof Error?r:2/(Math.exp(r)-Math.exp(-r))},exports.DECIMAL=function(r,e){return 1>arguments.length?error.value:parseInt(r,e)},exports.DEGREES=function(r){return r=utils.parseNumber(r),r instanceof Error?r:180*r/Math.PI},exports.EVEN=function(r){return r=utils.parseNumber(r),r instanceof Error?r:exports.CEILING(r,-2,-1)},exports.EXP=function(r){return 1>arguments.length?error.na:"number"!=typeof r||arguments.length>1?error.error:r=Math.exp(r)};var MEMOIZED_FACT=[];exports.FACT=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var e=Math.floor(r);return 0===e||1===e?1:MEMOIZED_FACT[e]>0?MEMOIZED_FACT[e]:MEMOIZED_FACT[e]=exports.FACT(e-1)*e},exports.FACTDOUBLE=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var e=Math.floor(r);return e>0?e*exports.FACTDOUBLE(e-2):1},exports.FLOOR=function(r,e){if(r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e))return error.value;if(0===e)return 0;if(!(r>0&&e>0||0>r&&0>e))return error.num;e=Math.abs(e);var t=-Math.floor(Math.log(e)/Math.log(10));return 0>r?-exports.ROUND(Math.ceil(Math.abs(r)/e),t):exports.ROUND(Math.floor(r/e)*e,t)},exports.FLOOR.MATH=function(r,e,t){if(e=e===undefined?1:e,t=t===undefined?0:t,r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t))return error.value;if(0===e)return 0;e=e?Math.abs(e):1;var n=-Math.floor(Math.log(e)/Math.log(10));return 0>r?0===t||t===undefined?-exports.ROUND(Math.ceil(Math.abs(r)/e)*e,n):-exports.ROUND(Math.floor(Math.abs(r)/e)*e,n):exports.ROUND(Math.floor(r/e)*e,n)},exports.FLOOR.PRECISE=exports.FLOOR.MATH,exports.GCD=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var e=r.length,t=r[0],n=0>t?-t:t,i=1;e>i;i++){for(var o=r[i],u=0>o?-o:o;n&&u;)n>u?n%=u:u%=n;n+=u}return n},exports.INT=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.floor(r)},exports.ISO={CEILING:exports.CEILING},exports.LCM=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var e,t,n,i,o=1;(n=r.pop())!==undefined;)for(;n>1;){if(n%2){for(e=3,t=Math.floor(Math.sqrt(n));t>=e&&n%e;e+=2);i=e>t?n:e}else i=2;for(n/=i,o*=i,e=r.length;e;r[--e]%i==0&&1==(r[e]/=i)&&r.splice(e,1));}return o},exports.LN=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.log(r)},exports.LN10=function(){return Math.log(10)},exports.LN2=function(){return Math.log(2)},exports.LOG10E=function(){return Math.LOG10E},exports.LOG2E=function(){return Math.LOG2E},exports.LOG=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:(e=e===undefined?10:e,Math.log(r)/Math.log(e))},exports.LOG10=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.log(r)/Math.log(10)},exports.MOD=function(r,e){if(r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e))return error.value;if(0===e)return error.div0;var t=Math.abs(r%e);return e>0?t:-t},exports.MROUND=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:0>r*e?error.num:Math.round(r/e)*e},exports.MULTINOMIAL=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var e=0,t=1,n=0;r.length>n;n++)e+=r[n],t*=exports.FACT(r[n]);return exports.FACT(e)/t},exports.ODD=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var e=Math.ceil(Math.abs(r));return e=1&e?e:e+1,r>0?e:-e},exports.PI=function(){return Math.PI},exports.E=function(){return Math.E},exports.POWER=function(r,e){if(r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e))return error.value;var t=Math.pow(r,e);return isNaN(t)?error.num:t},exports.PRODUCT=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var e=1,t=0;r.length>t;t++)e*=r[t];return e},exports.QUOTIENT=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:parseInt(r/e,10)},exports.RADIANS=function(r){return r=utils.parseNumber(r),r instanceof Error?r:r*Math.PI/180},exports.RAND=function(){return Math.random()},exports.RANDBETWEEN=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:r+Math.ceil((e-r+1)*Math.random())-1},exports.ROMAN=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;for(var e=(r+"").split(""),t=["","C","CC","CCC","CD","D","DC","DCC","DCCC","CM","","X","XX","XXX","XL","L","LX","LXX","LXXX","XC","","I","II","III","IV","V","VI","VII","VIII","IX"],n="",i=3;i--;)n=(t[+e.pop()+10*i]||"")+n;return Array(+e.join("")+1).join("M")+n},exports.ROUND=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:Math.round(r*Math.pow(10,e))/Math.pow(10,e)},exports.ROUNDDOWN=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:(r>0?1:-1)*Math.floor(Math.abs(r)*Math.pow(10,e))/Math.pow(10,e)},exports.ROUNDUP=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:(r>0?1:-1)*Math.ceil(Math.abs(r)*Math.pow(10,e))/Math.pow(10,e)},exports.SEC=function(r){return r=utils.parseNumber(r),r instanceof Error?r:1/Math.cos(r)},exports.SECH=function(r){return r=utils.parseNumber(r),r instanceof Error?r:2/(Math.exp(r)+Math.exp(-r))},exports.SERIESSUM=function(r,e,t,n){if(r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),n=utils.parseNumberArray(n),utils.anyIsError(r,e,t,n))return error.value;for(var i=n[0]*Math.pow(r,e),o=1;n.length>o;o++)i+=n[o]*Math.pow(r,e+o*t);return i},exports.SIGN=function(r){return r=utils.parseNumber(r),r instanceof Error?r:0>r?-1:0===r?0:1},exports.SIN=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.sin(r)},exports.SINH=function(r){return r=utils.parseNumber(r),r instanceof Error?r:(Math.exp(r)-Math.exp(-r))/2},exports.SQRT=function(r){return r=utils.parseNumber(r),r instanceof Error?r:0>r?error.num:Math.sqrt(r)},exports.SQRTPI=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.sqrt(r*Math.PI)},exports.SQRT1_2=function(){return 1/Math.sqrt(2)},exports.SQRT2=function(){return Math.sqrt(2)},exports.SUBTOTAL=function(r,e){if((r=utils.parseNumber(r))instanceof Error)return r;switch(r){case 1:return statistical.AVERAGE(e);case 2:return statistical.COUNT(e);case 3:return statistical.COUNTA(e);case 4:return statistical.MAX(e);case 5:return statistical.MIN(e);case 6:return exports.PRODUCT(e);case 7:return statistical.STDEV.S(e);case 8:return statistical.STDEV.P(e);case 9:return exports.SUM(e);case 10:return statistical.VAR.S(e);case 11:return statistical.VAR.P(e);case 101:return statistical.AVERAGE(e);case 102:return statistical.COUNT(e);case 103:return statistical.COUNTA(e);case 104:return statistical.MAX(e);case 105:return statistical.MIN(e);case 106:return exports.PRODUCT(e);case 107:return statistical.STDEV.S(e);case 108:return statistical.STDEV.P(e);case 109:return exports.SUM(e);case 110:return statistical.VAR.S(e);case 111:return statistical.VAR.P(e)}},exports.ADD=function(r,e){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:r+e)},exports.MINUS=function(r,e){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:r-e)},exports.DIVIDE=function(r,e){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:0===e?error.div0:r/e)},exports.MULTIPLY=function(r,e){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:r*e)},exports.GTE=function(r,e){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.error:r>=e)},exports.LT=function(r,e){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.error:e>r)},exports.LTE=function(r,e){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.error:e>=r)},exports.EQ=function(r,e){return 2!==arguments.length?error.na:r===e},exports.NE=function(r,e){return 2!==arguments.length?error.na:r!==e},exports.POW=function(r,e){return 2!==arguments.length?error.na:(r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.error:exports.POWER(r,e))},exports.SUM=function(){var r=0;return utils.arrayEach(utils.argsToArray(arguments),function(e){if("number"==typeof e)r+=e;else if("string"==typeof e){var t=parseFloat(e);!isNaN(t)&&(r+=t)}else Array.isArray(e)&&(r+=exports.SUM.apply(null,e))}),r},exports.SUMIF=function(range,criteria){if((range=utils.parseNumberArray(utils.flatten(range)))instanceof Error)return range;for(var result=0,i=0;range.length>i;i++)result+=eval(range[i]+criteria)?range[i]:0;return result},exports.SUMIFS=function(){var args=utils.argsToArray(arguments),range=utils.parseNumberArray(utils.flatten(args.shift()));if(range instanceof Error)return range;for(var criteria=args,n_range_elements=range.length,n_criterias=criteria.length,result=0,i=0;n_range_elements>i;i++){for(var el=range[i],condition="",c=0;n_criterias>c;c++)condition+=el+criteria[c],c!==n_criterias-1&&(condition+="&&");eval(condition)&&(result+=el)}return result},exports.SUMPRODUCT=function(){if(!arguments||0===arguments.length)return error.value;for(var r,e,t,n,i=arguments.length+1,o=0,u=0;arguments[0].length>u;u++)if(arguments[0][u]instanceof Array)for(var a=0;arguments[0][u].length>a;a++){for(r=1,e=1;i>e;e++){if((n=utils.parseNumber(arguments[e-1][u][a]))instanceof Error)return n;r*=n}o+=r}else{for(r=1,e=1;i>e;e++){if((t=utils.parseNumber(arguments[e-1][u]))instanceof Error)return t;r*=t}o+=r}return o},exports.SUMSQ=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var e=0,t=r.length,n=0;t>n;n++)e+=information.ISNUMBER(r[n])?r[n]*r[n]:0;return e},exports.SUMX2MY2=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e))return error.value;for(var t=0,n=0;r.length>n;n++)t+=r[n]*r[n]-e[n]*e[n];return t},exports.SUMX2PY2=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e))return error.value;var t=0;r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e));for(var n=0;r.length>n;n++)t+=r[n]*r[n]+e[n]*e[n];return t},exports.SUMXMY2=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e))return error.value;var t=0;r=utils.flatten(r),e=utils.flatten(e);for(var n=0;r.length>n;n++)t+=Math.pow(r[n]-e[n],2);return t},exports.TAN=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.tan(r)},exports.TANH=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var e=Math.exp(2*r);return(e-1)/(e+1)},exports.TRUNC=function(r,e){return e=e===undefined?0:e,r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:(r>0?1:-1)*Math.floor(Math.abs(r)*Math.pow(10,e))/Math.pow(10,e)}},function(module,exports,__webpack_require__){var mathTrig=__webpack_require__(4),text=__webpack_require__(6),jStat=__webpack_require__(11).jStat,utils=__webpack_require__(1),error=__webpack_require__(0),misc=__webpack_require__(12);exports.AVEDEV=function(){var r=utils.parseNumberArray(utils.flatten(arguments));return r instanceof Error?r:jStat.sum(jStat(r).subtract(jStat.mean(r)).abs()[0])/r.length},exports.AVERAGE=function(){for(var r,e=utils.numbers(utils.flatten(arguments)),t=e.length,n=0,i=0,o=0;t>o;o++)n+=e[o],i+=1;return r=n/i,isNaN(r)&&(r=error.num),r},exports.AVERAGEA=function(){for(var r,e=utils.flatten(arguments),t=e.length,n=0,i=0,o=0;t>o;o++){var u=e[o];"number"==typeof u&&(n+=u),!0===u&&n++,null!==u&&i++}return r=n/i,isNaN(r)&&(r=error.num),r},exports.AVERAGEIF=function(range,criteria,average_range){if(1>=arguments.length)return error.na;if(average_range=average_range||range,range=utils.flatten(range),(average_range=utils.parseNumberArray(utils.flatten(average_range)))instanceof Error)return average_range;for(var average_count=0,result=0,i=0;range.length>i;i++)eval(range[i]+criteria)&&(result+=average_range[i],average_count++);return result/average_count},exports.AVERAGEIFS=function(){for(var args=utils.argsToArray(arguments),criteria=(args.length-1)/2,range=utils.flatten(args[0]),count=0,result=0,i=0;range.length>i;i++){for(var condition="",j=0;criteria>j;j++)condition+=args[2*j+1][i]+args[2*j+2],j!==criteria-1&&(condition+="&&");eval(condition)&&(result+=range[i],count++)}var average=result/count;return isNaN(average)?0:average},exports.BETA={},exports.BETA.DIST=function(r,e,t,n,i,o){return 4>arguments.length?error.value:(i=i===undefined?0:i,o=o===undefined?1:o,r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),i=utils.parseNumber(i),o=utils.parseNumber(o),utils.anyIsError(r,e,t,i,o)?error.value:(r=(r-i)/(o-i),n?jStat.beta.cdf(r,e,t):jStat.beta.pdf(r,e,t)))},exports.BETA.INV=function(r,e,t,n,i){return n=n===undefined?0:n,i=i===undefined?1:i,r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),n=utils.parseNumber(n),i=utils.parseNumber(i),utils.anyIsError(r,e,t,n,i)?error.value:jStat.beta.inv(r,e,t)*(i-n)+n},exports.BINOM={},exports.BINOM.DIST=function(r,e,t,n){return r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),n=utils.parseNumber(n),utils.anyIsError(r,e,t,n)?error.value:n?jStat.binomial.cdf(r,e,t):jStat.binomial.pdf(r,e,t)},exports.BINOM.DIST.RANGE=function(r,e,t,n){if(n=n===undefined?t:n,r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),n=utils.parseNumber(n),utils.anyIsError(r,e,t,n))return error.value;for(var i=0,o=t;n>=o;o++)i+=mathTrig.COMBIN(r,o)*Math.pow(e,o)*Math.pow(1-e,r-o);return i},exports.BINOM.INV=function(r,e,t){if(r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t))return error.value;for(var n=0;r>=n;){if(jStat.binomial.cdf(n,r,e)>=t)return n;n++}},exports.CHISQ={},exports.CHISQ.DIST=function(r,e,t){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:t?jStat.chisquare.cdf(r,e):jStat.chisquare.pdf(r,e)},exports.CHISQ.DIST.RT=function(r,e){return!r|!e?error.na:1>r||e>Math.pow(10,10)?error.num:"number"!=typeof r||"number"!=typeof e?error.value:1-jStat.chisquare.cdf(r,e)},exports.CHISQ.INV=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:jStat.chisquare.inv(r,e)},exports.CHISQ.INV.RT=function(r,e){return!r|!e?error.na:0>r||r>1||1>e||e>Math.pow(10,10)?error.num:"number"!=typeof r||"number"!=typeof e?error.value:jStat.chisquare.inv(1-r,e)},exports.CHISQ.TEST=function(r,e){if(2!==arguments.length)return error.na;if(!(r instanceof Array&&e instanceof Array))return error.value;if(r.length!==e.length)return error.value;if(r[0]&&e[0]&&r[0].length!==e[0].length)return error.value;var t,n,i,o=r.length;for(n=0;o>n;n++)r[n]instanceof Array||(t=r[n],r[n]=[],r[n].push(t)),e[n]instanceof Array||(t=e[n],e[n]=[],e[n].push(t));var u=r[0].length,a=1===u?o-1:(o-1)*(u-1),s=0,l=Math.PI;for(n=0;o>n;n++)for(i=0;u>i;i++)s+=Math.pow(r[n][i]-e[n][i],2)/e[n][i];return Math.round(1e6*function(r,e){var t=Math.exp(-.5*r);e%2==1&&(t*=Math.sqrt(2*r/l));for(var n=e;n>=2;)t=t*r/n,n-=2;for(var i=t,o=e;i>1e-10*t;)o+=2,i=i*r/o,t+=i;return 1-t}(s,a))/1e6},exports.COLUMN=function(r,e){return 2!==arguments.length?error.na:0>e?error.num:r instanceof Array&&"number"==typeof e?0===r.length?undefined:jStat.col(r,e):error.value},exports.COLUMNS=function(r){return 1!==arguments.length?error.na:r instanceof Array?0===r.length?0:jStat.cols(r):error.value},exports.CONFIDENCE={},exports.CONFIDENCE.NORM=function(r,e,t){return r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t)?error.value:jStat.normalci(1,r,e,t)[1]-1},exports.CONFIDENCE.T=function(r,e,t){return r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t)?error.value:jStat.tci(1,r,e,t)[1]-1},exports.CORREL=function(r,e){return r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e)?error.value:jStat.corrcoeff(r,e)},exports.COUNT=function(){return utils.numbers(utils.flatten(arguments)).length},exports.COUNTA=function(){var r=utils.flatten(arguments);return r.length-exports.COUNTBLANK(r)},exports.COUNTIN=function(r,e){var t=0;r=utils.flatten(r);for(var n=0;r.length>n;n++)r[n]===e&&t++;return t},exports.COUNTBLANK=function(){for(var r,e=utils.flatten(arguments),t=0,n=0;e.length>n;n++)null!==(r=e[n])&&""!==r||t++;return t},exports.COUNTIF=function(range,criteria){range=utils.flatten(range),/[<>=!]/.test(criteria)||(criteria='=="'+criteria+'"');for(var matches=0,i=0;range.length>i;i++)"string"!=typeof range[i]?eval(range[i]+criteria)&&matches++:eval('"'+range[i]+'"'+criteria)&&matches++;return matches},exports.COUNTIFS=function(){for(var args=utils.argsToArray(arguments),results=Array(utils.flatten(args[0]).length),i=0;results.length>i;i++)results[i]=!0;for(i=0;args.length>i;i+=2){var range=utils.flatten(args[i]),criteria=args[i+1];/[<>=!]/.test(criteria)||(criteria='=="'+criteria+'"');for(var j=0;range.length>j;j++)results[j]="string"!=typeof range[j]?results[j]&&eval(range[j]+criteria):results[j]&&eval('"'+range[j]+'"'+criteria)}var result=0;for(i=0;results.length>i;i++)results[i]&&result++;return result},exports.COUNTUNIQUE=function(){return misc.UNIQUE.apply(null,utils.flatten(arguments)).length},exports.COVARIANCE={},exports.COVARIANCE.P=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e))return error.value;for(var t=jStat.mean(r),n=jStat.mean(e),i=0,o=r.length,u=0;o>u;u++)i+=(r[u]-t)*(e[u]-n);return i/o},exports.COVARIANCE.S=function(r,e){return r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e)?error.value:jStat.covariance(r,e)},exports.DEVSQ=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var e=jStat.mean(r),t=0,n=0;r.length>n;n++)t+=Math.pow(r[n]-e,2);return t},exports.EXPON={},exports.EXPON.DIST=function(r,e,t){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:t?jStat.exponential.cdf(r,e):jStat.exponential.pdf(r,e)},exports.F={},exports.F.DIST=function(r,e,t,n){return r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t)?error.value:n?jStat.centralF.cdf(r,e,t):jStat.centralF.pdf(r,e,t)},exports.F.DIST.RT=function(r,e,t){return 3!==arguments.length?error.na:0>r||1>e||1>t?error.num:"number"!=typeof r||"number"!=typeof e||"number"!=typeof t?error.value:1-jStat.centralF.cdf(r,e,t)},exports.F.INV=function(r,e,t){return r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t)?error.value:0>=r||r>1?error.num:jStat.centralF.inv(r,e,t)},exports.F.INV.RT=function(r,e,t){return 3!==arguments.length?error.na:0>r||r>1||1>e||e>Math.pow(10,10)||1>t||t>Math.pow(10,10)?error.num:"number"!=typeof r||"number"!=typeof e||"number"!=typeof t?error.value:jStat.centralF.inv(1-r,e,t)},exports.F.TEST=function(r,e){if(!r||!e)return error.na;if(!(r instanceof Array&&e instanceof Array))return error.na;if(2>r.length||2>e.length)return error.div0;var t=function(r,e){for(var t=0,n=0;r.length>n;n++)t+=Math.pow(r[n]-e,2);return t},n=mathTrig.SUM(r)/r.length,i=mathTrig.SUM(e)/e.length;return t(r,n)/(r.length-1)/(t(e,i)/(e.length-1))},exports.FISHER=function(r){return r=utils.parseNumber(r),r instanceof Error?r:Math.log((1+r)/(1-r))/2},exports.FISHERINV=function(r){if((r=utils.parseNumber(r))instanceof Error)return r;var e=Math.exp(2*r);return(e-1)/(e+1)},exports.FORECAST=function(r,e,t){if(r=utils.parseNumber(r),e=utils.parseNumberArray(utils.flatten(e)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,e,t))return error.value;for(var n=jStat.mean(t),i=jStat.mean(e),o=t.length,u=0,a=0,s=0;o>s;s++)u+=(t[s]-n)*(e[s]-i),a+=Math.pow(t[s]-n,2);var l=u/a;return i-l*n+l*r},exports.FREQUENCY=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e))return error.value;for(var t=r.length,n=e.length,i=[],o=0;n>=o;o++){i[o]=0;for(var u=0;t>u;u++)0===o?r[u]>e[0]||(i[0]+=1):n>o?r[u]>e[o-1]&&e[o]>=r[u]&&(i[o]+=1):o===n&&r[u]>e[n-1]&&(i[n]+=1)}return i},exports.GAMMA=function(r){return r=utils.parseNumber(r),r instanceof Error?r:0===r?error.num:parseInt(r,10)===r&&0>r?error.num:jStat.gammafn(r)},exports.GAMMA.DIST=function(r,e,t,n){return 4!==arguments.length?error.na:r>=0&&e>0&&t>0?"number"!=typeof r||"number"!=typeof e||"number"!=typeof t?error.value:n?jStat.gamma.cdf(r,e,t,!0):jStat.gamma.pdf(r,e,t,!1):error.value},exports.GAMMA.INV=function(r,e,t){return 3!==arguments.length?error.na:0>r||r>1||0>=e||0>=t?error.num:"number"!=typeof r||"number"!=typeof e||"number"!=typeof t?error.value:jStat.gamma.inv(r,e,t)},exports.GAMMALN=function(r){return r=utils.parseNumber(r),r instanceof Error?r:jStat.gammaln(r)},exports.GAMMALN.PRECISE=function(r){return 1!==arguments.length?error.na:r>0?"number"!=typeof r?error.value:jStat.gammaln(r):error.num},exports.GAUSS=function(r){return r=utils.parseNumber(r),r instanceof Error?r:jStat.normal.cdf(r,0,1)-.5},exports.GEOMEAN=function(){var r=utils.parseNumberArray(utils.flatten(arguments));return r instanceof Error?r:jStat.geomean(r)},exports.GROWTH=function(r,e,t,n){if((r=utils.parseNumberArray(r))instanceof Error)return r;var i;if(e===undefined)for(e=[],i=1;r.length>=i;i++)e.push(i);if(t===undefined)for(t=[],i=1;r.length>=i;i++)t.push(i);if(e=utils.parseNumberArray(e),t=utils.parseNumberArray(t),utils.anyIsError(e,t))return error.value;n===undefined&&(n=!0);var o=r.length,u=0,a=0,s=0,l=0;for(i=0;o>i;i++){var f=e[i],c=Math.log(r[i]);u+=f,a+=c,s+=f*c,l+=f*f}u/=o,a/=o,s/=o,l/=o;var d,m;n?(d=(s-u*a)/(l-u*u),m=a-d*u):(d=s/l,m=0);var p=[];for(i=0;t.length>i;i++)p.push(Math.exp(m+d*t[i]));return p},exports.HARMEAN=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var e=r.length,t=0,n=0;e>n;n++)t+=1/r[n];return e/t},exports.HYPGEOM={},exports.HYPGEOM.DIST=function(r,e,t,n,i){function o(r,e,t,n){return mathTrig.COMBIN(t,r)*mathTrig.COMBIN(n-t,e-r)/mathTrig.COMBIN(n,e)}return r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),n=utils.parseNumber(n),utils.anyIsError(r,e,t,n)?error.value:i?function(r,e,t,n){for(var i=0,u=0;r>=u;u++)i+=o(u,e,t,n);return i}(r,e,t,n):o(r,e,t,n)},exports.INTERCEPT=function(r,e){return r=utils.parseNumberArray(r),e=utils.parseNumberArray(e),utils.anyIsError(r,e)?error.value:r.length!==e.length?error.na:exports.FORECAST(0,r,e)},exports.KURT=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var e=jStat.mean(r),t=r.length,n=0,i=0;t>i;i++)n+=Math.pow(r[i]-e,4);return n/=Math.pow(jStat.stdev(r,!0),4),t*(t+1)/((t-1)*(t-2)*(t-3))*n-3*(t-1)*(t-1)/((t-2)*(t-3))},exports.LARGE=function(r,e){return r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumber(e),utils.anyIsError(r,e)?r:r.sort(function(r,e){return e-r})[e-1]},exports.LINEST=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e))return error.value;for(var t=jStat.mean(r),n=jStat.mean(e),i=e.length,o=0,u=0,a=0;i>a;a++)o+=(e[a]-n)*(r[a]-t),u+=Math.pow(e[a]-n,2);var s=o/u;return[s,t-s*n]},exports.LOGEST=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e))return error.value;for(var t=0;r.length>t;t++)r[t]=Math.log(r[t]);var n=exports.LINEST(r,e);return n[0]=Math.round(1e6*Math.exp(n[0]))/1e6,n[1]=Math.round(1e6*Math.exp(n[1]))/1e6,n},exports.LOGNORM={},exports.LOGNORM.DIST=function(r,e,t,n){return r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t)?error.value:n?jStat.lognormal.cdf(r,e,t):jStat.lognormal.pdf(r,e,t)},exports.LOGNORM.INV=function(r,e,t){return r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t)?error.value:jStat.lognormal.inv(r,e,t)},exports.MAX=function(){var r=utils.numbers(utils.flatten(arguments));return 0===r.length?0:Math.max.apply(Math,r)},exports.MAXA=function(){var r=utils.arrayValuesToNumbers(utils.flatten(arguments));return 0===r.length?0:Math.max.apply(Math,r)},exports.MEDIAN=function(){var r=utils.arrayValuesToNumbers(utils.flatten(arguments)),e=jStat.median(r);return isNaN(e)&&(e=error.num),e},exports.MIN=function(){var r=utils.numbers(utils.flatten(arguments));return 0===r.length?0:Math.min.apply(Math,r)},exports.MINA=function(){var r=utils.arrayValuesToNumbers(utils.flatten(arguments));return 0===r.length?0:Math.min.apply(Math,r)},exports.MODE={},exports.MODE.MULT=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var e,t=r.length,n={},i=[],o=0,u=0;t>u;u++)e=r[u],n[e]=n[e]?n[e]+1:1,n[e]>o&&(o=n[e],i=[]),n[e]===o&&(i[i.length]=e);return i},exports.MODE.SNGL=function(){var r=utils.parseNumberArray(utils.flatten(arguments));return r instanceof Error?r:exports.MODE.MULT(r).sort(function(r,e){return r-e})[0]},exports.NEGBINOM={},exports.NEGBINOM.DIST=function(r,e,t,n){return r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t)?error.value:n?jStat.negbin.cdf(r,e,t):jStat.negbin.pdf(r,e,t)},exports.NORM={},exports.NORM.DIST=function(r,e,t,n){return r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t)?error.value:t>0?n?jStat.normal.cdf(r,e,t):jStat.normal.pdf(r,e,t):error.num},exports.NORM.INV=function(r,e,t){return r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t)?error.value:jStat.normal.inv(r,e,t)},exports.NORM.S={},exports.NORM.S.DIST=function(r,e){return r=utils.parseNumber(r),r instanceof Error?error.value:e?jStat.normal.cdf(r,0,1):jStat.normal.pdf(r,0,1)},exports.NORM.S.INV=function(r){return r=utils.parseNumber(r),r instanceof Error?error.value:jStat.normal.inv(r,0,1)},exports.PEARSON=function(r,e){if(e=utils.parseNumberArray(utils.flatten(e)),r=utils.parseNumberArray(utils.flatten(r)),utils.anyIsError(e,r))return error.value;for(var t=jStat.mean(r),n=jStat.mean(e),i=r.length,o=0,u=0,a=0,s=0;i>s;s++)o+=(r[s]-t)*(e[s]-n),u+=Math.pow(r[s]-t,2),a+=Math.pow(e[s]-n,2);return o/Math.sqrt(u*a)},exports.PERCENTILE={},exports.PERCENTILE.EXC=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumber(e),utils.anyIsError(r,e))return error.value;r=r.sort(function(r,e){return r-e});var t=r.length;if(1/(t+1)>e||e>1-1/(t+1))return error.num;var n=e*(t+1)-1,i=Math.floor(n);return utils.cleanFloat(n===i?r[n]:r[i]+(n-i)*(r[i+1]-r[i]))},exports.PERCENTILE.INC=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumber(e),utils.anyIsError(r,e))return error.value;r=r.sort(function(r,e){return r-e});var t=r.length,n=e*(t-1),i=Math.floor(n);return utils.cleanFloat(n===i?r[n]:r[i]+(n-i)*(r[i+1]-r[i]))},exports.PERCENTRANK={},exports.PERCENTRANK.EXC=function(r,e,t){if(t=t===undefined?3:t,r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t))return error.value;r=r.sort(function(r,e){return r-e});for(var n=misc.UNIQUE.apply(null,r),i=r.length,o=n.length,u=Math.pow(10,t),a=0,s=!1,l=0;!s&&o>l;)e===n[l]?(a=(r.indexOf(n[l])+1)/(i+1),s=!0):n[l]>e||e>=n[l+1]&&l!==o-1||(a=(r.indexOf(n[l])+1+(e-n[l])/(n[l+1]-n[l]))/(i+1),s=!0),l++;return Math.floor(a*u)/u},exports.PERCENTRANK.INC=function(r,e,t){if(t=t===undefined?3:t,r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t))return error.value;r=r.sort(function(r,e){return r-e});for(var n=misc.UNIQUE.apply(null,r),i=r.length,o=n.length,u=Math.pow(10,t),a=0,s=!1,l=0;!s&&o>l;)e===n[l]?(a=r.indexOf(n[l])/(i-1),s=!0):n[l]>e||e>=n[l+1]&&l!==o-1||(a=(r.indexOf(n[l])+(e-n[l])/(n[l+1]-n[l]))/(i-1),s=!0),l++;return Math.floor(a*u)/u},exports.PERMUT=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:mathTrig.FACT(r)/mathTrig.FACT(r-e)},exports.PERMUTATIONA=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:Math.pow(r,e)},exports.PHI=function(r){return r=utils.parseNumber(r),r instanceof Error?error.value:Math.exp(-.5*r*r)/2.5066282746310002},exports.POISSON={},exports.POISSON.DIST=function(r,e,t){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:t?jStat.poisson.cdf(r,e):jStat.poisson.pdf(r,e)},exports.PROB=function(r,e,t,n){if(t===undefined)return 0;if(n=n===undefined?t:n,r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),t=utils.parseNumber(t),n=utils.parseNumber(n),utils.anyIsError(r,e,t,n))return error.value;if(t===n)return 0>r.indexOf(t)?0:e[r.indexOf(t)];for(var i=r.sort(function(r,e){return r-e}),o=i.length,u=0,a=0;o>a;a++)t>i[a]||i[a]>n||(u+=e[r.indexOf(i[a])]);return u},exports.QUARTILE={},exports.QUARTILE.EXC=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumber(e),utils.anyIsError(r,e))return error.value;switch(e){case 1:return exports.PERCENTILE.EXC(r,.25);case 2:return exports.PERCENTILE.EXC(r,.5);case 3:return exports.PERCENTILE.EXC(r,.75);default:return error.num}},exports.QUARTILE.INC=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumber(e),utils.anyIsError(r,e))return error.value;switch(e){case 1:return exports.PERCENTILE.INC(r,.25);case 2:return exports.PERCENTILE.INC(r,.5);case 3:return exports.PERCENTILE.INC(r,.75);default:return error.num}},exports.RANK={},exports.RANK.AVG=function(r,e,t){if(r=utils.parseNumber(r),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e))return error.value;e=utils.flatten(e),t=t||!1,e=e.sort(t?function(r,e){return r-e}:function(r,e){return e-r});for(var n=e.length,i=0,o=0;n>o;o++)e[o]===r&&i++;return i>1?(2*e.indexOf(r)+i+1)/2:e.indexOf(r)+1},exports.RANK.EQ=function(r,e,t){return r=utils.parseNumber(r),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e)?error.value:(t=t||!1,e=e.sort(t?function(r,e){return r-e}:function(r,e){return e-r}),e.indexOf(r)+1)},exports.ROW=function(r,e){return 2!==arguments.length?error.na:0>e?error.num:r instanceof Array&&"number"==typeof e?0===r.length?undefined:jStat.row(r,e):error.value},exports.ROWS=function(r){return 1!==arguments.length?error.na:r instanceof Array?0===r.length?0:jStat.rows(r):error.value},exports.RSQ=function(r,e){return r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e)?error.value:Math.pow(exports.PEARSON(r,e),2)},exports.SKEW=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var e=jStat.mean(r),t=r.length,n=0,i=0;t>i;i++)n+=Math.pow(r[i]-e,3);return t*n/((t-1)*(t-2)*Math.pow(jStat.stdev(r,!0),3))},exports.SKEW.P=function(){var r=utils.parseNumberArray(utils.flatten(arguments));if(r instanceof Error)return r;for(var e=jStat.mean(r),t=r.length,n=0,i=0,o=0;t>o;o++)i+=Math.pow(r[o]-e,3),n+=Math.pow(r[o]-e,2);return i/=t,n/=t,i/Math.pow(n,1.5)},exports.SLOPE=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e))return error.value;for(var t=jStat.mean(e),n=jStat.mean(r),i=e.length,o=0,u=0,a=0;i>a;a++)o+=(e[a]-t)*(r[a]-n),u+=Math.pow(e[a]-t,2);return o/u},exports.SMALL=function(r,e){return r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumber(e),utils.anyIsError(r,e)?r:r.sort(function(r,e){return r-e})[e-1]},exports.STANDARDIZE=function(r,e,t){return r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t)?error.value:(r-e)/t},exports.STDEV={},exports.STDEV.P=function(){var r=exports.VAR.P.apply(this,arguments),e=Math.sqrt(r);return isNaN(e)&&(e=error.num),e},exports.STDEV.S=function(){var r=exports.VAR.S.apply(this,arguments);return Math.sqrt(r)},exports.STDEVA=function(){var r=exports.VARA.apply(this,arguments);return Math.sqrt(r)},exports.STDEVPA=function(){var r=exports.VARPA.apply(this,arguments),e=Math.sqrt(r);return isNaN(e)&&(e=error.num),e},exports.STEYX=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e))return error.value;for(var t=jStat.mean(e),n=jStat.mean(r),i=e.length,o=0,u=0,a=0,s=0;i>s;s++)o+=Math.pow(r[s]-n,2),u+=(e[s]-t)*(r[s]-n),a+=Math.pow(e[s]-t,2);return Math.sqrt((o-u*u/a)/(i-2))},exports.TRANSPOSE=function(r){return r?jStat.transpose(r):error.na},exports.T=text.T,exports.T.DIST=function(r,e,t){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:t?jStat.studentt.cdf(r,e):jStat.studentt.pdf(r,e)},exports.T.DIST["2T"]=function(r,e){return 2!==arguments.length?error.na:0>r||1>e?error.num:"number"!=typeof r||"number"!=typeof e?error.value:2*(1-jStat.studentt.cdf(r,e))},exports.T.DIST.RT=function(r,e){return 2!==arguments.length?error.na:0>r||1>e?error.num:"number"!=typeof r||"number"!=typeof e?error.value:1-jStat.studentt.cdf(r,e)},exports.T.INV=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),utils.anyIsError(r,e)?error.value:jStat.studentt.inv(r,e)},exports.T.INV["2T"]=function(r,e){return r=utils.parseNumber(r),e=utils.parseNumber(e),0>=r||r>1||1>e?error.num:utils.anyIsError(r,e)?error.value:Math.abs(jStat.studentt.inv(r/2,e))},exports.T.TEST=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),utils.anyIsError(r,e))return error.value;var t,n=jStat.mean(r),i=jStat.mean(e),o=0,u=0;for(t=0;r.length>t;t++)o+=Math.pow(r[t]-n,2);for(t=0;e.length>t;t++)u+=Math.pow(e[t]-i,2);o/=r.length-1,u/=e.length-1;var a=Math.abs(n-i)/Math.sqrt(o/r.length+u/e.length);return exports.T.DIST["2T"](a,r.length+e.length-2)},exports.TREND=function(r,e,t){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumberArray(utils.flatten(e)),t=utils.parseNumberArray(utils.flatten(t)),utils.anyIsError(r,e,t))return error.value;var n=exports.LINEST(r,e),i=n[0],o=n[1],u=[];return t.forEach(function(r){u.push(i*r+o)}),u},exports.TRIMMEAN=function(r,e){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumber(e),utils.anyIsError(r,e))return error.value;var t=mathTrig.FLOOR(r.length*e,2)/2;return jStat.mean(utils.initial(utils.rest(r.sort(function(r,e){return r-e}),t),t))},exports.VAR={},exports.VAR.P=function(){for(var r,e=utils.numbers(utils.flatten(arguments)),t=e.length,n=0,i=exports.AVERAGE(e),o=0;t>o;o++)n+=Math.pow(e[o]-i,2);return r=n/t,isNaN(r)&&(r=error.num),r},exports.VAR.S=function(){for(var r=utils.numbers(utils.flatten(arguments)),e=r.length,t=0,n=exports.AVERAGE(r),i=0;e>i;i++)t+=Math.pow(r[i]-n,2);return t/(e-1)},exports.VARA=function(){for(var r=utils.flatten(arguments),e=r.length,t=0,n=0,i=exports.AVERAGEA(r),o=0;e>o;o++){var u=r[o];t+="number"==typeof u?Math.pow(u-i,2):!0===u?Math.pow(1-i,2):Math.pow(0-i,2),null!==u&&n++}return t/(n-1)},exports.VARPA=function(){for(var r,e=utils.flatten(arguments),t=e.length,n=0,i=0,o=exports.AVERAGEA(e),u=0;t>u;u++){var a=e[u];n+="number"==typeof a?Math.pow(a-o,2):!0===a?Math.pow(1-o,2):Math.pow(0-o,2),null!==a&&i++}return r=n/i,isNaN(r)&&(r=error.num),r},exports.WEIBULL={},exports.WEIBULL.DIST=function(r,e,t,n){return r=utils.parseNumber(r),e=utils.parseNumber(e),t=utils.parseNumber(t),utils.anyIsError(r,e,t)?error.value:n?1-Math.exp(-Math.pow(r/t,e)):Math.pow(r,e-1)*Math.exp(-Math.pow(r/t,e))*e/Math.pow(t,e)},exports.Z={},exports.Z.TEST=function(r,e,t){if(r=utils.parseNumberArray(utils.flatten(r)),e=utils.parseNumber(e),utils.anyIsError(r,e))return error.value;t=t||exports.STDEV.S(r);var n=r.length;return 1-exports.NORM.S.DIST((exports.AVERAGE(r)-e)/(t/Math.sqrt(n)),!0)}},function(r,e,t){var n=t(1),i=t(0),o=t(9);e.ASC=function(){throw Error("ASC is not implemented")},e.BAHTTEXT=function(){throw Error("BAHTTEXT is not implemented")},e.CHAR=function(r){return r=n.parseNumber(r),r instanceof Error?r:String.fromCharCode(r)},e.CLEAN=function(r){return r=r||"",r.replace(/[\0-\x1F]/g,"")},e.CODE=function(r){r=r||"";var e=r.charCodeAt(0);return isNaN(e)&&(e=i.na),e},e.CONCATENATE=function(){for(var r=n.flatten(arguments),e=0;(e=r.indexOf(!0))>-1;)r[e]="TRUE";for(var t=0;(t=r.indexOf(!1))>-1;)r[t]="FALSE";return r.join("")},e.DBCS=function(){throw Error("DBCS is not implemented")},e.DOLLAR=function(r,e){if(e=e===undefined?2:e,r=n.parseNumber(r),e=n.parseNumber(e),n.anyIsError(r,e))return i.value;var t="";return e>0?e>0&&(t="($0,0."+Array(e+1).join("0")+")"):(r=Math.round(r*Math.pow(10,e))/Math.pow(10,e),t="($0,0)"),o(r).format(t)},e.EXACT=function(r,e){return 2!==arguments.length?i.na:r===e},e.FIND=function(r,e,t){return 2>arguments.length?i.na:(t=t===undefined?0:t,e?e.indexOf(r,t-1)+1:null)},e.FIXED=function(r,e,t){if(e=e===undefined?2:e,t=t!==undefined&&t,r=n.parseNumber(r),e=n.parseNumber(e),n.anyIsError(r,e))return i.value;var u=t?"0":"0,0";return e>0?e>0&&(u+="."+Array(e+1).join("0")):r=Math.round(r*Math.pow(10,e))/Math.pow(10,e),o(r).format(u)},e.HTML2TEXT=function(r){var e="";return r&&(r instanceof Array?r.forEach(function(r){""!==e&&(e+="\n"),e+=r.replace(/<(?:.|\n)*?>/gm,"")}):e=r.replace(/<(?:.|\n)*?>/gm,"")),e},e.LEFT=function(r,e){return e=e===undefined?1:e,e=n.parseNumber(e),e instanceof Error||"string"!=typeof r?i.value:r?r.substring(0,e):null},e.LEN=function(r){return 0===arguments.length?i.error:"string"==typeof r?r?r.length:0:r.length?r.length:i.value},e.LOWER=function(r){return"string"!=typeof r?i.value:r?r.toLowerCase():r},e.MID=function(r,e,t){if(e=n.parseNumber(e),t=n.parseNumber(t),n.anyIsError(e,t)||"string"!=typeof r)return t;var i=e-1;return r.substring(i,i+t)},e.NUMBERVALUE=function(r,e,t){return e=void 0===e?".":e,t=void 0===t?",":t,+r.replace(e,".").replace(t,"")},e.PRONETIC=function(){throw Error("PRONETIC is not implemented")},e.PROPER=function(r){return r===undefined||0===r.length?i.value:(!0===r&&(r="TRUE"),!1===r&&(r="FALSE"),isNaN(r)&&"number"==typeof r?i.value:("number"==typeof r&&(r=""+r),r.replace(/\w\S*/g,function(r){return r.charAt(0).toUpperCase()+r.substr(1).toLowerCase()})))},e.REGEXEXTRACT=function(r,e){if(2>arguments.length)return i.na;var t=r.match(RegExp(e));return t?t[t.length>1?t.length-1:0]:null},e.REGEXMATCH=function(r,e,t){if(2>arguments.length)return i.na;var n=r.match(RegExp(e));return t?n:!!n},e.REGEXREPLACE=function(r,e,t){return 3>arguments.length?i.na:r.replace(RegExp(e),t)},e.REPLACE=function(r,e,t,o){return e=n.parseNumber(e),t=n.parseNumber(t),n.anyIsError(e,t)||"string"!=typeof r||"string"!=typeof o?i.value:r.substr(0,e-1)+o+r.substr(e-1+t)},e.REPT=function(r,e){return e=n.parseNumber(e),e instanceof Error?e:Array(e+1).join(r)},e.RIGHT=function(r,e){return e=e===undefined?1:e,e=n.parseNumber(e),e instanceof Error?e:r?r.substring(r.length-e):i.na},e.SEARCH=function(r,e,t){var n;return"string"!=typeof r||"string"!=typeof e?i.value:(t=t===undefined?0:t,n=e.toLowerCase().indexOf(r.toLowerCase(),t-1)+1,0===n?i.value:n)},e.SPLIT=function(r,e){return r.split(e)},e.SUBSTITUTE=function(r,e,t,n){if(2>arguments.length)return i.na;if(!(r&&e&&t))return r;if(n===undefined)return r.replace(RegExp(e,"g"),t);for(var o=0,u=0;r.indexOf(e,o)>0;)if(o=r.indexOf(e,o+1),++u===n)return r.substring(0,o)+t+r.substring(o+e.length)},e.T=function(r){return"string"==typeof r?r:""},e.TEXT=function(r,e){return r=n.parseNumber(r),n.anyIsError(r)?i.na:o(r).format(e)},e.TRIM=function(r){return"string"!=typeof r?i.value:r.replace(/ +/g," ").trim()},e.UNICHAR=e.CHAR,e.UNICODE=e.CODE,e.UPPER=function(r){return"string"!=typeof r?i.value:r.toUpperCase()},e.VALUE=function(r){if("string"!=typeof r)return i.value;var e=o().unformat(r);return void 0===e?0:e}},function(r,e,t){var n=t(0);e.CELL=function(){throw Error("CELL is not implemented")},e.ERROR={},e.ERROR.TYPE=function(r){switch(r){case n.nil:return 1;case n.div0:return 2;case n.value:return 3;case n.ref:return 4;case n.name:return 5;case n.num:return 6;case n.na:return 7;case n.data:return 8}return n.na},e.INFO=function(){throw Error("INFO is not implemented")},e.ISBLANK=function(r){return null===r},e.ISBINARY=function(r){return/^[01]{1,10}$/.test(r)},e.ISERR=function(r){return[n.value,n.ref,n.div0,n.num,n.name,n.nil].indexOf(r)>=0||"number"==typeof r&&(isNaN(r)||!isFinite(r))},e.ISERROR=function(r){return e.ISERR(r)||r===n.na},e.ISEVEN=function(r){return!(1&Math.floor(Math.abs(r)))},e.ISFORMULA=function(){throw Error("ISFORMULA is not implemented")},e.ISLOGICAL=function(r){return!0===r||!1===r},e.ISNA=function(r){return r===n.na},e.ISNONTEXT=function(r){return"string"!=typeof r},e.ISNUMBER=function(r){return"number"==typeof r&&!isNaN(r)&&isFinite(r)},e.ISODD=function(r){return!!(1&Math.floor(Math.abs(r)))},e.ISREF=function(){throw Error("ISREF is not implemented")},e.ISTEXT=function(r){return"string"==typeof r},e.N=function(r){return this.ISNUMBER(r)?r:r instanceof Date?r.getTime():!0===r?1:!1===r?0:this.ISERROR(r)?r:0},e.NA=function(){return n.na},e.SHEET=function(){throw Error("SHEET is not implemented")},e.SHEETS=function(){throw Error("SHEETS is not implemented")},e.TYPE=function(r){return this.ISNUMBER(r)?1:this.ISTEXT(r)?2:this.ISLOGICAL(r)?4:this.ISERROR(r)?16:Array.isArray(r)?64:void 0}},function(r,e,t){function n(r){return 1===new Date(r,1,29).getMonth()}function i(r,e){return Math.ceil((e-r)/1e3/60/60/24)}function o(r){return(r-s)/864e5+(r>-22038912e5?2:1)}var u=t(0),a=t(1),s=new Date(1900,0,1),l=[undefined,0,1,undefined,undefined,undefined,undefined,undefined,undefined,undefined,undefined,undefined,1,2,3,4,5,6,0],f=[[],[1,2,3,4,5,6,7],[7,1,2,3,4,5,6],[6,0,1,2,3,4,5],[],[],[],[],[],[],[],[7,1,2,3,4,5,6],[6,7,1,2,3,4,5],[5,6,7,1,2,3,4],[4,5,6,7,1,2,3],[3,4,5,6,7,1,2],[2,3,4,5,6,7,1],[1,2,3,4,5,6,7]],c=[[],[6,0],[0,1],[1,2],[2,3],[3,4],[4,5],[5,6],undefined,undefined,undefined,[0,0],[1,1],[2,2],[3,3],[4,4],[5,5],[6,6]];e.DATE=function(r,e,t){return r=a.parseNumber(r),e=a.parseNumber(e),t=a.parseNumber(t),a.anyIsError(r,e,t)?u.value:0>r||0>e||0>t?u.num:new Date(r,e-1,t)},e.DATEVALUE=function(r){if("string"!=typeof r)return u.value;var e=Date.parse(r);return isNaN(e)?u.value:e>-22038912e5?(e-s)/864e5+2:(e-s)/864e5+1},e.DAY=function(r){var e=a.parseDate(r);return e instanceof Error?e:e.getDate()},e.DAYS=function(r,e){return r=a.parseDate(r),e=a.parseDate(e),r instanceof Error?r:e instanceof Error?e:o(r)-o(e)},e.DAYS360=function(r,e,t){if(t=a.parseBool(t),r=a.parseDate(r),e=a.parseDate(e),r instanceof Error)return r;if(e instanceof Error)return e;if(t instanceof Error)return t;var n,i,o=r.getMonth(),u=e.getMonth();if(t)n=31===r.getDate()?30:r.getDate(),i=31===e.getDate()?30:e.getDate();else{var s=new Date(r.getFullYear(),o+1,0).getDate(),l=new Date(e.getFullYear(),u+1,0).getDate();n=r.getDate()===s?30:r.getDate(),e.getDate()===l?30>n?(u++,i=1):i=30:i=e.getDate()}return 360*(e.getFullYear()-r.getFullYear())+30*(u-o)+(i-n)},e.EDATE=function(r,e){return(r=a.parseDate(r))instanceof Error?r:isNaN(e)?u.value:(e=parseInt(e,10),r.setMonth(r.getMonth()+e),o(r))},e.EOMONTH=function(r,e){return(r=a.parseDate(r))instanceof Error?r:isNaN(e)?u.value:(e=parseInt(e,10),o(new Date(r.getFullYear(),r.getMonth()+e+1,0)))},e.HOUR=function(r){return r=a.parseDate(r),r instanceof Error?r:r.getHours()},e.INTERVAL=function(r){if("number"!=typeof r&&"string"!=typeof r)return u.value;r=parseInt(r,10);var e=Math.floor(r/94608e4);r%=94608e4;var t=Math.floor(r/2592e3);r%=2592e3;var n=Math.floor(r/86400);r%=86400;var i=Math.floor(r/3600);r%=3600;var o=Math.floor(r/60);r%=60;var a=r;return e=e>0?e+"Y":"",t=t>0?t+"M":"",n=n>0?n+"D":"",i=i>0?i+"H":"",o=o>0?o+"M":"",a=a>0?a+"S":"","P"+e+t+n+"T"+i+o+a},e.ISOWEEKNUM=function(r){if((r=a.parseDate(r))instanceof Error)return r;r.setHours(0,0,0),r.setDate(r.getDate()+4-(r.getDay()||7));var e=new Date(r.getFullYear(),0,1);return Math.ceil(((r-e)/864e5+1)/7)},e.MINUTE=function(r){return r=a.parseDate(r),r instanceof Error?r:r.getMinutes()},e.MONTH=function(r){return r=a.parseDate(r),r instanceof Error?r:r.getMonth()+1},e.NETWORKDAYS=function(r,e,t){return this.NETWORKDAYS.INTL(r,e,1,t)},e.NETWORKDAYS.INTL=function(r,e,t,n){if((r=a.parseDate(r))instanceof Error)return r;if((e=a.parseDate(e))instanceof Error)return e;if(!((t=t===undefined?c[1]:c[t])instanceof Array))return u.value;n===undefined?n=[]:n instanceof Array||(n=[n]);for(var i=0;n.length>i;i++){var o=a.parseDate(n[i]);if(o instanceof Error)return o;n[i]=o}var s=(e-r)/864e5+1,l=s,f=r;for(i=0;s>i;i++){var d=(new Date).getTimezoneOffset()>0?f.getUTCDay():f.getDay(),m=!1;d!==t[0]&&d!==t[1]||(m=!0);for(var p=0;n.length>p;p++){var h=n[p];if(h.getDate()===f.getDate()&&h.getMonth()===f.getMonth()&&h.getFullYear()===f.getFullYear()){m=!0;break}}m&&l--,f.setDate(f.getDate()+1)}return l},e.NOW=function(){return new Date},e.SECOND=function(r){return r=a.parseDate(r),r instanceof Error?r:r.getSeconds()},e.TIME=function(r,e,t){return r=a.parseNumber(r),e=a.parseNumber(e),t=a.parseNumber(t),a.anyIsError(r,e,t)?u.value:0>r||0>e||0>t?u.num:(3600*r+60*e+t)/86400},e.TIMEVALUE=function(r){return r=a.parseDate(r),r instanceof Error?r:(3600*r.getHours()+60*r.getMinutes()+r.getSeconds())/86400},e.TODAY=function(){return new Date},e.WEEKDAY=function(r,e){if((r=a.parseDate(r))instanceof Error)return r;e===undefined&&(e=1);var t=r.getDay();return f[e][t]},e.WEEKNUM=function(r,e){if((r=a.parseDate(r))instanceof Error)return r;if(e===undefined&&(e=1),21===e)return this.ISOWEEKNUM(r);var t=l[e],n=new Date(r.getFullYear(),0,1),i=n.getDay()e)return u.num;if(!((t=t===undefined?c[1]:c[t])instanceof Array))return u.value;n===undefined?n=[]:n instanceof Array||(n=[n]);for(var i=0;n.length>i;i++){var o=a.parseDate(n[i]);if(o instanceof Error)return o;n[i]=o}for(var s=0;e>s;){r.setDate(r.getDate()+1);var l=r.getDay();if(l!==t[0]&&l!==t[1]){for(var f=0;n.length>f;f++){var d=n[f];if(d.getDate()===r.getDate()&&d.getMonth()===r.getMonth()&&d.getFullYear()===r.getFullYear()){s--;break}}s++}}return r},e.YEAR=function(r){return r=a.parseDate(r),r instanceof Error?r:r.getFullYear()},e.YEARFRAC=function(r,e,t){if((r=a.parseDate(r))instanceof Error)return r;if((e=a.parseDate(e))instanceof Error)return e;t=t||0;var o=r.getDate(),u=r.getMonth()+1,s=r.getFullYear(),l=e.getDate(),f=e.getMonth()+1,c=e.getFullYear();switch(t){case 0:return 31===o&&31===l?(o=30,l=30):31===o?o=30:30===o&&31===l&&(l=30),(l+30*f+360*c-(o+30*u+360*s))/360;case 1:var d=365;if(s===c||s+1===c&&(u>f||u===f&&o>=l))return(s===c&&n(s)||function(r,e){var t=r.getFullYear(),i=new Date(t,2,1);if(n(t)&&i>r&&e>=i)return!0;var o=e.getFullYear(),u=new Date(o,2,1);return n(o)&&e>=u&&u>r}(r,e)||1===f&&29===l)&&(d=366),i(r,e)/d;var m=c-s+1,p=(new Date(c+1,0,1)-new Date(s,0,1))/1e3/60/60/24,h=p/m;return i(r,e)/h;case 2:return i(r,e)/360;case 3:return i(r,e)/365;case 4:return(l+30*f+360*c-(o+30*u+360*s))/360}}},function(r,e,t){(function(n){var i,o;/*! * numbro.js - * version : 1.9.3 + * version : 1.11.0 * author : Företagsplatsen AB * license : MIT * http://www.foretagsplatsen.se */ -(function(){"use strict";function o(r){this._value=r}function a(r){var t,e="";for(t=0;r>t;t++)e+="0";return e}function s(r,t){var e,n,u,i,o,s,l,f;return f=""+r,e=f.split("e")[0],i=f.split("e")[1],n=e.split(".")[0],u=e.split(".")[1]||"",+i>0?f=n+u+a(i-u.length):(o=0>+n?"-0":"0",t>0&&(o+="."),l=a(-1*i-1),s=(l+Math.abs(n)+u).substr(0,t),f=o+s),+i>0&&t>0&&(f+="."+a(t)),f}function l(r,t,e,n){var u,i,o=Math.pow(10,t);return(""+r).indexOf("e")>-1?(i=s(r,t),"-"!==i.charAt(0)||0>+i||(i=i.substr(1))):i=(e(r+"e+"+t)/o).toFixed(t),n&&(u=RegExp("0{1,"+n+"}$"),i=i.replace(u,"")),i}function f(r,t,e){var n=t.replace(/\{[^\{\}]*\}/g,"");return n.indexOf("$")>-1?p(r,S[$].currency.symbol,t,e):n.indexOf("%")>-1?d(r,t,e):n.indexOf(":")>-1?h(r,t):v(r._value,t,e)}function c(r,t){var e,n,u,i,o,a=t,s=!1;if(t.indexOf(":")>-1)r._value=E(t);else if(t===C)r._value=0;else{for("."!==S[$].delimiters.decimal&&(t=t.replace(/\./g,"").replace(S[$].delimiters.decimal,".")),e=RegExp("[^a-zA-Z]"+S[$].abbreviations.thousand+"(?:\\)|(\\"+S[$].currency.symbol+")?(?:\\))?)?$"),n=RegExp("[^a-zA-Z]"+S[$].abbreviations.million+"(?:\\)|(\\"+S[$].currency.symbol+")?(?:\\))?)?$"),u=RegExp("[^a-zA-Z]"+S[$].abbreviations.billion+"(?:\\)|(\\"+S[$].currency.symbol+")?(?:\\))?)?$"),i=RegExp("[^a-zA-Z]"+S[$].abbreviations.trillion+"(?:\\)|(\\"+S[$].currency.symbol+")?(?:\\))?)?$"),o=1;A.length>o&&!s;++o)t.indexOf(A[o])>-1?s=Math.pow(1024,o):t.indexOf(R[o])>-1&&(s=Math.pow(1e3,o));var l=t.replace(/[^0-9\.]+/g,"");""===l?r._value=NaN:(r._value=(s?s:1)*(a.match(e)?Math.pow(10,3):1)*(a.match(n)?Math.pow(10,6):1)*(a.match(u)?Math.pow(10,9):1)*(a.match(i)?Math.pow(10,12):1)*(t.indexOf("%")>-1?.01:1)*((t.split("-").length+Math.min(t.split("(").length-1,t.split(")").length-1))%2?1:-1)*+l,r._value=s?Math.ceil(r._value):r._value)}return r._value}function p(r,t,e,n){var u,i,o=e,a=o.indexOf("$"),s=o.indexOf("("),l=o.indexOf("+"),f=o.indexOf("-"),c="",p="";if(o.indexOf("$")===-1?"infix"===S[$].currency.position?(p=t,S[$].currency.spaceSeparated&&(p=" "+p+" ")):S[$].currency.spaceSeparated&&(c=" "):o.indexOf(" $")>-1?(c=" ",o=o.replace(" $","")):o.indexOf("$ ")>-1?(c=" ",o=o.replace("$ ","")):o=o.replace("$",""),i=v(r._value,o,n,p),e.indexOf("$")===-1)switch(S[$].currency.position){case"postfix":i.indexOf(")")>-1?(i=i.split(""),i.splice(-1,0,c+t),i=i.join("")):i=i+c+t;break;case"infix":break;case"prefix":i.indexOf("(")>-1||i.indexOf("-")>-1?(i=i.split(""),u=Math.max(s,f)+1,i.splice(u,0,t+c),i=i.join("")):i=t+c+i;break;default:throw Error('Currency position should be among ["prefix", "infix", "postfix"]')}else a>1?i.indexOf(")")>-1?(i=i.split(""),i.splice(-1,0,c+t),i=i.join("")):i=i+c+t:i.indexOf("(")>-1||i.indexOf("+")>-1||i.indexOf("-")>-1?(i=i.split(""),u=1,(s>a||l>a||f>a)&&(u=0),i.splice(u,0,t+c),i=i.join("")):i=t+c+i;return i}function m(r,t,e,n){return p(r,t,e,n)}function d(r,t,e){var n,u="",i=100*r._value;return t.indexOf(" %")>-1?(u=" ",t=t.replace(" %","")):t=t.replace("%",""),n=v(i,t,e),n.indexOf(")")>-1?(n=n.split(""),n.splice(-1,0,u+"%"),n=n.join("")):n=n+u+"%",n}function h(r){var t=Math.floor(r._value/60/60),e=Math.floor((r._value-60*t*60)/60),n=Math.round(r._value-60*t*60-60*e);return t+":"+(10>e?"0"+e:e)+":"+(10>n?"0"+n:n)}function E(r){var t=r.split(":"),e=0;return 3===t.length?(e+=60*+t[0]*60,e+=60*+t[1],e+=+t[2]):2===t.length&&(e+=60*+t[0],e+=+t[1]),+e}function g(r,t,e){var n,u,i,o=t[0],a=Math.abs(r);if(a>=e){for(n=1;t.length>n;++n)if(u=Math.pow(e,n),i=Math.pow(e,n+1),a>=u&&i>a){o=t[n],r/=u;break}o===t[0]&&(r/=Math.pow(e,t.length-1),o=t[t.length-1])}return{value:r,suffix:o}}function v(r,t,e,n){var u,i,o,s,f,c,p,m,d,h,E,v,N,b,y,I,w,M=!1,A=!1,R=!1,T="",O=!1,V=!1,D=!1,L=!1,_=!1,P="",U="",F=Math.abs(r),B="",j=!1,k=!1,G="";if(0===r&&null!==C)return C;if(!isFinite(r))return""+r;if(0===t.indexOf("{")){var Y=t.indexOf("}");if(Y===-1)throw Error('Format should also contain a "}"');h=t.slice(1,Y),t=t.slice(Y+1)}else h="";if(t.indexOf("}")===t.length-1){var W=t.indexOf("{");if(W===-1)throw Error('Format should also contain a "{"');E=t.slice(W+1,-1),t=t.slice(0,W+1)}else E="";var H;for(H=t.match(t.indexOf(".")===-1?/([0-9]+).*/:/([0-9]+)\..*/),I=null===H?-1:H[1].length,t.indexOf("-")!==-1&&(j=!0),t.indexOf("(")>-1?(M=!0,t=t.slice(1,-1)):t.indexOf("+")>-1&&(A=!0,t=t.replace(/\+/g,"")),t.indexOf("a")>-1&&(m=t.split(".")[0].match(/[0-9]+/g)||["0"],m=parseInt(m[0],10),O=t.indexOf("aK")>=0,V=t.indexOf("aM")>=0,D=t.indexOf("aB")>=0,L=t.indexOf("aT")>=0,_=O||V||D||L,t.indexOf(" a")>-1?(T=" ",t=t.replace(" a","")):t=t.replace("a",""),o=Math.floor(Math.log(F)/Math.LN10)+1,f=o%3,f=0===f?3:f,m&&0!==F&&(s=Math.floor(Math.log(F)/Math.LN10)+1-m,c=3*~~((Math.min(m,o)-f)/3),F/=Math.pow(10,c),t.indexOf(".")===-1&&m>3&&(t+="[.]",b=0===s?0:3*~~(s/3)-s,b=0>b?b+3:b,t+=a(b))),Math.floor(Math.log(Math.abs(r))/Math.LN10)+1!==m&&(F>=Math.pow(10,12)&&!_||L?(T+=S[$].abbreviations.trillion,r/=Math.pow(10,12)):F=Math.pow(10,9)&&!_||D?(T+=S[$].abbreviations.billion,r/=Math.pow(10,9)):F=Math.pow(10,6)&&!_||V?(T+=S[$].abbreviations.million,r/=Math.pow(10,6)):(F=Math.pow(10,3)&&!_||O)&&(T+=S[$].abbreviations.thousand,r/=Math.pow(10,3)))),w=0;x.length>w;++w)if(u=x[w],t.indexOf(u.marker)>-1){t.indexOf(" "+u.marker)>-1&&(P=" "),t=t.replace(P+u.marker,""),i=g(r,u.suffixes,u.scale),r=i.value,P+=i.suffix;break}if(t.indexOf("o")>-1&&(t.indexOf(" o")>-1?(U=" ",t=t.replace(" o","")):t=t.replace("o",""),S[$].ordinal&&(U+=S[$].ordinal(r))),t.indexOf("[.]")>-1&&(R=!0,t=t.replace("[.]",".")),p=(""+r).split(".")[0],d=t.split(".")[1],v=t.indexOf(","),d){if(d.indexOf("*")!==-1?B=l(r,(""+r).split(".")[1].length,e):d.indexOf("[")>-1?(d=d.replace("]",""),d=d.split("["),B=l(r,d[0].length+d[1].length,e,d[1].length)):B=l(r,d.length,e),p=B.split(".")[0],B.split(".")[1].length){B=(n?T+n:S[$].delimiters.decimal)+B.split(".")[1]}else B="";R&&0==+B.slice(1)&&(B="")}else p=l(r,0,e);return p.indexOf("-")>-1&&(p=p.slice(1),k=!0),I>p.length&&(p=a(I-p.length)+p),v>-1&&(p=(""+p).replace(/(\d)(?=(\d{3})+(?!\d))/g,"$1"+S[$].delimiters.thousands)),0===t.indexOf(".")&&(p=""),N=t.indexOf("("),y=t.indexOf("-"),G=y>N?(M&&k?"(":"")+(j&&k||!M&&k?"-":""):(j&&k||!M&&k?"-":"")+(M&&k?"(":""),h+G+(!k&&A&&0!==r?"+":"")+p+B+(U?U:"")+(T&&!n?T:"")+(P?P:"")+(M&&k?")":"")+E}function N(r,t){S[r]=t}function b(r){$=r;var t=S[r].defaults;t&&t.format&&M.defaultFormat(t.format),t&&t.currencyFormat&&M.defaultCurrencyFormat(t.currencyFormat)}function y(){return void 0!==n&&n.browser===undefined&&n.title&&(0===n.title.indexOf("node")||n.title.indexOf("meteor-tool")>0||"grunt"===n.title||"gulp"===n.title)&&!0}function I(r){var t=(""+r).split(".");return 2>t.length?1:Math.pow(10,t[1].length)}function w(){return Array.prototype.slice.call(arguments).reduce(function(r,t){var e=I(r),n=I(t);return e>n?e:n},-Infinity)}var M,A=["B","KiB","MiB","GiB","TiB","PiB","EiB","ZiB","YiB"],R=["B","KB","MB","GB","TB","PB","EB","ZB","YB"],T={general:{scale:1024,suffixes:R,marker:"bd"},binary:{scale:1024,suffixes:A,marker:"b"},decimal:{scale:1e3,suffixes:R,marker:"d"}},x=[T.general,T.binary,T.decimal],S={},O=S,$="en-US",C=null,V="0,0",D="0$",L=void 0!==r&&r.exports,_={delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){var t=r%10;return 1==~~(r%100/10)?"th":1===t?"st":2===t?"nd":3===t?"rd":"th"},currency:{symbol:"$",position:"prefix"},defaults:{currencyFormat:",0000 a"},formats:{fourDigits:"0000 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00"}};M=function(r){return M.isNumbro(r)?r=r.value():0===r||void 0===r?r=0:+r||(r=M.fn.unformat(r)),new o(+r)},M.version="1.9.3",M.isNumbro=function(r){return r instanceof o},M.setLanguage=function(r,t){console.warn("`setLanguage` is deprecated since version 1.6.0. Use `setCulture` instead");var e=r,n=r.split("-")[0],u=null;O[e]||(Object.keys(O).forEach(function(r){u||r.split("-")[0]!==n||(u=r)}),e=u||t||"en-US"),b(e)},M.setCulture=function(r,t){var e=r,n=r.split("-")[1],u=null;S[e]||(n&&Object.keys(S).forEach(function(r){u||r.split("-")[1]!==n||(u=r)}),e=u||t||"en-US"),b(e)},M.language=function(r,t){if(console.warn("`language` is deprecated since version 1.6.0. Use `culture` instead"),!r)return $;if(r&&!t){if(!O[r])throw Error("Unknown language : "+r);b(r)}return!t&&O[r]||N(r,t),M},M.culture=function(r,t){if(!r)return $;if(r&&!t){if(!S[r])throw Error("Unknown culture : "+r);b(r)}return!t&&S[r]||N(r,t),M},M.languageData=function(r){if(console.warn("`languageData` is deprecated since version 1.6.0. Use `cultureData` instead"),!r)return O[$];if(!O[r])throw Error("Unknown language : "+r);return O[r]},M.cultureData=function(r){if(!r)return S[$];if(!S[r])throw Error("Unknown culture : "+r);return S[r]},M.culture("en-US",_),M.languages=function(){return console.warn("`languages` is deprecated since version 1.6.0. Use `cultures` instead"),O},M.cultures=function(){return S},M.zeroFormat=function(r){C="string"==typeof r?r:null},M.defaultFormat=function(r){V="string"==typeof r?r:"0.0"},M.defaultCurrencyFormat=function(r){D="string"==typeof r?r:"0$"},M.validate=function(r,t){var e,n,u,i,o,a,s,l;if("string"!=typeof r&&(r+="",console.warn&&console.warn("Numbro.js: Value is not string. It has been co-erced to: ",r)),r=r.trim(),r=r.replace(/^[+-]?/,""),r.match(/^\d+$/))return!0;if(""===r)return!1;try{s=M.cultureData(t)}catch(f){s=M.cultureData(M.culture())}return u=s.currency.symbol,o=s.abbreviations,e=s.delimiters.decimal,n="."===s.delimiters.thousands?"\\.":s.delimiters.thousands,!(null!==(l=r.match(/^[^\d\.\,]+/))&&(r=r.substr(1),l[0]!==u)||null!==(l=r.match(/[^\d]+$/))&&(r=r.slice(0,-1),l[0]!==o.thousand&&l[0]!==o.million&&l[0]!==o.billion&&l[0]!==o.trillion)||(a=RegExp(n+"{2}"),r.match(/[^\d.,]/g)||(i=r.split(e),i.length>2||(2>i.length?!i[0].match(/^\d+.*\d$/)||i[0].match(a):""===i[0]?i[0].match(a)||!i[1].match(/^\d+$/):1===i[0].length?!i[0].match(/^\d+$/)||i[0].match(a)||!i[1].match(/^\d+$/):!i[0].match(/^\d+.*\d$/)||i[0].match(a)||!i[1].match(/^\d+$/)))))},M.loadLanguagesInNode=function(){console.warn("`loadLanguagesInNode` is deprecated since version 1.6.0. Use `loadCulturesInNode` instead"),M.loadCulturesInNode()},M.loadCulturesInNode=function(){var r=e(58);for(var t in r)t&&M.culture(t,r[t])},"function"!=typeof Array.prototype.reduce&&(Array.prototype.reduce=function(r,t){if(null===this||void 0===this)throw new TypeError("Array.prototype.reduce called on null or undefined");if("function"!=typeof r)throw new TypeError(r+" is not a function");var e,n,u=this.length>>>0,i=!1;for(arguments.length>1&&(n=t,i=!0),e=0;u>e;++e)this.hasOwnProperty(e)&&(i?n=r(n,this[e],e,this):(n=this[e],i=!0));if(!i)throw new TypeError("Reduce of empty array with no initial value");return n}),M.fn=o.prototype={clone:function(){return M(this)},format:function(r,t){return f(this,r?r:V,t!==undefined?t:Math.round)},formatCurrency:function(r,t){return p(this,S[$].currency.symbol,r?r:D,t!==undefined?t:Math.round)},formatForeignCurrency:function(r,t,e){return m(this,r,t?t:D,e!==undefined?e:Math.round)},unformat:function(r){if("number"==typeof r)return r;if("string"==typeof r){var t=c(this,r);return isNaN(t)?undefined:t}return undefined},binaryByteUnits:function(){return g(this._value,T.binary.suffixes,T.binary.scale).suffix},byteUnits:function(){return g(this._value,T.general.suffixes,T.general.scale).suffix},decimalByteUnits:function(){return g(this._value,T.decimal.suffixes,T.decimal.scale).suffix},value:function(){return this._value},valueOf:function(){return this._value},set:function(r){return this._value=+r,this},add:function(r){function t(r,t){return r+e*t}var e=w.call(null,this._value,r);return this._value=[this._value,r].reduce(t,0)/e,this},subtract:function(r){function t(r,t){return r-e*t}var e=w.call(null,this._value,r);return this._value=[r].reduce(t,this._value*e)/e,this},multiply:function(r){function t(r,t){var e=w(r,t),n=r*e;return n*=t*e,n/=e*e}return this._value=[this._value,r].reduce(t,1),this},divide:function(r){function t(r,t){var e=w(r,t);return r*e/(t*e)}return this._value=[this._value,r].reduce(t),this},difference:function(r){return Math.abs(M(this._value).subtract(r).value())}},y()&&M.loadCulturesInNode(),L?r.exports=M:("undefined"==typeof ender&&(this.numbro=M),u=[],(i=function(){return M}.apply(t,u))!==undefined&&(r.exports=i))}).call("undefined"==typeof window?this:window)}).call(t,e(15))},function(r,t){function e(){throw Error("setTimeout has not been defined")}function n(){throw Error("clearTimeout has not been defined")}function u(r){if(f===setTimeout)return setTimeout(r,0);if((f===e||!f)&&setTimeout)return f=setTimeout,setTimeout(r,0);try{return f(r,0)}catch(t){try{return f.call(null,r,0)}catch(e){return f.call(this,r,0)}}}function i(r){if(c===clearTimeout)return clearTimeout(r);if((c===n||!c)&&clearTimeout)return c=clearTimeout,clearTimeout(r);try{return c(r)}catch(t){try{return c.call(null,r)}catch(e){return c.call(this,r)}}}function o(){h&&m&&(h=!1,m.length?d=m.concat(d):E=-1,d.length&&a())}function a(){if(!h){var r=u(o);h=!0;for(var t=d.length;t;){for(m=d,d=[];++E1)for(var e=1;arguments.length>e;e++)t[e-1]=arguments[e];d.push(new s(r,t)),1!==d.length||h||u(a)},s.prototype.run=function(){this.fun.apply(null,this.array)},p.title="browser",p.browser=!0,p.env={},p.argv=[],p.version="",p.versions={},p.on=l,p.addListener=l,p.once=l,p.off=l,p.removeListener=l,p.removeAllListeners=l,p.emit=l,p.binding=function(r){throw Error("process.binding is not supported")},p.cwd=function(){return"/"},p.chdir=function(r){throw Error("process.chdir is not supported")},p.umask=function(){return 0}},function(r,t,e){"use strict";function n(r){return r&&r.__esModule?r:{"default":r}}function u(r,t){if(!(r instanceof t))throw new TypeError("Cannot call a class as a function")}function i(r,t){if(!r)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?r:t}function o(r,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);r.prototype=Object.create(t&&t.prototype,{constructor:{value:r,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(r,t):r.__proto__=t)}t.__esModule=!0;var a=e(78),s=n(a),l=e(17),f=n(l),c=e(80),p=e(31),m=e(3),d=e(1),h=n(d),E=e(9);t["default"]=function(r){function t(){u(this,t);var e=i(this,r.call(this));return e.parser=new c.Parser,e.parser.yy={toNumber:m.toNumber,trimEdges:p.trimEdges,invertNumber:m.invertNumber,throwError:function(r){return e._throwError(r)},callVariable:function(r){return e._callVariable(r)},evaluateByOperator:f["default"],callFunction:f["default"],cellValue:function(r){return e._callCellValue(r)},rangeValue:function(r,t){return e._callRangeValue(r,t)}},e.variables=Object.create(null),e.setVariable("TRUE",!0).setVariable("FALSE",!1).setVariable("NULL",null),e}return o(t,r),t.prototype.parse=function(r){var t=null,e=null;try{t=""===r?"":this.parser.parse(r)}catch(u){var n=(0,h["default"])(u.message);e=n?n:(0,h["default"])(d.ERROR)}return t instanceof Error&&(e=(0,h["default"])(t.message)||(0,h["default"])(d.ERROR),t=null),{error:e,result:t}},t.prototype.setVariable=function(r,t){return this.variables[r]=t,this},t.prototype.getVariable=function(r){return this.variables[r]},t.prototype._callVariable=function(r){var t=this.getVariable(r);if(this.emit("callVariable",r,function(r){void 0!==r&&(t=r)}),void 0===t)throw Error(d.ERROR_NAME);return t},t.prototype._callCellValue=function(r){r=r.toUpperCase();var t=(0,E.extractLabel)(r),e=t[0],n=t[1],u=void 0;return this.emit("callCellValue",{label:r,row:e,column:n},function(r){u=r}),u},t.prototype._callRangeValue=function(r,t){r=r.toUpperCase(),t=t.toUpperCase();var e=(0,E.extractLabel)(r),n=e[0],u=e[1],i=(0,E.extractLabel)(t),o=i[0],a=i[1],s={},l={};n.index>o.index?(s.row=o,l.row=n):(s.row=n,l.row=o),u.index>a.index?(s.column=a,l.column=u):(s.column=u,l.column=a),s.label=(0,E.toLabel)(s.row,s.column),l.label=(0,E.toLabel)(l.row,l.column);var f=[];return this.emit("callRangeValue",s,l,function(){f=arguments.length>0&&arguments[0]!==undefined?arguments[0]:[]}),f},t.prototype._throwError=function(r){if((0,d.isValidStrict)(r))throw Error(r);throw Error(d.ERROR)},t}(s["default"])},function(r,t,e){"use strict";function n(r){return r&&r.__esModule?r:{"default":r}}function u(r){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:[];if(r=r.toUpperCase(),!V[r])throw Error(C.ERROR_NAME);return V[r].apply(V,t)}function i(r,t){Array.isArray(r)||(r=[r.toUpperCase()]),r.forEach(function(r){V[r]=t.isFactory?t(r):t})}t.__esModule=!0,t["default"]=u,t.registerOperation=i;var o=e(18),a=n(o),s=e(19),l=n(s),f=e(20),c=n(f),p=e(21),m=n(p),d=e(22),h=n(d),E=e(24),g=n(E),v=e(23),N=n(v),b=e(26),y=n(b),I=e(25),w=n(I),M=e(27),A=n(M),R=e(28),T=n(R),x=e(29),S=n(x),O=e(30),$=n(O),C=e(1),V=Object.create(null);i(a["default"].SYMBOL,a["default"]),i(l["default"].SYMBOL,l["default"]),i(c["default"].SYMBOL,c["default"]),i(m["default"].SYMBOL,m["default"]),i($["default"].SYMBOL,$["default"]),i(h["default"].SYMBOL,h["default"]),i(g["default"].SYMBOL,g["default"]),i(N["default"].SYMBOL,N["default"]),i(y["default"].SYMBOL,y["default"]),i(w["default"].SYMBOL,w["default"]),i(T["default"].SYMBOL,T["default"]),i(S["default"].SYMBOL,S["default"]),i(A["default"].SYMBOL,A["default"])},function(r,t,e){"use strict";function n(r){for(var t=arguments.length,e=Array(t>1?t-1:0),n=1;t>n;n++)e[n-1]=arguments[n];var o=e.reduce(function(r,t){return r+(0,u.toNumber)(t)},(0,u.toNumber)(r));if(isNaN(o))throw Error(i.ERROR_VALUE);return o}t.__esModule=!0,t.SYMBOL=undefined,t["default"]=n;var u=e(3),i=e(1);n.SYMBOL=t.SYMBOL="+"},function(r,t,e){"use strict";function n(){for(var r=arguments.length,t=Array(r),e=0;r>e;e++)t[e]=arguments[e];return t.reduce(function(r,t){return r+""+t},"")}t.__esModule=!0,t["default"]=n,n.SYMBOL=t.SYMBOL="&"},function(r,t,e){"use strict";function n(r){for(var t=arguments.length,e=Array(t>1?t-1:0),n=1;t>n;n++)e[n-1]=arguments[n];var o=e.reduce(function(r,t){return r/(0,u.toNumber)(t)},(0,u.toNumber)(r));if(o===Infinity)throw Error(i.ERROR_DIV_ZERO);if(isNaN(o))throw Error(i.ERROR_VALUE);return o}t.__esModule=!0,t.SYMBOL=undefined,t["default"]=n;var u=e(3),i=e(1);n.SYMBOL=t.SYMBOL="/"},function(r,t,e){"use strict";function n(r,t){return r===t}t.__esModule=!0,t["default"]=n,n.SYMBOL=t.SYMBOL="="},function(r,t,e){"use strict";function n(r){return r&&r.__esModule?r:{"default":r}}function u(r){if(r&&r.__esModule)return r;var t={};if(null!=r)for(var e in r)Object.prototype.hasOwnProperty.call(r,e)&&(t[e]=r[e]);return t["default"]=r,t}function i(r){return function(){r=r.toUpperCase();var t=r.split("."),e=!1,n=void 0;if(1===t.length)a[t[0]]&&(e=!0,n=a[t[0]].apply(a,arguments));else{for(var u=t.length,i=0,o=a;u>i;)if(o=o[t[i]],i++,!o){o=null;break}o&&(e=!0,n=o.apply(undefined,arguments))}if(!e)throw Error(f.ERROR_NAME);return n}}t.__esModule=!0,t.SYMBOL=undefined,t["default"]=i;var o=e(33),a=u(o),s=e(10),l=n(s),f=e(1),c=t.SYMBOL=l["default"];i.isFactory=!0,i.SYMBOL=c},function(r,t,e){"use strict";function n(r,t){return r>=t}t.__esModule=!0,t["default"]=n,n.SYMBOL=t.SYMBOL=">="},function(r,t,e){"use strict";function n(r,t){return r>t}t.__esModule=!0,t["default"]=n,n.SYMBOL=t.SYMBOL=">"},function(r,t,e){"use strict";function n(r,t){return t>=r}t.__esModule=!0,t["default"]=n,n.SYMBOL=t.SYMBOL="<="},function(r,t,e){"use strict";function n(r,t){return t>r}t.__esModule=!0,t["default"]=n,n.SYMBOL=t.SYMBOL="<"},function(r,t,e){"use strict";function n(r){for(var t=arguments.length,e=Array(t>1?t-1:0),n=1;t>n;n++)e[n-1]=arguments[n];var o=e.reduce(function(r,t){return r-(0,u.toNumber)(t)},(0,u.toNumber)(r));if(isNaN(o))throw Error(i.ERROR_VALUE);return o}t.__esModule=!0,t.SYMBOL=undefined,t["default"]=n;var u=e(3),i=e(1);n.SYMBOL=t.SYMBOL="-"},function(r,t,e){"use strict";function n(r){for(var t=arguments.length,e=Array(t>1?t-1:0),n=1;t>n;n++)e[n-1]=arguments[n];var o=e.reduce(function(r,t){return r*(0,u.toNumber)(t)},(0,u.toNumber)(r));if(isNaN(o))throw Error(i.ERROR_VALUE);return o}t.__esModule=!0,t.SYMBOL=undefined,t["default"]=n;var u=e(3),i=e(1);n.SYMBOL=t.SYMBOL="*"},function(r,t,e){"use strict";function n(r,t){return r!==t}t.__esModule=!0,t["default"]=n,n.SYMBOL=t.SYMBOL="<>"},function(r,t,e){"use strict";function n(r,t){var e=Math.pow((0,u.toNumber)(r),(0,u.toNumber)(t));if(isNaN(e))throw Error(i.ERROR_VALUE);return e}t.__esModule=!0,t.SYMBOL=undefined,t["default"]=n;var u=e(3),i=e(1);n.SYMBOL=t.SYMBOL="^"},function(r,t,e){"use strict";function n(r){var t=arguments.length>1&&arguments[1]!==undefined?arguments[1]:1;return r=r.substring(t,r.length-t)}t.__esModule=!0,t.trimEdges=n},function(r,t,e){function n(r,t){return r.reduce(function(r,e){return t*r+e},0)}function u(r,t,e,n,u){u||(u=-1);var i,o=2/r;if(0===t)return e;if(1===t)return n;for(var a=1;a!=t;++a)i=n*a*o+u*e,e=n,n=i;return n}function i(r,t,e,n,i){return function(o,a){if(0===a)return r(o);if(1===a)return t(o);if(0>a)throw e+": Order ("+a+") must be nonnegative";if(1==n&&0===o)throw e+": Undefined when x == 0";if(2==n&&0>=o)throw e+": Undefined when x <= 0";return u(o,a,r(o),t(o),i)}}var o=Math,a=function(){function r(r){var t,u,f,c=r*r,p=o.abs(r)-.785398164;return 8>o.abs(r)?(u=n(e,c),f=n(i,c),t=u/f):(c=64/c,u=n(a,c),f=n(s,c),t=o.sqrt(l/o.abs(r))*(o.cos(p)*u-o.sin(p)*f*8/o.abs(r))),t}function t(r){var t,e,u,i=r*r,a=o.abs(r)-2.356194491;return 8>Math.abs(r)?(e=r*n(f,i),u=n(c,i),t=e/u):(i=64/i,e=n(p,i),u=n(m,i),t=o.sqrt(l/o.abs(r))*(o.cos(a)*e-o.sin(a)*u*8/o.abs(r)),0>r&&(t=-t)),t}var e=[57568490574,-13362590354,651619640.7,-11214424.18,77392.33017,-184.9052456].reverse(),i=[57568490411,1029532985,9494680.718,59272.64853,267.8532712,1].reverse(),a=[1,-.001098628627,2734510407e-14,-2073370639e-15,2.093887211e-7].reverse(),s=[-.01562499995,.0001430488765,-6911147651e-15,7.621095161e-7,-9.34935152e-8].reverse(),l=.636619772,f=[72362614232,-7895059235,242396853.1,-2972611.439,15704.4826,-30.16036606].reverse(),c=[144725228442,2300535178,18583304.74,99447.43394,376.9991397,1].reverse(),p=[1,.00183105,-3516396496e-14,2457520174e-15,-2.40337019e-7].reverse(),m=[.04687499995,-.0002002690873,8449199096e-15,-8.8228987e-7,1.05787412e-7].reverse();return function(e,n){if(0===(n=Math.round(n)))return r(o.abs(e));if(1===n)return t(o.abs(e));if(0>n)throw"BESSELJ: Order ("+n+") must be nonnegative";if(0===o.abs(e))return 0;var i,a,s,l,f,c,p,m,d=2/o.abs(e);if(o.abs(e)>n)i=u(e,n,r(o.abs(e)),t(o.abs(e)),-1);else{for(s=2*o.floor((n+o.floor(o.sqrt(40*n)))/2),l=0,c=i=f=0,p=1,a=s;a>0;a--)m=a*d*p-c,c=p,p=m,o.abs(p)>1e10&&(p*=1e-10,c*=1e-10,i*=1e-10,f*=1e-10),l&&(f+=p),l=!l,a==n&&(i=c);f=2*f-p,i/=f}return 0>e&&n%2?-i:i}}(),s=function(){function r(r){var t,i,c,p=r*r,m=r-.785398164;return 8>r?(i=n(e,p),c=n(u,p),t=i/c+f*a(r,0)*o.log(r)):(p=64/p,i=n(s,p),c=n(l,p),t=o.sqrt(f/r)*(o.sin(m)*i+o.cos(m)*c*8/r)),t}function t(r){var t,e,u,i=r*r,s=r-2.356194491;return 8>r?(e=r*n(c,i),u=n(p,i),t=e/u+f*(a(r,1)*o.log(r)-1/r)):(i=64/i,e=n(m,i),u=n(d,i),t=o.sqrt(f/r)*(o.sin(s)*e+o.cos(s)*u*8/r)),t}var e=[-2957821389,7062834065,-512359803.6,10879881.29,-86327.92757,228.4622733].reverse(),u=[40076544269,745249964.8,7189466.438,47447.2647,226.1030244,1].reverse(),s=[1,-.001098628627,2734510407e-14,-2073370639e-15,2.093887211e-7].reverse(),l=[-.01562499995,.0001430488765,-6911147651e-15,7.621095161e-7,-9.34945152e-8].reverse(),f=.636619772,c=[-4900604943e3,127527439e4,-51534381390,734926455.1,-4237922.726,8511.937935].reverse(),p=[249958057e5,424441966400,3733650367,22459040.02,102042.605,354.9632885,1].reverse(),m=[1,.00183105,-3516396496e-14,2457520174e-15,-2.40337019e-7].reverse(),d=[.04687499995,-.0002002690873,8449199096e-15,-8.8228987e-7,1.05787412e-7].reverse();return i(r,t,"BESSELY",1,-1)}(),l=function(){function r(r){return r>3.75?o.exp(o.abs(r))/o.sqrt(o.abs(r))*n(u,3.75/o.abs(r)):n(e,r*r/14.0625)}function t(r){return 3.75>r?r*n(i,r*r/14.0625):(0>r?-1:1)*o.exp(o.abs(r))/o.sqrt(o.abs(r))*n(a,3.75/o.abs(r))}var e=[1,3.5156229,3.0899424,1.2067492,.2659732,.0360768,.0045813].reverse(),u=[.39894228,.01328592,.00225319,-.00157565,.00916281,-.02057706,.02635537,-.01647633,.00392377].reverse(),i=[.5,.87890594,.51498869,.15084934,.02658733,.00301532,32411e-8].reverse(),a=[.39894228,-.03988024,-.00362018,.00163801,-.01031555,.02282967,-.02895312,.01787654,-.00420059].reverse();return function s(e,n){if(0===(n=Math.round(n)))return r(e);if(1==n)return t(e);if(0>n)throw"BESSELI Order ("+n+") must be nonnegative";if(0===o.abs(e))return 0;var u,i,a,l,f,c,p=2/o.abs(e);for(a=2*o.round((n+o.round(o.sqrt(40*n)))/2),l=u=0,f=1,i=a;i>0;i--)c=i*p*f+l,l=f,f=c,o.abs(f)>1e10&&(f*=1e-10,l*=1e-10,u*=1e-10),i==n&&(u=l);return u*=s(e,0)/f,0>e&&n%2?-u:u}}(),f=function(){function r(r){return r>2?o.exp(-r)/o.sqrt(r)*n(u,2/r):-o.log(r/2)*l(r,0)+n(e,r*r/4)}function t(r){return r>2?o.exp(-r)/o.sqrt(r)*n(s,2/r):o.log(r/2)*l(r,1)+1/r*n(a,r*r/4)}var e=[-.57721566,.4227842,.23069756,.0348859,.00262698,1075e-7,74e-7].reverse(),u=[1.25331414,-.07832358,.02189568,-.01062446,.00587872,-.0025154,53208e-8].reverse(),a=[1,.15443144,-.67278579,-.18156897,-.01919402,-.00110404,-4686e-8].reverse(),s=[1.25331414,.23498619,-.0365562,.01504268,-.00780353,.00325614,-68245e-8].reverse();return i(r,t,"BESSELK",2,1)}();t.besselj=a,t.bessely=s,t.besseli=l,t.besselk=f},function(r,t,e){var n=[e(34),e(35),e(11),e(37),e(4),e(8),e(6),e(36),e(7),e(38),e(5),e(12)];for(var u in n){var i=n[u];for(var o in i)t[o]=t[o]||i[o]}},function(r,t,e){function n(r,t){if(t)for(var e in t)r[e]=t[e];return r}var u=e(4),i=e(5),o=e(11),a=e(6);t.BETADIST=i.BETA.DIST,t.BETAINV=i.BETA.INV,t.BINOMDIST=i.BINOM.DIST,t.CEILING=t.ISOCEILING=n(u.CEILING.MATH,u.CEILING),t.CEILINGMATH=u.CEILING.MATH,t.CEILINGPRECISE=u.CEILING.PRECISE,t.CHIDIST=i.CHISQ.DIST,t.CHIDISTRT=i.CHISQ.DIST.RT,t.CHIINV=i.CHISQ.INV,t.CHIINVRT=i.CHISQ.INV.RT,t.CHITEST=i.CHISQ.TEST,t.CONFIDENCE=n(i.CONFIDENCE.NORM,i.CONFIDENCE),t.COVAR=i.COVARIANCE.P,t.COVARIANCEP=i.COVARIANCE.P,t.COVARIANCES=i.COVARIANCE.S,t.CRITBINOM=i.BINOM.INV,t.EXPONDIST=i.EXPON.DIST,t.ERFCPRECISE=o.ERFC.PRECISE,t.ERFPRECISE=o.ERF.PRECISE,t.FDIST=i.F.DIST,t.FDISTRT=i.F.DIST.RT,t.FINVRT=i.F.INV.RT,t.FINV=i.F.INV,t.FLOOR=n(u.FLOOR.MATH,u.FLOOR),t.FLOORMATH=u.FLOOR.MATH,t.FLOORPRECISE=u.FLOOR.PRECISE,t.FTEST=i.F.TEST,t.GAMMADIST=i.GAMMA.DIST,t.GAMMAINV=i.GAMMA.INV,t.GAMMALNPRECISE=i.GAMMALN.PRECISE,t.HYPGEOMDIST=i.HYPGEOM.DIST,t.LOGINV=i.LOGNORM.INV,t.LOGNORMINV=i.LOGNORM.INV,t.LOGNORMDIST=i.LOGNORM.DIST,t.MODE=n(i.MODE.SNGL,i.MODE),t.MODEMULT=i.MODE.MULT,t.MODESNGL=i.MODE.SNGL,t.NEGBINOMDIST=i.NEGBINOM.DIST,t.NETWORKDAYSINTL=a.NETWORKDAYS.INTL,t.NORMDIST=i.NORM.DIST,t.NORMINV=i.NORM.INV,t.NORMSDIST=i.NORM.S.DIST,t.NORMSINV=i.NORM.S.INV,t.PERCENTILE=n(i.PERCENTILE.EXC,i.PERCENTILE),t.PERCENTILEEXC=i.PERCENTILE.EXC,t.PERCENTILEINC=i.PERCENTILE.INC,t.PERCENTRANK=n(i.PERCENTRANK.INC,i.PERCENTRANK),t.PERCENTRANKEXC=i.PERCENTRANK.EXC,t.PERCENTRANKINC=i.PERCENTRANK.INC,t.POISSON=n(i.POISSON.DIST,i.POISSON),t.POISSONDIST=i.POISSON.DIST,t.QUARTILE=n(i.QUARTILE.INC,i.QUARTILE),t.QUARTILEEXC=i.QUARTILE.EXC,t.QUARTILEINC=i.QUARTILE.INC,t.RANK=n(i.RANK.EQ,i.RANK),t.RANKAVG=i.RANK.AVG,t.RANKEQ=i.RANK.EQ,t.SKEWP=i.SKEW.P,t.STDEV=n(i.STDEV.S,i.STDEV),t.STDEVP=i.STDEV.P,t.STDEVS=i.STDEV.S,t.TDIST=i.T.DIST,t.TDISTRT=i.T.DIST.RT,t.TINV=i.T.INV,t.TTEST=i.T.TEST,t.VAR=n(i.VAR.S,i.VAR),t.VARP=i.VAR.P,t.VARS=i.VAR.S,t.WEIBULL=n(i.WEIBULL.DIST,i.WEIBULL),t.WEIBULLDIST=i.WEIBULL.DIST,t.WORKDAYINTL=a.WORKDAY.INTL,t.ZTEST=i.Z.TEST},function(module,exports,__webpack_require__){function compact(r){var t=[];return utils.arrayEach(r,function(r){r&&t.push(r)}),t}function findResultIndex(database,criterias){for(var matches={},i=1;database[0].length>i;++i)matches[i]=!0;var maxCriteriaLength=criterias[0].length;for(i=1;criterias.length>i;++i)criterias[i].length>maxCriteriaLength&&(maxCriteriaLength=criterias[i].length);for(var k=1;database.length>k;++k)for(var l=1;database[k].length>l;++l){for(var currentCriteriaResult=!1,hasMatchingCriteria=!1,j=0;criterias.length>j;++j){var criteria=criterias[j];if(criteria.length>=maxCriteriaLength){var criteriaField=criteria[0];if(database[k][0]===criteriaField){hasMatchingCriteria=!0;for(var p=1;criteria.length>p;++p)currentCriteriaResult=currentCriteriaResult||eval(database[k][l]+criteria[p])}}}hasMatchingCriteria&&(matches[l]=matches[l]&¤tCriteriaResult)}for(var result=[],n=0;database[0].length>n;++n)matches[n]&&result.push(n-1);return result}var error=__webpack_require__(0),stats=__webpack_require__(5),maths=__webpack_require__(4),utils=__webpack_require__(2);exports.FINDFIELD=function(r,t){var e=null;return utils.arrayEach(r,function(r,n){if(r[0]===t)return e=n,!1}),null==e?error.value:e},exports.DAVERAGE=function(r,t,e){if(isNaN(t)&&"string"!=typeof t)return error.value;var n=findResultIndex(r,e),u=[];if("string"==typeof t){u=utils.rest(r[exports.FINDFIELD(r,t)])}else u=utils.rest(r[t]);var i=0;return utils.arrayEach(n,function(r){i+=u[r]}),0===n.length?error.div0:i/n.length},exports.DCOUNT=function(r,t,e){if(isNaN(t)&&"string"!=typeof t)return error.value;var n=findResultIndex(r,e),u=[];if("string"==typeof t){u=utils.rest(r[exports.FINDFIELD(r,t)])}else u=utils.rest(r[t]);var i=[];return utils.arrayEach(n,function(r){i.push(u[r])}),stats.COUNT(i)},exports.DCOUNTA=function(r,t,e){if(isNaN(t)&&"string"!=typeof t)return error.value;var n=findResultIndex(r,e),u=[];if("string"==typeof t){u=utils.rest(r[exports.FINDFIELD(r,t)])}else u=utils.rest(r[t]);var i=[];return utils.arrayEach(n,function(r){i.push(u[r])}),stats.COUNTA(i)},exports.DGET=function(r,t,e){if(isNaN(t)&&"string"!=typeof t)return error.value;var n=findResultIndex(r,e),u=[];if("string"==typeof t){u=utils.rest(r[exports.FINDFIELD(r,t)])}else u=utils.rest(r[t]);return 0===n.length?error.value:n.length>1?error.num:u[n[0]]},exports.DMAX=function(r,t,e){if(isNaN(t)&&"string"!=typeof t)return error.value;var n=findResultIndex(r,e),u=[];if("string"==typeof t){u=utils.rest(r[exports.FINDFIELD(r,t)])}else u=utils.rest(r[t]);var i=u[n[0]];return utils.arrayEach(n,function(r){u[r]>i&&(i=u[r])}),i},exports.DMIN=function(r,t,e){if(isNaN(t)&&"string"!=typeof t)return error.value;var n=findResultIndex(r,e),u=[];if("string"==typeof t){u=utils.rest(r[exports.FINDFIELD(r,t)])}else u=utils.rest(r[t]);var i=u[n[0]];return utils.arrayEach(n,function(r){i>u[r]&&(i=u[r])}),i},exports.DPRODUCT=function(r,t,e){if(isNaN(t)&&"string"!=typeof t)return error.value;var n=findResultIndex(r,e),u=[];if("string"==typeof t){u=utils.rest(r[exports.FINDFIELD(r,t)])}else u=utils.rest(r[t]);var i=[];utils.arrayEach(n,function(r){i.push(u[r])}),i=compact(i);var o=1;return utils.arrayEach(i,function(r){o*=r}),o},exports.DSTDEV=function(r,t,e){if(isNaN(t)&&"string"!=typeof t)return error.value;var n=findResultIndex(r,e),u=[];if("string"==typeof t){u=utils.rest(r[exports.FINDFIELD(r,t)])}else u=utils.rest(r[t]);var i=[];return utils.arrayEach(n,function(r){i.push(u[r])}),i=compact(i),stats.STDEV.S(i)},exports.DSTDEVP=function(r,t,e){if(isNaN(t)&&"string"!=typeof t)return error.value;var n=findResultIndex(r,e),u=[];if("string"==typeof t){u=utils.rest(r[exports.FINDFIELD(r,t)])}else u=utils.rest(r[t]);var i=[];return utils.arrayEach(n,function(r){i.push(u[r])}),i=compact(i),stats.STDEV.P(i)},exports.DSUM=function(r,t,e){if(isNaN(t)&&"string"!=typeof t)return error.value;var n=findResultIndex(r,e),u=[];if("string"==typeof t){u=utils.rest(r[exports.FINDFIELD(r,t)])}else u=utils.rest(r[t]);var i=[];return utils.arrayEach(n,function(r){i.push(u[r])}),maths.SUM(i)},exports.DVAR=function(r,t,e){if(isNaN(t)&&"string"!=typeof t)return error.value;var n=findResultIndex(r,e),u=[];if("string"==typeof t){u=utils.rest(r[exports.FINDFIELD(r,t)])}else u=utils.rest(r[t]);var i=[];return utils.arrayEach(n,function(r){i.push(u[r])}),stats.VAR.S(i)},exports.DVARP=function(r,t,e){if(isNaN(t)&&"string"!=typeof t)return error.value;var n=findResultIndex(r,e),u=[];if("string"==typeof t){u=utils.rest(r[exports.FINDFIELD(r,t)])}else u=utils.rest(r[t]);var i=[];return utils.arrayEach(n,function(r){i.push(u[r])}),stats.VAR.P(i)}},function(r,t,e){function n(r){return r&&r.getTime&&!isNaN(r.getTime())}function u(r){return r instanceof Date?r:new Date(r)}var i=e(0),o=e(6),a=e(2);t.ACCRINT=function(r,t,e,a,s,l,f){return r=u(r),t=u(t),e=u(e),n(r)&&n(t)&&n(e)?a>0&&s>0?[1,2,4].indexOf(l)===-1?i.num:[0,1,2,3,4].indexOf(f)===-1?i.num:e>r?(s=s||0,f=f||0,s*a*o.YEARFRAC(r,e,f)):i.num:i.num:i.value},t.ACCRINTM=function(){throw Error("ACCRINTM is not implemented")},t.AMORDEGRC=function(){throw Error("AMORDEGRC is not implemented")},t.AMORLINC=function(){throw Error("AMORLINC is not implemented")},t.COUPDAYBS=function(){throw Error("COUPDAYBS is not implemented")},t.COUPDAYS=function(){throw Error("COUPDAYS is not implemented")},t.COUPDAYSNC=function(){throw Error("COUPDAYSNC is not implemented")},t.COUPNCD=function(){throw Error("COUPNCD is not implemented")},t.COUPNUM=function(){throw Error("COUPNUM is not implemented")},t.COUPPCD=function(){throw Error("COUPPCD is not implemented")},t.CUMIPMT=function(r,e,n,u,o,s){if(r=a.parseNumber(r),e=a.parseNumber(e),n=a.parseNumber(n),a.anyIsError(r,e,n))return i.value;if(0>=r||0>=e||0>=n)return i.num;if(1>u||1>o||u>o)return i.num;if(0!==s&&1!==s)return i.num;var l=t.PMT(r,e,n,0,s),f=0;1===u&&0===s&&(f=-n,u++);for(var c=u;o>=c;c++)f+=1===s?t.FV(r,c-2,l,n,1)-l:t.FV(r,c-1,l,n,0);return f*=r},t.CUMPRINC=function(r,e,n,u,o,s){if(r=a.parseNumber(r),e=a.parseNumber(e),n=a.parseNumber(n),a.anyIsError(r,e,n))return i.value;if(0>=r||0>=e||0>=n)return i.num;if(1>u||1>o||u>o)return i.num;if(0!==s&&1!==s)return i.num;var l=t.PMT(r,e,n,0,s),f=0;1===u&&(f=0===s?l+n*r:l,u++);for(var c=u;o>=c;c++)f+=s>0?l-(t.FV(r,c-2,l,n,1)-l)*r:l-t.FV(r,c-1,l,n,0)*r;return f},t.DB=function(r,t,e,n,u){if(u=u===undefined?12:u,r=a.parseNumber(r),t=a.parseNumber(t),e=a.parseNumber(e),n=a.parseNumber(n),u=a.parseNumber(u),a.anyIsError(r,t,e,n,u))return i.value;if(0>r||0>t||0>e||0>n)return i.num;if([1,2,3,4,5,6,7,8,9,10,11,12].indexOf(u)===-1)return i.num;if(n>e)return i.num;if(t>=r)return 0;for(var o=(1-Math.pow(t/r,1/e)).toFixed(3),s=r*o*u/12,l=s,f=0,c=n===e?e-1:n,p=2;c>=p;p++)f=(r-l)*o,l+=f;return 1===n?s:n===e?(r-l)*o:f},t.DDB=function(r,t,e,n,u){if(u=u===undefined?2:u,r=a.parseNumber(r),t=a.parseNumber(t),e=a.parseNumber(e),n=a.parseNumber(n),u=a.parseNumber(u),a.anyIsError(r,t,e,n,u))return i.value;if(0>r||0>t||0>e||0>n||0>=u)return i.num;if(n>e)return i.num;if(t>=r)return 0;for(var o=0,s=0,l=1;n>=l;l++)s=Math.min(u/e*(r-o),r-t-o),o+=s;return s},t.DISC=function(){throw Error("DISC is not implemented")},t.DOLLARDE=function(r,t){if(r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t))return i.value;if(0>t)return i.num;if(t>=0&&1>t)return i.div0;t=parseInt(t,10);var e=parseInt(r,10);e+=r%1*Math.pow(10,Math.ceil(Math.log(t)/Math.LN10))/t;var n=Math.pow(10,Math.ceil(Math.log(t)/Math.LN2)+1);return e=Math.round(e*n)/n},t.DOLLARFR=function(r,t){if(r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t))return i.value;if(0>t)return i.num;if(t>=0&&1>t)return i.div0;t=parseInt(t,10);var e=parseInt(r,10);return e+=r%1*Math.pow(10,-Math.ceil(Math.log(t)/Math.LN10))*t},t.DURATION=function(){throw Error("DURATION is not implemented")},t.EFFECT=function(r,t){return r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t)?i.value:0>=r||1>t?i.num:(t=parseInt(t,10),Math.pow(1+r/t,t)-1)},t.FV=function(r,t,e,n,u){if(n=n||0,u=u||0,r=a.parseNumber(r),t=a.parseNumber(t),e=a.parseNumber(e),n=a.parseNumber(n),u=a.parseNumber(u),a.anyIsError(r,t,e,n,u))return i.value;var o;if(0===r)o=n+e*t;else{var s=Math.pow(1+r,t);o=1===u?n*s+e*(1+r)*(s-1)/r:n*s+e*(s-1)/r}return-o},t.FVSCHEDULE=function(r,t){if(r=a.parseNumber(r),t=a.parseNumberArray(a.flatten(t)),a.anyIsError(r,t))return i.value;for(var e=t.length,n=r,u=0;e>u;u++)n*=1+t[u];return n},t.INTRATE=function(){throw Error("INTRATE is not implemented")},t.IPMT=function(r,e,n,u,o,s){if(o=o||0,s=s||0,r=a.parseNumber(r),e=a.parseNumber(e),n=a.parseNumber(n),u=a.parseNumber(u),o=a.parseNumber(o),s=a.parseNumber(s),a.anyIsError(r,e,n,u,o,s))return i.value;var l=t.PMT(r,n,u,o,s);return(1===e?1===s?0:-u:1===s?t.FV(r,e-2,l,u,1)-l:t.FV(r,e-1,l,u,0))*r},t.IRR=function(r,t){if(t=t||0,r=a.parseNumberArray(a.flatten(r)),t=a.parseNumber(t),a.anyIsError(r,t))return i.value;for(var e=function(r,t,e){for(var n=e+1,u=r[0],i=1;r.length>i;i++)u+=r[i]/Math.pow(n,(t[i]-t[0])/365);return u},n=function(r,t,e){for(var n=e+1,u=0,i=1;r.length>i;i++){var o=(t[i]-t[0])/365;u-=o*r[i]/Math.pow(n,o+1)}return u},u=[],o=!1,s=!1,l=0;r.length>l;l++)u[l]=0===l?0:u[l-1]+365,r[l]>0&&(o=!0),0>r[l]&&(s=!0);if(!o||!s)return i.num;t=t===undefined?.1:t;var f,c,p,m=t,d=1e-10,h=!0;do{p=e(r,u,m),f=m-p/n(r,u,m),c=Math.abs(f-m),m=f,h=c>d&&Math.abs(p)>d}while(h);return m},t.ISPMT=function(r,t,e,n){return r=a.parseNumber(r),t=a.parseNumber(t),e=a.parseNumber(e),n=a.parseNumber(n),a.anyIsError(r,t,e,n)?i.value:n*r*(t/e-1)},t.MDURATION=function(){throw Error("MDURATION is not implemented")},t.MIRR=function(r,e,n){if(r=a.parseNumberArray(a.flatten(r)),e=a.parseNumber(e),n=a.parseNumber(n),a.anyIsError(r,e,n))return i.value;for(var u=r.length,o=[],s=[],l=0;u>l;l++)0>r[l]?o.push(r[l]):s.push(r[l]);var f=-t.NPV(n,s)*Math.pow(1+n,u-1),c=t.NPV(e,o)*(1+e);return Math.pow(f/c,1/(u-1))-1},t.NOMINAL=function(r,t){return r=a.parseNumber(r),t=a.parseNumber(t),a.anyIsError(r,t)?i.value:0>=r||1>t?i.num:(t=parseInt(t,10),(Math.pow(r+1,1/t)-1)*t)},t.NPER=function(r,t,e,n,u){if(u=u===undefined?0:u,n=n===undefined?0:n,r=a.parseNumber(r),t=a.parseNumber(t),e=a.parseNumber(e),n=a.parseNumber(n),u=a.parseNumber(u),a.anyIsError(r,t,e,n,u))return i.value;var o=t*(1+r*u)-n*r,s=e*r+t*(1+r*u);return Math.log(o/s)/Math.log(1+r)},t.NPV=function(){var r=a.parseNumberArray(a.flatten(arguments));if(r instanceof Error)return r;for(var t=r[0],e=0,n=1;r.length>n;n++)e+=r[n]/Math.pow(1+t,n);return e},t.ODDFPRICE=function(){throw Error("ODDFPRICE is not implemented")},t.ODDFYIELD=function(){throw Error("ODDFYIELD is not implemented")},t.ODDLPRICE=function(){throw Error("ODDLPRICE is not implemented")},t.ODDLYIELD=function(){throw Error("ODDLYIELD is not implemented")},t.PDURATION=function(r,t,e){return r=a.parseNumber(r),t=a.parseNumber(t),e=a.parseNumber(e),a.anyIsError(r,t,e)?i.value:r>0?(Math.log(e)-Math.log(t))/Math.log(1+r):i.num},t.PMT=function(r,t,e,n,u){if(n=n||0,u=u||0,r=a.parseNumber(r),t=a.parseNumber(t),e=a.parseNumber(e),n=a.parseNumber(n),u=a.parseNumber(u),a.anyIsError(r,t,e,n,u))return i.value;var o;if(0===r)o=(e+n)/t;else{var s=Math.pow(1+r,t);o=1===u?(n*r/(s-1)+e*r/(1-1/s))/(1+r):n*r/(s-1)+e*r/(1-1/s)}return-o},t.PPMT=function(r,e,n,u,o,s){return o=o||0,s=s||0,r=a.parseNumber(r),n=a.parseNumber(n),u=a.parseNumber(u),o=a.parseNumber(o),s=a.parseNumber(s),a.anyIsError(r,n,u,o,s)?i.value:t.PMT(r,n,u,o,s)-t.IPMT(r,e,n,u,o,s)},t.PRICE=function(){throw Error("PRICE is not implemented")},t.PRICEDISC=function(){throw Error("PRICEDISC is not implemented")},t.PRICEMAT=function(){throw Error("PRICEMAT is not implemented")},t.PV=function(r,t,e,n,u){return n=n||0,u=u||0,r=a.parseNumber(r),t=a.parseNumber(t),e=a.parseNumber(e),n=a.parseNumber(n),u=a.parseNumber(u),a.anyIsError(r,t,e,n,u)?i.value:0===r?-e*t-n:((1-Math.pow(1+r,t))/r*e*(1+r*u)-n)/Math.pow(1+r,t)},t.RATE=function(r,t,e,n,u,o){if(o=o===undefined?.01:o,n=n===undefined?0:n,u=u===undefined?0:u,r=a.parseNumber(r),t=a.parseNumber(t),e=a.parseNumber(e),n=a.parseNumber(n),u=a.parseNumber(u),o=a.parseNumber(o),a.anyIsError(r,t,e,n,u,o))return i.value;var s,l,f,c,p=1e-10,m=50,d=0,h=0,E=0,g=o;for(Math.abs(g)p&&m>E;)g=(f*c-l*d)/(f-l),c=d,d=g,Math.abs(g)n||n>e?i.num:(n=parseInt(n,10),(r-t)*(e-n+1)*2/(e*(e+1)))},t.TBILLEQ=function(r,t,e){return r=a.parseDate(r),t=a.parseDate(t),e=a.parseNumber(e),a.anyIsError(r,t,e)?i.value:e>0?r>t?i.num:t-r>31536e6?i.num:365*e/(360-e*o.DAYS360(r,t,!1)):i.num},t.TBILLPRICE=function(r,t,e){return r=a.parseDate(r),t=a.parseDate(t),e=a.parseNumber(e),a.anyIsError(r,t,e)?i.value:e>0?r>t?i.num:t-r>31536e6?i.num:100*(1-e*o.DAYS360(r,t,!1)/360):i.num},t.TBILLYIELD=function(r,t,e){return r=a.parseDate(r),t=a.parseDate(t),e=a.parseNumber(e),a.anyIsError(r,t,e)?i.value:e>0?r>t?i.num:t-r>31536e6?i.num:360*(100-e)/(e*o.DAYS360(r,t,!1)):i.num},t.VDB=function(){throw Error("VDB is not implemented")},t.XNPV=function(r,t,e){if(r=a.parseNumber(r),t=a.parseNumberArray(a.flatten(t)),e=a.parseDateArray(a.flatten(e)),a.anyIsError(r,t,e))return i.value;for(var n=0,u=0;t.length>u;u++)n+=t[u]/Math.pow(1+r,o.DAYS(e[u],e[0])/365);return n},t.YIELD=function(){throw Error("YIELD is not implemented")},t.YIELDDISC=function(){throw Error("YIELDDISC is not implemented")},t.YIELDMAT=function(){throw Error("YIELDMAT is not implemented")}},function(r,t,e){var n=e(0),u=e(2),i=e(7);t.AND=function(){for(var r=u.flatten(arguments),t=!0,e=0;r.length>e;e++)r[e]||(t=!1);return t},t.CHOOSE=function(){if(2>arguments.length)return n.na;var r=arguments[0];return 1>r||r>254?n.value:r+1>arguments.length?n.value:arguments[r]},t.FALSE=function(){return!1},t.IF=function(r,t,e){return r?t:e},t.IFERROR=function(r,t){return i.ISERROR(r)?t:r},t.IFNA=function(r,t){return r===n.na?t:r},t.NOT=function(r){return!r},t.OR=function(){for(var r=u.flatten(arguments),t=!1,e=0;r.length>e;e++)r[e]&&(t=!0);return t},t.TRUE=function(){return!0},t.XOR=function(){for(var r=u.flatten(arguments),t=0,e=0;r.length>e;e++)r[e]&&t++;return!!(1&Math.floor(Math.abs(t)))},t.SWITCH=function(){var r;if(arguments.length>0){var t=arguments[0],e=arguments.length-1,u=Math.floor(e/2),i=!1,o=e%2!=0,a=e%2==0?null:arguments[arguments.length-1];if(u)for(var s=0;u>s;s++)if(t===arguments[2*s+1]){r=arguments[2*s+2],i=!0;break}i||(r=o?a:n.na)}else r=n.value;return r}},function(r,t,e){var n=e(0);t.MATCH=function(r,t,e){if(!r&&!t)return n.na;if(2===arguments.length&&(e=1),!(t instanceof Array))return n.na;if(e!==-1&&0!==e&&1!==e)return n.na;for(var u,i,o=0;t.length>o;o++)if(1===e){if(t[o]===r)return o+1;r>t[o]&&(i?t[o]>i&&(u=o+1,i=t[o]):(u=o+1,i=t[o]))}else if(0===e){if("string"==typeof r){if(r=r.replace(/\?/g,"."),t[o].toLowerCase().match(r.toLowerCase()))return o+1}else if(t[o]===r)return o+1}else if(e===-1){if(t[o]===r)return o+1;t[o]>r&&(i?i>t[o]&&(u=o+1,i=t[o]):(u=o+1,i=t[o]))}return u?u:n.na}},function(r,t){/*! +(function(){"use strict";function u(r){this._value=r}function a(r){return 0===r?1:Math.floor(Math.log(Math.abs(r))/Math.LN10)+1}function s(r){var e,t="";for(e=0;r>e;e++)t+="0";return t}function l(r,e){var t,n,i,o,u,a,l,f;return f=""+r,t=f.split("e")[0],o=f.split("e")[1],n=t.split(".")[0],i=t.split(".")[1]||"",+o>0?f=n+i+s(o-i.length):(u=0>+n?"-0":"0",e>0&&(u+="."),l=s(-1*o-1),a=(l+Math.abs(n)+i).substr(0,e),f=u+a),+o>0&&e>0&&(f+="."+s(e)),f}function f(r,e,t,n){var i,o,u=Math.pow(10,e);return(""+r).indexOf("e")>-1?(o=l(r,e),"-"!==o.charAt(0)||0>+o||(o=o.substr(1))):o=(t(r+"e+"+e)/u).toFixed(e),n&&(i=RegExp("0{1,"+n+"}$"),o=o.replace(i,"")),o}function c(r,e,t){var n=e.replace(/\{[^\{\}]*\}/g,"");return n.indexOf("$")>-1?m(r,C[$].currency.symbol,e,t):n.indexOf("%")>-1?h(r,e,t):n.indexOf(":")>-1?b(r):E(r._value,e,t)}function d(r,e){var t,n,i,o,u,a=e,s=!1;if(e.indexOf(":")>-1)r._value=v(e);else if(e===O)r._value=0;else{for("."!==C[$].delimiters.decimal&&(e=e.replace(/\./g,"").replace(C[$].delimiters.decimal,".")),t=RegExp("[^a-zA-Z]"+C[$].abbreviations.thousand+"(?:\\)|(\\"+C[$].currency.symbol+")?(?:\\))?)?$"),n=RegExp("[^a-zA-Z]"+C[$].abbreviations.million+"(?:\\)|(\\"+C[$].currency.symbol+")?(?:\\))?)?$"),i=RegExp("[^a-zA-Z]"+C[$].abbreviations.billion+"(?:\\)|(\\"+C[$].currency.symbol+")?(?:\\))?)?$"),o=RegExp("[^a-zA-Z]"+C[$].abbreviations.trillion+"(?:\\)|(\\"+C[$].currency.symbol+")?(?:\\))?)?$"),u=1;x.length>u&&!s;++u)e.indexOf(x[u])>-1?s=Math.pow(1024,u):e.indexOf(A[u])>-1&&(s=Math.pow(1e3,u));var l=e.replace(/[^0-9\.]+/g,"");""===l?r._value=NaN:(r._value=(s||1)*(a.match(t)?Math.pow(10,3):1)*(a.match(n)?Math.pow(10,6):1)*(a.match(i)?Math.pow(10,9):1)*(a.match(o)?Math.pow(10,12):1)*(e.indexOf("%")>-1?.01:1)*((e.split("-").length+Math.min(e.split("(").length-1,e.split(")").length-1))%2?1:-1)*+l,r._value=s?Math.ceil(r._value):r._value)}return r._value}function m(r,e,t,n){var i,o,u=t,a=u.indexOf("$"),s=u.indexOf("("),l=u.indexOf("+"),f=u.indexOf("-"),c="",d="";if(-1===u.indexOf("$")?"infix"===C[$].currency.position?(d=e,C[$].currency.spaceSeparated&&(d=" "+d+" ")):C[$].currency.spaceSeparated&&(c=" "):u.indexOf(" $")>-1?(c=" ",u=u.replace(" $","")):u.indexOf("$ ")>-1?(c=" ",u=u.replace("$ ","")):u=u.replace("$",""),o=E(r._value,u,n,d),-1===t.indexOf("$"))switch(C[$].currency.position){case"postfix":o.indexOf(")")>-1?(o=o.split(""),o.splice(-1,0,c+e),o=o.join("")):o=o+c+e;break;case"infix":break;case"prefix":o.indexOf("(")>-1||o.indexOf("-")>-1?(o=o.split(""),i=Math.max(s,f)+1,o.splice(i,0,e+c),o=o.join("")):o=e+c+o;break;default:throw Error('Currency position should be among ["prefix", "infix", "postfix"]')}else a>1?o.indexOf(")")>-1?(o=o.split(""),o.splice(-1,0,c+e),o=o.join("")):o=o+c+e:o.indexOf("(")>-1||o.indexOf("+")>-1||o.indexOf("-")>-1?(o=o.split(""),i=1,(s>a||l>a||f>a)&&(i=0),o.splice(i,0,e+c),o=o.join("")):o=e+c+o;return o}function p(r,e,t,n){return m(r,e,t,n)}function h(r,e,t){var n,i="",o=100*r._value;return e.indexOf(" %")>-1?(i=" ",e=e.replace(" %","")):e=e.replace("%",""),n=E(o,e,t),n.indexOf(")")>-1?(n=n.split(""),n.splice(-1,0,i+"%"),n=n.join("")):n=n+i+"%",n}function b(r){var e=Math.floor(r._value/60/60),t=Math.floor((r._value-60*e*60)/60),n=Math.round(r._value-60*e*60-60*t);return e+":"+(10>t?"0"+t:t)+":"+(10>n?"0"+n:n)}function v(r){var e=r.split(":"),t=0;return 3===e.length?(t+=60*+e[0]*60,t+=60*+e[1],t+=+e[2]):2===e.length&&(t+=60*+e[0],t+=+e[1]),+t}function g(r,e,t){var n,i,o,u=e[0],a=Math.abs(r);if(a>=t){for(n=1;e.length>n;++n)if(i=Math.pow(t,n),o=Math.pow(t,n+1),a>=i&&o>a){u=e[n],r/=i;break}u===e[0]&&(r/=Math.pow(t,e.length-1),u=e[e.length-1])}return{value:r,suffix:u}}function E(r,e,t,n){var i,o,u,l,c,d,m,p,h,b,v,E,N,y,w,I,M=!1,x=!1,A=!1,R="",S=!1,D=!1,V=!1,L=!1,_=!1,P="",U="",F=Math.abs(r),k="",B=!1,G=!1,j="";if(0===r&&null!==O)return O;if(!isFinite(r))return""+r;if(0===e.indexOf("{")){var W=e.indexOf("}");if(-1===W)throw Error('Format should also contain a "}"');b=e.slice(1,W),e=e.slice(W+1)}else b="";if(e.indexOf("}")===e.length-1&&e.length){var Y=e.indexOf("{");if(-1===Y)throw Error('Format should also contain a "{"');v=e.slice(Y+1,-1),e=e.slice(0,Y+1)}else v="";var H;for(H=e.match(-1===e.indexOf(".")?/([0-9]+).*/:/([0-9]+)\..*/),w=null===H?-1:H[1].length,-1!==e.indexOf("-")&&(B=!0),e.indexOf("(")>-1?(M=!0,e=e.slice(1,-1)):e.indexOf("+")>-1&&(x=!0,e=e.replace(/\+/g,"")),e.indexOf("a")>-1&&(p=e.split(".")[0].match(/[0-9]+/g)||["0"],p=parseInt(p[0],10),S=e.indexOf("aK")>=0,D=e.indexOf("aM")>=0,V=e.indexOf("aB")>=0,L=e.indexOf("aT")>=0,_=S||D||V||L,e.indexOf(" a")>-1?(R=" ",e=e.replace(" a","")):e=e.replace("a",""),u=a(r),c=u%3,c=0===c?3:c,p&&0!==F&&(d=3*~~((Math.min(p,u)-c)/3),F/=Math.pow(10,d)),u!==p&&(F>=Math.pow(10,12)&&!_||L?(R+=C[$].abbreviations.trillion,r/=Math.pow(10,12)):F=Math.pow(10,9)&&!_||V?(R+=C[$].abbreviations.billion,r/=Math.pow(10,9)):F=Math.pow(10,6)&&!_||D?(R+=C[$].abbreviations.million,r/=Math.pow(10,6)):(F=Math.pow(10,3)&&!_||S)&&(R+=C[$].abbreviations.thousand,r/=Math.pow(10,3))),l=a(r),p&&p>l&&-1===e.indexOf(".")&&(e+="[.]",e+=s(p-l))),I=0;T.length>I;++I)if(i=T[I],e.indexOf(i.marker)>-1){e.indexOf(" "+i.marker)>-1&&(P=" "),e=e.replace(P+i.marker,""),o=g(r,i.suffixes,i.scale),r=o.value,P+=o.suffix;break}if(e.indexOf("o")>-1&&(e.indexOf(" o")>-1?(U=" ",e=e.replace(" o","")):e=e.replace("o",""),C[$].ordinal&&(U+=C[$].ordinal(r))),e.indexOf("[.]")>-1&&(A=!0,e=e.replace("[.]",".")),h=e.split(".")[1],E=e.indexOf(","),h){var q=[];if(-1!==h.indexOf("*")?(k=""+r,q=k.split("."),q.length>1&&(k=f(r,q[1].length,t))):h.indexOf("[")>-1?(h=h.replace("]",""),h=h.split("["),k=f(r,h[0].length+h[1].length,t,h[1].length)):k=f(r,h.length,t),q=k.split("."),m=q[0],q.length>1&&q[1].length){k=(n?R+n:C[$].delimiters.decimal)+q[1]}else k="";A&&0==+k.slice(1)&&(k="")}else m=f(r,0,t);return m.indexOf("-")>-1&&(m=m.slice(1),G=!0),w>m.length&&(m=s(w-m.length)+m),E>-1&&(m=(""+m).replace(/(\d)(?=(\d{3})+(?!\d))/g,"$1"+C[$].delimiters.thousands)),0===e.indexOf(".")&&(m=""),N=e.indexOf("("),y=e.indexOf("-"),j=y>N?(M&&G?"(":"")+(B&&G||!M&&G?"-":""):(B&&G||!M&&G?"-":"")+(M&&G?"(":""),b+j+(!G&&x&&0!==r?"+":"")+m+k+(U||"")+(R&&!n?R:"")+(P||"")+(M&&G?")":"")+v}function N(r,e){C[r]=e}function y(r){$=r;var e=C[r].defaults;e&&e.format&&M.defaultFormat(e.format),e&&e.currencyFormat&&M.defaultCurrencyFormat(e.currencyFormat)}function w(r){var e=(""+r).split(".");return 2>e.length?1:Math.pow(10,e[1].length)}function I(){return Array.prototype.slice.call(arguments).reduce(function(r,e){var t=w(r),n=w(e);return t>n?t:n},-Infinity)}var M,x=["B","KiB","MiB","GiB","TiB","PiB","EiB","ZiB","YiB"],A=["B","KB","MB","GB","TB","PB","EB","ZB","YB"],R={general:{scale:1024,suffixes:A,marker:"bd"},binary:{scale:1024,suffixes:x,marker:"b"},decimal:{scale:1e3,suffixes:A,marker:"d"}},T=[R.general,R.binary,R.decimal],C={},S=C,$="en-US",O=null,D="0,0",V="0$",L=void 0!==r&&r.exports,_={delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1==~~(r%100/10)?"th":1===e?"st":2===e?"nd":3===e?"rd":"th"},currency:{symbol:"$",position:"prefix"},defaults:{currencyFormat:",0000 a"},formats:{fourDigits:"0000 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00"}};M=function(r){return r=M.isNumbro(r)?r.value():"string"==typeof r||"number"==typeof r?M.fn.unformat(r):NaN,new u(+r)},M.version="1.11.0",M.isNumbro=function(r){return r instanceof u},M.setLanguage=function(r,e){console.warn("`setLanguage` is deprecated since version 1.6.0. Use `setCulture` instead");var t=r,n=r.split("-")[0],i=null;S[t]||(Object.keys(S).forEach(function(r){i||r.split("-")[0]!==n||(i=r)}),t=i||e||"en-US"),y(t)},M.setCulture=function(r,e){var t=r,n=r.split("-")[1],i=null;C[t]||(n&&Object.keys(C).forEach(function(r){i||r.split("-")[1]!==n||(i=r)}),t=i||e||"en-US"),y(t)},M.language=function(r,e){if(console.warn("`language` is deprecated since version 1.6.0. Use `culture` instead"),!r)return $;if(r&&!e){if(!S[r])throw Error("Unknown language : "+r);y(r)}return!e&&S[r]||N(r,e),M},M.culture=function(r,e){if(!r)return $;if(r&&!e){if(!C[r])throw Error("Unknown culture : "+r);y(r)}return!e&&C[r]||N(r,e),M},M.languageData=function(r){if(console.warn("`languageData` is deprecated since version 1.6.0. Use `cultureData` instead"),!r)return S[$];if(!S[r])throw Error("Unknown language : "+r);return S[r]},M.cultureData=function(r){if(!r)return C[$];if(!C[r])throw Error("Unknown culture : "+r);return C[r]},M.culture("en-US",_),M.languages=function(){return console.warn("`languages` is deprecated since version 1.6.0. Use `cultures` instead"),S},M.cultures=function(){return C},M.zeroFormat=function(r){O="string"==typeof r?r:null},M.defaultFormat=function(r){D="string"==typeof r?r:"0.0"},M.defaultCurrencyFormat=function(r){V="string"==typeof r?r:"0$"},M.validate=function(r,e){var t,n,i,o,u,a,s,l;if("string"!=typeof r&&(r+="",console.warn&&console.warn("Numbro.js: Value is not string. It has been co-erced to: ",r)),r=r.trim(),r=r.replace(/^[+-]?/,""),r.match(/^\d+$/))return!0;if(""===r)return!1;try{s=M.cultureData(e)}catch(f){s=M.cultureData(M.culture())}return i=s.currency.symbol,u=s.abbreviations,t=s.delimiters.decimal,n="."===s.delimiters.thousands?"\\.":s.delimiters.thousands,(null===(l=r.match(/^[^\d\.\,]+/))||(r=r.substr(1),l[0]===i))&&((null===(l=r.match(/[^\d]+$/))||(r=r.slice(0,-1),l[0]===u.thousand||l[0]===u.million||l[0]===u.billion||l[0]===u.trillion))&&(a=RegExp(n+"{2}"),!r.match(/[^\d.,]/g)&&(o=r.split(t),2>=o.length&&(2>o.length?!!o[0].match(/^\d+.*\d$/)&&!o[0].match(a):""===o[0]?!o[0].match(a)&&!!o[1].match(/^\d+$/):1===o[0].length?!!o[0].match(/^\d+$/)&&!o[0].match(a)&&!!o[1].match(/^\d+$/):!!o[0].match(/^\d+.*\d$/)&&!o[0].match(a)&&!!o[1].match(/^\d+$/)))))},M.loadLanguagesInNode=function(){console.warn("`loadLanguagesInNode` is deprecated since version 1.6.0. Use `loadCulturesInNode` instead"),M.loadCulturesInNode()},M.loadCulturesInNode=function(){var r=t(27);for(var e in r)e&&M.culture(e,r[e])},"function"!=typeof Array.prototype.reduce&&(Array.prototype.reduce=function(r,e){if(null===this||void 0===this)throw new TypeError("Array.prototype.reduce called on null or undefined");if("function"!=typeof r)throw new TypeError(r+" is not a function");var t,n,i=this.length>>>0,o=!1;for(arguments.length>1&&(n=e,o=!0),t=0;i>t;++t)this.hasOwnProperty(t)&&(o?n=r(n,this[t],t,this):(n=this[t],o=!0));if(!o)throw new TypeError("Reduce of empty array with no initial value");return n}),M.fn=u.prototype={clone:function(){return M(this)},format:function(r,e){return c(this,r||D,e!==undefined?e:Math.round)},formatCurrency:function(r,e){return m(this,C[$].currency.symbol,r||V,e!==undefined?e:Math.round)},formatForeignCurrency:function(r,e,t){return p(this,r,e||V,t!==undefined?t:Math.round)},unformat:function(r){if("number"==typeof r)return r;if("string"==typeof r){var e=d(this,r);return isNaN(e)?undefined:e}return undefined},binaryByteUnits:function(){return g(this._value,R.binary.suffixes,R.binary.scale).suffix},byteUnits:function(){return g(this._value,R.general.suffixes,R.general.scale).suffix},decimalByteUnits:function(){return g(this._value,R.decimal.suffixes,R.decimal.scale).suffix},value:function(){return this._value},valueOf:function(){return this._value},set:function(r){return this._value=+r,this},add:function(r){function e(r,e){return r+t*e}var t=I.call(null,this._value,r);return this._value=[this._value,r].reduce(e,0)/t,this},subtract:function(r){function e(r,e){return r-t*e}var t=I.call(null,this._value,r);return this._value=[r].reduce(e,this._value*t)/t,this},multiply:function(r){function e(r,e){var t=I(r,e),n=r*t;return n*=e*t,n/=t*t}return this._value=[this._value,r].reduce(e,1),this},divide:function(r){function e(r,e){var t=I(r,e);return r*t/(e*t)}return this._value=[this._value,r].reduce(e),this},difference:function(r){return Math.abs(M(this._value).subtract(r).value())}},function(){return void 0!==n&&n.browser===undefined&&n.title&&(-1!==n.title.indexOf("node")||n.title.indexOf("meteor-tool")>0||"grunt"===n.title||"gulp"===n.title)&&!0}()&&M.loadCulturesInNode(),L?r.exports=M:("undefined"==typeof ender&&(this.numbro=M),i=[],(o=function(){return M}.apply(e,i))!==undefined&&(r.exports=o))}).call("undefined"==typeof window?this:window)}).call(e,t(10))},function(r,e){function t(){throw Error("setTimeout has not been defined")}function n(){throw Error("clearTimeout has not been defined")}function i(r){if(f===setTimeout)return setTimeout(r,0);if((f===t||!f)&&setTimeout)return f=setTimeout,setTimeout(r,0);try{return f(r,0)}catch(e){try{return f.call(null,r,0)}catch(e){return f.call(this,r,0)}}}function o(r){if(c===clearTimeout)return clearTimeout(r);if((c===n||!c)&&clearTimeout)return c=clearTimeout,clearTimeout(r);try{return c(r)}catch(e){try{return c.call(null,r)}catch(e){return c.call(this,r)}}}function u(){h&&m&&(h=!1,m.length?p=m.concat(p):b=-1,p.length&&a())}function a(){if(!h){var r=i(u);h=!0;for(var e=p.length;e;){for(m=p,p=[];++b1)for(var t=1;arguments.length>t;t++)e[t-1]=arguments[t];p.push(new s(r,e)),1!==p.length||h||i(a)},s.prototype.run=function(){this.fun.apply(null,this.array)},d.title="browser",d.browser=!0,d.env={},d.argv=[],d.version="",d.versions={},d.on=l,d.addListener=l,d.once=l,d.off=l,d.removeListener=l,d.removeAllListeners=l,d.emit=l,d.binding=function(r){throw Error("process.binding is not supported")},d.cwd=function(){return"/"},d.chdir=function(r){throw Error("process.chdir is not supported")},d.umask=function(){return 0}},function(e,t,n){!function(r,t){e.exports=t()}(0,function(){var e=function(r,e){function t(e,t){var n=e>t?e:t;return r.pow(10,17-~~(r.log(n>0?n:-n)*r.LOG10E))}function n(r){return"[object Function]"===m.call(r)}function o(r){return"number"==typeof r&&r===r}function u(r){return c.apply([],r)}function a(){return new a._init(arguments)}function s(){return 0}function l(){return 1}function f(r,e){return r===e?1:0}var c=Array.prototype.concat,d=Array.prototype.slice,m=Object.prototype.toString,p=Array.isArray||function(r){return"[object Array]"===m.call(r)};a.fn=a.prototype,a._init=function(r){var e;if(p(r[0]))if(p(r[0][0])){n(r[1])&&(r[0]=a.map(r[0],r[1]));for(var e=0;r[0].length>e;e++)this[e]=r[0][e];this.length=r[0].length}else this[0]=n(r[1])?a.map(r[0],r[1]):r[0],this.length=1;else if(o(r[0]))this[0]=a.seq.apply(null,r),this.length=1;else{if(r[0]instanceof a)return a(r[0].toArray());this[0]=[],this.length=1}return this},a._init.prototype=a.prototype,a._init.constructor=a,a.utils={calcRdx:t,isArray:p,isFunction:n,isNumber:o,toVector:u},a.extend=function(r){var e,t;if(1===arguments.length){for(t in r)a[t]=r[t];return this}for(var e=1;arguments.length>e;e++)for(t in arguments[e])r[t]=arguments[e][t];return r},a.rows=function(r){return r.length||1},a.cols=function(r){return r[0].length||1},a.dimensions=function(r){return{rows:a.rows(r),cols:a.cols(r)}},a.row=function(r,e){return p(e)?e.map(function(e){return a.row(r,e)}):r[e]},a.rowa=function(r,e){return a.row(r,e)},a.col=function(r,e){if(p(e)){var t=a.arange(r.length).map(function(r){return Array(e.length)});return e.forEach(function(e,n){a.arange(r.length).forEach(function(i){t[i][n]=r[i][e]})}),t}for(var n=Array(r.length),i=0;r.length>i;i++)n[i]=[r[i][e]];return n},a.cola=function(r,e){return a.col(r,e).map(function(r){return r[0]})},a.diag=function(r){for(var e=a.rows(r),t=Array(e),n=0;e>n;n++)t[n]=[r[n][n]];return t},a.antidiag=function(r){for(var e=a.rows(r)-1,t=Array(e),n=0;e>=0;e--,n++)t[n]=[r[n][e]];return t},a.transpose=function(r){var e,t,n,i,o,u=[];p(r[0])||(r=[r]),t=r.length,n=r[0].length;for(var o=0;n>o;o++){for(e=Array(t),i=0;t>i;i++)e[i]=r[i][o];u.push(e)}return 1===u.length?u[0]:u},a.map=function(r,e,t){var n,i,o,u,a;for(p(r[0])||(r=[r]),i=r.length,o=r[0].length,u=t?r:Array(i),n=0;i>n;n++)for(u[n]||(u[n]=Array(o)),a=0;o>a;a++)u[n][a]=e(r[n][a],n,a);return 1===u.length?u[0]:u},a.cumreduce=function(r,e,t){var n,i,o,u,a;for(p(r[0])||(r=[r]),i=r.length,o=r[0].length,u=t?r:Array(i),n=0;i>n;n++)for(u[n]||(u[n]=Array(o)),o>0&&(u[n][0]=r[n][0]),a=1;o>a;a++)u[n][a]=e(u[n][a-1],r[n][a]);return 1===u.length?u[0]:u},a.alter=function(r,e){return a.map(r,e,!0)},a.create=function(r,e,t){var i,o,u=Array(r);n(e)&&(t=e,e=r);for(var i=0;r>i;i++)for(u[i]=Array(e),o=0;e>o;o++)u[i][o]=t(i,o);return u},a.zeros=function(r,e){return o(e)||(e=r),a.create(r,e,s)},a.ones=function(r,e){return o(e)||(e=r),a.create(r,e,l)},a.rand=function(e,t){return o(t)||(t=e),a.create(e,t,r.random)},a.identity=function(r,e){return o(e)||(e=r),a.create(r,e,f)},a.symmetric=function(r){var e,t,n=r.length;if(r.length!==r[0].length)return!1;for(e=0;n>e;e++)for(t=0;n>t;t++)if(r[t][e]!==r[e][t])return!1;return!0},a.clear=function(r){return a.alter(r,s)},a.seq=function(r,e,i,o){n(o)||(o=!1);var u,a=[],s=t(r,e),l=(e*s-r*s)/((i-1)*s),f=r;for(u=0;e>=f&&i>u;u++,f=(r*s+l*s*u)/s)a.push(o?o(f,u):f);return a},a.arange=function(r,t,n){var o=[];if(n=n||1,t===e&&(t=r,r=0),r===t||0===n)return[];if(t>r&&0>n)return[];if(r>t&&n>0)return[];if(n>0)for(i=r;it;i+=n)o.push(i);return o},a.slice=function(){function r(r,t,n,i){var o,u=[],s=r.length;if(t===e&&n===e&&i===e)return a.copy(r);if(t=t||0,n=n||r.length,t=0>t?s+t:t,n=0>n?s+n:n,i=i||1,t===n||0===i)return[];if(n>t&&0>i)return[];if(t>n&&i>0)return[];if(i>0)for(o=t;n>o;o+=i)u.push(r[o]);else for(o=t;o>n;o+=i)u.push(r[o]);return u}function t(e,t){if(t=t||{},o(t.row)){if(o(t.col))return e[t.row][t.col];var n=a.rowa(e,t.row),i=t.col||{};return r(n,i.start,i.end,i.step)}if(o(t.col)){var u=a.cola(e,t.col),s=t.row||{};return r(u,s.start,s.end,s.step)}var s=t.row||{},i=t.col||{};return r(e,s.start,s.end,s.step).map(function(e){return r(e,i.start,i.end,i.step)})}return t}(),a.sliceAssign=function(t,n,i){if(o(n.row)){if(o(n.col))return t[n.row][n.col]=i;n.col=n.col||{},n.col.start=n.col.start||0,n.col.end=n.col.end||t[0].length,n.col.step=n.col.step||1;var u=a.arange(n.col.start,r.min(t.length,n.col.end),n.col.step),s=n.row;return u.forEach(function(r,e){t[s][r]=i[e]}),t}if(o(n.col)){n.row=n.row||{},n.row.start=n.row.start||0,n.row.end=n.row.end||t.length,n.row.step=n.row.step||1;var l=a.arange(n.row.start,r.min(t[0].length,n.row.end),n.row.step),f=n.col;return l.forEach(function(r,e){t[r][f]=i[e]}),t}i[0].length===e&&(i=[i]),n.row.start=n.row.start||0,n.row.end=n.row.end||t.length,n.row.step=n.row.step||1,n.col.start=n.col.start||0,n.col.end=n.col.end||t[0].length,n.col.step=n.col.step||1;var l=a.arange(n.row.start,r.min(t.length,n.row.end),n.row.step),u=a.arange(n.col.start,r.min(t[0].length,n.col.end),n.col.step);return l.forEach(function(r,e){u.forEach(function(n,o){t[r][n]=i[e][o]})}),t},a.diagonal=function(r){var e=a.zeros(r.length,r.length);return r.forEach(function(r,t){e[t][t]=r}),e},a.copy=function(r){return r.map(function(r){return o(r)?r:r.map(function(r){return r})})};var h=a.prototype;return h.length=0,h.push=Array.prototype.push,h.sort=Array.prototype.sort,h.splice=Array.prototype.splice,h.slice=Array.prototype.slice,h.toArray=function(){return this.length>1?d.call(this):d.call(this)[0]},h.map=function(r,e){return a(a.map(this,r,e))},h.cumreduce=function(r,e){return a(a.cumreduce(this,r,e))},h.alter=function(r){return a.alter(this,r),this},function(r){for(var e=0;r.length>e;e++)!function(r){h[r]=function(e){var t,n=this;return e?(setTimeout(function(){e.call(n,h[r].call(n))}),this):(t=a[r](this),p(t)?a(t):t)}}(r[e])}("transpose clear symmetric rows cols dimensions diag antidiag".split(" ")),function(r){for(var e=0;r.length>e;e++)!function(r){h[r]=function(e,t){var n=this;return t?(setTimeout(function(){t.call(n,h[r].call(n,e))}),this):a(a[r](this,e))}}(r[e])}("row col".split(" ")),function(r){for(var e=0;r.length>e;e++)!function(r){h[r]=Function("return jStat(jStat."+r+".apply(null, arguments));")}(r[e])}("create zeros ones rand identity".split(" ")),a}(Math);return function(r,e){function t(r,e){return r-e}function n(r,t,n){return e.max(t,e.min(r,n))}var i=r.utils.isFunction;r.sum=function(r){for(var e=0,t=r.length;--t>=0;)e+=r[t];return e},r.sumsqrd=function(r){for(var e=0,t=r.length;--t>=0;)e+=r[t]*r[t];return e},r.sumsqerr=function(e){for(var t,n=r.mean(e),i=0,o=e.length;--o>=0;)t=e[o]-n,i+=t*t;return i},r.sumrow=function(r){for(var e=0,t=r.length;--t>=0;)e+=r[t];return e},r.product=function(r){for(var e=1,t=r.length;--t>=0;)e*=r[t];return e},r.min=function(r){for(var e=r[0],t=0;++tr[t]&&(e=r[t]);return e},r.max=function(r){for(var e=r[0],t=0;++te&&(e=r[t]);return e},r.unique=function(r){for(var e={},t=[],n=0;r.length>n;n++)e[r[n]]||(e[r[n]]=!0,t.push(r[n]));return t},r.mean=function(e){return r.sum(e)/e.length},r.meansqerr=function(e){return r.sumsqerr(e)/e.length},r.geomean=function(t){return e.pow(r.product(t),1/t.length)},r.median=function(r){var e=r.length,n=r.slice().sort(t);return 1&e?n[e/2|0]:(n[e/2-1]+n[e/2])/2},r.cumsum=function(e){return r.cumreduce(e,function(r,e){return r+e})},r.cumprod=function(e){return r.cumreduce(e,function(r,e){return r*e})},r.diff=function(r){for(var e,t=[],n=r.length,e=1;n>e;e++)t.push(r[e]-r[e-1]);return t},r.rank=function(r){for(var e=r.length,n=r.slice().sort(t),i=Array(e),o=0;e>o;o++){var u=n.indexOf(r[o]),a=n.lastIndexOf(r[o]);if(u===a)var s=u;else var s=(u+a)/2;i[o]=s+1}return i},r.mode=function(r){for(var e,n=r.length,i=r.slice().sort(t),o=1,u=0,a=0,s=[],e=0;n>e;e++)i[e]===i[e+1]?o++:(o>u?(s=[i[e]],u=o,a=0):o===u&&(s.push(i[e]),a++),o=1);return 0===a?s[0]:s},r.range=function(e){return r.max(e)-r.min(e)},r.variance=function(e,t){return r.sumsqerr(e)/(e.length-(t?1:0))},r.pooledvariance=function(e){return e.reduce(function(e,t){return e+r.sumsqerr(t)},0)/(e.reduce(function(r,e){return r+e.length},0)-e.length)},r.deviation=function(e){for(var t=r.mean(e),n=e.length,i=Array(n),o=0;n>o;o++)i[o]=e[o]-t;return i},r.stdev=function(t,n){return e.sqrt(r.variance(t,n))},r.pooledstdev=function(t){return e.sqrt(r.pooledvariance(t))},r.meandev=function(t){for(var n=r.mean(t),i=[],o=t.length-1;o>=0;o--)i.push(e.abs(t[o]-n));return r.mean(i)},r.meddev=function(t){for(var n=r.median(t),i=[],o=t.length-1;o>=0;o--)i.push(e.abs(t[o]-n));return r.median(i)},r.coeffvar=function(e){return r.stdev(e)/r.mean(e)},r.quartiles=function(r){var n=r.length,i=r.slice().sort(t);return[i[e.round(n/4)-1],i[e.round(n/2)-1],i[e.round(3*n/4)-1]]},r.quantiles=function(r,i,o,u){var a,s,l,f,c,d,m=r.slice().sort(t),p=[i.length],h=r.length;void 0===o&&(o=3/8),void 0===u&&(u=3/8);for(var a=0;i.length>a;a++)s=i[a],l=o+s*(1-o-u),f=h*s+l,c=e.floor(n(f,1,h-1)),d=n(f-c,0,1),p[a]=(1-d)*m[c-1]+d*m[c];return p},r.percentile=function(r,e){var n=r.slice().sort(t),i=e*(n.length-1),o=parseInt(i),u=i-o;return n.length>o+1?n[o]*(1-u)+n[o+1]*u:n[o]},r.percentileOfScore=function(r,e,t){var n,i,o=0,u=r.length,a=!1;"strict"===t&&(a=!0);for(var i=0;u>i;i++)n=r[i],(a&&e>n||!a&&e>=n)&&o++;return o/u},r.histogram=function(t,n){for(var i,o=r.min(t),u=n||4,a=(r.max(t)-o)/u,s=t.length,n=[],i=0;u>i;i++)n[i]=0;for(var i=0;s>i;i++)n[e.min(e.floor((t[i]-o)/a),u-1)]+=1;return n},r.covariance=function(e,t){for(var n,i=r.mean(e),o=r.mean(t),u=e.length,a=Array(u),n=0;u>n;n++)a[n]=(e[n]-i)*(t[n]-o);return r.sum(a)/(u-1)},r.corrcoeff=function(e,t){return r.covariance(e,t)/r.stdev(e,1)/r.stdev(t,1)},r.spearmancoeff=function(e,t){return e=r.rank(e),t=r.rank(t),r.corrcoeff(e,t)},r.stanMoment=function(t,n){for(var i=r.mean(t),o=r.stdev(t),u=t.length,a=0,s=0;u>s;s++)a+=e.pow((t[s]-i)/o,n);return a/t.length},r.skewness=function(e){return r.stanMoment(e,3)},r.kurtosis=function(e){return r.stanMoment(e,4)-3};var o=r.prototype;!function(e){for(var t=0;e.length>t;t++)!function(e){o[e]=function(t,n){var u=[],a=0,s=this;if(i(t)&&(n=t,t=!1),n)return setTimeout(function(){n.call(s,o[e].call(s,t))}),this;if(this.length>1){for(s=!0===t?this:this.transpose();s.length>a;a++)u[a]=r[e](s[a]);return u}return r[e](this[0],t)}}(e[t])}("cumsum cumprod".split(" ")),function(e){for(var t=0;e.length>t;t++)!function(e){o[e]=function(t,n){var u=[],a=0,s=this;if(i(t)&&(n=t,t=!1),n)return setTimeout(function(){n.call(s,o[e].call(s,t))}),this;if(this.length>1){for("sumrow"!==e&&(s=!0===t?this:this.transpose());s.length>a;a++)u[a]=r[e](s[a]);return!0===t?r[e](r.utils.toVector(u)):u}return r[e](this[0],t)}}(e[t])}("sum sumsqrd sumsqerr sumrow product min max unique mean meansqerr geomean median diff rank mode range variance deviation stdev meandev meddev coeffvar quartiles histogram skewness kurtosis".split(" ")),function(e){for(var t=0;e.length>t;t++)!function(e){o[e]=function(){var t=[],n=0,u=this,a=Array.prototype.slice.call(arguments);if(i(a[a.length-1])){var s=a[a.length-1],l=a.slice(0,a.length-1);return setTimeout(function(){s.call(u,o[e].apply(u,l))}),this}var s=undefined,f=function(t){return r[e].apply(u,[t].concat(a))};if(this.length>1){for(u=u.transpose();u.length>n;n++)t[n]=f(u[n]);return t}return f(this[0])}}(e[t])}("quantiles percentileOfScore".split(" "))}(e,Math),function(r,e){r.gammaln=function(r){var t,n,i,o=0,u=[76.18009172947146,-86.50532032941678,24.01409824083091,-1.231739572450155,.001208650973866179,-5395239384953e-18],a=1.000000000190015;for(i=(n=t=r)+5.5,i-=(t+.5)*e.log(i);6>o;o++)a+=u[o]/++n;return e.log(2.5066282746310007*a/t)-i},r.gammafn=function(r){var t,n,i,o,u=[-1.716185138865495,24.76565080557592,-379.80425647094563,629.3311553128184,866.9662027904133,-31451.272968848367,-36144.413418691176,66456.14382024054],a=[-30.8402300119739,315.35062697960416,-1015.1563674902192,-3107.771671572311,22538.11842098015,4755.846277527881,-134659.9598649693,-115132.2596755535],s=!1,l=0,f=0,c=0,d=r;if(0>=d){if(!(o=d%1+3.6e-16))return Infinity;s=(1&d?-1:1)*e.PI/e.sin(e.PI*o),d=1-d}i=d,n=1>d?d++:(d-=l=(0|d)-1)-1;for(var t=0;8>t;++t)c=(c+u[t])*n,f=f*n+a[t];if(o=c/f+1,d>i)o/=i;else if(i>d)for(var t=0;l>t;++t)o*=d,d++;return s&&(o=s/o),o},r.gammap=function(e,t){return r.lowRegGamma(e,t)*r.gammafn(e)},r.lowRegGamma=function(t,n){var i,o=r.gammaln(t),u=t,a=1/t,s=a,l=n+1-t,f=1/1e-30,c=1/l,d=c,m=1,p=-~(8.5*e.log(1>t?1/t:t)+.4*t+17);if(0>n||0>=t)return NaN;if(t+1>n){for(;p>=m;m++)a+=s*=n/++u;return a*e.exp(-n+t*e.log(n)-o)}for(;p>=m;m++)i=-m*(m-t),l+=2,c=i*c+l,f=l+i/f,c=1/c,d*=c*f;return 1-d*e.exp(-n+t*e.log(n)-o)},r.factorialln=function(e){return 0>e?NaN:r.gammaln(e+1)},r.factorial=function(e){return 0>e?NaN:r.gammafn(e+1)},r.combination=function(t,n){return t>170||n>170?e.exp(r.combinationln(t,n)):r.factorial(t)/r.factorial(n)/r.factorial(t-n)},r.combinationln=function(e,t){return r.factorialln(e)-r.factorialln(t)-r.factorialln(e-t)},r.permutation=function(e,t){return r.factorial(e)/r.factorial(e-t)},r.betafn=function(t,n){return t>0&&n>0?t+n>170?e.exp(r.betaln(t,n)):r.gammafn(t)*r.gammafn(n)/r.gammafn(t+n):undefined},r.betaln=function(e,t){return r.gammaln(e)+r.gammaln(t)-r.gammaln(e+t)},r.betacf=function(r,t,n){var i,o,u,a,s=1,l=t+n,f=t+1,c=t-1,d=1,m=1-l*r/f;for(1e-30>e.abs(m)&&(m=1e-30),m=1/m,a=m;100>=s&&(i=2*s,o=s*(n-s)*r/((c+i)*(t+i)),m=1+o*m,1e-30>e.abs(m)&&(m=1e-30),d=1+o/d,1e-30>e.abs(d)&&(d=1e-30),m=1/m,a*=m*d,o=-(t+s)*(l+s)*r/((t+i)*(f+i)),m=1+o*m,1e-30>e.abs(m)&&(m=1e-30),d=1+o/d,1e-30>e.abs(d)&&(d=1e-30),m=1/m,u=m*d,a*=u,3e-7<=e.abs(u-1));s++);return a},r.gammapinv=function(t,n){var i,o,u,a,s,l,f,c=0,d=n-1,m=r.gammaln(n);if(t>=1)return e.max(100,n+100*e.sqrt(n));if(0>=t)return 0;for(n>1?(l=e.log(d),f=e.exp(d*(l-1)-m),s=.5>t?t:1-t,u=e.sqrt(-2*e.log(s)),i=(2.30753+.27061*u)/(1+u*(.99229+.04481*u))-u,.5>t&&(i=-i),i=e.max(.001,n*e.pow(1-1/(9*n)-i/(3*e.sqrt(n)),3))):(u=1-n*(.253+.12*n),i=u>t?e.pow(t/u,1/n):1-e.log(1-(t-u)/(1-u)));12>c;c++){if(0>=i)return 0;if(o=r.lowRegGamma(n,i)-t,u=n>1?f*e.exp(-(i-d)+d*(e.log(i)-l)):e.exp(-i+d*e.log(i)-m),a=o/u,i-=u=a/(1-.5*e.min(1,a*((n-1)/i-1))),i>0||(i=.5*(i+u)),e.abs(u)<1e-8*i)break}return i},r.erf=function(r){var t,n,i,o,u=[-1.3026537197817094,.6419697923564902,.019476473204185836,-.00956151478680863,-.000946595344482036,.000366839497852761,42523324806907e-18,-20278578112534e-18,-1624290004647e-18,130365583558e-17,1.5626441722e-8,-8.5238095915e-8,6.529054439e-9,5.059343495e-9,-9.91364156e-10,-2.27365122e-10,9.6467911e-11,2.394038e-12,-6.886027e-12,8.94487e-13,3.13092e-13,-1.12708e-13,3.81e-16,7.106e-15,-1.523e-15,-9.4e-17,1.21e-16,-2.8e-17],a=27,s=!1,l=0,f=0;for(0>r&&(r=-r,s=!0),t=2/(2+r),n=4*t-2;a>0;a--)i=l,l=n*l-f+u[a],f=i;return o=t*e.exp(-r*r+.5*(u[0]+n*l)-f),s?o-1:1-o},r.erfc=function(e){return 1-r.erf(e)},r.erfcinv=function(t){var n,i,o,u,a=0;if(t>=2)return-100;if(0>=t)return 100;for(u=1>t?t:2-t,o=e.sqrt(-2*e.log(u/2)),n=-.70711*((2.30753+.27061*o)/(1+o*(.99229+.04481*o))-o);2>a;a++)i=r.erfc(n)-u,n+=i/(1.1283791670955126*e.exp(-n*n)-n*i);return 1>t?n:-n},r.ibetainv=function(t,n,i){var o,u,a,s,l,f,c,d,m,p,h,b=n-1,v=i-1,g=0;if(0>=t)return 0;if(t>=1)return 1;for(1>n||1>i?(o=e.log(n/(n+i)),u=e.log(i/(n+i)),s=e.exp(n*o)/n,l=e.exp(i*u)/i,p=s+l,c=s/p>t?e.pow(n*p*t,1/n):1-e.pow(i*p*(1-t),1/i)):(a=.5>t?t:1-t,s=e.sqrt(-2*e.log(a)),c=(2.30753+.27061*s)/(1+s*(.99229+.04481*s))-s,.5>t&&(c=-c),d=(c*c-3)/6,m=2/(1/(2*n-1)+1/(2*i-1)),p=c*e.sqrt(d+m)/m-(1/(2*i-1)-1/(2*n-1))*(d+5/6-2/(3*m)),c=n/(n+i*e.exp(2*p))),h=-r.gammaln(n)-r.gammaln(i)+r.gammaln(n+i);10>g;g++){if(0===c||1===c)return c;if(f=r.ibeta(c,n,i)-t,s=e.exp(b*e.log(c)+v*e.log(1-c)+h),l=f/s,c-=s=l/(1-.5*e.min(1,l*(b/c-v/(1-c)))),c>0||(c=.5*(c+s)),1>c||(c=.5*(c+s+1)),e.abs(s)<1e-8*c&&g>0)break}return c},r.ibeta=function(t,n,i){var o=0===t||1===t?0:e.exp(r.gammaln(n+i)-r.gammaln(n)-r.gammaln(i)+n*e.log(t)+i*e.log(1-t));return t>=0&&1>=t&&((n+1)/(n+i+2)>t?o*r.betacf(t,n,i)/n:1-o*r.betacf(1-t,i,n)/i)},r.randn=function(t,n){var i,o,u,a,s;if(n||(n=t),t)return r.create(t,n,function(){return r.randn()});do{i=e.random(),o=1.7156*(e.random()-.5),u=i-.449871,a=e.abs(o)+.386595,s=u*u+a*(.196*a-.25472*u)}while(s>.27597&&(s>.27846||o*o>-4*e.log(i)*i*i));return o/i},r.randg=function(t,n,i){var o,u,a,s,l,f,c=t;if(i||(i=n),t||(t=1),n)return f=r.zeros(n,i),f.alter(function(){return r.randg(t)}),f;1>t&&(t+=1),o=t-1/3,u=1/e.sqrt(9*o);do{do{l=r.randn(),s=1+u*l}while(0>=s);s*=s*s,a=e.random()}while(a>1-.331*e.pow(l,4)&&e.log(a)>.5*l*l+o*(1-s+e.log(s)));if(t==c)return o*s;do{a=e.random()}while(0===a);return e.pow(a,1/c)*o*s},function(e){for(var t=0;e.length>t;t++)!function(e){r.fn[e]=function(){return r(r.map(this,function(t){return r[e](t)}))}}(e[t])}("gammaln gammafn factorial factorialln".split(" ")),function(e){for(var t=0;e.length>t;t++)!function(e){r.fn[e]=function(){return r(r[e].apply(null,arguments))}}(e[t])}("randn".split(" "))}(e,Math),function(r,e){function t(r){return r/e.abs(r)}function n(t,n,i){var o=[.9815606342467192,.9041172563704749,.7699026741943047,.5873179542866175,.3678314989981802,.1252334085114689],u=[.04717533638651183,.10693932599531843,.16007832854334622,.20316742672306592,.2334925365383548,.24914704581340277],a=.5*t;if(a>=8)return 1;var s=2*r.normal.cdf(a,0,1,1,0)-1;s=s3?2:3;for(var f=a,c=(8-a)/l,d=f+c,m=0,p=i-1,h=1;l>=h;h++){for(var b=0,v=.5*(d+f),g=.5*(d-f),E=1;12>=E;E++){var N,y;E>6?(N=12-E+1,y=o[N-1]):(N=E,y=-o[N-1]);var w=g*y,I=v+w,M=I*I;if(M>60)break;var x=2*r.normal.cdf(I,0,1,1,0),A=2*r.normal.cdf(I,t,1,1,0),R=.5*x-.5*A;Re.exp(-30/n)?(s=e.pow(s,n),1>s?s:1):0}function i(r,t,n){var i=.5-.5*r,o=e.sqrt(e.log(1/(i*i))),u=o+((((-453642210148e-16*o-.204231210125)*o-.342242088547)*o-1)*o+.322232421088)/((((.0038560700634*o+.10353775285)*o+.531103462366)*o+.588581570495)*o+.099348462606);120>n&&(u+=(u*u*u+u)/n/4);var a=.8832-.2368*u;return 120>n&&(a+=-1.214/n+1.208*u/n),u*(a*e.log(t-1)+1.4142)}!function(e){for(var t=0;e.length>t;t++)!function(e){r[e]=function(r,e,t){return this instanceof arguments.callee?(this._a=r,this._b=e,this._c=t,this):new arguments.callee(r,e,t)},r.fn[e]=function(t,n,i){var o=r[e](t,n,i);return o.data=this,o},r[e].prototype.sample=function(t){var n=this._a,i=this._b,o=this._c;return t?r.alter(t,function(){return r[e].sample(n,i,o)}):r[e].sample(n,i,o)},function(t){for(var n=0;t.length>n;n++)!function(t){r[e].prototype[t]=function(n){var i=this._a,o=this._b,u=this._c;return n||0===n||(n=this.data),"number"!=typeof n?r.fn.map.call(n,function(n){return r[e][t](n,i,o,u)}):r[e][t](n,i,o,u)}}(t[n])}("pdf cdf inv".split(" ")),function(t){for(var n=0;t.length>n;n++)!function(t){r[e].prototype[t]=function(){return r[e][t](this._a,this._b,this._c)}}(t[n])}("mean median mode variance".split(" "))}(e[t])}("beta centralF cauchy chisquare exponential gamma invgamma kumaraswamy laplace lognormal noncentralt normal pareto studentt weibull uniform binomial negbin hypgeom poisson triangular tukey arcsine".split(" ")),r.extend(r.beta,{pdf:function(t,n,i){return t>1||0>t?0:1==n&&1==i?1:512>n&&512>i?e.pow(t,n-1)*e.pow(1-t,i-1)/r.betafn(n,i):e.exp((n-1)*e.log(t)+(i-1)*e.log(1-t)-r.betaln(n,i))},cdf:function(e,t,n){return e>1||0>e?1*(e>1):r.ibeta(e,t,n)},inv:function(e,t,n){return r.ibetainv(e,t,n)},mean:function(r,e){return r/(r+e)},median:function(e,t){return r.ibetainv(.5,e,t)},mode:function(r,e){return(r-1)/(r+e-2)},sample:function(e,t){var n=r.randg(e);return n/(n+r.randg(t))},variance:function(r,t){return r*t/(e.pow(r+t,2)*(r+t+1))}}),r.extend(r.centralF,{pdf:function(t,n,i){var o,u;return 0>t?0:n>2?(o=n*t/(i+t*n),u=i/(i+t*n),n*u/2*r.binomial.pdf((n-2)/2,(n+i-2)/2,o)):0===t&&2>n?Infinity:0===t&&2===n?1:1/r.betafn(n/2,i/2)*e.pow(n/i,n/2)*e.pow(t,n/2-1)*e.pow(1+n/i*t,-(n+i)/2)},cdf:function(e,t,n){return 0>e?0:r.ibeta(t*e/(t*e+n),t/2,n/2)},inv:function(e,t,n){return n/(t*(1/r.ibetainv(e,t/2,n/2)-1))},mean:function(r,e){return e>2?e/(e-2):undefined},mode:function(r,e){return r>2?e*(r-2)/(r*(e+2)):undefined},sample:function(e,t){return 2*r.randg(e/2)/e/(2*r.randg(t/2)/t)},variance:function(r,e){return e>4?2*e*e*(r+e-2)/(r*(e-2)*(e-2)*(e-4)):undefined}}),r.extend(r.cauchy,{pdf:function(r,t,n){return 0>n?0:n/(e.pow(r-t,2)+e.pow(n,2))/e.PI},cdf:function(r,t,n){return e.atan((r-t)/n)/e.PI+.5},inv:function(r,t,n){return t+n*e.tan(e.PI*(r-.5))},median:function(r,e){return r},mode:function(r,e){return r},sample:function(t,n){return r.randn()*e.sqrt(1/(2*r.randg(.5)))*n+t}}),r.extend(r.chisquare,{pdf:function(t,n){return 0>t?0:0===t&&2===n?.5:e.exp((n/2-1)*e.log(t)-t/2-n/2*e.log(2)-r.gammaln(n/2))},cdf:function(e,t){return 0>e?0:r.lowRegGamma(t/2,e/2)},inv:function(e,t){return 2*r.gammapinv(e,.5*t)},mean:function(r){return r},median:function(r){return r*e.pow(1-2/(9*r),3)},mode:function(r){return r-2>0?r-2:0},sample:function(e){return 2*r.randg(e/2)},variance:function(r){return 2*r}}),r.extend(r.exponential,{pdf:function(r,t){return 0>r?0:t*e.exp(-t*r)},cdf:function(r,t){return 0>r?0:1-e.exp(-t*r)},inv:function(r,t){return-e.log(1-r)/t},mean:function(r){return 1/r},median:function(r){return 1/r*e.log(2)},mode:function(r){return 0},sample:function(r){return-1/r*e.log(e.random())},variance:function(r){return e.pow(r,-2)}}),r.extend(r.gamma,{pdf:function(t,n,i){return 0>t?0:0===t&&1===n?1/i:e.exp((n-1)*e.log(t)-t/i-r.gammaln(n)-n*e.log(i))},cdf:function(e,t,n){return 0>e?0:r.lowRegGamma(t,e/n)},inv:function(e,t,n){return r.gammapinv(e,t)*n},mean:function(r,e){return r*e},mode:function(r,e){return r>1?(r-1)*e:undefined},sample:function(e,t){return r.randg(e)*t},variance:function(r,e){return r*e*e}}),r.extend(r.invgamma,{pdf:function(t,n,i){return t>0?e.exp(-(n+1)*e.log(t)-i/t-r.gammaln(n)+n*e.log(i)):0},cdf:function(e,t,n){return e>0?1-r.lowRegGamma(t,n/e):0},inv:function(e,t,n){return n/r.gammapinv(1-e,t)},mean:function(r,e){return r>1?e/(r-1):undefined},mode:function(r,e){return e/(r+1)},sample:function(e,t){return t/r.randg(e)},variance:function(r,e){return r>2?e*e/((r-1)*(r-1)*(r-2)):undefined}}),r.extend(r.kumaraswamy,{pdf:function(r,t,n){return 0===r&&1===t?n:1===r&&1===n?t:e.exp(e.log(t)+e.log(n)+(t-1)*e.log(r)+(n-1)*e.log(1-e.pow(r,t)))},cdf:function(r,t,n){return 0>r?0:r>1?1:1-e.pow(1-e.pow(r,t),n)},inv:function(r,t,n){return e.pow(1-e.pow(1-r,1/n),1/t)},mean:function(e,t){return t*r.gammafn(1+1/e)*r.gammafn(t)/r.gammafn(1+1/e+t)},median:function(r,t){return e.pow(1-e.pow(2,-1/t),1/r)},mode:function(r,t){return 1>r||1>t||1===r||1===t?undefined:e.pow((r-1)/(r*t-1),1/r)},variance:function(r,e){throw Error("variance not yet implemented")}}),r.extend(r.lognormal,{pdf:function(r,t,n){return r>0?e.exp(-e.log(r)-.5*e.log(2*e.PI)-e.log(n)-e.pow(e.log(r)-t,2)/(2*n*n)):0},cdf:function(t,n,i){return 0>t?0:.5+.5*r.erf((e.log(t)-n)/e.sqrt(2*i*i))},inv:function(t,n,i){return e.exp(-1.4142135623730951*i*r.erfcinv(2*t)+n)},mean:function(r,t){return e.exp(r+t*t/2)},median:function(r,t){return e.exp(r)},mode:function(r,t){return e.exp(r-t*t)},sample:function(t,n){return e.exp(r.randn()*n+t)},variance:function(r,t){return(e.exp(t*t)-1)*e.exp(2*r+t*t)}}),r.extend(r.noncentralt,{pdf:function(t,n,i){return 1e-14>e.abs(i)?r.studentt.pdf(t,n):1e-14>e.abs(t)?e.exp(r.gammaln((n+1)/2)-i*i/2-.5*e.log(e.PI*n)-r.gammaln(n/2)):n/t*(r.noncentralt.cdf(t*e.sqrt(1+2/n),n+2,i)-r.noncentralt.cdf(t,n,i))},cdf:function(t,n,i){if(1e-14>e.abs(i))return r.studentt.cdf(t,n);var o=!1;0>t&&(o=!0,i=-i);for(var u=r.normal.cdf(-i,0,1),a=1e-14+1,s=a,l=t*t/(t*t+n),f=0,c=e.exp(-i*i/2),d=e.exp(-i*i/2-.5*e.log(2)-r.gammaln(1.5))*i;200>f||s>1e-14||a>1e-14;)s=a,f>0&&(c*=i*i/(2*f),d*=i*i/(2*(f+.5))),a=c*r.beta.cdf(l,f+.5,n/2)+d*r.beta.cdf(l,f+1,n/2),u+=.5*a,f++;return o?1-u:u}}),r.extend(r.normal,{pdf:function(r,t,n){return e.exp(-.5*e.log(2*e.PI)-e.log(n)-e.pow(r-t,2)/(2*n*n))},cdf:function(t,n,i){return.5*(1+r.erf((t-n)/e.sqrt(2*i*i)))},inv:function(e,t,n){return-1.4142135623730951*n*r.erfcinv(2*e)+t},mean:function(r,e){return r},median:function(r,e){return r},mode:function(r,e){return r},sample:function(e,t){return r.randn()*t+e},variance:function(r,e){return e*e}}),r.extend(r.pareto,{pdf:function(r,t,n){return t>r?0:n*e.pow(t,n)/e.pow(r,n+1)},cdf:function(r,t,n){return t>r?0:1-e.pow(t/r,n)},inv:function(r,t,n){return t/e.pow(1-r,1/n)},mean:function(r,t){return t>1?t*e.pow(r,t)/(t-1):undefined},median:function(r,t){return r*(t*e.SQRT2)},mode:function(r,e){return r},variance:function(r,t){return t>2?r*r*t/(e.pow(t-1,2)*(t-2)):undefined}}),r.extend(r.studentt,{pdf:function(t,n){return n=n>1e100?1e100:n,1/(e.sqrt(n)*r.betafn(.5,n/2))*e.pow(1+t*t/n,-(n+1)/2)},cdf:function(t,n){var i=n/2;return r.ibeta((t+e.sqrt(t*t+n))/(2*e.sqrt(t*t+n)),i,i)},inv:function(t,n){var i=r.ibetainv(2*e.min(t,1-t),.5*n,.5);return i=e.sqrt(n*(1-i)/i),t>.5?i:-i},mean:function(r){return r>1?0:undefined},median:function(r){return 0},mode:function(r){return 0},sample:function(t){return r.randn()*e.sqrt(t/(2*r.randg(t/2)))},variance:function(r){return r>2?r/(r-2):r>1?Infinity:undefined}}),r.extend(r.weibull,{pdf:function(r,t,n){return 0>r||0>t||0>n?0:n/t*e.pow(r/t,n-1)*e.exp(-e.pow(r/t,n))},cdf:function(r,t,n){return 0>r?0:1-e.exp(-e.pow(r/t,n))},inv:function(r,t,n){return t*e.pow(-e.log(1-r),1/n)},mean:function(e,t){return e*r.gammafn(1+1/t)},median:function(r,t){return r*e.pow(e.log(2),1/t)},mode:function(r,t){return t>1?r*e.pow((t-1)/t,1/t):0},sample:function(r,t){return r*e.pow(-e.log(e.random()),1/t)},variance:function(t,n){return t*t*r.gammafn(1+2/n)-e.pow(r.weibull.mean(t,n),2)}}),r.extend(r.uniform,{pdf:function(r,e,t){return e>r||r>t?0:1/(t-e)},cdf:function(r,e,t){return e>r?0:t>r?(r-e)/(t-e):1},inv:function(r,e,t){return e+r*(t-e)},mean:function(r,e){return.5*(r+e)},median:function(e,t){return r.mean(e,t)},mode:function(r,e){throw Error("mode is not yet implemented")},sample:function(r,t){return r/2+t/2+(t/2-r/2)*(2*e.random()-1)},variance:function(r,t){return e.pow(t-r,2)/12}}),r.extend(r.binomial,{pdf:function(t,n,i){return 0===i||1===i?n*i===t?1:0:r.combination(n,t)*e.pow(i,t)*e.pow(1-i,n-t)},cdf:function(e,t,n){var i=[],o=0;if(0>e)return 0;if(t>e){for(;e>=o;o++)i[o]=r.binomial.pdf(o,t,n);return r.sum(i)}return 1}}),r.extend(r.negbin,{pdf:function(t,n,i){return t===t>>>0&&(0>t?0:r.combination(t+n-1,n-1)*e.pow(1-i,t)*e.pow(i,n))},cdf:function(e,t,n){var i=0,o=0;if(0>e)return 0;for(;e>=o;o++)i+=r.negbin.pdf(o,t,n);return i}}),r.extend(r.hypgeom,{pdf:function(t,n,i,o){if(t!==t|0)return!1;if(0>t||i-(n-o)>t)return 0;if(t>o||t>i)return 0;if(2*i>n)return 2*o>n?r.hypgeom.pdf(n-i-o+t,n,n-i,n-o):r.hypgeom.pdf(o-t,n,n-i,o);if(2*o>n)return r.hypgeom.pdf(i-t,n,i,n-o);if(o>i)return r.hypgeom.pdf(t,n,o,i);for(var u=1,a=0,s=0;t>s;s++){for(;u>1&&o>a;)u*=1-i/(n-a),a++;u*=(o-s)*(i-s)/((s+1)*(n-i-o+s+1))}for(;o>a;a++)u*=1-i/(n-a);return e.min(1,e.max(0,u))},cdf:function(t,n,i,o){if(0>t||i-(n-o)>t)return 0;if(o>t&&i>t){if(2*i>n)return 2*o>n?r.hypgeom.cdf(n-i-o+t,n,n-i,n-o):1-r.hypgeom.cdf(o-t-1,n,n-i,o);if(2*o>n)return 1-r.hypgeom.cdf(i-t-1,n,i,n-o);if(o>i)return r.hypgeom.cdf(t,n,o,i);for(var u=1,a=1,s=0,l=0;t>l;l++){for(;u>1&&o>s;){var f=1-i/(n-s);a*=f,u*=f,s++}a*=(o-l)*(i-l)/((l+1)*(n-i-o+l+1)),u+=a}for(;o>s;s++)u*=1-i/(n-s);return e.min(1,e.max(0,u))}return 1}}),r.extend(r.poisson,{pdf:function(t,n){return 0>n||t%1!=0||0>t?0:e.pow(n,t)*e.exp(-n)/r.factorial(t)},cdf:function(e,t){var n=[],i=0;if(0>e)return 0;for(;e>=i;i++)n.push(r.poisson.pdf(i,t));return r.sum(n)},mean:function(r){return r},variance:function(r){return r},sample:function(r){var t=1,n=0,i=e.exp(-r);do{n++,t*=e.random()}while(t>i);return n-1}}),r.extend(r.triangular,{pdf:function(r,e,t,n){return e>=t||e>n||n>t?NaN:e>r||r>t?0:n>r?2*(r-e)/((t-e)*(n-e)):r===n?2/(t-e):2*(t-r)/((t-e)*(t-n))},cdf:function(r,t,n,i){return t>=n||t>i||i>n?NaN:r>t?n>r?r>i?1-e.pow(n-r,2)/((n-t)*(n-i)):e.pow(r-t,2)/((n-t)*(i-t)):1:0},inv:function(r,t,n,i){return t>=n||t>i||i>n?NaN:r>(i-t)/(n-t)?t+(n-t)*(1-e.sqrt((1-r)*(1-(i-t)/(n-t)))):t+(n-t)*e.sqrt(r*((i-t)/(n-t)))},mean:function(r,e,t){return(r+e+t)/3},median:function(r,t,n){return n>(r+t)/2?n>(r+t)/2?r+e.sqrt((t-r)*(n-r))/e.sqrt(2):void 0:t-e.sqrt((t-r)*(t-n))/e.sqrt(2)},mode:function(r,e,t){return t},sample:function(r,t,n){var i=e.random();return(n-r)/(t-r)>i?r+e.sqrt(i*(t-r)*(n-r)):t-e.sqrt((1-i)*(t-r)*(t-n))},variance:function(r,e,t){return(r*r+e*e+t*t-r*e-r*t-e*t)/18}}),r.extend(r.arcsine,{pdf:function(r,t,n){return n>t?r>t&&n>r?2/e.PI*e.pow(e.pow(n-t,2)-e.pow(2*r-t-n,2),-.5):0:NaN},cdf:function(r,t,n){return t>r?0:n>r?2/e.PI*e.asin(e.sqrt((r-t)/(n-t))):1},inv:function(r,t,n){return t+(.5-.5*e.cos(e.PI*r))*(n-t)},mean:function(r,e){return e>r?(r+e)/2:NaN},median:function(r,e){return e>r?(r+e)/2:NaN},mode:function(r,e){throw Error("mode is not yet implemented")},sample:function(t,n){return(t+n)/2+(n-t)/2*e.sin(2*e.PI*r.uniform.sample(0,1))},variance:function(r,t){return t>r?e.pow(t-r,2)/8:NaN}}),r.extend(r.laplace,{pdf:function(r,t,n){return n>0?e.exp(-e.abs(r-t)/n)/(2*n):0},cdf:function(r,t,n){return n>0?t>r?.5*e.exp((r-t)/n):1-.5*e.exp(-(r-t)/n):0},mean:function(r,e){return r},median:function(r,e){return r},mode:function(r,e){return r},variance:function(r,e){return 2*e*e},sample:function(r,n){var i=e.random()-.5;return r-n*t(i)*e.log(1-2*e.abs(i))}}),r.extend(r.tukey,{cdf:function(t,i,o){var u=i,a=[.9894009349916499,.9445750230732326,.8656312023878318,.755404408355003,.6178762444026438,.45801677765722737,.2816035507792589,.09501250983763744],s=[.027152459411754096,.062253523938647894,.09515851168249279,.12462897125553388,.14959598881657674,.16915651939500254,.18260341504492358,.1894506104550685];if(0>=t)return 0;if(2>o||2>u)return NaN;if(!Number.isFinite(t))return 1;if(o>25e3)return n(t,1,u);var l,f=.5*o,c=f*e.log(o)-o*e.log(2)-r.gammaln(f),d=f-1,m=.25*o;l=o>100?o>800?o>5e3?.125:.25:.5:1,c+=e.log(l);for(var p=0,h=1;50>=h;h++){for(var b=0,v=(2*h-1)*l,g=1;16>=g;g++){var E,N;g>8?(E=g-8-1,N=c+d*e.log(v+a[E]*l)-(a[E]*l+v)*m):(E=g-1,N=c+d*e.log(v-a[E]*l)+(a[E]*l-v)*m);var y;if(N>=-30){y=g>8?t*e.sqrt(.5*(a[E]*l+v)):t*e.sqrt(.5*(-a[E]*l+v));b+=n(y,1,u)*s[E]*e.exp(N)}}if(h*l>=1&&1e-14>=b)break;p+=b}if(b>1e-14)throw Error("tukey.cdf failed to converge");return p>1&&(p=1),p},inv:function(t,n,o){var u=n;if(2>o||2>u)return NaN;if(0>t||t>1)return NaN;if(0===t)return 0;if(1===t)return Infinity;var a,s=i(t,u,o),l=r.tukey.cdf(s,n,o)-t;a=l>0?e.max(0,s-1):s+1;for(var f,c=r.tukey.cdf(a,n,o)-t,d=1;50>d;d++){f=a-c*(a-s)/(c-l),l=c,s=a,0>f&&(f=0,c=-t),c=r.tukey.cdf(f,n,o)-t,a=f;if(1e-4>e.abs(a-s))return f}throw Error("tukey.inv failed to converge")}})}(e,Math),function(e,t){function n(r){return u(r)||r instanceof e}var o=Array.prototype.push,u=e.utils.isArray;e.extend({add:function(r,t){return n(t)?(n(t[0])||(t=[t]),e.map(r,function(r,e,n){return r+t[e][n]})):e.map(r,function(r){return r+t})},subtract:function(r,t){return n(t)?(n(t[0])||(t=[t]),e.map(r,function(r,e,n){return r-t[e][n]||0})):e.map(r,function(r){return r-t})},divide:function(r,t){return n(t)?(n(t[0])||(t=[t]),e.multiply(r,e.inv(t))):e.map(r,function(r){return r/t})},multiply:function(r,t){var i,o,u,a,s,l,f,c;if(r.length===undefined&&t.length===undefined)return r*t;if(s=r.length,l=r[0].length,f=e.zeros(s,u=n(t)?t[0].length:l),c=0,n(t)){for(;u>c;c++)for(i=0;s>i;i++){for(a=0,o=0;l>o;o++)a+=r[i][o]*t[o][c];f[i][c]=a}return 1===s&&1===c?f[0][0]:f}return e.map(r,function(r){return r*t})},outer:function(r,t){return e.multiply(r.map(function(r){return[r]}),[t])},outer:function(r,t){return e.multiply(r.map(function(r){return[r]}),[t])},dot:function(r,t){n(r[0])||(r=[r]),n(t[0])||(t=[t]);for(var i,o,u=1===r[0].length&&1!==r.length?e.transpose(r):r,a=1===t[0].length&&1!==t.length?e.transpose(t):t,s=[],l=0,f=u.length,c=u[0].length;f>l;l++){for(s[l]=[],i=0,o=0;c>o;o++)i+=u[l][o]*a[l][o];s[l]=i}return 1===s.length?s[0]:s},pow:function(r,n){return e.map(r,function(r){return t.pow(r,n)})},exp:function(r){return e.map(r,function(r){return t.exp(r)})},log:function(r){return e.map(r,function(r){return t.log(r)})},abs:function(r){return e.map(r,function(r){return t.abs(r)})},norm:function(r,e){var i=0,o=0;for(isNaN(e)&&(e=2),n(r[0])&&(r=r[0]);r.length>o;o++)i+=t.pow(t.abs(r[o]),e);return t.pow(i,1/e)},angle:function(r,n){return t.acos(e.dot(r,n)/(e.norm(r)*e.norm(n)))},aug:function(r,e){for(var t=[],n=0;r.length>n;n++)t.push(r[n].slice());for(var n=0;t.length>n;n++)o.apply(t[n],e[n]);return t},inv:function(r){for(var t,n=r.length,i=r[0].length,o=e.identity(n,i),u=e.gauss_jordan(r,o),a=[],s=0;n>s;s++)for(a[s]=[],t=i;u[0].length>t;t++)a[s][t-i]=u[s][t];return a},det:function(r){var e,t=r.length,n=2*t,i=Array(n),o=t-1,u=n-1,a=o-t+1,s=u,l=0,f=0;if(2===t)return r[0][0]*r[1][1]-r[0][1]*r[1][0];for(;n>l;l++)i[l]=1;for(var l=0;t>l;l++){for(e=0;t>e;e++)i[0>a?a+t:a]*=r[l][e],i[t>s?s+t:s]*=r[l][e],a++,s--;a=--o-t+1,s=--u}for(var l=0;t>l;l++)f+=i[l];for(;n>l;l++)f-=i[l];return f},gauss_elimination:function(r,n){var i,o,u,a,s=0,l=0,f=r.length,c=r[0].length,d=1,m=0,p=[];r=e.aug(r,n),i=r[0].length;for(var s=0;f>s;s++){for(o=r[s][s],l=s,a=s+1;c>a;a++)oa;a++)u=r[s][a],r[s][a]=r[l][a],r[l][a]=u;for(l=s+1;f>l;l++)for(d=r[l][s]/r[s][s],a=s;i>a;a++)r[l][a]=r[l][a]-d*r[s][a]}for(var s=f-1;s>=0;s--){for(m=0,l=s+1;f-1>=l;l++)m+=p[l]*r[s][l];p[s]=(r[s][i-1]-m)/r[s][s]}return p},gauss_jordan:function(r,n){for(var i=e.aug(r,n),o=i.length,u=i[0].length,a=0,s=0;o>s;s++){for(var l=s,f=s+1;o>f;f++)t.abs(i[f][s])>t.abs(i[l][s])&&(l=f);var c=i[s];i[s]=i[l],i[l]=c;for(var f=s+1;o>f;f++){a=i[f][s]/i[s][s];for(var d=s;u>d;d++)i[f][d]-=i[s][d]*a}}for(var s=o-1;s>=0;s--){a=i[s][s];for(var f=0;s>f;f++)for(var d=u-1;d>s-1;d--)i[f][d]-=i[s][d]*i[f][s]/a;i[s][s]/=a;for(var d=o;u>d;d++)i[s][d]/=a}return i},triaUpSolve:function(r,t){var n,i=r[0].length,o=e.zeros(1,i)[0],u=!1;return t[0].length!=undefined&&(t=t.map(function(r){return r[0]}),u=!0),e.arange(i-1,-1,-1).forEach(function(u){n=e.arange(u+1,i).map(function(e){return o[e]*r[u][e]}),o[u]=(t[u]-e.sum(n))/r[u][u]}),u?o.map(function(r){return[r]}):o},triaLowSolve:function(r,t){var n,i=r[0].length,o=e.zeros(1,i)[0],u=!1;return t[0].length!=undefined&&(t=t.map(function(r){return r[0]}),u=!0),e.arange(i).forEach(function(i){n=e.arange(i).map(function(e){return r[i][e]*o[e]}),o[i]=(t[i]-e.sum(n))/r[i][i]}),u?o.map(function(r){return[r]}):o},lu:function(r){var t,n=r.length,o=e.identity(n),u=e.zeros(r.length,r[0].length);return e.arange(n).forEach(function(e){u[0][e]=r[0][e]}),e.arange(1,n).forEach(function(a){e.arange(a).forEach(function(n){t=e.arange(n).map(function(r){return o[a][r]*u[r][n]}),o[a][n]=(r[a][n]-e.sum(t))/u[n][n]}),e.arange(a,n).forEach(function(n){t=e.arange(a).map(function(r){return o[a][r]*u[r][n]}),u[a][n]=r[i][n]-e.sum(t)})}),[o,u]},cholesky:function(r){var n,i=r.length,o=e.zeros(r.length,r[0].length);return e.arange(i).forEach(function(u){n=e.arange(u).map(function(r){return t.pow(o[u][r],2)}),o[u][u]=t.sqrt(r[u][u]-e.sum(n)),e.arange(u+1,i).forEach(function(t){n=e.arange(u).map(function(r){return o[u][r]*o[t][r]}),o[t][u]=(r[u][t]-e.sum(n))/o[u][u]})}),o},gauss_jacobi:function(r,n,i,o){for(var u,a,s,l,f=0,c=0,d=r.length,m=[],p=[],h=[];d>f;f++)for(m[f]=[],p[f]=[],h[f]=[],c=0;d>c;c++)f>c?(m[f][c]=r[f][c],p[f][c]=h[f][c]=0):c>f?(p[f][c]=r[f][c],m[f][c]=h[f][c]=0):(h[f][c]=r[f][c],m[f][c]=p[f][c]=0);for(s=e.multiply(e.multiply(e.inv(h),e.add(m,p)),-1),a=e.multiply(e.inv(h),n),u=i,l=e.add(e.multiply(s,i),a),f=2;t.abs(e.norm(e.subtract(l,u)))>o;)u=l,l=e.add(e.multiply(s,u),a),f++;return l},gauss_seidel:function(r,n,i,o){for(var u,a,s,l,f,c=0,d=r.length,m=[],p=[],h=[];d>c;c++)for(m[c]=[],p[c]=[],h[c]=[],u=0;d>u;u++)c>u?(m[c][u]=r[c][u],p[c][u]=h[c][u]=0):u>c?(p[c][u]=r[c][u],m[c][u]=h[c][u]=0):(h[c][u]=r[c][u],m[c][u]=p[c][u]=0);for(l=e.multiply(e.multiply(e.inv(e.add(h,m)),p),-1),s=e.multiply(e.inv(e.add(h,m)),n),a=i,f=e.add(e.multiply(l,i),s),c=2;t.abs(e.norm(e.subtract(f,a)))>o;)a=f,f=e.add(e.multiply(l,a),s),c+=1;return f},SOR:function(r,n,i,o,u){for(var a,s,l,f,c,d=0,m=r.length,p=[],h=[],b=[];m>d;d++)for(p[d]=[],h[d]=[],b[d]=[],a=0;m>a;a++)d>a?(p[d][a]=r[d][a],h[d][a]=b[d][a]=0):a>d?(h[d][a]=r[d][a],p[d][a]=b[d][a]=0):(b[d][a]=r[d][a],p[d][a]=h[d][a]=0);for(f=e.multiply(e.inv(e.add(b,e.multiply(p,u))),e.subtract(e.multiply(b,1-u),e.multiply(h,u))),l=e.multiply(e.multiply(e.inv(e.add(b,e.multiply(p,u))),n),u),s=i,c=e.add(e.multiply(f,i),l),d=2;t.abs(e.norm(e.subtract(c,s)))>o;)s=c,c=e.add(e.multiply(f,s),l),d++;return c},householder:function(r){for(var n,i,o,u,a,s=r.length,l=r[0].length,f=0,c=[],d=[];s-1>f;f++){for(n=0,u=f+1;l>u;u++)n+=r[u][f]*r[u][f];for(a=r[f+1][f]>0?-1:1,n=a*t.sqrt(n),i=t.sqrt((n*n-r[f+1][f]*n)/2),c=e.zeros(s,1),c[f+1][0]=(r[f+1][f]-n)/(2*i),o=f+2;s>o;o++)c[o][0]=r[o][f]/(2*i);d=e.subtract(e.identity(s,l),e.multiply(e.multiply(c,e.transpose(c)),2)),r=e.multiply(d,e.multiply(r,d))}return r},QR:function(){function n(n){var u=n.length,a=n[0].length;n=e.copy(n),r=e.zeros(a,a);var s,l,f;for(l=0;a>l;l++){for(r[l][l]=t.sqrt(i(o(u).map(function(r){return n[r][l]*n[r][l]}))),s=0;u>s;s++)n[s][l]=n[s][l]/r[l][l];for(f=l+1;a>f;f++)for(r[l][f]=i(o(u).map(function(r){return n[r][l]*n[r][f]})),s=0;u>s;s++)n[s][f]=n[s][f]-n[s][l]*r[l][f]}return[n,r]}var i=e.sum,o=e.arange;return n}(),lstsq:function(r,t){function n(r){r=e.copy(r);var t=r.length,n=e.identity(t);return e.arange(t-1,-1,-1).forEach(function(t){e.sliceAssign(n,{row:t},e.divide(e.slice(n,{row:t}),r[t][t])),e.sliceAssign(r,{row:t},e.divide(e.slice(r,{row:t}),r[t][t])),e.arange(t).forEach(function(i){var o=e.multiply(r[i][t],-1),u=e.slice(r,{row:i}),a=e.multiply(e.slice(r,{row:t}),o);e.sliceAssign(r,{row:i},e.add(u,a));var s=e.slice(n,{row:i}),l=e.multiply(e.slice(n,{row:t}),o);e.sliceAssign(n,{row:i},e.add(s,l))})}),n}function i(r,t){var i=!1;t[0].length===undefined&&(t=t.map(function(r){return[r]}),i=!0);var o=e.QR(r),u=o[0],a=o[1],s=r[0].length,l=e.slice(u,{col:{end:s}}),f=e.slice(a,{row:{end:s}}),c=n(f),d=e.transpose(l);d[0].length===undefined&&(d=[d]);var m=e.multiply(e.multiply(c,d),t);return m.length===undefined&&(m=[[m]]),i?m.map(function(r){return r[0]}):m}return i}(),jacobi:function(r){for(var n,i,o,u,a,s,l,f,c=1,d=0,m=r.length,p=e.identity(m,m),h=[];1===c;){d++,s=r[0][1],u=0,a=1;for(var i=0;m>i;i++)for(o=0;m>o;o++)i!=o&&s0?t.PI/4:-t.PI/4:t.atan(2*r[u][a]/(r[u][u]-r[a][a]))/2,f=e.identity(m,m),f[u][u]=t.cos(l),f[u][a]=-t.sin(l),f[a][u]=t.sin(l),f[a][a]=t.cos(l),p=e.multiply(p,f),n=e.multiply(e.multiply(e.inv(f),r),f),r=n,c=0;for(var i=1;m>i;i++)for(o=1;m>o;o++)i!=o&&t.abs(r[i][o])>.001&&(c=1)}for(var i=0;m>i;i++)h.push(r[i][i]);return[p,h]},rungekutta:function(r,e,t,n,i,o){var u,a,s,l,f;if(2===o)for(;t>=n;)u=e*r(n,i),a=e*r(n+e,i+u),s=i+(u+a)/2,i=s,n+=e;if(4===o)for(;t>=n;)u=e*r(n,i),a=e*r(n+e/2,i+u/2),l=e*r(n+e/2,i+a/2),f=e*r(n+e,i+l),s=i+(u+2*a+2*l+f)/6,i=s,n+=e;return i},romberg:function(r,e,n,i){for(var o,u,a,s,l,f=0,c=(n-e)/2,d=[],m=[],p=[];i/2>f;){for(l=r(e),a=e,s=0;n>=a;a+=c,s++)d[s]=a;for(o=d.length,a=1;o-1>a;a++)l+=(a%2!=0?4:2)*r(d[a]);l=c/3*(l+r(n)),p[f]=l,c/=2,f++}for(u=p.length,o=1;1!==u;){for(a=0;u-1>a;a++)m[a]=(t.pow(4,o)*p[a+1]-p[a])/(t.pow(4,o)-1);u=m.length,p=m,m=[],o++}return p},richardson:function(r,e,n,i){function o(r,e){for(var t,n=0,i=r.length;i>n;n++)r[n]===e&&(t=n);return t}for(var u,a,s,l,f,c=t.abs(n-r[o(r,n)+1]),d=0,m=[],p=[];i>=c;)u=o(r,n+i),a=o(r,n),m[d]=(e[u]-2*e[a]+e[2*a-u])/(i*i),i/=2,d++;for(l=m.length,s=1;1!=l;){for(f=0;l-1>f;f++)p[f]=(t.pow(4,s)*m[f+1]-m[f])/(t.pow(4,s)-1);l=p.length,m=p,p=[],s++}return m},simpson:function(r,e,t,n){for(var i,o=(t-e)/n,u=r(e),a=[],s=e,l=0,f=1;t>=s;s+=o,l++)a[l]=s;for(i=a.length;i-1>f;f++)u+=(f%2!=0?4:2)*r(a[f]);return o/3*(u+r(t))},hermite:function(r,e,t,n){for(var i,o=r.length,u=0,a=0,s=[],l=[],f=[],c=[];o>a;a++){for(s[a]=1,i=0;o>i;i++)a!=i&&(s[a]*=(n-r[i])/(r[a]-r[i]));for(l[a]=0,i=0;o>i;i++)a!=i&&(l[a]+=1/(r[a]-r[i]));f[a]=s[a]*s[a]*(1-2*(n-r[a])*l[a]),c[a]=s[a]*s[a]*(n-r[a]),u+=f[a]*e[a]+c[a]*t[a]}return u},lagrange:function(r,e,t){for(var n,i,o=0,u=0,a=r.length;a>u;u++){for(i=e[u],n=0;a>n;n++)u!=n&&(i*=(t-r[n])/(r[u]-r[n]));o+=i}return o},cubic_spline:function(r,t,n){for(var i,o=r.length,u=0,a=[],s=[],l=[],f=[],c=[],d=[],m=[];o-1>u;u++)c[u]=r[u+1]-r[u];l[0]=0;for(var u=1;o-1>u;u++)l[u]=3/c[u]*(t[u+1]-t[u])-3/c[u-1]*(t[u]-t[u-1]);for(var u=1;o-1>u;u++)a[u]=[],s[u]=[],a[u][u-1]=c[u-1],a[u][u]=2*(c[u-1]+c[u]),a[u][u+1]=c[u],s[u][0]=l[u];for(f=e.multiply(e.inv(a),s),i=0;o-1>i;i++)d[i]=(t[i+1]-t[i])/c[i]-c[i]*(f[i+1][0]+2*f[i][0])/3,m[i]=(f[i+1][0]-f[i][0])/(3*c[i]);for(i=0;o>i&&r[i]<=n;i++);return i-=1,t[i]+(n-r[i])*d[i]+e.sq(n-r[i])*f[i]+(n-r[i])*e.sq(n-r[i])*m[i]},gauss_quadrature:function(){throw Error("gauss_quadrature not yet implemented")},PCA:function(r){for(var t,n,i=r.length,o=r[0].length,u=0,a=[],s=[],l=[],f=[],c=[],d=[],m=[],p=[],h=[],b=[],u=0;i>u;u++)a[u]=e.sum(r[u])/o;for(var u=0;o>u;u++)for(m[u]=[],t=0;i>t;t++)m[u][t]=r[t][u]-a[t];m=e.transpose(m);for(var u=0;i>u;u++)for(p[u]=[],t=0;i>t;t++)p[u][t]=e.dot([m[u]],[m[t]])/(o-1);l=e.jacobi(p),h=l[0],s=l[1],b=e.transpose(h);for(var u=0;s.length>u;u++)for(t=u;s.length>t;t++)s[t]>s[u]&&(n=s[u],s[u]=s[t],s[t]=n,f=b[u],b[u]=b[t],b[t]=f);d=e.transpose(m);for(var u=0;i>u;u++)for(c[u]=[],t=0;d.length>t;t++)c[u][t]=e.dot([b[u]],[d[t]]);return[r,s,b,c]}}),function(r){for(var t=0;r.length>t;t++)!function(r){e.fn[r]=function(t,n){var i=this;return n?(setTimeout(function(){n.call(i,e.fn[r].call(i,t))},15),this):"number"==typeof e[r](this,t)?e[r](this,t):e(e[r](this,t))}}(r[t])}("add divide multiply subtract dot pow exp log abs norm angle".split(" "))}(e,Math),function(r,e){function t(r,t,n,i){if(r>1||n>1||0>=r||0>=n)throw Error("Proportions should be greater than 0 and less than 1");var o=(r*t+n*i)/(t+i);return(r-n)/e.sqrt(o*(1-o)*(1/t+1/i))}var n=[].slice,i=r.utils.isNumber,o=r.utils.isArray;r.extend({zscore:function(){var e=n.call(arguments);return i(e[1])?(e[0]-e[1])/e[2]:(e[0]-r.mean(e[1]))/r.stdev(e[1],e[2])},ztest:function(){var t,i=n.call(arguments);return o(i[1])?(t=r.zscore(i[0],i[1],i[3]),1===i[2]?r.normal.cdf(-e.abs(t),0,1):2*r.normal.cdf(-e.abs(t),0,1)):i.length>2?(t=r.zscore(i[0],i[1],i[2]),1===i[3]?r.normal.cdf(-e.abs(t),0,1):2*r.normal.cdf(-e.abs(t),0,1)):(t=i[0],1===i[1]?r.normal.cdf(-e.abs(t),0,1):2*r.normal.cdf(-e.abs(t),0,1))}}),r.extend(r.fn,{zscore:function(r,e){return(r-this.mean())/this.stdev(e)},ztest:function(t,n,i){var o=e.abs(this.zscore(t,i));return 1===n?r.normal.cdf(-o,0,1):2*r.normal.cdf(-o,0,1)}}),r.extend({tscore:function(){var t=n.call(arguments);return 4===t.length?(t[0]-t[1])/(t[2]/e.sqrt(t[3])):(t[0]-r.mean(t[1]))/(r.stdev(t[1],!0)/e.sqrt(t[1].length))},ttest:function(){var t,o=n.call(arguments);return 5===o.length?(t=e.abs(r.tscore(o[0],o[1],o[2],o[3])),1===o[4]?r.studentt.cdf(-t,o[3]-1):2*r.studentt.cdf(-t,o[3]-1)):i(o[1])?(t=e.abs(o[0]),1==o[2]?r.studentt.cdf(-t,o[1]-1):2*r.studentt.cdf(-t,o[1]-1)):(t=e.abs(r.tscore(o[0],o[1])),1==o[2]?r.studentt.cdf(-t,o[1].length-1):2*r.studentt.cdf(-t,o[1].length-1))}}),r.extend(r.fn,{tscore:function(r){return(r-this.mean())/(this.stdev(!0)/e.sqrt(this.cols()))},ttest:function(t,n){return 1===n?1-r.studentt.cdf(e.abs(this.tscore(t)),this.cols()-1):2*r.studentt.cdf(-e.abs(this.tscore(t)),this.cols()-1)}}),r.extend({anovafscore:function(){var t,i,o,u,a,s,l,f,c=n.call(arguments);if(1===c.length){a=Array(c[0].length);for(var l=0;c[0].length>l;l++)a[l]=c[0][l];c=a}if(2===c.length)return r.variance(c[0])/r.variance(c[1]);i=[];for(var l=0;c.length>l;l++)i=i.concat(c[l]);o=r.mean(i),t=0;for(var l=0;c.length>l;l++)t+=c[l].length*e.pow(r.mean(c[l])-o,2);t/=c.length-1,s=0;for(var l=0;c.length>l;l++)for(u=r.mean(c[l]),f=0;c[l].length>f;f++)s+=e.pow(c[l][f]-u,2);return s/=i.length-c.length,t/s},anovaftest:function(){var e,t,o,u,a=n.call(arguments);if(i(a[0]))return 1-r.centralF.cdf(a[0],a[1],a[2]);anovafscore=r.anovafscore(a),e=a.length-1,o=0;for(var u=0;a.length>u;u++)o+=a[u].length;return t=o-e-1,1-r.centralF.cdf(anovafscore,e,t)},ftest:function(e,t,n){return 1-r.centralF.cdf(e,t,n)}}),r.extend(r.fn,{anovafscore:function(){return r.anovafscore(this.toArray())},anovaftes:function(){for(var e,t=0,e=0;this.length>e;e++)t+=this[e].length;return r.ftest(this.anovafscore(),this.length-1,t-this.length)}}),r.extend({qscore:function(){var t,o,u,a,s,l=n.call(arguments);return i(l[0])?(t=l[0],o=l[1],u=l[2],a=l[3],s=l[4]):(t=r.mean(l[0]),o=r.mean(l[1]),u=l[0].length,a=l[1].length,s=l[2]),e.abs(t-o)/(s*e.sqrt((1/u+1/a)/2))},qtest:function(){var e,t=n.call(arguments);3===t.length?(e=t[0],t=t.slice(1)):7===t.length?(e=r.qscore(t[0],t[1],t[2],t[3],t[4]),t=t.slice(5)):(e=r.qscore(t[0],t[1],t[2]),t=t.slice(3));var i=t[0],o=t[1];return 1-r.tukey.cdf(e,o,i-o)},tukeyhsd:function(e){for(var t=r.pooledstdev(e),n=e.map(function(e){return r.mean(e)}),i=e.reduce(function(r,e){return r+e.length},0),o=[],u=0;e.length>u;++u)for(var a=u+1;e.length>a;++a){var s=r.qtest(n[u],n[a],e[u].length,e[a].length,t,i,e.length);o.push([[u,a],s])}return o}}),r.extend({normalci:function(){var t,i=n.call(arguments),o=Array(2);return t=e.abs(4===i.length?r.normal.inv(i[1]/2,0,1)*i[2]/e.sqrt(i[3]):r.normal.inv(i[1]/2,0,1)*r.stdev(i[2])/e.sqrt(i[2].length)),o[0]=i[0]-t,o[1]=i[0]+t,o},tci:function(){var t,i=n.call(arguments),o=Array(2);return t=e.abs(4===i.length?r.studentt.inv(i[1]/2,i[3]-1)*i[2]/e.sqrt(i[3]):r.studentt.inv(i[1]/2,i[2].length-1)*r.stdev(i[2],!0)/e.sqrt(i[2].length)),o[0]=i[0]-t,o[1]=i[0]+t,o},significant:function(r,e){return e>r}}),r.extend(r.fn,{normalci:function(e,t){return r.normalci(e,t,this.toArray())},tci:function(e,t){return r.tci(e,t,this.toArray())}}),r.extend(r.fn,{oneSidedDifferenceOfProportions:function(e,n,i,o){var u=t(e,n,i,o);return r.ztest(u,1)},twoSidedDifferenceOfProportions:function(e,n,i,o){var u=t(e,n,i,o);return r.ztest(u,2)}})}(e,Math),e.models=function(){function r(r,e){return t(r,e)}function r(r){var n=r[0].length;return e.arange(n).map(function(i){var o=e.arange(n).filter(function(r){return r!==i});return t(e.col(r,i).map(function(r){return r[0]}),e.col(r,o))})}function t(r,t){var n=r.length,i=t[0].length-1,o=n-i-1,u=e.lstsq(t,r),a=e.multiply(t,u.map(function(r){return[r]})).map(function(r){return r[0]}),s=e.subtract(r,a),l=e.mean(r),f=e.sum(a.map(function(r){return Math.pow(r-l,2)})),c=e.sum(r.map(function(r,e){return Math.pow(r-a[e],2)})),d=f+c;return{exog:t,endog:r,nobs:n,df_model:i,df_resid:o,coef:u,predict:a,resid:s,ybar:l,SST:d,SSE:f,SSR:c,R2:f/d}}function n(t){var n=r(t.exog),i=Math.sqrt(t.SSR/t.df_resid),o=n.map(function(r){var e=r.SST,t=r.R2;return i/Math.sqrt(e*(1-t))}),u=t.coef.map(function(r,e){return(r-0)/o[e]}),a=u.map(function(r){var n=e.studentt.cdf(r,t.df_resid);return 2*(n>.5?1-n:n)}),s=e.studentt.inv(.975,t.df_resid),l=t.coef.map(function(r,e){var t=s*o[e];return[r-t,r+t]});return{se:o,t:u,p:a,sigmaHat:i,interval95:l}}function i(r){var t=r.R2/r.df_model/((1-r.R2)/r.df_resid);return{F_statistic:t,pvalue:1-function(r,t,n){return e.beta.cdf(r/(n/t+r),t/2,n/2)}(t,r.df_model,r.df_resid)}}function o(r,e){var o=t(r,e),u=n(o),a=i(o),s=1-(o.nobs-1)/o.df_resid*(1-o.rsquared);return o.t=u,o.f=a,o.adjust_R2=s,o}return{ols:o}}(),e.jStat=e,e})},function(r,e,t){var n=t(1),i=t(9),o=t(0);e.UNIQUE=function(){for(var r=[],e=0;arguments.length>e;++e){for(var t=!1,n=arguments[e],i=0;r.length>i&&!(t=r[i]===n);++i);t||r.push(n)}return r},e.FLATTEN=n.flatten,e.ARGS2ARRAY=function(){return Array.prototype.slice.call(arguments,0)},e.REFERENCE=function(r,e){if(!arguments.length)return o.error;try{for(var t=e.split("."),n=r,i=0;t.length>i;++i){var u=t[i];if("]"===u[u.length-1]){var a=u.indexOf("["),s=u.substring(a+1,u.length-1);n=n[u.substring(0,a)][s]}else n=n[u]}return n}catch(o){}},e.JOIN=function(r,e){return r.join(e)},e.NUMBERS=function(){return n.flatten(arguments).filter(function(r){return"number"==typeof r})},e.NUMERAL=function(r,e){return i(r).format(e)}},function(r,e,t){function n(r){return/^[01]{1,10}$/.test(r)}var i=t(0),o=t(11).jStat,u=t(6),a=t(1),s=t(88);e.BESSELI=function(r,e){return r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e)?i.value:s.besseli(r,e)},e.BESSELJ=function(r,e){return r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e)?i.value:s.besselj(r,e)},e.BESSELK=function(r,e){return r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e)?i.value:s.besselk(r,e)},e.BESSELY=function(r,e){return r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e)?i.value:s.bessely(r,e)},e.BIN2DEC=function(r){if(!n(r))return i.num;var e=parseInt(r,2),t=""+r;return 10===t.length&&"1"===t.substring(0,1)?parseInt(t.substring(1),2)-512:e},e.BIN2HEX=function(r,e){if(!n(r))return i.num;var t=""+r;if(10===t.length&&"1"===t.substring(0,1))return(0xfffffffe00+parseInt(t.substring(1),2)).toString(16);var o=parseInt(r,2).toString(16);return e===undefined?o:isNaN(e)?i.value:0>e?i.num:(e=Math.floor(e),o.length>e?i.num:u.REPT("0",e-o.length)+o)},e.BIN2OCT=function(r,e){if(!n(r))return i.num;var t=""+r;if(10===t.length&&"1"===t.substring(0,1))return(1073741312+parseInt(t.substring(1),2)).toString(8);var o=parseInt(r,2).toString(8);return e===undefined?o:isNaN(e)?i.value:0>e?i.num:(e=Math.floor(e),o.length>e?i.num:u.REPT("0",e-o.length)+o)},e.BITAND=function(r,e){return r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e)?i.value:0>r||0>e?i.num:Math.floor(r)!==r||Math.floor(e)!==e?i.num:r>0xffffffffffff||e>0xffffffffffff?i.num:r&e},e.BITLSHIFT=function(r,e){return r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e)?i.value:0>r?i.num:Math.floor(r)!==r?i.num:r>0xffffffffffff?i.num:Math.abs(e)>53?i.num:0>e?r>>-e:r<r||0>e?i.num:Math.floor(r)!==r||Math.floor(e)!==e?i.num:r>0xffffffffffff||e>0xffffffffffff?i.num:r|e},e.BITRSHIFT=function(r,e){return r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e)?i.value:0>r?i.num:Math.floor(r)!==r?i.num:r>0xffffffffffff?i.num:Math.abs(e)>53?i.num:0>e?r<<-e:r>>e},e.BITXOR=function(r,e){return r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e)?i.value:0>r||0>e?i.num:Math.floor(r)!==r||Math.floor(e)!==e?i.num:r>0xffffffffffff||e>0xffffffffffff?i.num:r^e},e.COMPLEX=function(r,e,t){return r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e)?r:"i"!==(t=t===undefined?"i":t)&&"j"!==t?i.value:0===r&&0===e?0:0===r?1===e?t:""+e+t:0===e?""+r:r+(e>0?"+":"")+(1===e?t:""+e+t)},e.CONVERT=function(r,e,t){if((r=a.parseNumber(r))instanceof Error)return r;for(var n,o=[["a.u. of action","?",null,"action",!1,!1,1.05457168181818e-34],["a.u. of charge","e",null,"electric_charge",!1,!1,1.60217653141414e-19],["a.u. of energy","Eh",null,"energy",!1,!1,4.35974417757576e-18],["a.u. of length","a?",null,"length",!1,!1,5.29177210818182e-11],["a.u. of mass","m?",null,"mass",!1,!1,9.10938261616162e-31],["a.u. of time","?/Eh",null,"time",!1,!1,2.41888432650516e-17],["admiralty knot","admkn",null,"speed",!1,!0,.514773333],["ampere","A",null,"electric_current",!0,!1,1],["ampere per meter","A/m",null,"magnetic_field_intensity",!0,!1,1],["ångström","Å",["ang"],"length",!1,!0,1e-10],["are","ar",null,"area",!1,!0,100],["astronomical unit","ua",null,"length",!1,!1,1.49597870691667e-11],["bar","bar",null,"pressure",!1,!1,1e5],["barn","b",null,"area",!1,!1,1e-28],["becquerel","Bq",null,"radioactivity",!0,!1,1],["bit","bit",["b"],"information",!1,!0,1],["btu","BTU",["btu"],"energy",!1,!0,1055.05585262],["byte","byte",null,"information",!1,!0,8],["candela","cd",null,"luminous_intensity",!0,!1,1],["candela per square metre","cd/m?",null,"luminance",!0,!1,1],["coulomb","C",null,"electric_charge",!0,!1,1],["cubic ångström","ang3",["ang^3"],"volume",!1,!0,1e-30],["cubic foot","ft3",["ft^3"],"volume",!1,!0,.028316846592],["cubic inch","in3",["in^3"],"volume",!1,!0,16387064e-12],["cubic light-year","ly3",["ly^3"],"volume",!1,!0,8.46786664623715e-47],["cubic metre","m?",null,"volume",!0,!0,1],["cubic mile","mi3",["mi^3"],"volume",!1,!0,4168181825.44058],["cubic nautical mile","Nmi3",["Nmi^3"],"volume",!1,!0,6352182208],["cubic Pica","Pica3",["Picapt3","Pica^3","Picapt^3"],"volume",!1,!0,7.58660370370369e-8],["cubic yard","yd3",["yd^3"],"volume",!1,!0,.764554857984],["cup","cup",null,"volume",!1,!0,.0002365882365],["dalton","Da",["u"],"mass",!1,!1,1.66053886282828e-27],["day","d",["day"],"time",!1,!0,86400],["degree","°",null,"angle",!1,!1,.0174532925199433],["degrees Rankine","Rank",null,"temperature",!1,!0,.555555555555556],["dyne","dyn",["dy"],"force",!1,!0,1e-5],["electronvolt","eV",["ev"],"energy",!1,!0,1.60217656514141],["ell","ell",null,"length",!1,!0,1.143],["erg","erg",["e"],"energy",!1,!0,1e-7],["farad","F",null,"electric_capacitance",!0,!1,1],["fluid ounce","oz",null,"volume",!1,!0,295735295625e-16],["foot","ft",null,"length",!1,!0,.3048],["foot-pound","flb",null,"energy",!1,!0,1.3558179483314],["gal","Gal",null,"acceleration",!1,!1,.01],["gallon","gal",null,"volume",!1,!0,.003785411784],["gauss","G",["ga"],"magnetic_flux_density",!1,!0,1],["grain","grain",null,"mass",!1,!0,647989e-10],["gram","g",null,"mass",!1,!0,.001],["gray","Gy",null,"absorbed_dose",!0,!1,1],["gross registered ton","GRT",["regton"],"volume",!1,!0,2.8316846592],["hectare","ha",null,"area",!1,!0,1e4],["henry","H",null,"inductance",!0,!1,1],["hertz","Hz",null,"frequency",!0,!1,1],["horsepower","HP",["h"],"power",!1,!0,745.69987158227],["horsepower-hour","HPh",["hh","hph"],"energy",!1,!0,2684519.538],["hour","h",["hr"],"time",!1,!0,3600],["imperial gallon (U.K.)","uk_gal",null,"volume",!1,!0,.00454609],["imperial hundredweight","lcwt",["uk_cwt","hweight"],"mass",!1,!0,50.802345],["imperial quart (U.K)","uk_qt",null,"volume",!1,!0,.0011365225],["imperial ton","brton",["uk_ton","LTON"],"mass",!1,!0,1016.046909],["inch","in",null,"length",!1,!0,.0254],["international acre","uk_acre",null,"area",!1,!0,4046.8564224],["IT calorie","cal",null,"energy",!1,!0,4.1868],["joule","J",null,"energy",!0,!0,1],["katal","kat",null,"catalytic_activity",!0,!1,1],["kelvin","K",["kel"],"temperature",!0,!0,1],["kilogram","kg",null,"mass",!0,!0,1],["knot","kn",null,"speed",!1,!0,.514444444444444],["light-year","ly",null,"length",!1,!0,9460730472580800],["litre","L",["l","lt"],"volume",!1,!0,.001],["lumen","lm",null,"luminous_flux",!0,!1,1],["lux","lx",null,"illuminance",!0,!1,1],["maxwell","Mx",null,"magnetic_flux",!1,!1,1e-18],["measurement ton","MTON",null,"volume",!1,!0,1.13267386368],["meter per hour","m/h",["m/hr"],"speed",!1,!0,.00027777777777778],["meter per second","m/s",["m/sec"],"speed",!0,!0,1],["meter per second squared","m?s??",null,"acceleration",!0,!1,1],["parsec","pc",["parsec"],"length",!1,!0,0x6da012f958ee1c],["meter squared per second","m?/s",null,"kinematic_viscosity",!0,!1,1],["metre","m",null,"length",!0,!0,1],["miles per hour","mph",null,"speed",!1,!0,.44704],["millimetre of mercury","mmHg",null,"pressure",!1,!1,133.322],["minute","?",null,"angle",!1,!1,.000290888208665722],["minute","min",["mn"],"time",!1,!0,60],["modern teaspoon","tspm",null,"volume",!1,!0,5e-6],["mole","mol",null,"amount_of_substance",!0,!1,1],["morgen","Morgen",null,"area",!1,!0,2500],["n.u. of action","?",null,"action",!1,!1,1.05457168181818e-34],["n.u. of mass","m?",null,"mass",!1,!1,9.10938261616162e-31],["n.u. of speed","c?",null,"speed",!1,!1,299792458],["n.u. of time","?/(me?c??)",null,"time",!1,!1,1.28808866778687e-21],["nautical mile","M",["Nmi"],"length",!1,!0,1852],["newton","N",null,"force",!0,!0,1],["œrsted","Oe ",null,"magnetic_field_intensity",!1,!1,79.5774715459477],["ohm","Ω",null,"electric_resistance",!0,!1,1],["ounce mass","ozm",null,"mass",!1,!0,.028349523125],["pascal","Pa",null,"pressure",!0,!1,1],["pascal second","Pa?s",null,"dynamic_viscosity",!0,!1,1],["pferdestärke","PS",null,"power",!1,!0,735.49875],["phot","ph",null,"illuminance",!1,!1,1e-4],["pica (1/6 inch)","pica",null,"length",!1,!0,.00035277777777778],["pica (1/72 inch)","Pica",["Picapt"],"length",!1,!0,.00423333333333333],["poise","P",null,"dynamic_viscosity",!1,!1,.1],["pond","pond",null,"force",!1,!0,.00980665],["pound force","lbf",null,"force",!1,!0,4.4482216152605],["pound mass","lbm",null,"mass",!1,!0,.45359237],["quart","qt",null,"volume",!1,!0,.000946352946],["radian","rad",null,"angle",!0,!1,1],["second","?",null,"angle",!1,!1,484813681109536e-20],["second","s",["sec"],"time",!0,!0,1],["short hundredweight","cwt",["shweight"],"mass",!1,!0,45.359237],["siemens","S",null,"electrical_conductance",!0,!1,1],["sievert","Sv",null,"equivalent_dose",!0,!1,1],["slug","sg",null,"mass",!1,!0,14.59390294],["square ångström","ang2",["ang^2"],"area",!1,!0,1e-20],["square foot","ft2",["ft^2"],"area",!1,!0,.09290304],["square inch","in2",["in^2"],"area",!1,!0,64516e-8],["square light-year","ly2",["ly^2"],"area",!1,!0,8.95054210748189e31],["square meter","m?",null,"area",!0,!0,1],["square mile","mi2",["mi^2"],"area",!1,!0,2589988.110336],["square nautical mile","Nmi2",["Nmi^2"],"area",!1,!0,3429904],["square Pica","Pica2",["Picapt2","Pica^2","Picapt^2"],"area",!1,!0,1792111111111e-17],["square yard","yd2",["yd^2"],"area",!1,!0,.83612736],["statute mile","mi",null,"length",!1,!0,1609.344],["steradian","sr",null,"solid_angle",!0,!1,1],["stilb","sb",null,"luminance",!1,!1,1e-4],["stokes","St",null,"kinematic_viscosity",!1,!1,1e-4],["stone","stone",null,"mass",!1,!0,6.35029318],["tablespoon","tbs",null,"volume",!1,!0,147868e-10],["teaspoon","tsp",null,"volume",!1,!0,492892e-11],["tesla","T",null,"magnetic_flux_density",!0,!0,1],["thermodynamic calorie","c",null,"energy",!1,!0,4.184],["ton","ton",null,"mass",!1,!0,907.18474],["tonne","t",null,"mass",!1,!1,1e3],["U.K. pint","uk_pt",null,"volume",!1,!0,.00056826125],["U.S. bushel","bushel",null,"volume",!1,!0,.03523907],["U.S. oil barrel","barrel",null,"volume",!1,!0,.158987295],["U.S. pint","pt",["us_pt"],"volume",!1,!0,.000473176473],["U.S. survey mile","survey_mi",null,"length",!1,!0,1609.347219],["U.S. survey/statute acre","us_acre",null,"area",!1,!0,4046.87261],["volt","V",null,"voltage",!0,!1,1],["watt","W",null,"power",!0,!0,1],["watt-hour","Wh",["wh"],"energy",!1,!0,3600],["weber","Wb",null,"magnetic_flux",!0,!1,1],["yard","yd",null,"length",!1,!0,.9144],["year","yr",null,"time",!1,!0,31557600]],u={Yi:["yobi",80,1.2089258196146292e24,"Yi","yotta"],Zi:["zebi",70,0x400000000000000000,"Zi","zetta"],Ei:["exbi",60,0x1000000000000000,"Ei","exa"],Pi:["pebi",50,0x4000000000000,"Pi","peta"],Ti:["tebi",40,1099511627776,"Ti","tera"],Gi:["gibi",30,1073741824,"Gi","giga"],Mi:["mebi",20,1048576,"Mi","mega"],ki:["kibi",10,1024,"ki","kilo"]},s={Y:["yotta",1e24,"Y"],Z:["zetta",1e21,"Z"],E:["exa",1e18,"E"],P:["peta",1e15,"P"],T:["tera",1e12,"T"],G:["giga",1e9,"G"],M:["mega",1e6,"M"],k:["kilo",1e3,"k"],h:["hecto",100,"h"],e:["dekao",10,"e"],d:["deci",.1,"d"],c:["centi",.01,"c"],m:["milli",.001,"m"],u:["micro",1e-6,"u"],n:["nano",1e-9,"n"],p:["pico",1e-12,"p"],f:["femto",1e-15,"f"],a:["atto",1e-18,"a"],z:["zepto",1e-21,"z"],y:["yocto",1e-24,"y"]},l=null,f=null,c=e,d=t,m=1,p=1,h=0;146>h;h++)n=null===o[h][2]?[]:o[h][2],o[h][1]!==c&&0>n.indexOf(c)||(l=o[h]),o[h][1]!==d&&0>n.indexOf(d)||(f=o[h]);if(null===l){var b=u[e.substring(0,2)],v=s[e.substring(0,1)];"da"===e.substring(0,2)&&(v=["dekao",10,"da"]),b?(m=b[2],c=e.substring(2)):v&&(m=v[1],c=e.substring(v[2].length));for(var g=0;146>g;g++)n=null===o[g][2]?[]:o[g][2],o[g][1]!==c&&0>n.indexOf(c)||(l=o[g])}if(null===f){var E=u[t.substring(0,2)],N=s[t.substring(0,1)];"da"===t.substring(0,2)&&(N=["dekao",10,"da"]),E?(p=E[2],d=t.substring(2)):N&&(p=N[1],d=t.substring(N[2].length));for(var y=0;146>y;y++)n=null===o[y][2]?[]:o[y][2],o[y][1]!==d&&0>n.indexOf(d)||(f=o[y])}return null===l||null===f?i.na:l[3]!==f[3]?i.na:r*l[6]*m/(f[6]*p)},e.DEC2BIN=function(r,e){if((r=a.parseNumber(r))instanceof Error)return r;if(!/^-?[0-9]{1,3}$/.test(r)||-512>r||r>511)return i.num;if(0>r)return"1"+u.REPT("0",9-(512+r).toString(2).length)+(512+r).toString(2);var t=parseInt(r,10).toString(2);return void 0===e?t:isNaN(e)?i.value:0>e?i.num:(e=Math.floor(e),t.length>e?i.num:u.REPT("0",e-t.length)+t)},e.DEC2HEX=function(r,e){if((r=a.parseNumber(r))instanceof Error)return r;if(!/^-?[0-9]{1,12}$/.test(r)||-549755813888>r||r>549755813887)return i.num;if(0>r)return(1099511627776+r).toString(16);var t=parseInt(r,10).toString(16);return void 0===e?t:isNaN(e)?i.value:0>e?i.num:(e=Math.floor(e),t.length>e?i.num:u.REPT("0",e-t.length)+t)},e.DEC2OCT=function(r,e){if((r=a.parseNumber(r))instanceof Error)return r;if(!/^-?[0-9]{1,9}$/.test(r)||-536870912>r||r>536870911)return i.num;if(0>r)return(1073741824+r).toString(8);var t=parseInt(r,10).toString(8);return void 0===e?t:isNaN(e)?i.value:0>e?i.num:(e=Math.floor(e),t.length>e?i.num:u.REPT("0",e-t.length)+t)},e.DELTA=function(r,e){return e=e===undefined?0:e,r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e)?i.value:r===e?1:0},e.ERF=function(r,e){return e=e===undefined?0:e,r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e)?i.value:o.erf(r)},e.ERF.PRECISE=function(){throw Error("ERF.PRECISE is not implemented")},e.ERFC=function(r){return isNaN(r)?i.value:o.erfc(r)},e.ERFC.PRECISE=function(){throw Error("ERFC.PRECISE is not implemented")},e.GESTEP=function(r,e){return e=e||0,r=a.parseNumber(r),a.anyIsError(e,r)?r:e>r?0:1},e.HEX2BIN=function(r,e){if(!/^[0-9A-Fa-f]{1,10}$/.test(r))return i.num;var t=10===r.length&&"f"===r.substring(0,1).toLowerCase(),n=t?parseInt(r,16)-1099511627776:parseInt(r,16);if(-512>n||n>511)return i.num;if(t)return"1"+u.REPT("0",9-(512+n).toString(2).length)+(512+n).toString(2);var o=n.toString(2);return e===undefined?o:isNaN(e)?i.value:0>e?i.num:(e=Math.floor(e),o.length>e?i.num:u.REPT("0",e-o.length)+o)},e.HEX2DEC=function(r){if(!/^[0-9A-Fa-f]{1,10}$/.test(r))return i.num;var e=parseInt(r,16);return 549755813888>e?e:e-1099511627776},e.HEX2OCT=function(r,e){if(!/^[0-9A-Fa-f]{1,10}$/.test(r))return i.num;var t=parseInt(r,16);if(t>536870911&&0xffe0000000>t)return i.num;if(t>=0xffe0000000)return(t-0xffc0000000).toString(8);var n=t.toString(8);return e===undefined?n:isNaN(e)?i.value:0>e?i.num:(e=Math.floor(e),n.length>e?i.num:u.REPT("0",e-n.length)+n)},e.IMABS=function(r){var t=e.IMREAL(r),n=e.IMAGINARY(r);return a.anyIsError(t,n)?i.value:Math.sqrt(Math.pow(t,2)+Math.pow(n,2))},e.IMAGINARY=function(r){if(r===undefined||!0===r||!1===r)return i.value;if(0===r||"0"===r)return 0;if(["i","j"].indexOf(r)>=0)return 1;r=r.replace("+i","+1i").replace("-i","-1i").replace("+j","+1j").replace("-j","-1j");var e=r.indexOf("+"),t=r.indexOf("-");0===e&&(e=r.indexOf("+",1)),0===t&&(t=r.indexOf("-",1));var n=r.substring(r.length-1,r.length),o="i"===n||"j"===n;return 0>e&&0>t?o?isNaN(r.substring(0,r.length-1))?i.num:r.substring(0,r.length-1):isNaN(r)?i.num:0:o?0>e?isNaN(r.substring(0,t))||isNaN(r.substring(t+1,r.length-1))?i.num:-+r.substring(t+1,r.length-1):isNaN(r.substring(0,e))||isNaN(r.substring(e+1,r.length-1))?i.num:+r.substring(e+1,r.length-1):i.num},e.IMARGUMENT=function(r){var t=e.IMREAL(r),n=e.IMAGINARY(r);return a.anyIsError(t,n)?i.value:0===t&&0===n?i.div0:0===t&&n>0?Math.PI/2:0===t&&0>n?-Math.PI/2:0===n&&t>0?0:0===n&&0>t?-Math.PI:t>0?Math.atan(n/t):0>t&&n>=0?Math.atan(n/t)+Math.PI:Math.atan(n/t)-Math.PI},e.IMCONJUGATE=function(r){var t=e.IMREAL(r),n=e.IMAGINARY(r);if(a.anyIsError(t,n))return i.value;var o=r.substring(r.length-1);return o="i"===o||"j"===o?o:"i",0!==n?e.COMPLEX(t,-n,o):r},e.IMCOS=function(r){var t=e.IMREAL(r),n=e.IMAGINARY(r);if(a.anyIsError(t,n))return i.value;var o=r.substring(r.length-1);return o="i"===o||"j"===o?o:"i",e.COMPLEX(Math.cos(t)*(Math.exp(n)+Math.exp(-n))/2,-Math.sin(t)*(Math.exp(n)-Math.exp(-n))/2,o)},e.IMCOSH=function(r){var t=e.IMREAL(r),n=e.IMAGINARY(r);if(a.anyIsError(t,n))return i.value;var o=r.substring(r.length-1);return o="i"===o||"j"===o?o:"i",e.COMPLEX(Math.cos(n)*(Math.exp(t)+Math.exp(-t))/2,Math.sin(n)*(Math.exp(t)-Math.exp(-t))/2,o)},e.IMCOT=function(r){var t=e.IMREAL(r),n=e.IMAGINARY(r);return a.anyIsError(t,n)?i.value:e.IMDIV(e.IMCOS(r),e.IMSIN(r))},e.IMDIV=function(r,t){var n=e.IMREAL(r),o=e.IMAGINARY(r),u=e.IMREAL(t),s=e.IMAGINARY(t);if(a.anyIsError(n,o,u,s))return i.value;var l=r.substring(r.length-1),f=t.substring(t.length-1),c="i";if("j"===l?c="j":"j"===f&&(c="j"),0===u&&0===s)return i.num;var d=u*u+s*s;return e.COMPLEX((n*u+o*s)/d,(o*u-n*s)/d,c)},e.IMEXP=function(r){var t=e.IMREAL(r),n=e.IMAGINARY(r);if(a.anyIsError(t,n))return i.value;var o=r.substring(r.length-1);o="i"===o||"j"===o?o:"i";var u=Math.exp(t);return e.COMPLEX(u*Math.cos(n),u*Math.sin(n),o)},e.IMLN=function(r){var t=e.IMREAL(r),n=e.IMAGINARY(r);if(a.anyIsError(t,n))return i.value;var o=r.substring(r.length-1);return o="i"===o||"j"===o?o:"i",e.COMPLEX(Math.log(Math.sqrt(t*t+n*n)),Math.atan(n/t),o)},e.IMLOG10=function(r){var t=e.IMREAL(r),n=e.IMAGINARY(r);if(a.anyIsError(t,n))return i.value;var o=r.substring(r.length-1);return o="i"===o||"j"===o?o:"i",e.COMPLEX(Math.log(Math.sqrt(t*t+n*n))/Math.log(10),Math.atan(n/t)/Math.log(10),o)},e.IMLOG2=function(r){var t=e.IMREAL(r),n=e.IMAGINARY(r);if(a.anyIsError(t,n))return i.value;var o=r.substring(r.length-1);return o="i"===o||"j"===o?o:"i",e.COMPLEX(Math.log(Math.sqrt(t*t+n*n))/Math.log(2),Math.atan(n/t)/Math.log(2),o)},e.IMPOWER=function(r,t){t=a.parseNumber(t);var n=e.IMREAL(r),o=e.IMAGINARY(r);if(a.anyIsError(t,n,o))return i.value;var u=r.substring(r.length-1);u="i"===u||"j"===u?u:"i";var s=Math.pow(e.IMABS(r),t),l=e.IMARGUMENT(r);return e.COMPLEX(s*Math.cos(t*l),s*Math.sin(t*l),u)},e.IMPRODUCT=function(){var r=arguments[0];if(!arguments.length)return i.value;for(var t=1;arguments.length>t;t++){var n=e.IMREAL(r),o=e.IMAGINARY(r),u=e.IMREAL(arguments[t]),s=e.IMAGINARY(arguments[t]);if(a.anyIsError(n,o,u,s))return i.value;r=e.COMPLEX(n*u-o*s,n*s+o*u)}return r},e.IMREAL=function(r){if(r===undefined||!0===r||!1===r)return i.value;if(0===r||"0"===r)return 0;if(["i","+i","1i","+1i","-i","-1i","j","+j","1j","+1j","-j","-1j"].indexOf(r)>=0)return 0;var e=r.indexOf("+"),t=r.indexOf("-");0===e&&(e=r.indexOf("+",1)),0===t&&(t=r.indexOf("-",1));var n=r.substring(r.length-1,r.length),o="i"===n||"j"===n;return 0>e&&0>t?o?isNaN(r.substring(0,r.length-1))?i.num:0:isNaN(r)?i.num:r:o?0>e?isNaN(r.substring(0,t))||isNaN(r.substring(t+1,r.length-1))?i.num:+r.substring(0,t):isNaN(r.substring(0,e))||isNaN(r.substring(e+1,r.length-1))?i.num:+r.substring(0,e):i.num},e.IMSEC=function(r){if(!0===r||!1===r)return i.value;var t=e.IMREAL(r),n=e.IMAGINARY(r);return a.anyIsError(t,n)?i.value:e.IMDIV("1",e.IMCOS(r))},e.IMSECH=function(r){var t=e.IMREAL(r),n=e.IMAGINARY(r);return a.anyIsError(t,n)?i.value:e.IMDIV("1",e.IMCOSH(r))},e.IMSIN=function(r){var t=e.IMREAL(r),n=e.IMAGINARY(r);if(a.anyIsError(t,n))return i.value;var o=r.substring(r.length-1);return o="i"===o||"j"===o?o:"i",e.COMPLEX(Math.sin(t)*(Math.exp(n)+Math.exp(-n))/2,Math.cos(t)*(Math.exp(n)-Math.exp(-n))/2,o)},e.IMSINH=function(r){var t=e.IMREAL(r),n=e.IMAGINARY(r);if(a.anyIsError(t,n))return i.value;var o=r.substring(r.length-1);return o="i"===o||"j"===o?o:"i",e.COMPLEX(Math.cos(n)*(Math.exp(t)-Math.exp(-t))/2,Math.sin(n)*(Math.exp(t)+Math.exp(-t))/2,o)},e.IMSQRT=function(r){var t=e.IMREAL(r),n=e.IMAGINARY(r);if(a.anyIsError(t,n))return i.value;var o=r.substring(r.length-1);o="i"===o||"j"===o?o:"i";var u=Math.sqrt(e.IMABS(r)),s=e.IMARGUMENT(r);return e.COMPLEX(u*Math.cos(s/2),u*Math.sin(s/2),o)},e.IMCSC=function(r){if(!0===r||!1===r)return i.value;var t=e.IMREAL(r),n=e.IMAGINARY(r);return a.anyIsError(t,n)?i.num:e.IMDIV("1",e.IMSIN(r))},e.IMCSCH=function(r){if(!0===r||!1===r)return i.value;var t=e.IMREAL(r),n=e.IMAGINARY(r);return a.anyIsError(t,n)?i.num:e.IMDIV("1",e.IMSINH(r))},e.IMSUB=function(r,e){var t=this.IMREAL(r),n=this.IMAGINARY(r),o=this.IMREAL(e),u=this.IMAGINARY(e);if(a.anyIsError(t,n,o,u))return i.value;var s=r.substring(r.length-1),l=e.substring(e.length-1),f="i";return"j"===s?f="j":"j"===l&&(f="j"),this.COMPLEX(t-o,n-u,f)},e.IMSUM=function(){if(!arguments.length)return i.value;for(var r=a.flatten(arguments),e=r[0],t=1;r.length>t;t++){var n=this.IMREAL(e),o=this.IMAGINARY(e),u=this.IMREAL(r[t]),s=this.IMAGINARY(r[t]);if(a.anyIsError(n,o,u,s))return i.value;e=this.COMPLEX(n+u,o+s)}return e},e.IMTAN=function(r){if(!0===r||!1===r)return i.value;var t=e.IMREAL(r),n=e.IMAGINARY(r);return a.anyIsError(t,n)?i.value:this.IMDIV(this.IMSIN(r),this.IMCOS(r))},e.OCT2BIN=function(r,e){if(!/^[0-7]{1,10}$/.test(r))return i.num;var t=10===r.length&&"7"===r.substring(0,1),n=t?parseInt(r,8)-1073741824:parseInt(r,8);if(-512>n||n>511)return i.num;if(t)return"1"+u.REPT("0",9-(512+n).toString(2).length)+(512+n).toString(2);var o=n.toString(2);return void 0===e?o:isNaN(e)?i.value:0>e?i.num:(e=Math.floor(e),o.length>e?i.num:u.REPT("0",e-o.length)+o)},e.OCT2DEC=function(r){if(!/^[0-7]{1,10}$/.test(r))return i.num;var e=parseInt(r,8);return 536870912>e?e:e-1073741824},e.OCT2HEX=function(r,e){if(!/^[0-7]{1,10}$/.test(r))return i.num;var t=parseInt(r,8);if(t>=536870912)return"ff"+(t+3221225472).toString(16);var n=t.toString(16);return e===undefined?n:isNaN(e)?i.value:0>e?i.num:(e=Math.floor(e),n.length>e?i.num:u.REPT("0",e-n.length)+n)}},function(r,e,t){"use strict";e.__esModule=!0,e["default"]=["ABS","ACCRINT","ACOS","ACOSH","ACOT","ACOTH","ADD","AGGREGATE","AND","ARABIC","ARGS2ARRAY","ASIN","ASINH","ATAN","ATAN2","ATANH","AVEDEV","AVERAGE","AVERAGEA","AVERAGEIF","AVERAGEIFS","BASE","BESSELI","BESSELJ","BESSELK","BESSELY","BETA.DIST","BETA.INV","BETADIST","BETAINV","BIN2DEC","BIN2HEX","BIN2OCT","BINOM.DIST","BINOM.DIST.RANGE","BINOM.INV","BINOMDIST","BITAND","BITLSHIFT","BITOR","BITRSHIFT","BITXOR","CEILING","CEILINGMATH","CEILINGPRECISE","CHAR","CHISQ.DIST","CHISQ.DIST.RT","CHISQ.INV","CHISQ.INV.RT","CHOOSE","CHOOSE","CLEAN","CODE","COLUMN","COLUMNS","COMBIN","COMBINA","COMPLEX","CONCATENATE","CONFIDENCE","CONFIDENCE.NORM","CONFIDENCE.T","CONVERT","CORREL","COS","COSH","COT","COTH","COUNT","COUNTA","COUNTBLANK","COUNTIF","COUNTIFS","COUNTIN","COUNTUNIQUE","COVARIANCE.P","COVARIANCE.S","CSC","CSCH","CUMIPMT","CUMPRINC","DATE","DATEVALUE","DAY","DAYS","DAYS360","DB","DDB","DEC2BIN","DEC2HEX","DEC2OCT","DECIMAL","DEGREES","DELTA","DEVSQ","DIVIDE","DOLLAR","DOLLARDE","DOLLARFR","E","EDATE","EFFECT","EOMONTH","EQ","ERF","ERFC","EVEN","EXACT","EXPON.DIST","EXPONDIST","F.DIST","F.DIST.RT","F.INV","F.INV.RT","FACT","FACTDOUBLE","FALSE","FDIST","FDISTRT","FIND","FINV","FINVRT","FISHER","FISHERINV","FIXED","FLATTEN","FLOOR","FORECAST","FREQUENCY","FV","FVSCHEDULE","GAMMA","GAMMA.DIST","GAMMA.INV","GAMMADIST","GAMMAINV","GAMMALN","GAMMALN.PRECISE","GAUSS","GCD","GEOMEAN","GESTEP","GROWTH","GTE","HARMEAN","HEX2BIN","HEX2DEC","HEX2OCT","HOUR","HTML2TEXT","HYPGEOM.DIST","HYPGEOMDIST","IF","IMABS","IMAGINARY","IMARGUMENT","IMCONJUGATE","IMCOS","IMCOSH","IMCOT","IMCSC","IMCSCH","IMDIV","IMEXP","IMLN","IMLOG10","IMLOG2","IMPOWER","IMPRODUCT","IMREAL","IMSEC","IMSECH","IMSIN","IMSINH","IMSQRT","IMSUB","IMSUM","IMTAN","INT","INTERCEPT","INTERVAL","IPMT","IRR","ISBINARY","ISBLANK","ISEVEN","ISLOGICAL","ISNONTEXT","ISNUMBER","ISODD","ISODD","ISOWEEKNUM","ISPMT","ISTEXT","JOIN","KURT","LARGE","LCM","LEFT","LEN","LINEST","LN","LOG","LOG10","LOGEST","LOGNORM.DIST","LOGNORM.INV","LOGNORMDIST","LOGNORMINV","LOWER","LT","LTE","MATCH","MAX","MAXA","MEDIAN","MID","MIN","MINA","MINUS","MINUTE","MIRR","MOD","MODE.MULT","MODE.SNGL","MODEMULT","MODESNGL","MONTH","MROUND","MULTINOMIAL","MULTIPLY","NE","NEGBINOM.DIST","NEGBINOMDIST","NETWORKDAYS","NOMINAL","NORM.DIST","NORM.INV","NORM.S.DIST","NORM.S.INV","NORMDIST","NORMINV","NORMSDIST","NORMSINV","NOT","NOW","NPER","NPV","NUMBERS","NUMERAL","OCT2BIN","OCT2DEC","OCT2HEX","ODD","OR","PDURATION","PEARSON","PERCENTILEEXC","PERCENTILEINC","PERCENTRANKEXC","PERCENTRANKINC","PERMUT","PERMUTATIONA","PHI","PI","PMT","POISSON.DIST","POISSONDIST","POW","POWER","PPMT","PROB","PRODUCT","PROPER","PV","QUARTILE.EXC","QUARTILE.INC","QUARTILEEXC","QUARTILEINC","QUOTIENT","RADIANS","RAND","RANDBETWEEN","RANK.AVG","RANK.EQ","RANKAVG","RANKEQ","RATE","REFERENCE","REGEXEXTRACT","REGEXMATCH","REGEXREPLACE","REPLACE","REPT","RIGHT","ROMAN","ROUND","ROUNDDOWN","ROUNDUP","ROW","ROWS","RRI","RSQ","SEARCH","SEC","SECH","SECOND","SERIESSUM","SIGN","SIN","SINH","SKEW","SKEW.P","SKEWP","SLN","SLOPE","SMALL","SPLIT","SPLIT","SQRT","SQRTPI","STANDARDIZE","STDEV.P","STDEV.S","STDEVA","STDEVP","STDEVPA","STDEVS","STEYX","SUBSTITUTE","SUBTOTAL","SUM","SUMIF","SUMIFS","SUMPRODUCT","SUMSQ","SUMX2MY2","SUMX2PY2","SUMXMY2","SWITCH","SYD","T","T.DIST","T.DIST.2T","T.DIST.RT","T.INV","T.INV.2T","TAN","TANH","TBILLEQ","TBILLPRICE","TBILLYIELD","TDIST","TDIST2T","TDISTRT","TEXT","TIME","TIMEVALUE","TINV","TINV2T","TODAY","TRANSPOSE","TREND","TRIM","TRIMMEAN","TRUE","TRUNC","UNICHAR","UNICODE","UNIQUE","UPPER","VALUE","VAR.P","VAR.S","VARA","VARP","VARPA","VARS","WEEKDAY","WEEKNUM","WEIBULL.DIST","WEIBULLDIST","WORKDAY","XIRR","XNPV","XOR","YEAR","YEARFRAC"]},function(r,e,t){"use strict";function n(r){var e=parseInt(r,10);return e=isNaN(e)?-1:Math.max(e-1,-1)}function i(r){var e="";return 0>r||(e=""+(r+1)),e}function o(r){var e=0;if("string"==typeof r){r=r.toUpperCase();for(var t=0,n=r.length-1;r.length>t;t+=1,n-=1)e+=Math.pow(f,n)*(l.indexOf(r[t])+1)}return--e}function u(r){for(var e="";r>=0;)e=String.fromCharCode(r%f+97)+e,r=Math.floor(r/f)-1;return e.toUpperCase()}function a(r){if("string"!=typeof r||!c.test(r))return[];var e=r.toUpperCase().match(c),t=e[1],i=e[2],u=e[3],a=e[4];return[{index:n(a),label:a,isAbsolute:"$"===u},{index:o(i),label:i,isAbsolute:"$"===t}]}function s(r,e){var t=(r.isAbsolute?"$":"")+i(r.index);return(e.isAbsolute?"$":"")+u(e.index)+t}e.__esModule=!0,e.rowLabelToIndex=n,e.rowIndexToLabel=i,e.columnLabelToIndex=o,e.columnIndexToLabel=u,e.extractLabel=a,e.toLabel=s;var l="ABCDEFGHIJKLMNOPQRSTUVWXYZ",f=l.length,c=/^([$])?([A-Za-z]+)([$])?([0-9]+)$/},function(r,e,t){"use strict";function n(r){return r&&r.__esModule?r:{"default":r}}e.__esModule=!0,e.rowLabelToIndex=e.rowIndexToLabel=e.columnLabelToIndex=e.columnIndexToLabel=e.toLabel=e.extractLabel=e.error=e.Parser=e.ERROR_VALUE=e.ERROR_REF=e.ERROR_NUM=e.ERROR_NULL=e.ERROR_NOT_AVAILABLE=e.ERROR_NAME=e.ERROR_DIV_ZERO=e.ERROR=e.SUPPORTED_FORMULAS=undefined;var i=t(17),o=n(i),u=t(14),a=n(u),s=t(2),l=n(s),f=t(15);e.SUPPORTED_FORMULAS=a["default"],e.ERROR=s.ERROR,e.ERROR_DIV_ZERO=s.ERROR_DIV_ZERO,e.ERROR_NAME=s.ERROR_NAME,e.ERROR_NOT_AVAILABLE=s.ERROR_NOT_AVAILABLE,e.ERROR_NULL=s.ERROR_NULL,e.ERROR_NUM=s.ERROR_NUM,e.ERROR_REF=s.ERROR_REF,e.ERROR_VALUE=s.ERROR_VALUE,e.Parser=o["default"],e.error=l["default"],e.extractLabel=f.extractLabel,e.toLabel=f.toLabel,e.columnIndexToLabel=f.columnIndexToLabel,e.columnLabelToIndex=f.columnLabelToIndex,e.rowIndexToLabel=f.rowIndexToLabel,e.rowLabelToIndex=f.rowLabelToIndex},function(r,e,t){"use strict";function n(r){return r&&r.__esModule?r:{"default":r}}function i(r,e){if(!(r instanceof e))throw new TypeError("Cannot call a class as a function")}function o(r,e){if(!r)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?r:e}function u(r,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);r.prototype=Object.create(e&&e.prototype,{constructor:{value:r,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(r,e):r.__proto__=e)}e.__esModule=!0;var a=t(18),s=n(a),l=t(19),f=n(l),c=t(101),d=t(103),m=t(3),p=t(2),h=n(p),b=t(15);e["default"]=function(r){function e(){i(this,e);var t=o(this,r.call(this));return t.parser=new c.Parser,t.parser.yy={toNumber:m.toNumber,trimEdges:d.trimEdges,invertNumber:m.invertNumber,throwError:function(r){return t._throwError(r)},callVariable:function(r){return t._callVariable(r)},evaluateByOperator:f["default"],callFunction:f["default"],cellValue:function(r){return t._callCellValue(r)},rangeValue:function(r,e){return t._callRangeValue(r,e)}},t.variables=Object.create(null),t.setVariable("TRUE",!0).setVariable("FALSE",!1).setVariable("NULL",null),t}return u(e,r),e.prototype.parse=function(r){var e=null,t=null;try{e=""===r?"":this.parser.parse(r)}catch(i){var n=(0,h["default"])(i.message);t=n||(0,h["default"])(p.ERROR)}return e instanceof Error&&(t=(0,h["default"])(e.message)||(0,h["default"])(p.ERROR),e=null),{error:t,result:e}},e.prototype.setVariable=function(r,e){return this.variables[r]=e,this},e.prototype.getVariable=function(r){return this.variables[r]},e.prototype._callVariable=function(r){var e=this.getVariable(r);if(this.emit("callVariable",r,function(r){void 0!==r&&(e=r)}),void 0===e)throw Error(p.ERROR_NAME);return e},e.prototype._callCellValue=function(r){r=r.toUpperCase();var e=(0,b.extractLabel)(r),t=e[0],n=e[1],i=void 0;return this.emit("callCellValue",{label:r,row:t,column:n},function(r){i=r}),i},e.prototype._callRangeValue=function(r,e){r=r.toUpperCase(),e=e.toUpperCase();var t=(0,b.extractLabel)(r),n=t[0],i=t[1],o=(0,b.extractLabel)(e),u=o[0],a=o[1],s={},l={};n.index>u.index?(s.row=u,l.row=n):(s.row=n,l.row=u),i.index>a.index?(s.column=a,l.column=i):(s.column=i,l.column=a),s.label=(0,b.toLabel)(s.row,s.column),l.label=(0,b.toLabel)(l.row,l.column);var f=[];return this.emit("callRangeValue",s,l,function(){var r=arguments.length>0&&arguments[0]!==undefined?arguments[0]:[];f=r}),f},e.prototype._throwError=function(r){if((0,p.isValidStrict)(r))throw Error(r);throw Error(p.ERROR)},e}(s["default"])},function(r,e){function t(){}t.prototype={on:function(r,e,t){var n=this.e||(this.e={});return(n[r]||(n[r]=[])).push({fn:e,ctx:t}),this},once:function(r,e,t){function n(){i.off(r,n),e.apply(t,arguments)}var i=this;return n._=e,this.on(r,n,t)},emit:function(r){var e=[].slice.call(arguments,1),t=((this.e||(this.e={}))[r]||[]).slice(),n=0,i=t.length;for(n;i>n;n++)t[n].fn.apply(t[n].ctx,e);return this},off:function(r,e){var t=this.e||(this.e={}),n=t[r],i=[];if(n&&e)for(var o=0,u=n.length;u>o;o++)n[o].fn!==e&&n[o].fn._!==e&&i.push(n[o]);return i.length?t[r]=i:delete t[r],this}},r.exports=t},function(r,e,t){"use strict";function n(r){return r&&r.__esModule?r:{"default":r}}function i(r){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:[];if(r=r.toUpperCase(),!D[r])throw Error(O.ERROR_NAME);return D[r].apply(D,e)}function o(r,e){Array.isArray(r)||(r=[r.toUpperCase()]),r.forEach(function(r){D[r]=e.isFactory?e(r):e})}e.__esModule=!0,e["default"]=i,e.registerOperation=o;var u=t(20),a=n(u),s=t(21),l=n(s),f=t(22),c=n(f),d=t(23),m=n(d),p=t(24),h=n(p),b=t(93),v=n(b),g=t(94),E=n(g),N=t(95),y=n(N),w=t(96),I=n(w),M=t(97),x=n(M),A=t(98),R=n(A),T=t(99),C=n(T),S=t(100),$=n(S),O=t(2),D=Object.create(null);o(a["default"].SYMBOL,a["default"]),o(l["default"].SYMBOL,l["default"]),o(c["default"].SYMBOL,c["default"]),o(m["default"].SYMBOL,m["default"]),o($["default"].SYMBOL,$["default"]),o(h["default"].SYMBOL,h["default"]),o(v["default"].SYMBOL,v["default"]),o(E["default"].SYMBOL,E["default"]),o(y["default"].SYMBOL,y["default"]),o(I["default"].SYMBOL,I["default"]),o(R["default"].SYMBOL,R["default"]),o(C["default"].SYMBOL,C["default"]),o(x["default"].SYMBOL,x["default"])},function(r,e,t){"use strict";function n(r){for(var e=arguments.length,t=Array(e>1?e-1:0),n=1;e>n;n++)t[n-1]=arguments[n];var u=t.reduce(function(r,e){return r+(0,i.toNumber)(e)},(0,i.toNumber)(r));if(isNaN(u))throw Error(o.ERROR_VALUE);return u}e.__esModule=!0,e.SYMBOL=undefined,e["default"]=n;var i=t(3),o=t(2);n.SYMBOL=e.SYMBOL="+"},function(r,e,t){"use strict";function n(){for(var r=arguments.length,e=Array(r),t=0;r>t;t++)e[t]=arguments[t];return e.reduce(function(r,e){return r+""+e},"")}e.__esModule=!0,e["default"]=n,n.SYMBOL=e.SYMBOL="&"},function(r,e,t){"use strict";function n(r){for(var e=arguments.length,t=Array(e>1?e-1:0),n=1;e>n;n++)t[n-1]=arguments[n];var u=t.reduce(function(r,e){return r/(0,i.toNumber)(e)},(0,i.toNumber)(r));if(u===Infinity)throw Error(o.ERROR_DIV_ZERO);if(isNaN(u))throw Error(o.ERROR_VALUE);return u}e.__esModule=!0,e.SYMBOL=undefined,e["default"]=n;var i=t(3),o=t(2);n.SYMBOL=e.SYMBOL="/"},function(r,e,t){"use strict";function n(r,e){return r===e}e.__esModule=!0,e["default"]=n,n.SYMBOL=e.SYMBOL="="},function(r,e,t){"use strict";function n(r){return function(){r=r.toUpperCase();var e=r.split("."),t=!1,n=void 0;if(1===e.length)o[e[0]]&&(t=!0,n=o[e[0]].apply(o,arguments));else{for(var i=e.length,u=0,a=o;i>u;)if(a=a[e[u]],u++,!a){a=null;break}a&&(t=!0,n=a.apply(undefined,arguments))}if(!t)throw Error(s.ERROR_NAME);return n}}e.__esModule=!0,e.SYMBOL=undefined,e["default"]=n;var i=t(25),o=function(r){if(r&&r.__esModule)return r;var e={};if(null!=r)for(var t in r)Object.prototype.hasOwnProperty.call(r,t)&&(e[t]=r[t]);return e["default"]=r,e}(i),u=t(14),a=function(r){return r&&r.__esModule?r:{"default":r}}(u),s=t(2),l=e.SYMBOL=a["default"];n.isFactory=!0,n.SYMBOL=l},function(r,e,t){var n=[t(26),t(89),t(13),t(90),t(4),t(6),t(8),t(91),t(7),t(92),t(5),t(12)];for(var i in n){var o=n[i];for(var u in o)e[u]=e[u]||o[u]}},function(r,e,t){function n(r,e){if(e)for(var t in e)r[t]=e[t];return r}var i=t(4),o=t(5),u=t(13),a=t(8);e.BETADIST=o.BETA.DIST,e.BETAINV=o.BETA.INV,e.BINOMDIST=o.BINOM.DIST,e.CEILING=e.ISOCEILING=n(i.CEILING.MATH,i.CEILING),e.CEILINGMATH=i.CEILING.MATH,e.CEILINGPRECISE=i.CEILING.PRECISE,e.CHIDIST=o.CHISQ.DIST,e.CHIDISTRT=o.CHISQ.DIST.RT,e.CHIINV=o.CHISQ.INV,e.CHIINVRT=o.CHISQ.INV.RT,e.CHITEST=o.CHISQ.TEST,e.CONFIDENCE=n(o.CONFIDENCE.NORM,o.CONFIDENCE),e.COVAR=o.COVARIANCE.P,e.COVARIANCEP=o.COVARIANCE.P,e.COVARIANCES=o.COVARIANCE.S,e.CRITBINOM=o.BINOM.INV,e.EXPONDIST=o.EXPON.DIST,e.ERFCPRECISE=u.ERFC.PRECISE,e.ERFPRECISE=u.ERF.PRECISE,e.FDIST=o.F.DIST,e.FDISTRT=o.F.DIST.RT,e.FINVRT=o.F.INV.RT,e.FINV=o.F.INV,e.FLOOR=n(i.FLOOR.MATH,i.FLOOR),e.FLOORMATH=i.FLOOR.MATH,e.FLOORPRECISE=i.FLOOR.PRECISE,e.FTEST=o.F.TEST,e.GAMMADIST=o.GAMMA.DIST,e.GAMMAINV=o.GAMMA.INV,e.GAMMALNPRECISE=o.GAMMALN.PRECISE,e.HYPGEOMDIST=o.HYPGEOM.DIST,e.LOGINV=o.LOGNORM.INV,e.LOGNORMINV=o.LOGNORM.INV,e.LOGNORMDIST=o.LOGNORM.DIST,e.MODE=n(o.MODE.SNGL,o.MODE),e.MODEMULT=o.MODE.MULT,e.MODESNGL=o.MODE.SNGL,e.NEGBINOMDIST=o.NEGBINOM.DIST,e.NETWORKDAYSINTL=a.NETWORKDAYS.INTL,e.NORMDIST=o.NORM.DIST,e.NORMINV=o.NORM.INV,e.NORMSDIST=o.NORM.S.DIST,e.NORMSINV=o.NORM.S.INV,e.PERCENTILE=n(o.PERCENTILE.EXC,o.PERCENTILE),e.PERCENTILEEXC=o.PERCENTILE.EXC,e.PERCENTILEINC=o.PERCENTILE.INC,e.PERCENTRANK=n(o.PERCENTRANK.INC,o.PERCENTRANK),e.PERCENTRANKEXC=o.PERCENTRANK.EXC,e.PERCENTRANKINC=o.PERCENTRANK.INC,e.POISSON=n(o.POISSON.DIST,o.POISSON),e.POISSONDIST=o.POISSON.DIST,e.QUARTILE=n(o.QUARTILE.INC,o.QUARTILE),e.QUARTILEEXC=o.QUARTILE.EXC,e.QUARTILEINC=o.QUARTILE.INC,e.RANK=n(o.RANK.EQ,o.RANK),e.RANKAVG=o.RANK.AVG,e.RANKEQ=o.RANK.EQ,e.SKEWP=o.SKEW.P,e.STDEV=n(o.STDEV.S,o.STDEV),e.STDEVP=o.STDEV.P,e.STDEVS=o.STDEV.S,e.TDIST=o.T.DIST,e.TDISTRT=o.T.DIST.RT,e.TINV=o.T.INV,e.TTEST=o.T.TEST,e.VAR=n(o.VAR.S,o.VAR),e.VARP=o.VAR.P,e.VARS=o.VAR.S,e.WEIBULL=n(o.WEIBULL.DIST,o.WEIBULL),e.WEIBULLDIST=o.WEIBULL.DIST,e.WORKDAYINTL=a.WORKDAY.INTL,e.ZTEST=o.Z.TEST},function(r,e,t){e.bg=t(28),e["cs-CZ"]=t(29),e["da-DK"]=t(30),e["de-AT"]=t(31),e["de-CH"]=t(32),e["de-DE"]=t(33),e["de-LI"]=t(34),e.el=t(35),e["en-AU"]=t(36),e["en-GB"]=t(37),e["en-IE"]=t(38),e["en-NZ"]=t(39),e["en-ZA"]=t(40),e["es-AR"]=t(41),e["es-CL"]=t(42),e["es-CO"]=t(43),e["es-CR"]=t(44),e["es-ES"]=t(45),e["es-NI"]=t(46),e["es-PE"]=t(47),e["es-PR"]=t(48),e["es-SV"]=t(49),e["et-EE"]=t(50),e["fa-IR"]=t(51),e["fi-FI"]=t(52),e["fil-PH"]=t(53),e["fr-CA"]=t(54),e["fr-CH"]=t(55),e["fr-FR"]=t(56),e["he-IL"]=t(57),e["hu-HU"]=t(58),e.id=t(59),e["it-CH"]=t(60),e["it-IT"]=t(61),e["ja-JP"]=t(62),e["ko-KR"]=t(63),e["lv-LV"]=t(64),e["nb-NO"]=t(65),e.nb=t(66),e["nl-BE"]=t(67),e["nl-NL"]=t(68),e.nn=t(69),e["pl-PL"]=t(70),e["pt-BR"]=t(71),e["pt-PT"]=t(72),e["ro-RO"]=t(73),e.ro=t(74),e["ru-RU"]=t(75),e["ru-UA"]=t(76),e["sk-SK"]=t(77),e.sl=t(78),e["sr-Cyrl-RS"]=t(79),e["sv-SE"]=t(80),e["th-TH"]=t(81),e["tr-TR"]=t(82),e["uk-UA"]=t(83),e["zh-CN"]=t(84),e["zh-MO"]=t(85),e["zh-SG"]=t(86),e["zh-TW"]=t(87)},function(r,e){/*! + * numbro.js language configuration + * language : Bulgarian + * author : Tim McIntosh (StayinFront NZ) + */ +(function(){"use strict";var e={langLocaleCode:"bg",cultureCode:"bg",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"И",million:"А",billion:"M",trillion:"T"},ordinal:function(){return"."},currency:{symbol:"лв."}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&this.numbro.culture("bg",e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Czech * locale: Czech Republic - * author : Anatoli Papirovski : https://github.com/apapirovski + * author : Jan Pesa : https://github.com/smajl (based on work from Anatoli Papirovski : https://github.com/apapirovski) */ -(function(){"use strict";var t={langLocaleCode:"cs-CZ",cultureCode:"cs-CZ",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"tis.",million:"mil.",billion:"b",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"Kč",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"cs-CZ",cultureCode:"cs-CZ",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"tis.",million:"mil.",billion:"mld.",trillion:"bil."},ordinal:function(){return"."},currency:{symbol:"Kč",position:"postfix",spaceSeparated:!0},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Danish * locale: Denmark * author : Michael Storgaard : https://github.com/mstorgaard */ -(function(){"use strict";var t={langLocaleCode:"da-DK",cultureCode:"da-DK",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"k",million:"mio",billion:"mia",trillion:"b"},ordinal:function(){return"."},currency:{symbol:"kr",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"da-DK",cultureCode:"da-DK",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"k",million:"mio",billion:"mia",trillion:"b"},ordinal:function(){return"."},currency:{symbol:"kr",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : German + * locale: Austria + * author : Tim McIntosh (StayinFront NZ) + */ +(function(){"use strict";var e={langLocaleCode:"de-AT",cultureCode:"de-AT",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"€"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : German * locale: Switzerland * author : Michael Piefel : https://github.com/piefel (based on work from Marco Krage : https://github.com/sinky) */ -(function(){"use strict";var t={langLocaleCode:"de-CH",cultureCode:"de-CH",delimiters:{thousands:"'",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"CHF",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"de-CH",cultureCode:"de-CH",delimiters:{thousands:"'",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"CHF",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : German * locale: Germany @@ -31,43 +42,102 @@ * * Generally useful in Germany, Austria, Luxembourg, Belgium */ -(function(){"use strict";var t={langLocaleCode:"de-DE",cultureCode:"de-DE",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"€",position:"postfix",spaceSeparated:!0},defaults:{currencyFormat:",4"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"de-DE",cultureCode:"de-DE",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"€",position:"postfix",spaceSeparated:!0},defaults:{currencyFormat:",4"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : German + * locale: Liechtenstein + * author : Michael Piefel : https://github.com/piefel (based on work from Marco Krage : https://github.com/sinky) + */ +(function(){"use strict";var e={langLocaleCode:"de-LI",cultureCode:"de-LI",delimiters:{thousands:"'",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"CHF",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Greek (el) + * author : Tim McIntosh (StayinFront NZ) + */ +(function(){"use strict";var e={langLocaleCode:"el",cultureCode:"el",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"χ",million:"ε",billion:"δ",trillion:"τ"},ordinal:function(){return"."},currency:{symbol:"€"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture("el",e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : English * locale: Australia * author : Benedikt Huss : https://github.com/ben305 */ -(function(){"use strict";var t={langLocaleCode:"en-AU",cultureCode:"en-AU",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){var t=r%10;return 1==~~(r%100/10)?"th":1===t?"st":2===t?"nd":3===t?"rd":"th"},currency:{symbol:"$",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"$ ,0"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"en-AU",cultureCode:"en-AU",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1==~~(r%100/10)?"th":1===e?"st":2===e?"nd":3===e?"rd":"th"},currency:{symbol:"$",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"$ ,0"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : English * locale: United Kingdom of Great Britain and Northern Ireland * author : Dan Ristic : https://github.com/dristic */ -(function(){"use strict";var t={langLocaleCode:"en-GB",cultureCode:"en-GB",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){var t=r%10;return 1==~~(r%100/10)?"th":1===t?"st":2===t?"nd":3===t?"rd":"th"},currency:{symbol:"£",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"$ ,0"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"en-GB",cultureCode:"en-GB",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1==~~(r%100/10)?"th":1===e?"st":2===e?"nd":3===e?"rd":"th"},currency:{symbol:"£",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"$ ,0"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! ++ * numbro.js language configuration + * language : English + * locale: Ireland + * author : Tim McIntosh (StayinFront NZ) + */ +(function(){"use strict";var e={langLocaleCode:"en-IE",cultureCode:"en-IE",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1==~~(r%100/10)?"th":1===e?"st":2===e?"nd":3===e?"rd":"th"},currency:{symbol:"€"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture("en-gb",e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : English * locale: New Zealand * author : Benedikt Huss : https://github.com/ben305 */ -(function(){"use strict";var t={langLocaleCode:"en-NZ",cultureCode:"en-NZ",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){var t=r%10;return 1==~~(r%100/10)?"th":1===t?"st":2===t?"nd":3===t?"rd":"th"},currency:{symbol:"$",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"$ ,0"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"en-NZ",cultureCode:"en-NZ",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1==~~(r%100/10)?"th":1===e?"st":2===e?"nd":3===e?"rd":"th"},currency:{symbol:"$",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"$ ,0"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : English * locale: South Africa * author : Stewart Scott https://github.com/stewart42 */ -(function(){"use strict";var t={langLocaleCode:"en-ZA",cultureCode:"en-ZA",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){var t=r%10;return 1==~~(r%100/10)?"th":1===t?"st":2===t?"nd":3===t?"rd":"th"},currency:{symbol:"R",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"$ ,0"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"en-ZA",cultureCode:"en-ZA",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1==~~(r%100/10)?"th":1===e?"st":2===e?"nd":3===e?"rd":"th"},currency:{symbol:"R",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"$ ,0"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Spanish * locale: Argentina * author : Hernan Garcia : https://github.com/hgarcia */ -(function(){"use strict";var t={langLocaleCode:"es-AR",cultureCode:"es-AR",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"k",million:"mm",billion:"b",trillion:"t"},ordinal:function(r){var t=r%10;return 1===t||3===t?"er":2===t?"do":7===t||0===t?"mo":8===t?"vo":9===t?"no":"to"},currency:{symbol:"$",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"es-AR",cultureCode:"es-AR",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"k",million:"mm",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1===e||3===e?"er":2===e?"do":7===e||0===e?"mo":8===e?"vo":9===e?"no":"to"},currency:{symbol:"$",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Spanish + * locale: Chile + * author : Gwyn Judd : https://github.com/gwynjudd + */ +(function(){"use strict";var e={langLocaleCode:"es-CL",cultureCode:"es-CL",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"k",million:"mm",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1===e||3===e?"er":2===e?"do":7===e||0===e?"mo":8===e?"vo":9===e?"no":"to"},currency:{symbol:"$",position:"prefix"},defaults:{currencyFormat:"$0,0"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Spanish + * locale: Colombia + * author : Gwyn Judd : https://github.com/gwynjudd + */ +(function(){"use strict";var e={langLocaleCode:"es-CO",cultureCode:"es-CO",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"k",million:"mm",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1===e||3===e?"er":2===e?"do":7===e||0===e?"mo":8===e?"vo":9===e?"no":"to"},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Spanish + * locale: Costa Rica + * author : Gwyn Judd : https://github.com/gwynjudd + */ +(function(){"use strict";var e={langLocaleCode:"es-CR",cultureCode:"es-CR",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"k",million:"mm",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1===e||3===e?"er":2===e?"do":7===e||0===e?"mo":8===e?"vo":9===e?"no":"to"},currency:{symbol:"₡",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Spanish * locale: Spain * author : Hernan Garcia : https://github.com/hgarcia */ -(function(){"use strict";var t={langLocaleCode:"es-ES",cultureCode:"es-ES",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"k",million:"mm",billion:"b",trillion:"t"},ordinal:function(r){var t=r%10;return 1===t||3===t?"er":2===t?"do":7===t||0===t?"mo":8===t?"vo":9===t?"no":"to"},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"es-ES",cultureCode:"es-ES",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"k",million:"mm",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1===e||3===e?"er":2===e?"do":7===e||0===e?"mo":8===e?"vo":9===e?"no":"to"},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Spanish + * locale: Nicaragua + * author : Gwyn Judd : https://github.com/gwynjudd + */ +(function(){"use strict";var e={langLocaleCode:"es-NI",cultureCode:"es-NI",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"mm",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1===e||3===e?"er":2===e?"do":7===e||0===e?"mo":8===e?"vo":9===e?"no":"to"},currency:{symbol:"C$",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Spanish + * locale: Peru + * author : Gwyn Judd : https://github.com/gwynjudd + */ +(function(){"use strict";var e={langLocaleCode:"es-PE",cultureCode:"es-PE",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"mm",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1===e||3===e?"er":2===e?"do":7===e||0===e?"mo":8===e?"vo":9===e?"no":"to"},currency:{symbol:"S/.",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Spanish + * locale: Puerto Rico + * author : Gwyn Judd : https://github.com/gwynjudd + */ +(function(){"use strict";var e={langLocaleCode:"es-PR",cultureCode:"es-PR",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"mm",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1===e||3===e?"er":2===e?"do":7===e||0===e?"mo":8===e?"vo":9===e?"no":"to"},currency:{symbol:"$",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Spanish + * locale: El Salvador + * author : Gwyn Judd : https://github.com/gwynjudd + */ +(function(){"use strict";var e={langLocaleCode:"es-SV",cultureCode:"es-SV",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"mm",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1===e||3===e?"er":2===e?"do":7===e||0===e?"mo":8===e?"vo":9===e?"no":"to"},currency:{symbol:"$",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Estonian * locale: Estonia @@ -76,145 +146,188 @@ * Note: in Estonian, abbreviations are always separated * from numbers with a space */ -(function(){"use strict";var t={langLocaleCode:"et-EE",cultureCode:"et-EE",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:" tuh",million:" mln",billion:" mld",trillion:" trl"},ordinal:function(){return"."},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"et-EE",cultureCode:"et-EE",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:" tuh",million:" mln",billion:" mld",trillion:" trl"},ordinal:function(){return"."},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Farsi * locale: Iran * author : neo13 : https://github.com/neo13 */ -(function(){"use strict";var t={langLocaleCode:"fa-IR",cultureCode:"fa-IR",delimiters:{thousands:"،",decimal:"."},abbreviations:{thousand:"هزار",million:"میلیون",billion:"میلیارد",trillion:"تریلیون"},ordinal:function(){return"ام"},currency:{symbol:"﷼"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"fa-IR",cultureCode:"fa-IR",delimiters:{thousands:"،",decimal:"."},abbreviations:{thousand:"هزار",million:"میلیون",billion:"میلیارد",trillion:"تریلیون"},ordinal:function(){return"ام"},currency:{symbol:"﷼"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Finnish * locale: Finland * author : Sami Saada : https://github.com/samitheberber */ -(function(){"use strict";var t={langLocaleCode:"fi-FI",cultureCode:"fi-FI",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"k",million:"M",billion:"G",trillion:"T"},ordinal:function(){return"."},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"fi-FI",cultureCode:"fi-FI",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"k",million:"M",billion:"G",trillion:"T"},ordinal:function(){return"."},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Filipino (Pilipino) * locale: Philippines * author : Michael Abadilla : https://github.com/mjmaix */ -(function(){"use strict";var t={langLocaleCode:"fil-PH",cultureCode:"fil-PH",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){var t=r%10;return 1==~~(r%100/10)?"th":1===t?"st":2===t?"nd":3===t?"rd":"th"},currency:{symbol:"₱"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"fil-PH",cultureCode:"fil-PH",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){var e=r%10;return 1==~~(r%100/10)?"th":1===e?"st":2===e?"nd":3===e?"rd":"th"},currency:{symbol:"₱"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : French * locale: Canada * author : Léo Renaud-Allaire : https://github.com/renaudleo */ -(function(){"use strict";var t={langLocaleCode:"fr-CA",cultureCode:"fr-CA",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"k",million:"M",billion:"G",trillion:"T"},ordinal:function(r){return 1===r?"er":"ème"},currency:{symbol:"$",position:"postfix",spaceSeparated:!0},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"$ ,0"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"fr-CA",cultureCode:"fr-CA",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"k",million:"M",billion:"G",trillion:"T"},ordinal:function(r){return 1===r?"er":"ème"},currency:{symbol:"$",position:"postfix",spaceSeparated:!0},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"$ ,0"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : French * locale: Switzerland * author : Adam Draper : https://github.com/adamwdraper */ -(function(){"use strict";var t={langLocaleCode:"fr-CH",cultureCode:"fr-CH",delimiters:{thousands:"'",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){return 1===r?"er":"ème"},currency:{symbol:"CHF",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"fr-CH",cultureCode:"fr-CH",delimiters:{thousands:" ",decimal:"."},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){return 1===r?"er":"ème"},currency:{symbol:"CHF",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : French * locale: France * author : Adam Draper : https://github.com/adamwdraper */ -(function(){"use strict";var t={langLocaleCode:"fr-FR",cultureCode:"fr-FR",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){return 1===r?"er":"ème"},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"fr-FR",cultureCode:"fr-FR",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(r){return 1===r?"er":"ème"},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Hebrew * locale : IL * author : Eli Zehavi : https://github.com/eli-zehavi */ -(function(){"use strict";var t={langLocaleCode:"he-IL",cultureCode:"he-IL",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"אלף",million:"מליון",billion:"בליון",trillion:"טריליון"},currency:{symbol:"₪",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"₪ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"₪ ,0"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"he-IL",cultureCode:"he-IL",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"אלף",million:"מליון",billion:"בליון",trillion:"טריליון"},currency:{symbol:"₪",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"₪ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"₪ ,0"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Hungarian * locale: Hungary * author : Peter Bakondy : https://github.com/pbakondy */ -(function(){"use strict";var t={langLocaleCode:"hu-HU",cultureCode:"hu-HU",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"E",million:"M",billion:"Mrd",trillion:"T"},ordinal:function(){return"."},currency:{symbol:" Ft",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t,e){t["cs-CZ"]=e(39),t["da-DK"]=e(40),t["de-CH"]=e(41),t["de-DE"]=e(42),t["en-AU"]=e(43),t["en-GB"]=e(44),t["en-NZ"]=e(45),t["en-ZA"]=e(46),t["es-AR"]=e(47),t["es-ES"]=e(48),t["et-EE"]=e(49),t["fa-IR"]=e(50),t["fi-FI"]=e(51),t["fil-PH"]=e(52),t["fr-CA"]=e(53),t["fr-CH"]=e(54),t["fr-FR"]=e(55),t["he-IL"]=e(56),t["hu-HU"]=e(57),t["it-IT"]=e(59),t["ja-JP"]=e(60),t["ko-KR"]=e(61),t["lv-LV"]=e(62),t["nb-NO"]=e(63),t["nl-BE"]=e(64),t["nl-NL"]=e(65),t["pl-PL"]=e(66),t["pt-BR"]=e(67),t["pt-PT"]=e(68),t["ru-RU"]=e(69),t["ru-UA"]=e(70),t["sk-SK"]=e(71),t["sv-SE"]=e(72),t["th-TH"]=e(73),t["tr-TR"]=e(74),t["uk-UA"]=e(75),t["zh-CN"]=e(76),t["zh-TW"]=e(77)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"hu-HU",cultureCode:"hu-HU",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"E",million:"M",billion:"Mrd",trillion:"T"},ordinal:function(){return"."},currency:{symbol:" Ft",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Indonesian + * author : Tim McIntosh (StayinFront NZ) + */ +(function(){"use strict";var e={langLocaleCode:"id",cultureCode:"id",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"r",million:"j",billion:"m",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"Rp"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture("id",e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Italian + * locale: Switzerland + * author : Tim McIntosh (StayinFront NZ) + */ +(function(){"use strict";var e={langLocaleCode:"it-CH",cultureCode:"it-CH",delimiters:{thousands:"'",decimal:"."},abbreviations:{thousand:"mila",million:"mil",billion:"b",trillion:"t"},ordinal:function(){return"°"},currency:{symbol:"CHF"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture("it-CH",e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Italian * locale: Italy * author : Giacomo Trombi : http://cinquepunti.it */ -(function(){"use strict";var t={langLocaleCode:"it-IT",cultureCode:"it-IT",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"mila",million:"mil",billion:"b",trillion:"t"},ordinal:function(){return"º"},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"it-IT",cultureCode:"it-IT",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"mila",million:"mil",billion:"b",trillion:"t"},ordinal:function(){return"º"},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Japanese * locale: Japan * author : teppeis : https://github.com/teppeis */ -(function(){"use strict";var t={langLocaleCode:"ja-JP",cultureCode:"ja-JP",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"千",million:"百万",billion:"十億",trillion:"兆"},ordinal:function(){return"."},currency:{symbol:"¥",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"$ ,0"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"ja-JP",cultureCode:"ja-JP",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"千",million:"百万",billion:"十億",trillion:"兆"},ordinal:function(){return"."},currency:{symbol:"¥",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"$ ,0"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Korean * author (numbro.js Version): Randy Wilander : https://github.com/rocketedaway * author (numeral.js Version) : Rich Daley : https://github.com/pedantic-git */ -(function(){"use strict";var t={langLocaleCode:"ko-KR",cultureCode:"ko-KR",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"천",million:"백만",billion:"십억",trillion:"일조"},ordinal:function(){return"."},currency:{symbol:"₩"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"ko-KR",cultureCode:"ko-KR",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"천",million:"백만",billion:"십억",trillion:"일조"},ordinal:function(){return"."},currency:{symbol:"₩"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Latvian * locale: Latvia * author : Lauris Bukšis-Haberkorns : https://github.com/Lafriks */ -(function(){"use strict";var t={langLocaleCode:"lv-LV",cultureCode:"lv-LV",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:" tūkst.",million:" milj.",billion:" mljrd.",trillion:" trilj."},ordinal:function(){return"."},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"lv-LV",cultureCode:"lv-LV",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:" tūkst.",million:" milj.",billion:" mljrd.",trillion:" trilj."},ordinal:function(){return"."},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language: Norwegian Bokmål * locale: Norway * author : Benjamin Van Ryseghem */ -(function(){"use strict";var t={langLocaleCode:"nb-NO",cultureCode:"nb-NO",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"t",million:"M",billion:"md",trillion:"t"},currency:{symbol:"kr",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"nb-NO",cultureCode:"nb-NO",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"t",million:"M",billion:"md",trillion:"t"},currency:{symbol:"kr",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Norwegian Bokmål (nb) + * author : Tim McIntosh (StayinFront NZ) + */ +(function(){"use strict";var e={langLocaleCode:"nb",cultureCode:"nb",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"t",million:"mil",billion:"mia",trillion:"b"},ordinal:function(){return"."},currency:{symbol:"kr"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture("nb",e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Dutch * locale: Belgium * author : Dieter Luypaert : https://github.com/moeriki */ -(function(){"use strict";var t={langLocaleCode:"nl-BE",cultureCode:"nl-BE",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"k",million:"mln",billion:"mld",trillion:"bln"},ordinal:function(r){var t=r%100;return 0!==r&&1>=t||8===t||t>=20?"ste":"de"},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"nl-BE",cultureCode:"nl-BE",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"k",million:"mln",billion:"mld",trillion:"bln"},ordinal:function(r){var e=r%100;return 0!==r&&1>=e||8===e||e>=20?"ste":"de"},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Dutch * locale: Netherlands * author : Dave Clayton : https://github.com/davedx */ -(function(){"use strict";var t={langLocaleCode:"nl-NL",cultureCode:"nl-NL",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"k",million:"mln",billion:"mrd",trillion:"bln"},ordinal:function(r){var t=r%100;return 0!==r&&1>=t||8===t||t>=20?"ste":"de"},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"nl-NL",cultureCode:"nl-NL",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"k",million:"mln",billion:"mrd",trillion:"bln"},ordinal:function(r){var e=r%100;return 0!==r&&1>=e||8===e||e>=20?"ste":"de"},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Norwegian Nynorsk (nn) + * author : Tim McIntosh (StayinFront NZ) + */ +!function(){"use strict";var e={langLocaleCode:"nn",cultureCode:"nn",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"t",million:"mil",billion:"mia",trillion:"b"},ordinal:function(){return"."},currency:{symbol:"kr"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.language&&window.numbro.language("nn",e)}()},function(r,e){/*! * numbro.js language configuration * language : Polish * locale : Poland * author : Dominik Bulaj : https://github.com/dominikbulaj */ -(function(){"use strict";var t={langLocaleCode:"pl-PL",cultureCode:"pl-PL",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"tys.",million:"mln",billion:"mld",trillion:"bln"},ordinal:function(){return"."},currency:{symbol:" zł",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"pl-PL",cultureCode:"pl-PL",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"tys.",million:"mln",billion:"mld",trillion:"bln"},ordinal:function(){return"."},currency:{symbol:" zł",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Portuguese * locale : Brazil * author : Ramiro Varandas Jr : https://github.com/ramirovjr */ -(function(){"use strict";var t={langLocaleCode:"pt-BR",cultureCode:"pt-BR",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"mil",million:"milhões",billion:"b",trillion:"t"},ordinal:function(){return"º"},currency:{symbol:"R$",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"pt-BR",cultureCode:"pt-BR",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"mil",million:"milhões",billion:"b",trillion:"t"},ordinal:function(){return"º"},currency:{symbol:"R$",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Portuguese * locale : Portugal * author : Diogo Resende : https://github.com/dresende */ -(function(){"use strict";var t={langLocaleCode:"pt-PT",cultureCode:"pt-PT",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(){return"º"},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"pt-PT",cultureCode:"pt-PT",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"k",million:"m",billion:"b",trillion:"t"},ordinal:function(){return"º"},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numeral.js language configuration + * language : Romanian + * author : Andrei Alecu https://github.com/andreialecu + */ +(function(){"use strict";var e={langLocaleCode:"ro-RO",cultureCode:"ro-RO",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"mii",million:"mil",billion:"mld",trillion:"bln"},ordinal:function(){return"."},currency:{symbol:" lei",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Romanian (ro) + * author : Tim McIntosh (StayinFront NZ) + */ +(function(){"use strict";var e={langLocaleCode:"ro",cultureCode:"ro",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"mie",million:"mln",billion:"mld",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"RON"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture("ro",e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Russian * locale : Russsia * author : Anatoli Papirovski : https://github.com/apapirovski */ -(function(){"use strict";var t={langLocaleCode:"ru-RU",cultureCode:"ru-RU",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"тыс.",million:"млн",billion:"b",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"руб.",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"ru-RU",cultureCode:"ru-RU",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"тыс.",million:"млн",billion:"b",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"руб.",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Russian * locale : Ukraine * author : Anatoli Papirovski : https://github.com/apapirovski */ -(function(){"use strict";var t={langLocaleCode:"ru-UA",cultureCode:"ru-UA",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"тыс.",million:"млн",billion:"b",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"₴",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"ru-UA",cultureCode:"ru-UA",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"тыс.",million:"млн",billion:"b",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"₴",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Slovak * locale : Slovakia - * author : Ahmed Al Hafoudh : http://www.freevision.sk + * author : Jan Pesa : https://github.com/smajl (based on work from Ahmed Al Hafoudh : http://www.freevision.sk) + */ +(function(){"use strict";var e={langLocaleCode:"sk-SK",cultureCode:"sk-SK",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"tis.",million:"mil.",billion:"mld.",trillion:"bil."},ordinal:function(){return"."},currency:{symbol:"€",position:"postfix",spaceSeparated:!0},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Slovene + * locale: Slovenia + * author : Tim McIntosh (StayinFront NZ) + */ +!function(){"use strict";var e={langLocaleCode:"sl",cultureCode:"sl",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"tis.",million:"mil.",billion:"b",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"€"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture("sl",e)}()},function(r,e){/*! + * numbro.js language configuration + * language : Serbian (sr) + * country : Serbia (Cyrillic) + * author : Tim McIntosh (StayinFront NZ) */ -(function(){"use strict";var t={langLocaleCode:"sk-SK",cultureCode:"sk-SK",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"tis.",million:"mil.",billion:"b",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"€",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +!function(){"use strict";var e={langLocaleCode:"sr-Cyrl-RS",cultureCode:"sr-Cyrl-RS",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"тыс.",million:"млн",billion:"b",trillion:"t"},ordinal:function(){return"."},currency:{symbol:"RSD"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture("sr-Cyrl-RS",e)}()},function(r,e){/*! * numbro.js language configuration * language : Swedish * locale : Sweden * author : Benjamin Van Ryseghem (benjamin.vanryseghem.com) */ -(function(){"use strict";var t={langLocaleCode:"sv-SE",cultureCode:"sv-SE",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"t",million:"M",billion:"md",trillion:"tmd"},currency:{symbol:"kr",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"sv-SE",cultureCode:"sv-SE",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"t",million:"M",billion:"md",trillion:"tmd"},currency:{symbol:"kr",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Thai * locale : Thailand * author : Sathit Jittanupat : https://github.com/jojosati */ -(function(){"use strict";var t={langLocaleCode:"th-TH",cultureCode:"th-TH",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"พัน",million:"ล้าน",billion:"พันล้าน",trillion:"ล้านล้าน"},ordinal:function(){return"."},currency:{symbol:"฿",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"th-TH",cultureCode:"th-TH",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"พัน",million:"ล้าน",billion:"พันล้าน",trillion:"ล้านล้าน"},ordinal:function(){return"."},currency:{symbol:"฿",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Turkish * locale : Turkey @@ -222,22 +335,34 @@ * Erhan Gundogan : https://github.com/erhangundogan, * Burak Yiğit Kaya: https://github.com/BYK */ -(function(){"use strict";var t={1:"'inci",5:"'inci",8:"'inci",70:"'inci",80:"'inci",2:"'nci",7:"'nci",20:"'nci",50:"'nci",3:"'üncü",4:"'üncü",100:"'üncü",6:"'ncı",9:"'uncu",10:"'uncu",30:"'uncu",60:"'ıncı",90:"'ıncı"},e={langLocaleCode:"tr-TR",cultureCode:"tr-TR",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"bin",million:"milyon",billion:"milyar",trillion:"trilyon"},ordinal:function(r){if(0===r)return"'ıncı";var e=r%10,n=r%100-e,u=100>r?null:100;return t[e]||t[n]||t[u]},currency:{symbol:"₺",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={1:"'inci",5:"'inci",8:"'inci",70:"'inci",80:"'inci",2:"'nci",7:"'nci",20:"'nci",50:"'nci",3:"'üncü",4:"'üncü",100:"'üncü",6:"'ncı",9:"'uncu",10:"'uncu",30:"'uncu",60:"'ıncı",90:"'ıncı"},t={langLocaleCode:"tr-TR",cultureCode:"tr-TR",delimiters:{thousands:".",decimal:","},abbreviations:{thousand:"bin",million:"milyon",billion:"milyar",trillion:"trilyon"},ordinal:function(r){if(0===r)return"'ıncı";var t=r%10,n=r%100-t,i=100>r?null:100;return e[t]||e[n]||e[i]},currency:{symbol:"₺",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Ukrainian * locale : Ukraine * author : Michael Piefel : https://github.com/piefel (with help from Tetyana Kuzmenko) */ -(function(){"use strict";var t={langLocaleCode:"uk-UA",cultureCode:"uk-UA",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"тис.",million:"млн",billion:"млрд",trillion:"блн"},ordinal:function(){return""},currency:{symbol:"₴",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"uk-UA",cultureCode:"uk-UA",delimiters:{thousands:" ",decimal:","},abbreviations:{thousand:"тис.",million:"млн",billion:"млрд",trillion:"блн"},ordinal:function(){return""},currency:{symbol:"₴",position:"postfix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:",0.00 $",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:",0 $"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : simplified chinese * locale : China * author : badplum : https://github.com/badplum */ -(function(){"use strict";var t={langLocaleCode:"zh-CN",cultureCode:"zh-CN",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"千",million:"百万",billion:"十亿",trillion:"兆"},ordinal:function(){return"."},currency:{symbol:"¥",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"$ ,0"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){/*! +(function(){"use strict";var e={langLocaleCode:"zh-CN",cultureCode:"zh-CN",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"千",million:"百万",billion:"十亿",trillion:"兆"},ordinal:function(){return"."},currency:{symbol:"¥",position:"prefix"},defaults:{currencyFormat:",4 a"},formats:{fourDigits:"4 a",fullWithTwoDecimals:"$ ,0.00",fullWithTwoDecimalsNoCurrency:",0.00",fullWithNoDecimals:"$ ,0"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! + * numbro.js language configuration + * language : Chinese traditional + * locale: Macau + * author : Tim McIntosh (StayinFront NZ) + */ +!function(){"use strict";var e={langLocaleCode:"zh-MO",cultureCode:"zh-MO",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"千",million:"百萬",billion:"十億",trillion:"兆"},ordinal:function(){return"."},currency:{symbol:"MOP"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture("zh-MO",e)}()},function(r,e){/*! + * numbro.js language configuration + * language : Chinese simplified + * locale: Singapore + * author : Tim McIntosh (StayinFront NZ) + */ +(function(){"use strict";var e={langLocaleCode:"zh-SG",cultureCode:"zh-SG",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"千",million:"百万",billion:"十亿",trillion:"兆"},ordinal:function(){return"."},currency:{symbol:"$"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture("zh-SG",e)}).call("undefined"==typeof window?this:window)},function(r,e){/*! * numbro.js language configuration * language : Chinese (Taiwan) * author (numbro.js Version): Randy Wilander : https://github.com/rocketedaway * author (numeral.js Version) : Rich Daley : https://github.com/pedantic-git */ -(function(){"use strict";var t={langLocaleCode:"zh-TW",cultureCode:"zh-TW",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"千",million:"百萬",billion:"十億",trillion:"兆"},ordinal:function(){return"第"},currency:{symbol:"NT$"}};void 0!==r&&r.exports&&(r.exports=t),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(t.cultureCode,t)}).call("undefined"==typeof window?this:window)},function(r,t){function e(){}e.prototype={on:function(r,t,e){var n=this.e||(this.e={});return(n[r]||(n[r]=[])).push({fn:t,ctx:e}),this},once:function(r,t,e){function n(){u.off(r,n),t.apply(e,arguments)}var u=this;return n._=t,this.on(r,n,e)},emit:function(r){var t=[].slice.call(arguments,1),e=((this.e||(this.e={}))[r]||[]).slice(),n=0,u=e.length;for(n;u>n;n++)e[n].fn.apply(e[n].ctx,t);return this},off:function(r,t){var e=this.e||(this.e={}),n=e[r],u=[];if(n&&t)for(var i=0,o=n.length;o>i;i++)n[i].fn!==t&&n[i].fn._!==t&&u.push(n[i]);return u.length?e[r]=u:delete e[r],this}},r.exports=e},function(r,t){r.exports=function(r){return r.webpackPolyfill||(r.deprecate=function(){},r.paths=[],r.children||(r.children=[]),Object.defineProperty(r,"loaded",{enumerable:!0,get:function(){return r.l}}),Object.defineProperty(r,"id",{enumerable:!0,get:function(){return r.i}}),r.webpackPolyfill=1),r}},function(module,exports,__webpack_require__){(function(module,process){var grammarParser=function(){function Parser(){this.yy={}}var o=function(r,t,e,n){for(e=e||{},n=r.length;n--;e[r[n]]=t);return e},$V0=[1,5],$V1=[1,8],$V2=[1,6],$V3=[1,7],$V4=[1,9],$V5=[1,14],$V6=[1,15],$V7=[1,16],$V8=[1,12],$V9=[1,13],$Va=[1,17],$Vb=[1,19],$Vc=[1,20],$Vd=[1,21],$Ve=[1,22],$Vf=[1,23],$Vg=[1,24],$Vh=[1,25],$Vi=[1,26],$Vj=[1,27],$Vk=[1,28],$Vl=[5,9,10,11,13,14,15,16,17,18,19,20,29,30],$Vm=[5,9,10,11,13,14,15,16,17,18,19,20,29,30,32],$Vn=[5,9,10,11,13,14,15,16,17,18,19,20,29,30,34],$Vo=[5,10,11,13,14,15,16,17,29,30],$Vp=[5,10,13,14,15,16,29,30],$Vq=[5,10,11,13,14,15,16,17,18,19,29,30],$Vr=[13,29,30],parser={trace:function(){},yy:{},symbols_:{error:2,expressions:3,expression:4,EOF:5,variableSequence:6,number:7,STRING:8,"&":9,"=":10,"+":11,"(":12,")":13,"<":14,">":15,NOT:16,"-":17,"*":18,"/":19,"^":20,FUNCTION:21,expseq:22,cell:23,ABSOLUTE_CELL:24,RELATIVE_CELL:25,MIXED_CELL:26,":":27,ARRAY:28,";":29,",":30,VARIABLE:31,DECIMAL:32,NUMBER:33,"%":34,ERROR:35,$accept:0,$end:1},terminals_:{5:"EOF",8:"STRING",9:"&",10:"=",11:"+",12:"(",13:")",14:"<",15:">",16:"NOT",17:"-",18:"*",19:"/",20:"^",21:"FUNCTION",24:"ABSOLUTE_CELL",25:"RELATIVE_CELL",26:"MIXED_CELL",27:":",28:"ARRAY",29:";",30:",",31:"VARIABLE",32:"DECIMAL",33:"NUMBER",34:"%",35:"ERROR"},productions_:[0,[3,2],[4,1],[4,1],[4,1],[4,3],[4,3],[4,3],[4,3],[4,4],[4,4],[4,4],[4,3],[4,3],[4,3],[4,3],[4,3],[4,3],[4,3],[4,2],[4,2],[4,3],[4,4],[4,1],[4,1],[4,2],[23,1],[23,1],[23,1],[23,3],[23,3],[23,3],[23,3],[23,3],[23,3],[23,3],[23,3],[23,3],[22,1],[22,1],[22,3],[22,3],[6,1],[6,3],[7,1],[7,3],[7,2],[2,1]],performAction:function anonymous(yytext,yyleng,yylineno,yy,yystate,$$,_$){var $0=$$.length-1;switch(yystate){case 1:return $$[$0-1];case 2:this.$=yy.callVariable($$[$0][0]);break;case 3:this.$=yy.toNumber($$[$0]);break;case 4:this.$=yy.trimEdges($$[$0]);break;case 5:this.$=yy.evaluateByOperator("&",[$$[$0-2],$$[$0]]);break;case 6:this.$=yy.evaluateByOperator("=",[$$[$0-2],$$[$0]]);break;case 7:this.$=yy.evaluateByOperator("+",[$$[$0-2],$$[$0]]);break;case 8:this.$=$$[$0-1];break;case 9:this.$=yy.evaluateByOperator("<=",[$$[$0-3],$$[$0]]);break;case 10:this.$=yy.evaluateByOperator(">=",[$$[$0-3],$$[$0]]);break;case 11:this.$=yy.evaluateByOperator("<>",[$$[$0-3],$$[$0]]);break;case 12:this.$=yy.evaluateByOperator("NOT",[$$[$0-2],$$[$0]]);break;case 13:this.$=yy.evaluateByOperator(">",[$$[$0-2],$$[$0]]);break;case 14:this.$=yy.evaluateByOperator("<",[$$[$0-2],$$[$0]]);break;case 15:this.$=yy.evaluateByOperator("-",[$$[$0-2],$$[$0]]);break;case 16:this.$=yy.evaluateByOperator("*",[$$[$0-2],$$[$0]]);break;case 17:this.$=yy.evaluateByOperator("/",[$$[$0-2],$$[$0]]);break;case 18:this.$=yy.evaluateByOperator("^",[$$[$0-2],$$[$0]]);break;case 19:var n1=yy.invertNumber($$[$0]);this.$=n1,isNaN(this.$)&&(this.$=0);break;case 20:var n1=yy.toNumber($$[$0]);this.$=n1,isNaN(this.$)&&(this.$=0);break;case 21:this.$=yy.callFunction($$[$0-2]);break;case 22:this.$=yy.callFunction($$[$0-3],$$[$0-1]);break;case 26:case 27:case 28:this.$=yy.cellValue($$[$0]);break;case 29:case 30:case 31:case 32:case 33:case 34:case 35:case 36:case 37:this.$=yy.rangeValue($$[$0-2],$$[$0]);break;case 38:case 42:this.$=[$$[$0]];break;case 39:var result=[],arr=eval("["+yytext+"]");arr.forEach(function(r){result.push(r)}),this.$=result;break;case 40:case 41:$$[$0-2].push($$[$0]),this.$=$$[$0-2];break;case 43:this.$=Array.isArray($$[$0-2])?$$[$0-2]:[$$[$0-2]],this.$.push($$[$0]);break;case 44:this.$=$$[$0];break;case 45:this.$=1*($$[$0-2]+"."+$$[$0]);break;case 46:this.$=.01*$$[$0-1];break;case 47:this.$=yy.throwError($$[$0])}},table:[{2:11,3:1,4:2,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{1:[3]},{5:[1,18],9:$Vb,10:$Vc,11:$Vd,14:$Ve,15:$Vf,16:$Vg,17:$Vh,18:$Vi,19:$Vj,20:$Vk},o($Vl,[2,2],{32:[1,29]}),o($Vl,[2,3],{34:[1,30]}),o($Vl,[2,4]),{2:11,4:31,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:32,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:33,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{12:[1,34]},o($Vl,[2,23]),o($Vl,[2,24],{2:35,35:$Va}),o($Vm,[2,42]),o($Vn,[2,44],{32:[1,36]}),o($Vl,[2,26],{27:[1,37]}),o($Vl,[2,27],{27:[1,38]}),o($Vl,[2,28],{27:[1,39]}),o([5,9,10,11,13,14,15,16,17,18,19,20,29,30,35],[2,47]),{1:[2,1]},{2:11,4:40,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:41,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:42,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:45,6:3,7:4,8:$V0,10:[1,43],11:$V1,12:$V2,15:[1,44],17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:47,6:3,7:4,8:$V0,10:[1,46],11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:48,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:49,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:50,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:51,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:52,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{31:[1,53]},o($Vn,[2,46]),{9:$Vb,10:$Vc,11:$Vd,13:[1,54],14:$Ve,15:$Vf,16:$Vg,17:$Vh,18:$Vi,19:$Vj,20:$Vk},o($Vo,[2,19],{9:$Vb,18:$Vi,19:$Vj,20:$Vk}),o($Vo,[2,20],{9:$Vb,18:$Vi,19:$Vj,20:$Vk}),{2:11,4:57,6:3,7:4,8:$V0,11:$V1,12:$V2,13:[1,55],17:$V3,21:$V4,22:56,23:10,24:$V5,25:$V6,26:$V7,28:[1,58],31:$V8,33:$V9,35:$Va},o($Vl,[2,25]),{33:[1,59]},{24:[1,60],25:[1,61],26:[1,62]},{24:[1,63],25:[1,64],26:[1,65]},{24:[1,66],25:[1,67],26:[1,68]},o($Vl,[2,5]),o([5,10,13,29,30],[2,6],{9:$Vb,11:$Vd,14:$Ve,15:$Vf,16:$Vg,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o($Vo,[2,7],{9:$Vb,18:$Vi,19:$Vj,20:$Vk}),{2:11,4:69,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:70,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},o($Vp,[2,14],{9:$Vb,11:$Vd,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),{2:11,4:71,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},o($Vp,[2,13],{9:$Vb,11:$Vd,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o([5,10,13,16,29,30],[2,12],{9:$Vb,11:$Vd,14:$Ve,15:$Vf,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o($Vo,[2,15],{9:$Vb,18:$Vi,19:$Vj,20:$Vk}),o($Vq,[2,16],{9:$Vb,20:$Vk}),o($Vq,[2,17],{9:$Vb,20:$Vk}),o([5,10,11,13,14,15,16,17,18,19,20,29,30],[2,18],{9:$Vb}),o($Vm,[2,43]),o($Vl,[2,8]),o($Vl,[2,21]),{13:[1,72],29:[1,73],30:[1,74]},o($Vr,[2,38],{9:$Vb,10:$Vc,11:$Vd,14:$Ve,15:$Vf,16:$Vg,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o($Vr,[2,39]),o($Vn,[2,45]),o($Vl,[2,29]),o($Vl,[2,30]),o($Vl,[2,31]),o($Vl,[2,32]),o($Vl,[2,33]),o($Vl,[2,34]),o($Vl,[2,35]),o($Vl,[2,36]),o($Vl,[2,37]),o($Vp,[2,9],{9:$Vb,11:$Vd,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o($Vp,[2,11],{9:$Vb,11:$Vd,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o($Vp,[2,10],{9:$Vb,11:$Vd,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o($Vl,[2,22]),{2:11,4:75,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:76,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},o($Vr,[2,40],{9:$Vb,10:$Vc,11:$Vd,14:$Ve,15:$Vf,16:$Vg,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o($Vr,[2,41],{9:$Vb,10:$Vc,11:$Vd,14:$Ve,15:$Vf,16:$Vg,17:$Vh,18:$Vi,19:$Vj,20:$Vk})],defaultActions:{18:[2,1]},parseError:function(r,t){function e(r,t){this.message=r,this.hash=t}if(!t.recoverable)throw e.prototype=Error,new e(r,t);this.trace(r)},parse:function(r){function t(r){u.length=u.length-2*r,i.length=i.length-r,o.length=o.length-r}function e(r){for(var t=u.length-1,e=0;;){if(""+p in a[r])return e;if(0===r||2>t)return!1;t-=2,r=u[t],++e}}var n=this,u=[0],i=[null],o=[],a=this.table,s="",l=0,f=0,c=0,p=2,m=1,d=o.slice.call(arguments,1),h=Object.create(this.lexer),E={yy:{}};for(var g in this.yy)Object.prototype.hasOwnProperty.call(this.yy,g)&&(E.yy[g]=this.yy[g]);h.setInput(r,E.yy),E.yy.lexer=h,E.yy.parser=this,"undefined"==typeof h.yylloc&&(h.yylloc={});var v=h.yylloc;o.push(v);var N=h.options&&h.options.ranges;this.parseError="function"==typeof E.yy.parseError?E.yy.parseError:Object.getPrototypeOf(this).parseError;for(var b,y,I,w,M,A,R,T,x,S=function(){var r;return r=h.lex()||m,"number"!=typeof r&&(r=n.symbols_[r]||r),r},O={};;){if(I=u[u.length-1],this.defaultActions[I]?w=this.defaultActions[I]:(null!==b&&void 0!==b||(b=S()),w=a[I]&&a[I][b]),void 0===w||!w.length||!w[0]){var $,C="";if(c)y!==m&&($=e(I));else{$=e(I),x=[];for(A in a[I])this.terminals_[A]&&A>p&&x.push("'"+this.terminals_[A]+"'");C=h.showPosition?"Parse error on line "+(l+1)+":\n"+h.showPosition()+"\nExpecting "+x.join(", ")+", got '"+(this.terminals_[b]||b)+"'":"Parse error on line "+(l+1)+": Unexpected "+(b==m?"end of input":"'"+(this.terminals_[b]||b)+"'"),this.parseError(C,{text:h.match,token:this.terminals_[b]||b,line:h.yylineno,loc:v,expected:x,recoverable:$!==!1})}if(3==c){if(b===m||y===m)throw Error(C||"Parsing halted while starting to recover from another error.");f=h.yyleng,s=h.yytext,l=h.yylineno,v=h.yylloc,b=S()}if($===!1)throw Error(C||"Parsing halted. No suitable error recovery rule available.");t($),y=b==p?null:b,b=p,I=u[u.length-1],w=a[I]&&a[I][p],c=3}if(w[0]instanceof Array&&w.length>1)throw Error("Parse Error: multiple actions possible at state: "+I+", token: "+b);switch(w[0]){case 1:u.push(b),i.push(h.yytext),o.push(h.yylloc),u.push(w[1]),b=null,y?(b=y,y=null):(f=h.yyleng,s=h.yytext,l=h.yylineno,v=h.yylloc,c>0&&c--);break;case 2:if(R=this.productions_[w[1]][1],O.$=i[i.length-R],O._$={first_line:o[o.length-(R||1)].first_line,last_line:o[o.length-1].last_line,first_column:o[o.length-(R||1)].first_column,last_column:o[o.length-1].last_column},N&&(O._$.range=[o[o.length-(R||1)].range[0],o[o.length-1].range[1]]),void 0!==(M=this.performAction.apply(O,[s,f,l,E.yy,w[1],i,o].concat(d))))return M;R&&(u=u.slice(0,-1*R*2),i=i.slice(0,-1*R),o=o.slice(0,-1*R)),u.push(this.productions_[w[1]][0]),i.push(O.$),o.push(O._$),T=a[u[u.length-2]][u[u.length-1]],u.push(T);break;case 3:return!0}}return!0}},lexer=function(){return{EOF:1,parseError:function(r,t){if(!this.yy.parser)throw Error(r);this.yy.parser.parseError(r,t)},setInput:function(r,t){return this.yy=t||this.yy||{},this._input=r,this._more=this._backtrack=this.done=!1,this.yylineno=this.yyleng=0,this.yytext=this.matched=this.match="",this.conditionStack=["INITIAL"],this.yylloc={first_line:1,first_column:0,last_line:1,last_column:0},this.options.ranges&&(this.yylloc.range=[0,0]),this.offset=0,this},input:function(){var r=this._input[0];return this.yytext+=r,this.yyleng++,this.offset++,this.match+=r,this.matched+=r,r.match(/(?:\r\n?|\n).*/g)?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),r},unput:function(r){var t=r.length,e=r.split(/(?:\r\n?|\n)/g);this._input=r+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-t),this.offset-=t;var n=this.match.split(/(?:\r\n?|\n)/g);this.match=this.match.substr(0,this.match.length-1),this.matched=this.matched.substr(0,this.matched.length-1),e.length-1&&(this.yylineno-=e.length-1);var u=this.yylloc.range;return this.yylloc={first_line:this.yylloc.first_line,last_line:this.yylineno+1,first_column:this.yylloc.first_column,last_column:e?(e.length===n.length?this.yylloc.first_column:0)+n[n.length-e.length].length-e[0].length:this.yylloc.first_column-t},this.options.ranges&&(this.yylloc.range=[u[0],u[0]+this.yyleng-t]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},reject:function(){return this.options.backtrack_lexer?(this._backtrack=!0,this):this.parseError("Lexical error on line "+(this.yylineno+1)+". You can only invoke reject() in the lexer when the lexer is of the backtracking persuasion (options.backtrack_lexer = true).\n"+this.showPosition(),{text:"",token:null,line:this.yylineno})},less:function(r){this.unput(this.match.slice(r))},pastInput:function(){var r=this.matched.substr(0,this.matched.length-this.match.length);return(r.length>20?"...":"")+r.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var r=this.match;return 20>r.length&&(r+=this._input.substr(0,20-r.length)),(r.substr(0,20)+(r.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var r=this.pastInput(),t=Array(r.length+1).join("-");return r+this.upcomingInput()+"\n"+t+"^"},test_match:function(r,t){var e,n,u;if(this.options.backtrack_lexer&&(u={yylineno:this.yylineno,yylloc:{first_line:this.yylloc.first_line,last_line:this.last_line,first_column:this.yylloc.first_column,last_column:this.yylloc.last_column},yytext:this.yytext,match:this.match,matches:this.matches,matched:this.matched,yyleng:this.yyleng,offset:this.offset,_more:this._more,_input:this._input,yy:this.yy,conditionStack:this.conditionStack.slice(0),done:this.done},this.options.ranges&&(u.yylloc.range=this.yylloc.range.slice(0))),n=r[0].match(/(?:\r\n?|\n).*/g),n&&(this.yylineno+=n.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:n?n[n.length-1].length-n[n.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+r[0].length},this.yytext+=r[0],this.match+=r[0],this.matches=r,this.yyleng=this.yytext.length,this.options.ranges&&(this.yylloc.range=[this.offset,this.offset+=this.yyleng]),this._more=!1,this._backtrack=!1,this._input=this._input.slice(r[0].length),this.matched+=r[0],e=this.performAction.call(this,this.yy,this,t,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),e)return e;if(this._backtrack){for(var i in u)this[i]=u[i];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var r,t,e,n;this._more||(this.yytext="",this.match="");for(var u=this._currentRules(),i=0;u.length>i;i++)if((e=this._input.match(this.rules[u[i]]))&&(!t||e[0].length>t[0].length)){if(t=e,n=i,this.options.backtrack_lexer){if((r=this.test_match(e,u[i]))!==!1)return r;if(this._backtrack){t=!1;continue}return!1}if(!this.options.flex)break}return t?(r=this.test_match(t,u[n]))!==!1&&r:""===this._input?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+". Unrecognized text.\n"+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var r=this.next();return r?r:this.lex()},begin:function(r){this.conditionStack.push(r)},popState:function(){return this.conditionStack.length-1>0?this.conditionStack.pop():this.conditionStack[0]},_currentRules:function(){return this.conditionStack.length&&this.conditionStack[this.conditionStack.length-1]?this.conditions[this.conditionStack[this.conditionStack.length-1]].rules:this.conditions.INITIAL.rules},topState:function(r){return r=this.conditionStack.length-1-Math.abs(r||0),0>r?"INITIAL":this.conditionStack[r]},pushState:function(r){this.begin(r)},stateStackSize:function(){return this.conditionStack.length},options:{},performAction:function(r,t,e,n){switch(e){case 0:break;case 1:return 8;case 2:return 8;case 3:return 21;case 4:return 35;case 5:return 24;case 6:return 26;case 7:return 26;case 8:return 25;case 9:return 21;case 10:return 31;case 11:return 31;case 12:return 33;case 13:return 28;case 14:return 9;case 15:return" ";case 16:return 32;case 17:return 27;case 18:return 29;case 19:return 30;case 20:return 18;case 21:return 19;case 22:return 17;case 23:return 11;case 24:return 20;case 25:return 12;case 26:return 13;case 27:return 15;case 28:return 14;case 29:return 16;case 30:return'"';case 31:return"'";case 32:return"!";case 33:return 10;case 34:return 34;case 35:return"#";case 36:return 5}},rules:[/^(?:\s+)/,/^(?:"(\\["]|[^"])*")/,/^(?:'(\\[']|[^'])*')/,/^(?:[A-Za-z]{1,}[A-Za-z_0-9\.]+(?=[(]))/,/^(?:#[A-Z0-9\/]+(!|\?)?)/,/^(?:\$[A-Za-z]+\$[0-9]+)/,/^(?:\$[A-Za-z]+[0-9]+)/,/^(?:[A-Za-z]+\$[0-9]+)/,/^(?:[A-Za-z]+[0-9]+)/,/^(?:[A-Za-z\.]+(?=[(]))/,/^(?:[A-Za-z]{1,}[A-Za-z_0-9]+)/,/^(?:[A-Za-z_]+)/,/^(?:[0-9]+)/,/^(?:\[(.*)?\])/,/^(?:&)/,/^(?: )/,/^(?:[.])/,/^(?::)/,/^(?:;)/,/^(?:,)/,/^(?:\*)/,/^(?:\/)/,/^(?:-)/,/^(?:\+)/,/^(?:\^)/,/^(?:\()/,/^(?:\))/,/^(?:>)/,/^(?:<)/,/^(?:NOT\b)/,/^(?:")/,/^(?:')/,/^(?:!)/,/^(?:=)/,/^(?:%)/,/^(?:[#])/,/^(?:$)/],conditions:{INITIAL:{rules:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36],inclusive:!0}}}}();return parser.lexer=lexer,Parser.prototype=parser,parser.Parser=Parser,new Parser}();exports.parser=grammarParser,exports.Parser=grammarParser.Parser,exports.parse=function(){return grammarParser.parse.apply(grammarParser,arguments)},void 0!==module&&__webpack_require__.c[__webpack_require__.s]===module&&exports.main(process.argv.slice(1))}).call(exports,__webpack_require__(79)(module),__webpack_require__(15))},function(r,t,e){"use strict";function n(r){return r&&r.__esModule?r:{"default":r}}t.__esModule=!0,t.rowLabelToIndex=t.rowIndexToLabel=t.columnLabelToIndex=t.columnIndexToLabel=t.toLabel=t.extractLabel=t.error=t.Parser=t.ERROR_VALUE=t.ERROR_REF=t.ERROR_NUM=t.ERROR_NULL=t.ERROR_NOT_AVAILABLE=t.ERROR_NAME=t.ERROR_DIV_ZERO=t.ERROR=t.SUPPORTED_FORMULAS=undefined;var u=e(16),i=n(u),o=e(10),a=n(o),s=e(1),l=n(s),f=e(9);t.SUPPORTED_FORMULAS=a["default"],t.ERROR=s.ERROR,t.ERROR_DIV_ZERO=s.ERROR_DIV_ZERO,t.ERROR_NAME=s.ERROR_NAME,t.ERROR_NOT_AVAILABLE=s.ERROR_NOT_AVAILABLE,t.ERROR_NULL=s.ERROR_NULL,t.ERROR_NUM=s.ERROR_NUM,t.ERROR_REF=s.ERROR_REF,t.ERROR_VALUE=s.ERROR_VALUE,t.Parser=i["default"],t.error=l["default"],t.extractLabel=f.extractLabel,t.toLabel=f.toLabel,t.columnIndexToLabel=f.columnIndexToLabel,t.columnLabelToIndex=f.columnLabelToIndex,t.rowIndexToLabel=f.rowIndexToLabel,t.rowLabelToIndex=f.rowLabelToIndex}])}); \ No newline at end of file +(function(){"use strict";var e={langLocaleCode:"zh-TW",cultureCode:"zh-TW",delimiters:{thousands:",",decimal:"."},abbreviations:{thousand:"千",million:"百萬",billion:"十億",trillion:"兆"},ordinal:function(){return"第"},currency:{symbol:"NT$"}};void 0!==r&&r.exports&&(r.exports=e),"undefined"!=typeof window&&window.numbro&&window.numbro.culture&&window.numbro.culture(e.cultureCode,e)}).call("undefined"==typeof window?this:window)},function(r,e,t){function n(r,e){return r.reduce(function(r,t){return e*r+t},0)}function i(r,e,t,n,i){i||(i=-1);var o,u=2/r;if(0===e)return t;if(1===e)return n;for(var a=1;a!=e;++a)o=n*a*u+i*t,t=n,n=o;return n}function o(r,e,t,n,o){return function(u,a){if(0===a)return r(u);if(1===a)return e(u);if(0>a)throw t+": Order ("+a+") must be nonnegative";if(1==n&&0===u)throw t+": Undefined when x == 0";if(2==n&&0>=u)throw t+": Undefined when x <= 0";return i(u,a,r(u),e(u),o)}}var u=Math,a=function(){function r(r){var e,i,f,c=r*r,d=u.abs(r)-.785398164;return 8>u.abs(r)?(i=n(t,c),f=n(o,c),e=i/f):(c=64/c,i=n(a,c),f=n(s,c),e=u.sqrt(l/u.abs(r))*(u.cos(d)*i-u.sin(d)*f*8/u.abs(r))),e}function e(r){var e,t,i,o=r*r,a=u.abs(r)-2.356194491;return 8>Math.abs(r)?(t=r*n(f,o),i=n(c,o),e=t/i):(o=64/o,t=n(d,o),i=n(m,o),e=u.sqrt(l/u.abs(r))*(u.cos(a)*t-u.sin(a)*i*8/u.abs(r)),0>r&&(e=-e)),e}var t=[57568490574,-13362590354,651619640.7,-11214424.18,77392.33017,-184.9052456].reverse(),o=[57568490411,1029532985,9494680.718,59272.64853,267.8532712,1].reverse(),a=[1,-.001098628627,2734510407e-14,-2073370639e-15,2.093887211e-7].reverse(),s=[-.01562499995,.0001430488765,-6911147651e-15,7.621095161e-7,-9.34935152e-8].reverse(),l=.636619772,f=[72362614232,-7895059235,242396853.1,-2972611.439,15704.4826,-30.16036606].reverse(),c=[144725228442,2300535178,18583304.74,99447.43394,376.9991397,1].reverse(),d=[1,.00183105,-3516396496e-14,2457520174e-15,-2.40337019e-7].reverse(),m=[.04687499995,-.0002002690873,8449199096e-15,-8.8228987e-7,1.05787412e-7].reverse();return function(t,n){if(0===(n=Math.round(n)))return r(u.abs(t));if(1===n)return e(u.abs(t));if(0>n)throw"BESSELJ: Order ("+n+") must be nonnegative";if(0===u.abs(t))return 0;var o,a,s,l,f,c,d,m,p=2/u.abs(t);if(u.abs(t)>n)o=i(t,n,r(u.abs(t)),e(u.abs(t)),-1);else{for(s=2*u.floor((n+u.floor(u.sqrt(40*n)))/2),l=0,c=o=f=0,d=1,a=s;a>0;a--)m=a*p*d-c,c=d,d=m,u.abs(d)>1e10&&(d*=1e-10,c*=1e-10,o*=1e-10,f*=1e-10),l&&(f+=d),l=!l,a==n&&(o=c);f=2*f-d,o/=f}return 0>t&&n%2?-o:o}}(),s=function(){function r(r){var e,o,c,d=r*r,m=r-.785398164;return 8>r?(o=n(t,d),c=n(i,d),e=o/c+f*a(r,0)*u.log(r)):(d=64/d,o=n(s,d),c=n(l,d),e=u.sqrt(f/r)*(u.sin(m)*o+u.cos(m)*c*8/r)),e}function e(r){var e,t,i,o=r*r,s=r-2.356194491;return 8>r?(t=r*n(c,o),i=n(d,o),e=t/i+f*(a(r,1)*u.log(r)-1/r)):(o=64/o,t=n(m,o),i=n(p,o),e=u.sqrt(f/r)*(u.sin(s)*t+u.cos(s)*i*8/r)),e}var t=[-2957821389,7062834065,-512359803.6,10879881.29,-86327.92757,228.4622733].reverse(),i=[40076544269,745249964.8,7189466.438,47447.2647,226.1030244,1].reverse(),s=[1,-.001098628627,2734510407e-14,-2073370639e-15,2.093887211e-7].reverse(),l=[-.01562499995,.0001430488765,-6911147651e-15,7.621095161e-7,-9.34945152e-8].reverse(),f=.636619772,c=[-4900604943e3,127527439e4,-51534381390,734926455.1,-4237922.726,8511.937935].reverse(),d=[249958057e5,424441966400,3733650367,22459040.02,102042.605,354.9632885,1].reverse(),m=[1,.00183105,-3516396496e-14,2457520174e-15,-2.40337019e-7].reverse(),p=[.04687499995,-.0002002690873,8449199096e-15,-8.8228987e-7,1.05787412e-7].reverse();return o(r,e,"BESSELY",1,-1)}(),l=function(){function r(r){return r>3.75?u.exp(u.abs(r))/u.sqrt(u.abs(r))*n(i,3.75/u.abs(r)):n(t,r*r/14.0625)}function e(r){return 3.75>r?r*n(o,r*r/14.0625):(0>r?-1:1)*u.exp(u.abs(r))/u.sqrt(u.abs(r))*n(a,3.75/u.abs(r))}var t=[1,3.5156229,3.0899424,1.2067492,.2659732,.0360768,.0045813].reverse(),i=[.39894228,.01328592,.00225319,-.00157565,.00916281,-.02057706,.02635537,-.01647633,.00392377].reverse(),o=[.5,.87890594,.51498869,.15084934,.02658733,.00301532,32411e-8].reverse(),a=[.39894228,-.03988024,-.00362018,.00163801,-.01031555,.02282967,-.02895312,.01787654,-.00420059].reverse();return function s(t,n){if(0===(n=Math.round(n)))return r(t);if(1==n)return e(t);if(0>n)throw"BESSELI Order ("+n+") must be nonnegative";if(0===u.abs(t))return 0;var i,o,a,l,f,c,d=2/u.abs(t);for(a=2*u.round((n+u.round(u.sqrt(40*n)))/2),l=i=0,f=1,o=a;o>0;o--)c=o*d*f+l,l=f,f=c,u.abs(f)>1e10&&(f*=1e-10,l*=1e-10,i*=1e-10),o==n&&(i=l);return i*=s(t,0)/f,0>t&&n%2?-i:i}}(),f=function(){function r(r){return r>2?u.exp(-r)/u.sqrt(r)*n(i,2/r):-u.log(r/2)*l(r,0)+n(t,r*r/4)}function e(r){return r>2?u.exp(-r)/u.sqrt(r)*n(s,2/r):u.log(r/2)*l(r,1)+1/r*n(a,r*r/4)}var t=[-.57721566,.4227842,.23069756,.0348859,.00262698,1075e-7,74e-7].reverse(),i=[1.25331414,-.07832358,.02189568,-.01062446,.00587872,-.0025154,53208e-8].reverse(),a=[1,.15443144,-.67278579,-.18156897,-.01919402,-.00110404,-4686e-8].reverse(),s=[1.25331414,.23498619,-.0365562,.01504268,-.00780353,.00325614,-68245e-8].reverse();return o(r,e,"BESSELK",2,1)}();e.besselj=a,e.bessely=s,e.besseli=l,e.besselk=f},function(module,exports,__webpack_require__){function compact(r){var e=[];return utils.arrayEach(r,function(r){r&&e.push(r)}),e}function findResultIndex(database,criterias){for(var matches={},i=1;database[0].length>i;++i)matches[i]=!0;var maxCriteriaLength=criterias[0].length;for(i=1;criterias.length>i;++i)criterias[i].length>maxCriteriaLength&&(maxCriteriaLength=criterias[i].length);for(var k=1;database.length>k;++k)for(var l=1;database[k].length>l;++l){for(var currentCriteriaResult=!1,hasMatchingCriteria=!1,j=0;criterias.length>j;++j){var criteria=criterias[j];if(criteria.length>=maxCriteriaLength){var criteriaField=criteria[0];if(database[k][0]===criteriaField){hasMatchingCriteria=!0;for(var p=1;criteria.length>p;++p)currentCriteriaResult=currentCriteriaResult||eval(database[k][l]+criteria[p])}}}hasMatchingCriteria&&(matches[l]=matches[l]&¤tCriteriaResult)}for(var result=[],n=0;database[0].length>n;++n)matches[n]&&result.push(n-1);return result}var error=__webpack_require__(0),stats=__webpack_require__(5),maths=__webpack_require__(4),utils=__webpack_require__(1);exports.FINDFIELD=function(r,e){var t=null;return utils.arrayEach(r,function(r,n){if(r[0]===e)return t=n,!1}),null==t?error.value:t},exports.DAVERAGE=function(r,e,t){if(isNaN(e)&&"string"!=typeof e)return error.value;var n=findResultIndex(r,t),i=[];if("string"==typeof e){var o=exports.FINDFIELD(r,e);i=utils.rest(r[o])}else i=utils.rest(r[e]);var u=0;return utils.arrayEach(n,function(r){u+=i[r]}),0===n.length?error.div0:u/n.length},exports.DCOUNT=function(r,e,t){if(isNaN(e)&&"string"!=typeof e)return error.value;var n=findResultIndex(r,t),i=[];if("string"==typeof e){var o=exports.FINDFIELD(r,e);i=utils.rest(r[o])}else i=utils.rest(r[e]);var u=[];return utils.arrayEach(n,function(r){u.push(i[r])}),stats.COUNT(u)},exports.DCOUNTA=function(r,e,t){if(isNaN(e)&&"string"!=typeof e)return error.value;var n=findResultIndex(r,t),i=[];if("string"==typeof e){var o=exports.FINDFIELD(r,e);i=utils.rest(r[o])}else i=utils.rest(r[e]);var u=[];return utils.arrayEach(n,function(r){u.push(i[r])}),stats.COUNTA(u)},exports.DGET=function(r,e,t){if(isNaN(e)&&"string"!=typeof e)return error.value;var n=findResultIndex(r,t),i=[];if("string"==typeof e){var o=exports.FINDFIELD(r,e);i=utils.rest(r[o])}else i=utils.rest(r[e]);return 0===n.length?error.value:n.length>1?error.num:i[n[0]]},exports.DMAX=function(r,e,t){if(isNaN(e)&&"string"!=typeof e)return error.value;var n=findResultIndex(r,t),i=[];if("string"==typeof e){var o=exports.FINDFIELD(r,e);i=utils.rest(r[o])}else i=utils.rest(r[e]);var u=i[n[0]];return utils.arrayEach(n,function(r){i[r]>u&&(u=i[r])}),u},exports.DMIN=function(r,e,t){if(isNaN(e)&&"string"!=typeof e)return error.value;var n=findResultIndex(r,t),i=[];if("string"==typeof e){var o=exports.FINDFIELD(r,e);i=utils.rest(r[o])}else i=utils.rest(r[e]);var u=i[n[0]];return utils.arrayEach(n,function(r){u>i[r]&&(u=i[r])}),u},exports.DPRODUCT=function(r,e,t){if(isNaN(e)&&"string"!=typeof e)return error.value;var n=findResultIndex(r,t),i=[];if("string"==typeof e){var o=exports.FINDFIELD(r,e);i=utils.rest(r[o])}else i=utils.rest(r[e]);var u=[];utils.arrayEach(n,function(r){u.push(i[r])}),u=compact(u);var a=1;return utils.arrayEach(u,function(r){a*=r}),a},exports.DSTDEV=function(r,e,t){if(isNaN(e)&&"string"!=typeof e)return error.value;var n=findResultIndex(r,t),i=[];if("string"==typeof e){var o=exports.FINDFIELD(r,e);i=utils.rest(r[o])}else i=utils.rest(r[e]);var u=[];return utils.arrayEach(n,function(r){u.push(i[r])}),u=compact(u),stats.STDEV.S(u)},exports.DSTDEVP=function(r,e,t){if(isNaN(e)&&"string"!=typeof e)return error.value;var n=findResultIndex(r,t),i=[];if("string"==typeof e){var o=exports.FINDFIELD(r,e);i=utils.rest(r[o])}else i=utils.rest(r[e]);var u=[];return utils.arrayEach(n,function(r){u.push(i[r])}),u=compact(u),stats.STDEV.P(u)},exports.DSUM=function(r,e,t){if(isNaN(e)&&"string"!=typeof e)return error.value;var n=findResultIndex(r,t),i=[];if("string"==typeof e){var o=exports.FINDFIELD(r,e);i=utils.rest(r[o])}else i=utils.rest(r[e]);var u=[];return utils.arrayEach(n,function(r){u.push(i[r])}),maths.SUM(u)},exports.DVAR=function(r,e,t){if(isNaN(e)&&"string"!=typeof e)return error.value;var n=findResultIndex(r,t),i=[];if("string"==typeof e){var o=exports.FINDFIELD(r,e);i=utils.rest(r[o])}else i=utils.rest(r[e]);var u=[];return utils.arrayEach(n,function(r){u.push(i[r])}),stats.VAR.S(u)},exports.DVARP=function(r,e,t){if(isNaN(e)&&"string"!=typeof e)return error.value;var n=findResultIndex(r,t),i=[];if("string"==typeof e){var o=exports.FINDFIELD(r,e);i=utils.rest(r[o])}else i=utils.rest(r[e]);var u=[];return utils.arrayEach(n,function(r){u.push(i[r])}),stats.VAR.P(u)}},function(r,e,t){var n=t(0),i=t(1),o=t(7);e.AND=function(){for(var r=i.flatten(arguments),e=!0,t=0;r.length>t;t++)r[t]||(e=!1);return e},e.CHOOSE=function(){if(2>arguments.length)return n.na;var r=arguments[0];return 1>r||r>254?n.value:r+1>arguments.length?n.value:arguments[r]},e.FALSE=function(){return!1},e.IF=function(r,e,t){return r?e:t},e.IFERROR=function(r,e){return o.ISERROR(r)?e:r},e.IFNA=function(r,e){return r===n.na?e:r},e.NOT=function(r){return!r},e.OR=function(){for(var r=i.flatten(arguments),e=!1,t=0;r.length>t;t++)r[t]&&(e=!0);return e},e.TRUE=function(){return!0},e.XOR=function(){for(var r=i.flatten(arguments),e=0,t=0;r.length>t;t++)r[t]&&e++;return!!(1&Math.floor(Math.abs(e)))},e.SWITCH=function(){var r;if(arguments.length>0){var e=arguments[0],t=arguments.length-1,i=Math.floor(t/2),o=!1,u=t%2!=0,a=t%2==0?null:arguments[arguments.length-1];if(i)for(var s=0;i>s;s++)if(e===arguments[2*s+1]){r=arguments[2*s+2],o=!0;break}o||(r=u?a:n.na)}else r=n.value;return r}},function(r,e,t){function n(r){return r&&r.getTime&&!isNaN(r.getTime())}function i(r){return r instanceof Date?r:new Date(r)}var o=t(0),u=t(8),a=t(1);e.ACCRINT=function(r,e,t,a,s,l,f){return r=i(r),e=i(e),t=i(t),n(r)&&n(e)&&n(t)?a>0&&s>0?-1===[1,2,4].indexOf(l)?o.num:-1===[0,1,2,3,4].indexOf(f)?o.num:t>r?(s=s||0,f=f||0,s*a*u.YEARFRAC(r,t,f)):o.num:o.num:o.value},e.ACCRINTM=function(){throw Error("ACCRINTM is not implemented")},e.AMORDEGRC=function(){throw Error("AMORDEGRC is not implemented")},e.AMORLINC=function(){throw Error("AMORLINC is not implemented")},e.COUPDAYBS=function(){throw Error("COUPDAYBS is not implemented")},e.COUPDAYS=function(){throw Error("COUPDAYS is not implemented")},e.COUPDAYSNC=function(){throw Error("COUPDAYSNC is not implemented")},e.COUPNCD=function(){throw Error("COUPNCD is not implemented")},e.COUPNUM=function(){throw Error("COUPNUM is not implemented")},e.COUPPCD=function(){throw Error("COUPPCD is not implemented")},e.CUMIPMT=function(r,t,n,i,u,s){if(r=a.parseNumber(r),t=a.parseNumber(t),n=a.parseNumber(n),a.anyIsError(r,t,n))return o.value;if(0>=r||0>=t||0>=n)return o.num;if(1>i||1>u||i>u)return o.num;if(0!==s&&1!==s)return o.num;var l=e.PMT(r,t,n,0,s),f=0;1===i&&0===s&&(f=-n,i++);for(var c=i;u>=c;c++)f+=1===s?e.FV(r,c-2,l,n,1)-l:e.FV(r,c-1,l,n,0);return f*=r},e.CUMPRINC=function(r,t,n,i,u,s){if(r=a.parseNumber(r),t=a.parseNumber(t),n=a.parseNumber(n),a.anyIsError(r,t,n))return o.value;if(0>=r||0>=t||0>=n)return o.num;if(1>i||1>u||i>u)return o.num;if(0!==s&&1!==s)return o.num;var l=e.PMT(r,t,n,0,s),f=0;1===i&&(f=0===s?l+n*r:l,i++);for(var c=i;u>=c;c++)f+=s>0?l-(e.FV(r,c-2,l,n,1)-l)*r:l-e.FV(r,c-1,l,n,0)*r;return f},e.DB=function(r,e,t,n,i){if(i=i===undefined?12:i,r=a.parseNumber(r),e=a.parseNumber(e),t=a.parseNumber(t),n=a.parseNumber(n),i=a.parseNumber(i),a.anyIsError(r,e,t,n,i))return o.value;if(0>r||0>e||0>t||0>n)return o.num;if(-1===[1,2,3,4,5,6,7,8,9,10,11,12].indexOf(i))return o.num;if(n>t)return o.num;if(e>=r)return 0;for(var u=(1-Math.pow(e/r,1/t)).toFixed(3),s=r*u*i/12,l=s,f=0,c=n===t?t-1:n,d=2;c>=d;d++)f=(r-l)*u,l+=f;return 1===n?s:n===t?(r-l)*u:f},e.DDB=function(r,e,t,n,i){if(i=i===undefined?2:i,r=a.parseNumber(r),e=a.parseNumber(e),t=a.parseNumber(t),n=a.parseNumber(n),i=a.parseNumber(i),a.anyIsError(r,e,t,n,i))return o.value;if(0>r||0>e||0>t||0>n||0>=i)return o.num;if(n>t)return o.num;if(e>=r)return 0;for(var u=0,s=0,l=1;n>=l;l++)s=Math.min(i/t*(r-u),r-e-u),u+=s;return s},e.DISC=function(){throw Error("DISC is not implemented")},e.DOLLARDE=function(r,e){if(r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e))return o.value;if(0>e)return o.num;if(e>=0&&1>e)return o.div0;e=parseInt(e,10);var t=parseInt(r,10);t+=r%1*Math.pow(10,Math.ceil(Math.log(e)/Math.LN10))/e;var n=Math.pow(10,Math.ceil(Math.log(e)/Math.LN2)+1);return t=Math.round(t*n)/n},e.DOLLARFR=function(r,e){if(r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e))return o.value;if(0>e)return o.num;if(e>=0&&1>e)return o.div0;e=parseInt(e,10);var t=parseInt(r,10);return t+=r%1*Math.pow(10,-Math.ceil(Math.log(e)/Math.LN10))*e},e.DURATION=function(){throw Error("DURATION is not implemented")},e.EFFECT=function(r,e){return r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e)?o.value:0>=r||1>e?o.num:(e=parseInt(e,10),Math.pow(1+r/e,e)-1)},e.FV=function(r,e,t,n,i){if(n=n||0,i=i||0,r=a.parseNumber(r),e=a.parseNumber(e),t=a.parseNumber(t),n=a.parseNumber(n),i=a.parseNumber(i),a.anyIsError(r,e,t,n,i))return o.value;var u;if(0===r)u=n+t*e;else{var s=Math.pow(1+r,e);u=1===i?n*s+t*(1+r)*(s-1)/r:n*s+t*(s-1)/r}return-u},e.FVSCHEDULE=function(r,e){if(r=a.parseNumber(r),e=a.parseNumberArray(a.flatten(e)),a.anyIsError(r,e))return o.value;for(var t=e.length,n=r,i=0;t>i;i++)n*=1+e[i];return n},e.INTRATE=function(){throw Error("INTRATE is not implemented")},e.IPMT=function(r,t,n,i,u,s){if(u=u||0,s=s||0,r=a.parseNumber(r),t=a.parseNumber(t),n=a.parseNumber(n),i=a.parseNumber(i),u=a.parseNumber(u),s=a.parseNumber(s),a.anyIsError(r,t,n,i,u,s))return o.value;var l=e.PMT(r,n,i,u,s);return(1===t?1===s?0:-i:1===s?e.FV(r,t-2,l,i,1)-l:e.FV(r,t-1,l,i,0))*r},e.IRR=function(r,e){if(e=e||0,r=a.parseNumberArray(a.flatten(r)),e=a.parseNumber(e),a.anyIsError(r,e))return o.value;for(var t=[],n=!1,i=!1,u=0;r.length>u;u++)t[u]=0===u?0:t[u-1]+365,r[u]>0&&(n=!0),0>r[u]&&(i=!0);if(!n||!i)return o.num;e=e===undefined?.1:e;var s,l,f,c=e,d=!0;do{f=function(r,e,t){for(var n=t+1,i=r[0],o=1;r.length>o;o++)i+=r[o]/Math.pow(n,(e[o]-e[0])/365);return i}(r,t,c),s=c-f/function(r,e,t){for(var n=t+1,i=0,o=1;r.length>o;o++){var u=(e[o]-e[0])/365;i-=u*r[o]/Math.pow(n,u+1)}return i}(r,t,c),l=Math.abs(s-c),c=s,d=l>1e-10&&Math.abs(f)>1e-10}while(d);return c},e.ISPMT=function(r,e,t,n){return r=a.parseNumber(r),e=a.parseNumber(e),t=a.parseNumber(t),n=a.parseNumber(n),a.anyIsError(r,e,t,n)?o.value:n*r*(e/t-1)},e.MDURATION=function(){throw Error("MDURATION is not implemented")},e.MIRR=function(r,t,n){if(r=a.parseNumberArray(a.flatten(r)),t=a.parseNumber(t),n=a.parseNumber(n),a.anyIsError(r,t,n))return o.value;for(var i=r.length,u=[],s=[],l=0;i>l;l++)0>r[l]?u.push(r[l]):s.push(r[l]);var f=-e.NPV(n,s)*Math.pow(1+n,i-1),c=e.NPV(t,u)*(1+t);return Math.pow(f/c,1/(i-1))-1},e.NOMINAL=function(r,e){return r=a.parseNumber(r),e=a.parseNumber(e),a.anyIsError(r,e)?o.value:0>=r||1>e?o.num:(e=parseInt(e,10),(Math.pow(r+1,1/e)-1)*e)},e.NPER=function(r,e,t,n,i){if(i=i===undefined?0:i,n=n===undefined?0:n,r=a.parseNumber(r),e=a.parseNumber(e),t=a.parseNumber(t),n=a.parseNumber(n),i=a.parseNumber(i),a.anyIsError(r,e,t,n,i))return o.value;var u=e*(1+r*i)-n*r,s=t*r+e*(1+r*i);return Math.log(u/s)/Math.log(1+r)},e.NPV=function(){var r=a.parseNumberArray(a.flatten(arguments));if(r instanceof Error)return r;for(var e=r[0],t=0,n=1;r.length>n;n++)t+=r[n]/Math.pow(1+e,n);return t},e.ODDFPRICE=function(){throw Error("ODDFPRICE is not implemented")},e.ODDFYIELD=function(){throw Error("ODDFYIELD is not implemented")},e.ODDLPRICE=function(){throw Error("ODDLPRICE is not implemented")},e.ODDLYIELD=function(){throw Error("ODDLYIELD is not implemented")},e.PDURATION=function(r,e,t){return r=a.parseNumber(r),e=a.parseNumber(e),t=a.parseNumber(t),a.anyIsError(r,e,t)?o.value:r>0?(Math.log(t)-Math.log(e))/Math.log(1+r):o.num},e.PMT=function(r,e,t,n,i){if(n=n||0,i=i||0,r=a.parseNumber(r),e=a.parseNumber(e),t=a.parseNumber(t),n=a.parseNumber(n),i=a.parseNumber(i),a.anyIsError(r,e,t,n,i))return o.value;var u;if(0===r)u=(t+n)/e;else{var s=Math.pow(1+r,e);u=1===i?(n*r/(s-1)+t*r/(1-1/s))/(1+r):n*r/(s-1)+t*r/(1-1/s)}return-u},e.PPMT=function(r,t,n,i,u,s){return u=u||0,s=s||0,r=a.parseNumber(r),n=a.parseNumber(n),i=a.parseNumber(i),u=a.parseNumber(u),s=a.parseNumber(s),a.anyIsError(r,n,i,u,s)?o.value:e.PMT(r,n,i,u,s)-e.IPMT(r,t,n,i,u,s)},e.PRICE=function(){throw Error("PRICE is not implemented")},e.PRICEDISC=function(){throw Error("PRICEDISC is not implemented")},e.PRICEMAT=function(){throw Error("PRICEMAT is not implemented")},e.PV=function(r,e,t,n,i){return n=n||0,i=i||0,r=a.parseNumber(r),e=a.parseNumber(e),t=a.parseNumber(t),n=a.parseNumber(n),i=a.parseNumber(i),a.anyIsError(r,e,t,n,i)?o.value:0===r?-t*e-n:((1-Math.pow(1+r,e))/r*t*(1+r*i)-n)/Math.pow(1+r,e)},e.RATE=function(r,e,t,n,i,u){if(u=u===undefined?.01:u,n=n===undefined?0:n,i=i===undefined?0:i,r=a.parseNumber(r),e=a.parseNumber(e),t=a.parseNumber(t),n=a.parseNumber(n),i=a.parseNumber(i),u=a.parseNumber(u),a.anyIsError(r,e,t,n,i,u))return o.value;var s,l,f,c,d=0,m=0,p=0,h=u;for(1e-10>Math.abs(h)?s=t*(1+r*h)+e*(1+h*i)*r+n:(m=Math.exp(r*Math.log(1+h)),s=t*m+e*(1/h+i)*(m-1)+n),l=t+e*r+n,f=t*m+e*(1/h+i)*(m-1)+n,p=c=0,d=h;Math.abs(l-f)>1e-10&&50>p;)h=(f*c-l*d)/(f-l),c=d,d=h,1e-10>Math.abs(h)?s=t*(1+r*h)+e*(1+h*i)*r+n:(m=Math.exp(r*Math.log(1+h)),s=t*m+e*(1/h+i)*(m-1)+n),l=f,f=s,++p;return h},e.RECEIVED=function(){throw Error("RECEIVED is not implemented")},e.RRI=function(r,e,t){return r=a.parseNumber(r),e=a.parseNumber(e),t=a.parseNumber(t),a.anyIsError(r,e,t)?o.value:0===r||0===e?o.num:Math.pow(t/e,1/r)-1},e.SLN=function(r,e,t){return r=a.parseNumber(r),e=a.parseNumber(e),t=a.parseNumber(t),a.anyIsError(r,e,t)?o.value:0===t?o.num:(r-e)/t},e.SYD=function(r,e,t,n){return r=a.parseNumber(r),e=a.parseNumber(e),t=a.parseNumber(t),n=a.parseNumber(n),a.anyIsError(r,e,t,n)?o.value:0===t?o.num:1>n||n>t?o.num:(n=parseInt(n,10),(r-e)*(t-n+1)*2/(t*(t+1)))},e.TBILLEQ=function(r,e,t){return r=a.parseDate(r),e=a.parseDate(e),t=a.parseNumber(t),a.anyIsError(r,e,t)?o.value:t>0?r>e?o.num:e-r>31536e6?o.num:365*t/(360-t*u.DAYS360(r,e,!1)):o.num},e.TBILLPRICE=function(r,e,t){return r=a.parseDate(r),e=a.parseDate(e),t=a.parseNumber(t),a.anyIsError(r,e,t)?o.value:t>0?r>e?o.num:e-r>31536e6?o.num:100*(1-t*u.DAYS360(r,e,!1)/360):o.num},e.TBILLYIELD=function(r,e,t){return r=a.parseDate(r),e=a.parseDate(e),t=a.parseNumber(t),a.anyIsError(r,e,t)?o.value:t>0?r>e?o.num:e-r>31536e6?o.num:360*(100-t)/(t*u.DAYS360(r,e,!1)):o.num},e.VDB=function(){throw Error("VDB is not implemented")},e.XNPV=function(r,e,t){if(r=a.parseNumber(r),e=a.parseNumberArray(a.flatten(e)),t=a.parseDateArray(a.flatten(t)),a.anyIsError(r,e,t))return o.value;for(var n=0,i=0;e.length>i;i++)n+=e[i]/Math.pow(1+r,u.DAYS(t[i],t[0])/365);return n},e.YIELD=function(){throw Error("YIELD is not implemented")},e.YIELDDISC=function(){throw Error("YIELDDISC is not implemented")},e.YIELDMAT=function(){throw Error("YIELDMAT is not implemented")}},function(r,e,t){var n=t(0),i=t(1);e.MATCH=function(r,e,t){if(!r&&!e)return n.na;if(2===arguments.length&&(t=1),!(e instanceof Array))return n.na;if(-1!==t&&0!==t&&1!==t)return n.na;for(var i,o,u=0;e.length>u;u++)if(1===t){if(e[u]===r)return u+1;r>e[u]&&(o?e[u]>o&&(i=u+1,o=e[u]):(i=u+1,o=e[u]))}else if(0===t){if("string"==typeof r){if(r=r.replace(/\?/g,"."),e[u].toLowerCase().match(r.toLowerCase()))return u+1}else if(e[u]===r)return u+1}else if(-1===t){if(e[u]===r)return u+1;e[u]>r&&(o?o>e[u]&&(i=u+1,o=e[u]):(i=u+1,o=e[u]))}return i||n.na},e.VLOOKUP=function(r,e,t,i){if(!r||!e||!t)return n.na;i=i||!1;for(var o=0;e.length>o;o++){var u=e[o];if(!i&&u[0]===r||u[0]===r||i&&"string"==typeof u[0]&&-1!==u[0].toLowerCase().indexOf(r.toLowerCase()))return u.length+1>t?u[t-1]:n.ref}return n.na},e.HLOOKUP=function(r,e,t,o){if(!r||!e||!t)return n.na;o=o||!1;for(var u=i.transpose(e),a=0;u.length>a;a++){var s=u[a];if(!o&&s[0]===r||s[0]===r||o&&"string"==typeof s[0]&&-1!==s[0].toLowerCase().indexOf(r.toLowerCase()))return s.length+1>t?s[t-1]:n.ref}return n.na}},function(r,e,t){"use strict";function n(r,e){return r>e}e.__esModule=!0,e["default"]=n,n.SYMBOL=e.SYMBOL=">"},function(r,e,t){"use strict";function n(r,e){return r>=e}e.__esModule=!0,e["default"]=n,n.SYMBOL=e.SYMBOL=">="},function(r,e,t){"use strict";function n(r,e){return e>r}e.__esModule=!0,e["default"]=n,n.SYMBOL=e.SYMBOL="<"},function(r,e,t){"use strict";function n(r,e){return e>=r}e.__esModule=!0,e["default"]=n,n.SYMBOL=e.SYMBOL="<="},function(r,e,t){"use strict";function n(r){for(var e=arguments.length,t=Array(e>1?e-1:0),n=1;e>n;n++)t[n-1]=arguments[n];var u=t.reduce(function(r,e){return r-(0,i.toNumber)(e)},(0,i.toNumber)(r));if(isNaN(u))throw Error(o.ERROR_VALUE);return u}e.__esModule=!0,e.SYMBOL=undefined,e["default"]=n;var i=t(3),o=t(2);n.SYMBOL=e.SYMBOL="-"},function(r,e,t){"use strict";function n(r){for(var e=arguments.length,t=Array(e>1?e-1:0),n=1;e>n;n++)t[n-1]=arguments[n];var u=t.reduce(function(r,e){return r*(0,i.toNumber)(e)},(0,i.toNumber)(r));if(isNaN(u))throw Error(o.ERROR_VALUE);return u}e.__esModule=!0,e.SYMBOL=undefined,e["default"]=n;var i=t(3),o=t(2);n.SYMBOL=e.SYMBOL="*"},function(r,e,t){"use strict";function n(r,e){return r!==e}e.__esModule=!0,e["default"]=n,n.SYMBOL=e.SYMBOL="<>"},function(r,e,t){"use strict";function n(r,e){var t=Math.pow((0,i.toNumber)(r),(0,i.toNumber)(e));if(isNaN(t))throw Error(o.ERROR_VALUE);return t}e.__esModule=!0,e.SYMBOL=undefined,e["default"]=n;var i=t(3),o=t(2);n.SYMBOL=e.SYMBOL="^"},function(module,exports,__webpack_require__){(function(module,process){var grammarParser=function(){function Parser(){this.yy={}}var o=function(r,e,t,n){for(t=t||{},n=r.length;n--;t[r[n]]=e);return t},$V0=[1,5],$V1=[1,8],$V2=[1,6],$V3=[1,7],$V4=[1,9],$V5=[1,14],$V6=[1,15],$V7=[1,16],$V8=[1,12],$V9=[1,13],$Va=[1,17],$Vb=[1,19],$Vc=[1,20],$Vd=[1,21],$Ve=[1,22],$Vf=[1,23],$Vg=[1,24],$Vh=[1,25],$Vi=[1,26],$Vj=[1,27],$Vk=[1,28],$Vl=[5,9,10,11,13,14,15,16,17,18,19,20,29,30],$Vm=[5,9,10,11,13,14,15,16,17,18,19,20,29,30,32],$Vn=[5,9,10,11,13,14,15,16,17,18,19,20,29,30,34],$Vo=[5,10,11,13,14,15,16,17,29,30],$Vp=[5,10,13,14,15,16,29,30],$Vq=[5,10,11,13,14,15,16,17,18,19,29,30],$Vr=[13,29,30],parser={trace:function(){},yy:{},symbols_:{error:2,expressions:3,expression:4,EOF:5,variableSequence:6,number:7,STRING:8,"&":9,"=":10,"+":11,"(":12,")":13,"<":14,">":15,NOT:16,"-":17,"*":18,"/":19,"^":20,FUNCTION:21,expseq:22,cell:23,ABSOLUTE_CELL:24,RELATIVE_CELL:25,MIXED_CELL:26,":":27,ARRAY:28,";":29,",":30,VARIABLE:31,DECIMAL:32,NUMBER:33,"%":34,ERROR:35,$accept:0,$end:1},terminals_:{5:"EOF",8:"STRING",9:"&",10:"=",11:"+",12:"(",13:")",14:"<",15:">",16:"NOT",17:"-",18:"*",19:"/",20:"^",21:"FUNCTION",24:"ABSOLUTE_CELL",25:"RELATIVE_CELL",26:"MIXED_CELL",27:":",28:"ARRAY",29:";",30:",",31:"VARIABLE",32:"DECIMAL",33:"NUMBER",34:"%",35:"ERROR"},productions_:[0,[3,2],[4,1],[4,1],[4,1],[4,3],[4,3],[4,3],[4,3],[4,4],[4,4],[4,4],[4,3],[4,3],[4,3],[4,3],[4,3],[4,3],[4,3],[4,2],[4,2],[4,3],[4,4],[4,1],[4,1],[4,2],[23,1],[23,1],[23,1],[23,3],[23,3],[23,3],[23,3],[23,3],[23,3],[23,3],[23,3],[23,3],[22,1],[22,1],[22,3],[22,3],[6,1],[6,3],[7,1],[7,3],[7,2],[2,1]],performAction:function anonymous(yytext,yyleng,yylineno,yy,yystate,$$,_$){var $0=$$.length-1;switch(yystate){case 1:return $$[$0-1];case 2:this.$=yy.callVariable($$[$0][0]);break;case 3:this.$=yy.toNumber($$[$0]);break;case 4:this.$=yy.trimEdges($$[$0]);break;case 5:this.$=yy.evaluateByOperator("&",[$$[$0-2],$$[$0]]);break;case 6:this.$=yy.evaluateByOperator("=",[$$[$0-2],$$[$0]]);break;case 7:this.$=yy.evaluateByOperator("+",[$$[$0-2],$$[$0]]);break;case 8:this.$=$$[$0-1];break;case 9:this.$=yy.evaluateByOperator("<=",[$$[$0-3],$$[$0]]);break;case 10:this.$=yy.evaluateByOperator(">=",[$$[$0-3],$$[$0]]);break;case 11:this.$=yy.evaluateByOperator("<>",[$$[$0-3],$$[$0]]);break;case 12:this.$=yy.evaluateByOperator("NOT",[$$[$0-2],$$[$0]]);break;case 13:this.$=yy.evaluateByOperator(">",[$$[$0-2],$$[$0]]);break;case 14:this.$=yy.evaluateByOperator("<",[$$[$0-2],$$[$0]]);break;case 15:this.$=yy.evaluateByOperator("-",[$$[$0-2],$$[$0]]);break;case 16:this.$=yy.evaluateByOperator("*",[$$[$0-2],$$[$0]]);break;case 17:this.$=yy.evaluateByOperator("/",[$$[$0-2],$$[$0]]);break;case 18:this.$=yy.evaluateByOperator("^",[$$[$0-2],$$[$0]]);break;case 19:var n1=yy.invertNumber($$[$0]);this.$=n1,isNaN(this.$)&&(this.$=0);break;case 20:var n1=yy.toNumber($$[$0]);this.$=n1,isNaN(this.$)&&(this.$=0);break;case 21:this.$=yy.callFunction($$[$0-2]);break;case 22:this.$=yy.callFunction($$[$0-3],$$[$0-1]);break;case 26:case 27:case 28:this.$=yy.cellValue($$[$0]);break;case 29:case 30:case 31:case 32:case 33:case 34:case 35:case 36:case 37:this.$=yy.rangeValue($$[$0-2],$$[$0]);break;case 38:case 42:this.$=[$$[$0]];break;case 39:var result=[],arr=eval("["+yytext+"]");arr.forEach(function(r){result.push(r)}),this.$=result;break;case 40:case 41:$$[$0-2].push($$[$0]),this.$=$$[$0-2];break;case 43:this.$=Array.isArray($$[$0-2])?$$[$0-2]:[$$[$0-2]],this.$.push($$[$0]);break;case 44:this.$=$$[$0];break;case 45:this.$=1*($$[$0-2]+"."+$$[$0]);break;case 46:this.$=.01*$$[$0-1];break;case 47:this.$=yy.throwError($$[$0])}},table:[{2:11,3:1,4:2,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{1:[3]},{5:[1,18],9:$Vb,10:$Vc,11:$Vd,14:$Ve,15:$Vf,16:$Vg,17:$Vh,18:$Vi,19:$Vj,20:$Vk},o($Vl,[2,2],{32:[1,29]}),o($Vl,[2,3],{34:[1,30]}),o($Vl,[2,4]),{2:11,4:31,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:32,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:33,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{12:[1,34]},o($Vl,[2,23]),o($Vl,[2,24],{2:35,35:$Va}),o($Vm,[2,42]),o($Vn,[2,44],{32:[1,36]}),o($Vl,[2,26],{27:[1,37]}),o($Vl,[2,27],{27:[1,38]}),o($Vl,[2,28],{27:[1,39]}),o([5,9,10,11,13,14,15,16,17,18,19,20,29,30,35],[2,47]),{1:[2,1]},{2:11,4:40,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:41,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:42,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:45,6:3,7:4,8:$V0,10:[1,43],11:$V1,12:$V2,15:[1,44],17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:47,6:3,7:4,8:$V0,10:[1,46],11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:48,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:49,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:50,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:51,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:52,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{31:[1,53]},o($Vn,[2,46]),{9:$Vb,10:$Vc,11:$Vd,13:[1,54],14:$Ve,15:$Vf,16:$Vg,17:$Vh,18:$Vi,19:$Vj,20:$Vk},o($Vo,[2,19],{9:$Vb,18:$Vi,19:$Vj,20:$Vk}),o($Vo,[2,20],{9:$Vb,18:$Vi,19:$Vj,20:$Vk}),{2:11,4:57,6:3,7:4,8:$V0,11:$V1,12:$V2,13:[1,55],17:$V3,21:$V4,22:56,23:10,24:$V5,25:$V6,26:$V7,28:[1,58],31:$V8,33:$V9,35:$Va},o($Vl,[2,25]),{33:[1,59]},{24:[1,60],25:[1,61],26:[1,62]},{24:[1,63],25:[1,64],26:[1,65]},{24:[1,66],25:[1,67],26:[1,68]},o($Vl,[2,5]),o([5,10,13,29,30],[2,6],{9:$Vb,11:$Vd,14:$Ve,15:$Vf,16:$Vg,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o($Vo,[2,7],{9:$Vb,18:$Vi,19:$Vj,20:$Vk}),{2:11,4:69,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:70,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},o($Vp,[2,14],{9:$Vb,11:$Vd,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),{2:11,4:71,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},o($Vp,[2,13],{9:$Vb,11:$Vd,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o([5,10,13,16,29,30],[2,12],{9:$Vb,11:$Vd,14:$Ve,15:$Vf,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o($Vo,[2,15],{9:$Vb,18:$Vi,19:$Vj,20:$Vk}),o($Vq,[2,16],{9:$Vb,20:$Vk}),o($Vq,[2,17],{9:$Vb,20:$Vk}),o([5,10,11,13,14,15,16,17,18,19,20,29,30],[2,18],{9:$Vb}),o($Vm,[2,43]),o($Vl,[2,8]),o($Vl,[2,21]),{13:[1,72],29:[1,73],30:[1,74]},o($Vr,[2,38],{9:$Vb,10:$Vc,11:$Vd,14:$Ve,15:$Vf,16:$Vg,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o($Vr,[2,39]),o($Vn,[2,45]),o($Vl,[2,29]),o($Vl,[2,30]),o($Vl,[2,31]),o($Vl,[2,32]),o($Vl,[2,33]),o($Vl,[2,34]),o($Vl,[2,35]),o($Vl,[2,36]),o($Vl,[2,37]),o($Vp,[2,9],{9:$Vb,11:$Vd,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o($Vp,[2,11],{9:$Vb,11:$Vd,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o($Vp,[2,10],{9:$Vb,11:$Vd,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o($Vl,[2,22]),{2:11,4:75,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},{2:11,4:76,6:3,7:4,8:$V0,11:$V1,12:$V2,17:$V3,21:$V4,23:10,24:$V5,25:$V6,26:$V7,31:$V8,33:$V9,35:$Va},o($Vr,[2,40],{9:$Vb,10:$Vc,11:$Vd,14:$Ve,15:$Vf,16:$Vg,17:$Vh,18:$Vi,19:$Vj,20:$Vk}),o($Vr,[2,41],{9:$Vb,10:$Vc,11:$Vd,14:$Ve,15:$Vf,16:$Vg,17:$Vh,18:$Vi,19:$Vj,20:$Vk})],defaultActions:{18:[2,1]},parseError:function(r,e){function t(r,e){this.message=r,this.hash=e}if(!e.recoverable)throw t.prototype=Error,new t(r,e);this.trace(r)},parse:function(r){function e(r){for(var e=n.length-1,t=0;;){if(""+c in u[r])return t;if(0===r||2>e)return!1;e-=2,r=n[e],++t}}var t=this,n=[0],i=[null],o=[],u=this.table,a="",s=0,l=0,f=0,c=2,d=o.slice.call(arguments,1),m=Object.create(this.lexer),p={yy:{}};for(var h in this.yy)Object.prototype.hasOwnProperty.call(this.yy,h)&&(p.yy[h]=this.yy[h]);m.setInput(r,p.yy),p.yy.lexer=m,p.yy.parser=this,"undefined"==typeof m.yylloc&&(m.yylloc={});var b=m.yylloc;o.push(b);var v=m.options&&m.options.ranges;this.parseError="function"==typeof p.yy.parseError?p.yy.parseError:Object.getPrototypeOf(this).parseError;for(var g,E,N,y,w,I,M,x,A,R=function(){var r;return r=m.lex()||1,"number"!=typeof r&&(r=t.symbols_[r]||r),r},T={};;){if(N=n[n.length-1],this.defaultActions[N]?y=this.defaultActions[N]:(null!==g&&void 0!==g||(g=R()),y=u[N]&&u[N][g]),void 0===y||!y.length||!y[0]){var C,S="";if(f)1!==E&&(C=e(N));else{C=e(N),A=[];for(I in u[N])this.terminals_[I]&&I>c&&A.push("'"+this.terminals_[I]+"'");S=m.showPosition?"Parse error on line "+(s+1)+":\n"+m.showPosition()+"\nExpecting "+A.join(", ")+", got '"+(this.terminals_[g]||g)+"'":"Parse error on line "+(s+1)+": Unexpected "+(1==g?"end of input":"'"+(this.terminals_[g]||g)+"'"),this.parseError(S,{text:m.match,token:this.terminals_[g]||g,line:m.yylineno,loc:b,expected:A,recoverable:!1!==C})}if(3==f){if(1===g||1===E)throw Error(S||"Parsing halted while starting to recover from another error.");l=m.yyleng,a=m.yytext,s=m.yylineno,b=m.yylloc,g=R()}if(!1===C)throw Error(S||"Parsing halted. No suitable error recovery rule available.");!function(r){n.length=n.length-2*r,i.length=i.length-r,o.length=o.length-r}(C),E=g==c?null:g,g=c,N=n[n.length-1],y=u[N]&&u[N][c],f=3}if(y[0]instanceof Array&&y.length>1)throw Error("Parse Error: multiple actions possible at state: "+N+", token: "+g);switch(y[0]){case 1:n.push(g),i.push(m.yytext),o.push(m.yylloc),n.push(y[1]),g=null,E?(g=E,E=null):(l=m.yyleng,a=m.yytext,s=m.yylineno,b=m.yylloc,f>0&&f--);break;case 2:if(M=this.productions_[y[1]][1],T.$=i[i.length-M],T._$={first_line:o[o.length-(M||1)].first_line,last_line:o[o.length-1].last_line,first_column:o[o.length-(M||1)].first_column,last_column:o[o.length-1].last_column},v&&(T._$.range=[o[o.length-(M||1)].range[0],o[o.length-1].range[1]]),void 0!==(w=this.performAction.apply(T,[a,l,s,p.yy,y[1],i,o].concat(d))))return w;M&&(n=n.slice(0,-1*M*2),i=i.slice(0,-1*M),o=o.slice(0,-1*M)),n.push(this.productions_[y[1]][0]),i.push(T.$),o.push(T._$),x=u[n[n.length-2]][n[n.length-1]],n.push(x);break;case 3:return!0}}return!0}},lexer=function(){return{EOF:1,parseError:function(r,e){if(!this.yy.parser)throw Error(r);this.yy.parser.parseError(r,e)},setInput:function(r,e){return this.yy=e||this.yy||{},this._input=r,this._more=this._backtrack=this.done=!1,this.yylineno=this.yyleng=0,this.yytext=this.matched=this.match="",this.conditionStack=["INITIAL"],this.yylloc={first_line:1,first_column:0,last_line:1,last_column:0},this.options.ranges&&(this.yylloc.range=[0,0]),this.offset=0,this},input:function(){var r=this._input[0];return this.yytext+=r,this.yyleng++,this.offset++,this.match+=r,this.matched+=r,r.match(/(?:\r\n?|\n).*/g)?(this.yylineno++,this.yylloc.last_line++):this.yylloc.last_column++,this.options.ranges&&this.yylloc.range[1]++,this._input=this._input.slice(1),r},unput:function(r){var e=r.length,t=r.split(/(?:\r\n?|\n)/g);this._input=r+this._input,this.yytext=this.yytext.substr(0,this.yytext.length-e),this.offset-=e;var n=this.match.split(/(?:\r\n?|\n)/g);this.match=this.match.substr(0,this.match.length-1),this.matched=this.matched.substr(0,this.matched.length-1),t.length-1&&(this.yylineno-=t.length-1);var i=this.yylloc.range;return this.yylloc={first_line:this.yylloc.first_line,last_line:this.yylineno+1,first_column:this.yylloc.first_column,last_column:t?(t.length===n.length?this.yylloc.first_column:0)+n[n.length-t.length].length-t[0].length:this.yylloc.first_column-e},this.options.ranges&&(this.yylloc.range=[i[0],i[0]+this.yyleng-e]),this.yyleng=this.yytext.length,this},more:function(){return this._more=!0,this},reject:function(){return this.options.backtrack_lexer?(this._backtrack=!0,this):this.parseError("Lexical error on line "+(this.yylineno+1)+". You can only invoke reject() in the lexer when the lexer is of the backtracking persuasion (options.backtrack_lexer = true).\n"+this.showPosition(),{text:"",token:null,line:this.yylineno})},less:function(r){this.unput(this.match.slice(r))},pastInput:function(){var r=this.matched.substr(0,this.matched.length-this.match.length);return(r.length>20?"...":"")+r.substr(-20).replace(/\n/g,"")},upcomingInput:function(){var r=this.match;return 20>r.length&&(r+=this._input.substr(0,20-r.length)),(r.substr(0,20)+(r.length>20?"...":"")).replace(/\n/g,"")},showPosition:function(){var r=this.pastInput(),e=Array(r.length+1).join("-");return r+this.upcomingInput()+"\n"+e+"^"},test_match:function(r,e){var t,n,i;if(this.options.backtrack_lexer&&(i={yylineno:this.yylineno,yylloc:{first_line:this.yylloc.first_line,last_line:this.last_line,first_column:this.yylloc.first_column,last_column:this.yylloc.last_column},yytext:this.yytext,match:this.match,matches:this.matches,matched:this.matched,yyleng:this.yyleng,offset:this.offset,_more:this._more,_input:this._input,yy:this.yy,conditionStack:this.conditionStack.slice(0),done:this.done},this.options.ranges&&(i.yylloc.range=this.yylloc.range.slice(0))),n=r[0].match(/(?:\r\n?|\n).*/g),n&&(this.yylineno+=n.length),this.yylloc={first_line:this.yylloc.last_line,last_line:this.yylineno+1,first_column:this.yylloc.last_column,last_column:n?n[n.length-1].length-n[n.length-1].match(/\r?\n?/)[0].length:this.yylloc.last_column+r[0].length},this.yytext+=r[0],this.match+=r[0],this.matches=r,this.yyleng=this.yytext.length,this.options.ranges&&(this.yylloc.range=[this.offset,this.offset+=this.yyleng]),this._more=!1,this._backtrack=!1,this._input=this._input.slice(r[0].length),this.matched+=r[0],t=this.performAction.call(this,this.yy,this,e,this.conditionStack[this.conditionStack.length-1]),this.done&&this._input&&(this.done=!1),t)return t;if(this._backtrack){for(var o in i)this[o]=i[o];return!1}return!1},next:function(){if(this.done)return this.EOF;this._input||(this.done=!0);var r,e,t,n;this._more||(this.yytext="",this.match="");for(var i=this._currentRules(),o=0;i.length>o;o++)if((t=this._input.match(this.rules[i[o]]))&&(!e||t[0].length>e[0].length)){if(e=t,n=o,this.options.backtrack_lexer){if(!1!==(r=this.test_match(t,i[o])))return r;if(this._backtrack){e=!1;continue}return!1}if(!this.options.flex)break}return e?!1!==(r=this.test_match(e,i[n]))&&r:""===this._input?this.EOF:this.parseError("Lexical error on line "+(this.yylineno+1)+". Unrecognized text.\n"+this.showPosition(),{text:"",token:null,line:this.yylineno})},lex:function(){var r=this.next();return r||this.lex()},begin:function(r){this.conditionStack.push(r)},popState:function(){return this.conditionStack.length-1>0?this.conditionStack.pop():this.conditionStack[0]},_currentRules:function(){return this.conditionStack.length&&this.conditionStack[this.conditionStack.length-1]?this.conditions[this.conditionStack[this.conditionStack.length-1]].rules:this.conditions.INITIAL.rules},topState:function(r){return r=this.conditionStack.length-1-Math.abs(r||0),0>r?"INITIAL":this.conditionStack[r]},pushState:function(r){this.begin(r)},stateStackSize:function(){return this.conditionStack.length},options:{},performAction:function(r,e,t,n){switch(t){case 0:break;case 1:case 2:return 8;case 3:return 21;case 4:return 35;case 5:return 24;case 6:case 7:return 26;case 8:return 25;case 9:return 21;case 10:case 11:return 31;case 12:return 33;case 13:return 28;case 14:return 9;case 15:return" ";case 16:return 32;case 17:return 27;case 18:return 29;case 19:return 30;case 20:return 18;case 21:return 19;case 22:return 17;case 23:return 11;case 24:return 20;case 25:return 12;case 26:return 13;case 27:return 15;case 28:return 14;case 29:return 16;case 30:return'"';case 31:return"'";case 32:return"!";case 33:return 10;case 34:return 34;case 35:return"#";case 36:return 5}},rules:[/^(?:\s+)/,/^(?:"(\\["]|[^"])*")/,/^(?:'(\\[']|[^'])*')/,/^(?:[A-Za-z]{1,}[A-Za-z_0-9\.]+(?=[(]))/,/^(?:#[A-Z0-9\/]+(!|\?)?)/,/^(?:\$[A-Za-z]+\$[0-9]+)/,/^(?:\$[A-Za-z]+[0-9]+)/,/^(?:[A-Za-z]+\$[0-9]+)/,/^(?:[A-Za-z]+[0-9]+)/,/^(?:[A-Za-z\.]+(?=[(]))/,/^(?:[A-Za-z]{1,}[A-Za-z_0-9]+)/,/^(?:[A-Za-z_]+)/,/^(?:[0-9]+)/,/^(?:\[(.*)?\])/,/^(?:&)/,/^(?: )/,/^(?:[.])/,/^(?::)/,/^(?:;)/,/^(?:,)/,/^(?:\*)/,/^(?:\/)/,/^(?:-)/,/^(?:\+)/,/^(?:\^)/,/^(?:\()/,/^(?:\))/,/^(?:>)/,/^(?:<)/,/^(?:NOT\b)/,/^(?:")/,/^(?:')/,/^(?:!)/,/^(?:=)/,/^(?:%)/,/^(?:[#])/,/^(?:$)/],conditions:{INITIAL:{rules:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36],inclusive:!0}}}}();return parser.lexer=lexer,Parser.prototype=parser,parser.Parser=Parser,new Parser}();exports.parser=grammarParser,exports.Parser=grammarParser.Parser,exports.parse=function(){return grammarParser.parse.apply(grammarParser,arguments)},void 0!==module&&__webpack_require__.c[__webpack_require__.s]===module&&exports.main(process.argv.slice(1))}).call(exports,__webpack_require__(102)(module),__webpack_require__(10))},function(r,e){r.exports=function(r){return r.webpackPolyfill||(r.deprecate=function(){},r.paths=[],r.children||(r.children=[]),Object.defineProperty(r,"loaded",{enumerable:!0,get:function(){return r.l}}),Object.defineProperty(r,"id",{enumerable:!0,get:function(){return r.i}}),r.webpackPolyfill=1),r}},function(r,e,t){"use strict";function n(r){var e=arguments.length>1&&arguments[1]!==undefined?arguments[1]:1;return r=r.substring(e,r.length-e)}e.__esModule=!0,e.trimEdges=n}])}); \ No newline at end of file diff --git a/package.json b/package.json index 111d1430..b023063e 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "hot-formula-parser", - "version": "2.0.3", + "version": "2.1.0", "description": "Formula parser", "browser": "dist/formula-parser.js", "main": "lib/index.js",