min.js (3373B)
1 "use strict"; 2 3 Object.defineProperty(exports, "__esModule", { 4 value: true 5 }); 6 exports.createMin = void 0; 7 8 var _collection = require("../../utils/collection.js"); 9 10 var _factory = require("../../utils/factory.js"); 11 12 var _improveErrorMessage = require("./utils/improveErrorMessage.js"); 13 14 var name = 'min'; 15 var dependencies = ['typed', 'config', 'numeric', 'smaller']; 16 var createMin = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) { 17 var typed = _ref.typed, 18 config = _ref.config, 19 numeric = _ref.numeric, 20 smaller = _ref.smaller; 21 22 /** 23 * Compute the minimum value of a matrix or a list of values. 24 * In case of a multi dimensional array, the minimum of the flattened array 25 * will be calculated. When `dim` is provided, the minimum over the selected 26 * dimension will be calculated. Parameter `dim` is zero-based. 27 * 28 * Syntax: 29 * 30 * math.min(a, b, c, ...) 31 * math.min(A) 32 * math.min(A, dim) 33 * 34 * Examples: 35 * 36 * math.min(2, 1, 4, 3) // returns 1 37 * math.min([2, 1, 4, 3]) // returns 1 38 * 39 * // minimum over a specified dimension (zero-based) 40 * math.min([[2, 5], [4, 3], [1, 7]], 0) // returns [1, 3] 41 * math.min([[2, 5], [4, 3], [1, 7]], 1) // returns [2, 3, 1] 42 * 43 * math.max(2.7, 7.1, -4.5, 2.0, 4.1) // returns 7.1 44 * math.min(2.7, 7.1, -4.5, 2.0, 4.1) // returns -4.5 45 * 46 * See also: 47 * 48 * mean, median, max, prod, std, sum, variance 49 * 50 * @param {... *} args A single matrix or or multiple scalar values 51 * @return {*} The minimum value 52 */ 53 return typed(name, { 54 // min([a, b, c, d, ...]) 55 'Array | Matrix': _min, 56 // min([a, b, c, d, ...], dim) 57 'Array | Matrix, number | BigNumber': function ArrayMatrixNumberBigNumber(array, dim) { 58 return (0, _collection.reduce)(array, dim.valueOf(), _smallest); 59 }, 60 // min(a, b, c, d, ...) 61 '...': function _(args) { 62 if ((0, _collection.containsCollections)(args)) { 63 throw new TypeError('Scalar values expected in function min'); 64 } 65 66 return _min(args); 67 } 68 }); 69 /** 70 * Return the smallest of two values 71 * @param {*} x 72 * @param {*} y 73 * @returns {*} Returns x when x is smallest, or y when y is smallest 74 * @private 75 */ 76 77 function _smallest(x, y) { 78 try { 79 return smaller(x, y) ? x : y; 80 } catch (err) { 81 throw (0, _improveErrorMessage.improveErrorMessage)(err, 'min', y); 82 } 83 } 84 /** 85 * Recursively calculate the minimum value in an n-dimensional array 86 * @param {Array} array 87 * @return {number} min 88 * @private 89 */ 90 91 92 function _min(array) { 93 var min; 94 (0, _collection.deepForEach)(array, function (value) { 95 try { 96 if (isNaN(value) && typeof value === 'number') { 97 min = NaN; 98 } else if (min === undefined || smaller(value, min)) { 99 min = value; 100 } 101 } catch (err) { 102 throw (0, _improveErrorMessage.improveErrorMessage)(err, 'min', value); 103 } 104 }); 105 106 if (min === undefined) { 107 throw new Error('Cannot calculate min of an empty array'); 108 } // make sure returning numeric value: parse a string into a numeric value 109 110 111 if (typeof min === 'string') { 112 min = numeric(min, config.number); 113 } 114 115 return min; 116 } 117 }); 118 exports.createMin = createMin;