xor.js 2.3 KB

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