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