Google
 

Trailing-Edge - PDP-10 Archives - SRI_NIC_PERM_FS_1_19910112 - c/lib5/pml/dsinh.c
There are 5 other files named dsinh.c in the archive. Click here to see a list.
/*
 *	+++ NAME +++
 *
 *	 DSINH   Double precision hyperbolic sine
 *
 *	+++ INDEX +++
 *
 *	 DSINH
 *	 machine independent routines
 *	 math libraries
 *
 *	+++ DESCRIPTION +++
 *
 *	Returns double precision hyperbolic sine of double precision
 *	floating point number.
 *
 *	+++ USAGE +++
 *
 *	 double dsinh(x)
 *	 double x;
 *
 *	+++ REFERENCES +++
 *
 *	Fortran IV plus user's guide, Digital Equipment Corp. pp B-5
 *
 *	+++ RESTRICTIONS +++
 *
 *	Inputs greater than LN(MAX_POS_DBLF) result in overflow.
 *	Inputs less than LN(MIN_POS_DBLF) result in underflow.
 *
 *	For precision information refer to documentation of the
 *	floating point library routines called.
 *
 *	+++ PROGRAMMER +++
 *
 *	 Fred Fish
 *	 Goodyear Aerospace Corp, Arizona Div.
 *	 (602) 932-7000 work
 *	 (602) 894-6881 home
 *
 *	+++ INTERNALS +++
 *
 *	Computes hyperbolic sine from:
 *
 *		DSINH(X) = 0.5 * (DEXP(X) - DEXP(-X))
 *
 *	---
 */

/*)LIBRARY
*/

#include <stdio.h>
#include "c:pmluse.h"
#include "pml.h"
double dsinh(x)
double x;
{
    double dexp();

    if (x > LN_MAXPOSDBL) {
	pmlerr(DSINH_OVERFLOW);
	return (MAX_POS_DBLF);
    } else if (x < LN_MINPOSDBL) {
	pmlerr(DSINH_UNDERFLOW);
	return (MIN_POS_DBLF);
    } else {
	return (0.5 * (dexp(x) - dexp(-x)) );
    }
}