not.js 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.createNot = void 0;
  6. var _collection = require("../../utils/collection.js");
  7. var _factory = require("../../utils/factory.js");
  8. var _index = require("../../plain/number/index.js");
  9. var name = 'not';
  10. var dependencies = ['typed'];
  11. var createNot = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {
  12. var typed = _ref.typed;
  13. /**
  14. * Logical `not`. Flips boolean value of a given parameter.
  15. * For matrices, the function is evaluated element wise.
  16. *
  17. * Syntax:
  18. *
  19. * math.not(x)
  20. *
  21. * Examples:
  22. *
  23. * math.not(2) // returns false
  24. * math.not(0) // returns true
  25. * math.not(true) // returns false
  26. *
  27. * a = [2, -7, 0]
  28. * math.not(a) // returns [false, false, true]
  29. *
  30. * See also:
  31. *
  32. * and, or, xor
  33. *
  34. * @param {number | BigNumber | Complex | Unit | Array | Matrix} x First value to check
  35. * @return {boolean | Array | Matrix}
  36. * Returns true when input is a zero or empty value.
  37. */
  38. return typed(name, {
  39. 'null | undefined': function nullUndefined() {
  40. return true;
  41. },
  42. number: _index.notNumber,
  43. Complex: function Complex(x) {
  44. return x.re === 0 && x.im === 0;
  45. },
  46. BigNumber: function BigNumber(x) {
  47. return x.isZero() || x.isNaN();
  48. },
  49. Unit: typed.referToSelf(function (self) {
  50. return function (x) {
  51. return typed.find(self, x.valueType())(x.value);
  52. };
  53. }),
  54. 'Array | Matrix': typed.referToSelf(function (self) {
  55. return function (x) {
  56. return (0, _collection.deepMap)(x, self);
  57. };
  58. })
  59. });
  60. });
  61. exports.createNot = createNot;