log
, , logf
, logl
, log10
, , log10f
log10l
Oblicza logarytmy.
Składnia
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 higher
#define log10(X) // Requires C11 or higher
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
Wartość, której logarytm ma zostać znaleziony.
Wartość zwracana
Funkcje log
zwracają logarytm naturalny (podstawa e
) wartości x
, jeśli powiedzie się. Funkcje log10
zwracają logarytm base-10. Jeśli x
jest ujemna, te funkcje zwracają domyślnie nieokreślony (IND
). Jeśli x
wartość to 0, zwracają nieskończoność (INF
).
Dane wejściowe | Wyjątek SEH | Wyjątek _matherr |
---|---|---|
± QNaN, IND | Brak | _DOMAIN |
± 0 | ZERODIVIDE |
_SING |
x < 0 |
INVALID |
_DOMAIN |
log
i log10
mają implementację korzystającą z rozszerzeń SIMD przesyłania strumieniowego 2 (SSE2). Zobacz _set_SSE2_enable
, aby uzyskać informacje i ograniczenia dotyczące korzystania z implementacji SSE2.
Uwagi
Język C++ umożliwia przeciążenie, dzięki czemu można wywoływać przeciążenia log
elementów i log10
, które przyjmują i zwracają float
lub long double
wartości. W programie języka C, chyba że używasz makra <tgmath.h>
do wywoływania tej funkcji i log
zawsze pobieraj i log10
zwraca wartość double
.
Jeśli używasz makra <tgmath.h> log()
, typ argumentu określa, która wersja funkcji jest zaznaczona. Aby uzyskać szczegółowe informacje, zobacz Typy ogólne matematyczne .
Domyślnie stan globalny tej funkcji jest zakresem aplikacji. Aby zmienić to zachowanie, zobacz Stan globalny w CRT.
Wymagania
Procedura | Wymagany nagłówek |
---|---|
log , , logf , logl , log10 , , log10f log10l |
<math.h> |
log Makro |
<tgmath.h> |
Aby uzyskać więcej informacji o zgodności, zobacz Zgodność.
Przykład
// 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
Aby wygenerować logarytmy dla innych baz, użyj relacji matematycznej: log base b z == dziennika naturalnego (a) / dziennika naturalnego (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
Zobacz też
Obsługa obliczeń matematycznych i zmiennoprzecinkowych
exp
, , expf
expl
_matherr
pow
, , powf
powl
_CIlog
_CIlog10
\