or.js 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. import { createMatAlgo03xDSf } from '../../type/matrix/utils/matAlgo03xDSf.js';
  2. import { createMatAlgo12xSfs } from '../../type/matrix/utils/matAlgo12xSfs.js';
  3. import { createMatAlgo05xSfSf } from '../../type/matrix/utils/matAlgo05xSfSf.js';
  4. import { factory } from '../../utils/factory.js';
  5. import { createMatrixAlgorithmSuite } from '../../type/matrix/utils/matrixAlgorithmSuite.js';
  6. import { orNumber } from '../../plain/number/index.js';
  7. var name = 'or';
  8. var dependencies = ['typed', 'matrix', 'equalScalar', 'DenseMatrix'];
  9. export var createOr = /* #__PURE__ */factory(name, dependencies, _ref => {
  10. var {
  11. typed,
  12. matrix,
  13. equalScalar,
  14. DenseMatrix
  15. } = _ref;
  16. var matAlgo03xDSf = createMatAlgo03xDSf({
  17. typed
  18. });
  19. var matAlgo05xSfSf = createMatAlgo05xSfSf({
  20. typed,
  21. equalScalar
  22. });
  23. var matAlgo12xSfs = createMatAlgo12xSfs({
  24. typed,
  25. DenseMatrix
  26. });
  27. var matrixAlgorithmSuite = createMatrixAlgorithmSuite({
  28. typed,
  29. matrix
  30. });
  31. /**
  32. * Logical `or`. Test if at least one value is defined with a nonzero/nonempty value.
  33. * For matrices, the function is evaluated element wise.
  34. *
  35. * Syntax:
  36. *
  37. * math.or(x, y)
  38. *
  39. * Examples:
  40. *
  41. * math.or(2, 4) // returns true
  42. *
  43. * a = [2, 5, 0]
  44. * b = [0, 22, 0]
  45. * c = 0
  46. *
  47. * math.or(a, b) // returns [true, true, false]
  48. * math.or(b, c) // returns [false, true, false]
  49. *
  50. * See also:
  51. *
  52. * and, not, xor
  53. *
  54. * @param {number | BigNumber | Complex | Unit | Array | Matrix} x First value to check
  55. * @param {number | BigNumber | Complex | Unit | Array | Matrix} y Second value to check
  56. * @return {boolean | Array | Matrix}
  57. * Returns true when one of the inputs is defined with a nonzero/nonempty value.
  58. */
  59. return typed(name, {
  60. 'number, number': orNumber,
  61. 'Complex, Complex': function ComplexComplex(x, y) {
  62. return x.re !== 0 || x.im !== 0 || y.re !== 0 || y.im !== 0;
  63. },
  64. 'BigNumber, BigNumber': function BigNumberBigNumber(x, y) {
  65. return !x.isZero() && !x.isNaN() || !y.isZero() && !y.isNaN();
  66. },
  67. 'Unit, Unit': typed.referToSelf(self => (x, y) => self(x.value || 0, y.value || 0))
  68. }, matrixAlgorithmSuite({
  69. SS: matAlgo05xSfSf,
  70. DS: matAlgo03xDSf,
  71. Ss: matAlgo12xSfs
  72. }));
  73. });