tanl
tan, tanf, tanl
在头文件 | | |
---|---|---|
float tanf( float arg | (1) | (since C99) |
double tan( double arg | (2) | |
long double tanl( long double arg | (3) | (since C99) |
Defined in header <tgmath.h> | | |
#define tan( arg ) | (4) | (since C99) |
1-3)计算arg的正切(以弧度测量)。
4)类型 - 通用宏:如果参数的类型为long double,则调用tanl。 否则,如果参数具有整数类型或类型double,则调用tan。 否则,调用tanf。 如果参数很复杂,那么宏调用相应的复合函数(ctanf,ctan,ctanl)。
参数
ARG | - | 以弧度表示角度的浮点值 |
---|
返回值
如果没有发生错误,则返回arg(tan(arg))的正切值。
如果arg的大小很大,结果可能几乎没有意义。 | (直到C99) |
---|
如果发生域错误,则返回实现定义的值(NaN,如果支持)。
如果由于下溢而发生范围错误,则返回正确的结果(舍入后)。
错误处理
按照math_errhandling中的指定报告错误。
如果实现支持IEEE浮点运算(IEC 60559),
- 如果参数为±0,则不加修改地返回
注意
参数无限的情况在C中没有被指定为域错误,但是在POSIX中被定义为域错误。
该函数在π(1/2 + n)处具有数学极点; 然而,没有共同的浮点表示法能够精确地表示π/ 2,因此没有出现极点错误的参数值。
例
#include <stdio.h>
#include <math.h>
#include <errno.h>
#include <fenv.h>
#pragma STDC FENV_ACCESS ON
int main(void)
{
double pi = acos(-1
// typical usage
printf("tan (pi/4) = %+f\n", tan( pi/4) // 45 deg
printf("tan(3*pi/4) = %+f\n", tan(3*pi/4) // 135 deg
printf("tan(5*pi/4) = %+f\n", tan(5*pi/4) // -135 deg
printf("tan(7*pi/4) = %+f\n", tan(7*pi/4) // -45 deg
// special values
printf("tan(+0) = %f\n", tan(0.0)
printf("tan(-0) = %f\n", tan(-0.0)
// error handling
feclearexcept(FE_ALL_EXCEPT
printf("tan(INFINITY) = %f\n", tan(INFINITY)
if(fetestexcept(FE_INVALID)) puts(" FE_INVALID raised"
}
可能的输出:
tan (pi/4) = +1.000000
tan(3*pi/4) = -1.000000
tan(5*pi/4) = +1.000000
tan(7*pi/4) = -1.000000
tan(+0) = 0.000000
tan(-0) = -0.000000
tan(INFINITY) = -nan
FE_INVALID raised
参考
- C11标准(ISO / IEC 9899:2011):
扩展内容
sinsinfsinl(C99)(C99) | 计算正弦(sin(x))(函数) |
---|---|
coscosfcosl(C99)(C99) | 计算余弦(cos(x))(函数) |
atanatanfatanl(C99)(C99) | 计算反正切(arctan(x))(函数) |
(C99)(C99)(C99) | 计算复正切(函数) |
| 用于tan的C ++文档 |