Partilhar via


acos, acosf, acosl

Calcula o arco cosseno.

Sintaxe

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

Parâmetros

x
Valor entre -1 e 1, usado para calcular o arco cosseno (o cosseno inverso).

Valor retornado

A função acos retorna o arco cosseno de x no intervalo de 0 a π radianos.

Por padrão, se x for menor que -1 ou maior que 1, acos retornará um indefinido.

Entrada Exceção SEH Exceção _matherr
± INF INVALID _DOMAIN
± QNaN, IND nenhum _DOMAIN
|x| > 1 INVALID _DOMAIN

Comentários

Como C++ permite sobrecargas, é possível chamar sobrecargas de acos que usam e retornam tipos float e long double. Em um programa do C, a menos que você esteja usando a macro <tgmath.h> para chamar essa função, acos sempre recebe e retorna um double.

Se você usar a acos macro de <tgmath.h>, o tipo do argumento determinará qual versão da função será selecionada. Confira Matemática do tipo genérico para obter detalhes.

Por padrão, o estado global dessa função tem como escopo o aplicativo. Para alterar esse comportamento, confira Estado global no CRT.

Requisitos

Rotina Cabeçalho necessário Cabeçalhos opcionais
acos, acosf, acosl <math.h> <errno.h>
Macro acos <tgmath.h>

Exemplo

Este programa solicita um valor no intervalo de –1 a 1. Valores de entrada fora desse intervalo produzem mensagens de erro de _DOMAIN. Se um valor válido for inserido, o programa imprimirá o arco seno e o arco cosseno desse valor.

// 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

Confira também

Suporte matemático e de ponto flutuante
asin, asinf, asinl
atan, atanf, atanl, atan2, atan2f, , atan2l
cos, cosf, cosl
_matherr
sin, sinf, sinl
tan, tanf, tanl