Sdílet prostřednictvím


acos, acosf, acosl

Vypočítá arkus kosinus.

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

Parametry

x
Hodnota mezi -1 a 1, pro kterou se má vypočítat arkus kosinus (inverzní kosinus).

Vrácená hodnota

Funkce acos vrátí arkus kosinus x v rozsahu 0 až π radiánů.

Pokud je ve výchozím nastavení x menší než -1 nebo větší než 1, acos vrátí neurčitou hodnotu.

Vstup Výjimka SEH Výjimka _matherr
± INF INVALID _DOMAIN
± QNaN, IND žádný _DOMAIN
|x| > 1 INVALID _DOMAIN

Poznámky

Vzhledem k tomu, že jazyk C++ umožňuje přetížení, můžete volat přetížení acos , která přebírají a vracejí float a long double typy. Pokud v programu jazyka C nepoužíváte <tgmath.h> makro k volání této funkce, acos vždy vezme a vrátí hodnotu double.

Pokud použijete acos makro z <tgmath.h>, typ argumentu určuje, která verze funkce je vybrána. Podrobnosti najdete v tématu Matematika pro obecné typy.

Ve výchozím nastavení je globální stav této funkce vymezen na aplikaci. Chcete-li toto chování změnit, přečtěte si téma Globální stav v CRT.

Požadavky

Rutina Požadovaný hlavičkový soubor Volitelná záhlaví
acos, acosf, acosl <math.h> <errno.h>
acos Makro <tgmath.h>

Příklad

Tento program zobrazí výzvu k zadání hodnoty v rozsahu -1 až 1. Vstupní hodnoty mimo tento rozsah vytvářejí _DOMAIN chybové zprávy. Pokud je zadána platná hodnota, program vytiskne arkusinus a arkusinus této hodnoty.

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

Viz také

Podpora pro matematiku a plovoucí desetinou čárku
asin, asinf, asinl
atan, atanf, atanl, atan2, atan2f, atan2l
cos, cosf, cosl
_matherr
sin, sinf, sinl
tan, tanf, tanl