acos
, acosf
, acosl
Calcola l'arcocoseno.
Sintassi
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
Parametri
x
Valore compreso tra -1 e 1, per il quale calcolare l'arcocosina (il coseno inverso).
Valore restituito
La acos
funzione restituisce l'arcocosina di x
nell'intervallo da 0 a π radianti.
Per impostazione predefinita, se x
è minore di -1 o maggiore di 1, acos
restituisce un valore illimitato.
Input | Eccezione SEH | Eccezione _matherr |
---|---|---|
± INF | INVALID |
_DOMAIN |
± QNaN, IND | Nessuno | _DOMAIN |
|x| > 1 |
INVALID |
_DOMAIN |
Osservazioni:
Poiché C++ consente l'overload, è possibile chiamare gli overload di acos
che accettano e restituiscono i tipi float
e long double
. In un programma C, a meno che non si usi la <tgmath.h>
macro per chiamare questa funzione, acos
accetta sempre e restituisce un oggetto double
.
Se si utilizza la acos
macro da <tgmath.h>
, il tipo dell'argomento determina quale versione della funzione è selezionata. Per informazioni dettagliate, vedere La matematica generica dei tipi.
Per impostazione predefinita, lo stato globale di questa funzione è limitato all'applicazione. Per modificare questo comportamento, vedere Stato globale in CRT.
Requisiti
Ciclo | Intestazione obbligatoria | Intestazioni facoltative |
---|---|---|
acos , acosf , acosl |
<math.h> |
<errno.h> |
acos macro |
<tgmath.h> |
Esempio
Questo programma richiede un valore compreso tra -1 e 1. I valori di input all'esterno di questo intervallo producono i messaggi di errore _DOMAIN
. Se viene immesso un valore valido, il programma stampa l'arcoseno e l'arcocoseno di tale valore.
// 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
Vedi anche
Supporto matematico e a virgola mobile
asin
, asinf
, asinl
atan
, atanf
, atanl
, atan2
, atan2f
atan2l
cos
, cosf
, cosl
_matherr
sin
, sinf
, sinl
tan
, tanf
, tanl