Defined in header <math.h> | ||
---|---|---|
float coshf( float arg ); | (1) | (since C99) |
double cosh( double arg ); | (2) | |
long double coshl( long double arg ); | (3) | (since C99) |
Defined in header <tgmath.h> | ||
#define cosh( arg ) | (4) | (since C99) |
arg
.long double
, coshl
is called. Otherwise, if the argument has integer type or the type double
, cosh
is called. Otherwise, coshf
is called. If the argument is complex, then the macro invokes the corresponding complex function (ccoshf
, ccosh
, ccoshl
).arg | - | floating point value representing a hyperbolic angle |
arg
(cosh(arg), or earg+e-arg/2) is returned. If a range error due to overflow occurs, +HUGE_VAL
, +HUGE_VALF
, or +HUGE_VALL
is returned.
Errors are reported as specified in math_errhandling
.
If the implementation supports IEEE floating-point arithmetic (IEC 60559),
For the IEEE-compatible type double
, if |arg| > 710.5, then cosh(arg)
overflows.
#include <stdio.h> #include <math.h> #include <errno.h> #include <fenv.h> // #pragma STDC FENV_ACCESS ON int main(void) { printf("cosh(1) = %f\ncosh(-1)= %f\n", cosh(1), cosh(-1)); printf("log(sinh(1) + cosh(1))=%f\n", log(sinh(1)+cosh(1))); // special values printf("cosh(+0) = %f\ncosh(-0) = %f\n", cosh(0.0), cosh(-0.0)); // error handling errno=0; feclearexcept(FE_ALL_EXCEPT); printf("cosh(710.5) = %f\n", cosh(710.5)); if(errno == ERANGE) perror(" errno == ERANGE"); if(fetestexcept(FE_OVERFLOW)) puts(" FE_OVERFLOW raised"); }
Possible output:
cosh(1) = 1.543081 cosh(-1)= 1.543081 log(sinh(1) + cosh(1))=1.000000 cosh(+0) = 1.000000 cosh(-0) = 1.000000 cosh(710.5) = inf errno == ERANGE: Numerical result out of range FE_OVERFLOW raised
(C99)(C99) | computes hyperbolic sine (\({\small\sinh{x} }\)sinh(x)) (function) |
(C99)(C99) | computes hyperbolic tangent (\({\small\tanh{x} }\)tanh(x)) (function) |
(C99)(C99)(C99) | computes inverse hyperbolic cosine (\({\small\operatorname{arcosh}{x} }\)arcosh(x)) (function) |
(C99)(C99)(C99) | computes the complex hyperbolic cosine (function) |
C++ documentation for cosh |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/c/numeric/math/cosh