Udostępnij przez


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\