acos
, , acosf
acosl
Calcule l’arc cosinus.
Syntaxe
double acos( double x );
float acosf( float x );
long double acosl( long double x );
#define acos(X) // Requires C11 or higher
float acos( float x ); // C++ only
long double acos( long double x ); // C++ only
Paramètres
x
Valeur comprise entre -1 et 1, pour laquelle calculer l’arccosine (cosinus inverse).
Valeur retournée
La acos
fonction retourne l’arccosine de x
la plage 0 à π radians.
Par défaut, s’il x
est inférieur à -1 ou supérieur à 1, acos
retourne une valeur indéfinie.
Input | Exception SEH | Exception _matherr |
---|---|---|
± INF | INVALID |
_DOMAIN |
± QNaN, IND | Aucune | _DOMAIN |
|x| > 1 |
INVALID |
_DOMAIN |
Notes
C++ autorisant la surcharge, vous pouvez appeler des surcharges de acos
qui acceptent et retournent des types float
et long double
. Dans un programme C, sauf si vous utilisez la <tgmath.h>
macro pour appeler cette fonction, acos
prend toujours et retourne un double
.
Si vous utilisez la acos
macro à partir de <tgmath.h>
laquelle , le type de l’argument détermine la version de la fonction sélectionnée. Pour plus d’informations, consultez les mathématiques génériques de type.
Par défaut, l’état global de cette fonction est limité à l’application. Pour modifier ce comportement, consultez État global dans le CRT.
Spécifications
Routine | En-tête requis | En-têtes facultatifs |
---|---|---|
acos , , acosf acosl |
<math.h> |
<errno.h> |
Macro acos |
<tgmath.h> |
Exemple
Ce programme vous invite à entrer une valeur comprise entre -1 et 1. Les valeurs d’entrée en dehors de cette plage génèrent des messages d’erreur _DOMAIN
. Si une valeur valide est entrée, le programme affiche l’arc sinus et l’arc cosinus de cette valeur.
// crt_asincos.c
// arguments: 0
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
int main( int ac, char* av[] )
{
double x,
y;
errno_t err;
// argument checking
if (ac != 2)
{
fprintf_s( stderr, "Usage: %s <number between -1 and 1>\n",
av[0]);
return 1;
}
// Convert argument into a double value
if ((err = sscanf_s( av[1], "%lf", &x )) != 1)
{
fprintf_s( stderr, "Error converting argument into ",
"double value.\n");
return 1;
}
// Arcsine of X
y = asin( x );
printf_s( "Arcsine of %f = %f\n", x, y );
// Arccosine of X
y = acos( x );
printf_s( "Arccosine of %f = %f\n", x, y );
}
Arcsine of 0.000000 = 0.000000
Arccosine of 0.000000 = 1.570796
Voir aussi
Prise en charge des fonctions mathématiques et à virgule flottante
asin
, , asinf
asinl
atan
, , atanf
, atan2
atanl
, , atan2f
atan2l
cos
, , cosf
cosl
_matherr
sin
, , sinf
sinl
tan
, , tanf
tanl