Condividi tramite


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, atan2fatan2l
cos, cosf, cosl
_matherr
sin, sinf, sinl
tan, tanf, tanl