Poznámka:
Přístup k této stránce vyžaduje autorizaci. Můžete se zkusit přihlásit nebo změnit adresáře.
Přístup k této stránce vyžaduje autorizaci. Můžete zkusit změnit adresáře.
Vypočítá logaritmus.
Syntaxe
double log(double x);
float logf(float x);
long double logl(double x);
double log10(double x);
float log10f (float x);
long double log10l(double x);
#define log(X) // Requires C11 or later
#define log10(X) // Requires C11 or later
float log(float x); // C++ only
long double log(long double x); // C++ only
float log10(float x); // C++ only
long double log10(long double x); // C++ only
Parametry
x
Hodnota, jejíž logaritmus se má najít.
Vrácená hodnota
Funkce log vrátí přirozený logaritmus (základ e), x pokud je úspěšný. Funkce log10 vrátí logaritmus base-10. Pokud x jsou záporné, vrátí tyto funkce ve výchozím nastavení neomezenou hodnotu (IND). Pokud x je 0, vrátí nekonečno (INF).
| Vstup | Výjimka SEH | Výjimka _matherr |
|---|---|---|
| ± QNaN, IND | Žádná | _DOMAIN |
| ± 0 | ZERODIVIDE |
_SING |
x < 0 |
INVALID |
_DOMAIN |
log a log10 mají implementaci, která používá rozšíření SIMD Streaming 2 (SSE2). Informace _set_SSE2_enable a omezení týkající se použití implementace SSE2
Poznámky
Jazyk C++ umožňuje přetížení, takže můžete volat přetíženílog, která přebírají a log10 vracejí nebo float vracejí long double hodnoty. V programu jazyka C, pokud k volání této funkce nepoužíváte <tgmath.h> makro, log a log10 vždy vezměte a vraťte znak double.
Pokud použijete <tgmath.h> log() makro, 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 |
|---|---|
log, logf, logl, log10, , log10flog10l |
<math.h> |
log makro |
<tgmath.h> |
Další informace o kompatibilitě najdete v tématu Kompatibilita.
Příklad
// crt_log.c
/* This program uses log and log10
* to calculate the natural logarithm and
* the base-10 logarithm of 9,000.
*/
#include <math.h>
#include <stdio.h>
int main( void )
{
double x = 9000.0;
double y;
y = log( x );
printf( "log( %.2f ) = %f\n", x, y );
y = log10( x );
printf( "log10( %.2f ) = %f\n", x, y );
}
log( 9000.00 ) = 9.104980
log10( 9000.00 ) = 3.954243
Chcete-li generovat logaritmus pro jiné základy, použijte matematický vztah: základ protokolu b z a == přirozený protokol (a) / přirozený protokol (b).
// logbase.cpp
#include <math.h>
#include <stdio.h>
double logbase(double a, double base)
{
return log(a) / log(base);
}
int main()
{
double x = 65536;
double result;
result = logbase(x, 2);
printf("Log base 2 of %lf is %lf\n", x, result);
}
Log base 2 of 65536.000000 is 16.000000
Viz také
Podpora pro matematiku a plovoucí desetinou čárku
exp, , expfexpl
_matherr
pow, , powfpowl
_CIlog
_CIlog10