UNPKG

mathjs

Version:

Math.js is an extensive math library for JavaScript and Node.js. It features a flexible expression parser and offers an integrated solution to work with numbers, big numbers, complex numbers, units, and matrices.

64 lines (56 loc) 1.65 kB
module.exports = function (math) { var Matrix = require('../../type/Matrix'), collection = require('../../type/collection'), isCollection = collection.isCollection; /** * Compute the sum of a list of values * In case of a (multi dimensional) array or matrix, the sum of all * elements will be calculated. * * sum(a, b, c, ...) * sum(A) * * @param {... *} args A single matrix or or multiple scalar values * @return {*} res */ math.sum = function sum(args) { if (arguments.length == 0) { throw new SyntaxError('Function sum requires one or more parameters (0 provided)'); } if (isCollection(args)) { if (arguments.length == 1) { // sum([a, b, c, d, ...]) return _sum(args); } else if (arguments.length == 2) { // sum([a, b, c, d, ...], dim) // TODO: implement sum(A, dim) throw new Error('sum(A, dim) is not yet supported'); //return collection.reduce(arguments[0], arguments[1], math.add); } else { throw new SyntaxError('Wrong number of parameters'); } } else { // sum(a, b, c, d, ...) return _sum(arguments); } }; /** * Recursively calculate the sum of an n-dimensional array * @param {Array} array * @return {Number} sum * @private */ function _sum(array) { var sum = undefined; collection.deepForEach(array, function (value) { sum = (sum === undefined) ? value : math.add(sum, value); }); if (sum === undefined) { throw new Error('Cannot calculate sum of an empty array'); } return sum; } };