floor.js 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.createFloorNumber = exports.createFloor = void 0;
  7. var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
  8. var _decimal = _interopRequireDefault(require("decimal.js"));
  9. var _factory = require("../../utils/factory.js");
  10. var _collection = require("../../utils/collection.js");
  11. var _number = require("../../utils/number.js");
  12. var _nearlyEqual = require("../../utils/bignumber/nearlyEqual.js");
  13. var _matAlgo11xS0s = require("../../type/matrix/utils/matAlgo11xS0s.js");
  14. var _matAlgo12xSfs = require("../../type/matrix/utils/matAlgo12xSfs.js");
  15. var _matAlgo14xDs = require("../../type/matrix/utils/matAlgo14xDs.js");
  16. var name = 'floor';
  17. var dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix'];
  18. var createFloorNumber = /* #__PURE__ */(0, _factory.factory)(name, ['typed', 'config', 'round'], function (_ref) {
  19. var typed = _ref.typed,
  20. config = _ref.config,
  21. round = _ref.round;
  22. return typed(name, {
  23. number: function number(x) {
  24. if ((0, _number.nearlyEqual)(x, round(x), config.epsilon)) {
  25. return round(x);
  26. } else {
  27. return Math.floor(x);
  28. }
  29. },
  30. 'number, number': function numberNumber(x, n) {
  31. if ((0, _number.nearlyEqual)(x, round(x, n), config.epsilon)) {
  32. return round(x, n);
  33. } else {
  34. var _split = "".concat(x, "e").split('e'),
  35. _split2 = (0, _slicedToArray2["default"])(_split, 2),
  36. number = _split2[0],
  37. exponent = _split2[1];
  38. var result = Math.floor(Number("".concat(number, "e").concat(Number(exponent) + n)));
  39. var _split3 = "".concat(result, "e").split('e');
  40. var _split4 = (0, _slicedToArray2["default"])(_split3, 2);
  41. number = _split4[0];
  42. exponent = _split4[1];
  43. return Number("".concat(number, "e").concat(Number(exponent) - n));
  44. }
  45. }
  46. });
  47. });
  48. exports.createFloorNumber = createFloorNumber;
  49. var createFloor = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref2) {
  50. var typed = _ref2.typed,
  51. config = _ref2.config,
  52. round = _ref2.round,
  53. matrix = _ref2.matrix,
  54. equalScalar = _ref2.equalScalar,
  55. zeros = _ref2.zeros,
  56. DenseMatrix = _ref2.DenseMatrix;
  57. var matAlgo11xS0s = (0, _matAlgo11xS0s.createMatAlgo11xS0s)({
  58. typed: typed,
  59. equalScalar: equalScalar
  60. });
  61. var matAlgo12xSfs = (0, _matAlgo12xSfs.createMatAlgo12xSfs)({
  62. typed: typed,
  63. DenseMatrix: DenseMatrix
  64. });
  65. var matAlgo14xDs = (0, _matAlgo14xDs.createMatAlgo14xDs)({
  66. typed: typed
  67. });
  68. var floorNumber = createFloorNumber({
  69. typed: typed,
  70. config: config,
  71. round: round
  72. });
  73. /**
  74. * Round a value towards minus infinity.
  75. * For matrices, the function is evaluated element wise.
  76. *
  77. * Syntax:
  78. *
  79. * math.floor(x)
  80. * math.floor(x, n)
  81. *
  82. * Examples:
  83. *
  84. * math.floor(3.2) // returns number 3
  85. * math.floor(3.8) // returns number 3
  86. * math.floor(-4.2) // returns number -5
  87. * math.floor(-4.7) // returns number -5
  88. *
  89. * math.floor(3.212, 2) // returns number 3.21
  90. * math.floor(3.288, 2) // returns number 3.28
  91. * math.floor(-4.212, 2) // returns number -4.22
  92. * math.floor(-4.782, 2) // returns number -4.79
  93. *
  94. * const c = math.complex(3.24, -2.71)
  95. * math.floor(c) // returns Complex 3 - 3i
  96. * math.floor(c, 1) // returns Complex 3.2 -2.8i
  97. *
  98. * math.floor([3.2, 3.8, -4.7]) // returns Array [3, 3, -5]
  99. * math.floor([3.21, 3.82, -4.71], 1) // returns Array [3.2, 3.8, -4.8]
  100. *
  101. * math.floor(math.tau, [2, 3]) // returns Array [6.28, 6.283]
  102. *
  103. * // Note that floor(array, array) currently not implemented.
  104. *
  105. * See also:
  106. *
  107. * ceil, fix, round
  108. *
  109. * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded
  110. * @param {number | BigNumber | Array} [n=0] Number of decimals
  111. * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value
  112. */
  113. return typed('floor', {
  114. number: floorNumber.signatures.number,
  115. 'number,number': floorNumber.signatures['number,number'],
  116. Complex: function Complex(x) {
  117. return x.floor();
  118. },
  119. 'Complex, number': function ComplexNumber(x, n) {
  120. return x.floor(n);
  121. },
  122. 'Complex, BigNumber': function ComplexBigNumber(x, n) {
  123. return x.floor(n.toNumber());
  124. },
  125. BigNumber: function BigNumber(x) {
  126. if ((0, _nearlyEqual.nearlyEqual)(x, round(x), config.epsilon)) {
  127. return round(x);
  128. } else {
  129. return x.floor();
  130. }
  131. },
  132. 'BigNumber, BigNumber': function BigNumberBigNumber(x, n) {
  133. if ((0, _nearlyEqual.nearlyEqual)(x, round(x, n), config.epsilon)) {
  134. return round(x, n);
  135. } else {
  136. return x.toDecimalPlaces(n.toNumber(), _decimal["default"].ROUND_FLOOR);
  137. }
  138. },
  139. Fraction: function Fraction(x) {
  140. return x.floor();
  141. },
  142. 'Fraction, number': function FractionNumber(x, n) {
  143. return x.floor(n);
  144. },
  145. 'Fraction, BigNumber': function FractionBigNumber(x, n) {
  146. return x.floor(n.toNumber());
  147. },
  148. 'Array | Matrix': typed.referToSelf(function (self) {
  149. return function (x) {
  150. // deep map collection, skip zeros since floor(0) = 0
  151. return (0, _collection.deepMap)(x, self, true);
  152. };
  153. }),
  154. 'Array, number | BigNumber': typed.referToSelf(function (self) {
  155. return function (x, n) {
  156. // deep map collection, skip zeros since ceil(0) = 0
  157. return (0, _collection.deepMap)(x, function (i) {
  158. return self(i, n);
  159. }, true);
  160. };
  161. }),
  162. 'SparseMatrix, number | BigNumber': typed.referToSelf(function (self) {
  163. return function (x, y) {
  164. return matAlgo11xS0s(x, y, self, false);
  165. };
  166. }),
  167. 'DenseMatrix, number | BigNumber': typed.referToSelf(function (self) {
  168. return function (x, y) {
  169. return matAlgo14xDs(x, y, self, false);
  170. };
  171. }),
  172. 'number | Complex | Fraction | BigNumber, Array': typed.referToSelf(function (self) {
  173. return function (x, y) {
  174. // use matrix implementation
  175. return matAlgo14xDs(matrix(y), x, self, true).valueOf();
  176. };
  177. }),
  178. 'number | Complex | Fraction | BigNumber, Matrix': typed.referToSelf(function (self) {
  179. return function (x, y) {
  180. if (equalScalar(x, 0)) return zeros(y.size(), y.storage());
  181. if (y.storage() === 'dense') {
  182. return matAlgo14xDs(y, x, self, true);
  183. }
  184. return matAlgo12xSfs(y, x, self, true);
  185. };
  186. })
  187. });
  188. });
  189. exports.createFloor = createFloor;