log, logf, log10, log10f

calcola i logaritmi.

double log(
   double x 
);
float log(
   float x
);  // C++ only
long double log(
   long double x
);  // C++ only
float logf(
   float x 
);
double log10(
   double x
);
float log10(
   float x
);  // C++ only
long double log10(
   long double x
);  // C++ only
float log10f (
   float x
);

Parametri

  • x
    Valore di cui il logaritmo deve essere in inglese).

Valore restituito

il registro le funzioni restituisce il logaritmo naturale (base e) di x se ha esito positivo.Le funzioni log10 restituisce il logaritmo in base 10.se x è negative, queste funzioni restituiscono un non definito, per impostazione predefinita.se x è 0, che restituisce i INF (infiniti).

Input

SEH eccezione

eccezione di Matherr

± QNAN, IND

nessuno

_DOMAIN

± 0

ZERODIVIDE

_SING

x < 0

NON VALIDO

_DOMAIN

il registro e log10 dispone di un'implementazione che utilizza le estensioni di flusso 2 (SSE2) di SIMD.vedere _set_SSE2_enable per informazioni e le restrizioni sull'implementazione SSE2.

Note

C++ consente l'overload, pertanto è possibile chiamare gli overload di il registro e log10.In un programma c, il registro e log10 sempre prendere e restituire un valore double.

Requisiti

routine

Intestazione di associazione

il registro, logf, log10, log10f

<math.h>

per informazioni di compatibilità aggiuntive, vedere compatibilità nell'introduzione.

Librerie

Tutte le versioni di Librerie di runtime del linguaggio C.

Esempio

// 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 );
}

Output

log( 9000.00 ) = 9.104980
log10( 9000.00 ) = 3.954243

Per generare i logaritmi per altre basi, utilizzare il rapporto matematico: registrare b di base di un registro naturale di == ()/il logaritmo naturale (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);
}

Output

Log base 2 of 65536.000000 is 16.000000

Equivalente .NET Framework

Vedere anche

Riferimenti

Supporto per le operazioni in virgola mobile

exp, expf

_matherr

della rimozione di pow, powf

_CIlog

_CIlog10