acsc.js 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. "use strict";
  2. Object.defineProperty(exports, "__esModule", {
  3. value: true
  4. });
  5. exports.createAcsc = void 0;
  6. var _factory = require("../../utils/factory.js");
  7. var _index = require("../../plain/number/index.js");
  8. var name = 'acsc';
  9. var dependencies = ['typed', 'config', 'Complex', 'BigNumber'];
  10. var createAcsc = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {
  11. var typed = _ref.typed,
  12. config = _ref.config,
  13. Complex = _ref.Complex,
  14. _BigNumber = _ref.BigNumber;
  15. /**
  16. * Calculate the inverse cosecant of a value, defined as `acsc(x) = asin(1/x)`.
  17. *
  18. * To avoid confusion with the matrix arccosecant, this function does not
  19. * apply to matrices.
  20. *
  21. * Syntax:
  22. *
  23. * math.acsc(x)
  24. *
  25. * Examples:
  26. *
  27. * math.acsc(2) // returns 0.5235987755982989
  28. * math.acsc(0.5) // returns Complex 1.5707963267948966 -1.3169578969248166i
  29. * math.acsc(math.csc(1.5)) // returns number ~1.5
  30. *
  31. * See also:
  32. *
  33. * csc, asin, asec
  34. *
  35. * @param {number | BigNumber | Complex} x Function input
  36. * @return {number | BigNumber | Complex} The arc cosecant of x
  37. */
  38. return typed(name, {
  39. number: function number(x) {
  40. if (x <= -1 || x >= 1 || config.predictable) {
  41. return (0, _index.acscNumber)(x);
  42. }
  43. return new Complex(x, 0).acsc();
  44. },
  45. Complex: function Complex(x) {
  46. return x.acsc();
  47. },
  48. BigNumber: function BigNumber(x) {
  49. return new _BigNumber(1).div(x).asin();
  50. }
  51. });
  52. });
  53. exports.createAcsc = createAcsc;