ceil.js 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.createCeilNumber = exports.createCeil = 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 = 'ceil';
  17. var dependencies = ['typed', 'config', 'round', 'matrix', 'equalScalar', 'zeros', 'DenseMatrix'];
  18. var createCeilNumber = /* #__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.ceil(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.ceil(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.createCeilNumber = createCeilNumber;
  49. var createCeil = /* #__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 ceilNumber = createCeilNumber({
  69. typed: typed,
  70. config: config,
  71. round: round
  72. });
  73. /**
  74. * Round a value towards plus infinity
  75. * If `x` is complex, both real and imaginary part are rounded towards plus infinity.
  76. * For matrices, the function is evaluated element wise.
  77. *
  78. * Syntax:
  79. *
  80. * math.ceil(x)
  81. * math.ceil(x, n)
  82. *
  83. * Examples:
  84. *
  85. * math.ceil(3.2) // returns number 4
  86. * math.ceil(3.8) // returns number 4
  87. * math.ceil(-4.2) // returns number -4
  88. * math.ceil(-4.7) // returns number -4
  89. *
  90. * math.ceil(3.212, 2) // returns number 3.22
  91. * math.ceil(3.288, 2) // returns number 3.29
  92. * math.ceil(-4.212, 2) // returns number -4.21
  93. * math.ceil(-4.782, 2) // returns number -4.78
  94. *
  95. * const c = math.complex(3.24, -2.71)
  96. * math.ceil(c) // returns Complex 4 - 2i
  97. * math.ceil(c, 1) // returns Complex 3.3 - 2.7i
  98. *
  99. * math.ceil([3.2, 3.8, -4.7]) // returns Array [4, 4, -4]
  100. * math.ceil([3.21, 3.82, -4.71], 1) // returns Array [3.3, 3.9, -4.7]
  101. *
  102. * See also:
  103. *
  104. * floor, fix, round
  105. *
  106. * @param {number | BigNumber | Fraction | Complex | Array | Matrix} x Number to be rounded
  107. * @param {number | BigNumber | Array} [n=0] Number of decimals
  108. * @return {number | BigNumber | Fraction | Complex | Array | Matrix} Rounded value
  109. */
  110. return typed('ceil', {
  111. number: ceilNumber.signatures.number,
  112. 'number,number': ceilNumber.signatures['number,number'],
  113. Complex: function Complex(x) {
  114. return x.ceil();
  115. },
  116. 'Complex, number': function ComplexNumber(x, n) {
  117. return x.ceil(n);
  118. },
  119. 'Complex, BigNumber': function ComplexBigNumber(x, n) {
  120. return x.ceil(n.toNumber());
  121. },
  122. BigNumber: function BigNumber(x) {
  123. if ((0, _nearlyEqual.nearlyEqual)(x, round(x), config.epsilon)) {
  124. return round(x);
  125. } else {
  126. return x.ceil();
  127. }
  128. },
  129. 'BigNumber, BigNumber': function BigNumberBigNumber(x, n) {
  130. if ((0, _nearlyEqual.nearlyEqual)(x, round(x, n), config.epsilon)) {
  131. return round(x, n);
  132. } else {
  133. return x.toDecimalPlaces(n.toNumber(), _decimal["default"].ROUND_CEIL);
  134. }
  135. },
  136. Fraction: function Fraction(x) {
  137. return x.ceil();
  138. },
  139. 'Fraction, number': function FractionNumber(x, n) {
  140. return x.ceil(n);
  141. },
  142. 'Fraction, BigNumber': function FractionBigNumber(x, n) {
  143. return x.ceil(n.toNumber());
  144. },
  145. 'Array | Matrix': typed.referToSelf(function (self) {
  146. return function (x) {
  147. // deep map collection, skip zeros since ceil(0) = 0
  148. return (0, _collection.deepMap)(x, self, true);
  149. };
  150. }),
  151. 'Array, number | BigNumber': typed.referToSelf(function (self) {
  152. return function (x, n) {
  153. // deep map collection, skip zeros since ceil(0) = 0
  154. return (0, _collection.deepMap)(x, function (i) {
  155. return self(i, n);
  156. }, true);
  157. };
  158. }),
  159. 'SparseMatrix, number | BigNumber': typed.referToSelf(function (self) {
  160. return function (x, y) {
  161. return matAlgo11xS0s(x, y, self, false);
  162. };
  163. }),
  164. 'DenseMatrix, number | BigNumber': typed.referToSelf(function (self) {
  165. return function (x, y) {
  166. return matAlgo14xDs(x, y, self, false);
  167. };
  168. }),
  169. 'number | Complex | Fraction | BigNumber, Array': typed.referToSelf(function (self) {
  170. return function (x, y) {
  171. // use matrix implementation
  172. return matAlgo14xDs(matrix(y), x, self, true).valueOf();
  173. };
  174. }),
  175. 'number | Complex | Fraction | BigNumber, Matrix': typed.referToSelf(function (self) {
  176. return function (x, y) {
  177. if (equalScalar(x, 0)) return zeros(y.size(), y.storage());
  178. if (y.storage() === 'dense') {
  179. return matAlgo14xDs(y, x, self, true);
  180. }
  181. return matAlgo12xSfs(y, x, self, true);
  182. };
  183. })
  184. });
  185. });
  186. exports.createCeil = createCeil;