shithub: riscv

ref: 52b773d635aa7ffefac5f1e64ed97c3d67d34e5f
dir: /sys/src/libc/port/tanh.c/

View raw version
#include <u.h>
#include <libc.h>

/*
	tanh(arg) computes the hyperbolic tangent of its floating
	point argument.

	sinh and cosh are called except for large arguments, which
	would cause overflow improperly.
 */

double
tanh(double arg)
{

	if(arg < 0) {
		arg = -arg;
		if(arg > 21)
			return -1;
		return -sinh(arg)/cosh(arg);
	}
	if(arg > 21)
		return 1;
	return sinh(arg)/cosh(arg);
}