UNPKG

mathjs

Version:

Math.js is an extensive math library for JavaScript and Node.js. It features a flexible expression parser and offers an integrated solution to work with numbers, big numbers, complex numbers, units, and matrices.

56 lines (47 loc) 1.25 kB
'use strict'; var deepMap = require('../../utils/collection/deepMap'); function factory (type, config, load, typed) { /** * Calculate the hyperbolic arctangent of a value, * defined as `atanh(x) = ln((1 + x)/(1 - x)) / 2`. * * For matrices, the function is evaluated element wise. * * Syntax: * * math.atanh(x) * * Examples: * * math.atanh(0.5); // returns 0.5493061443340549 * * See also: * * acosh, asinh * * @param {number | Complex | Array | Matrix} x Function input * @return {number | Complex | Array | Matrix} Hyperbolic arctangent of x */ var atanh = typed('atanh', { 'number': function (x) { if ((x <= 1 && x >= -1) || config.predictable) { return Math.log((1 + x)/(1 - x)) / 2; } return new type.Complex(x, 0).atanh(); }, 'Complex': function (x) { return x.atanh(); }, 'BigNumber': function (x) { return x.atanh(); }, 'Array | Matrix': function (x) { // deep map collection, skip zeros since atanh(0) = 0 return deepMap(x, atanh, true); } }); atanh.toTex = '\\tanh^{-1}\\left(${args[0]}\\right)'; return atanh; } exports.name = 'atanh'; exports.factory = factory;