logb, logbf, logbl - Obtenir l’exposant d’un nombre à virgule flottante
Bibliothèque de math (libm, -lm)
#include <math.h>
double logb(double x);
float logbf(float x);
long double logbl(long double x);
Exigences de macros de test de fonctionnalités pour la glibc (consulter feature_test_macros(7)) :
logb() :
_ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L
|| _XOPEN_SOURCE >= 500
|| /* Depuis la glibc 2.19 : */ _DEFAULT_SOURCE
|| /* Versions <= 2.19 de la glibc : */ _BSD_SOURCE || _SVID_SOURCE
logbf(), logbl() :
_ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L
|| /* Depuis la glibc 2.19 : */ _DEFAULT_SOURCE
|| /* glibc <= 2.19 : */ _BSD_SOURCE || _SVID_SOURCE
Ces fonctions extraient l’exposant de la représentation interne en virgule flottante de x et le renvoie sous forme de nombre en virgule flottante. La constante entière FLT_RADIX, définie dans <float.h>, indique la base utilisée pour la représentation des nombres en virgule flottante du système. Si FLT_RADIX vaut 2, alors logb(x) est équivalent à floor(log2(x)) et elle est probablement plus rapide.
Si x est dénormalisé, logb() renvoie l’exposant x comme s’il était normalisé.
En cas de réussite, ces fonctions renvoient l’exposant de x.
Si x n’est pas un nombre, un NaN est renvoyé.
Si x est zéro, une erreur de pôle se produit et les fonctions renvoient -HUGE_VAL, -HUGE_VALF ou -HUGE_VALL, respectivement.
Si x est l’infini positif ou négatif, l’infini positif est renvoyé.
Voir math_error(7) pour savoir comment déterminer si une erreur s’est produite lors de l’appel d’une de ces fonctions.
Les erreurs suivantes peuvent se produire :
Erreur de pôle : x est zéro
Une exception de division par zéro de virgule flottante (FE_DIVBYZERO) est levée.
Ces fonctions n’affectent pas de valeur à errno.
Pour une explication des termes utilisés dans cette section, consulter attributes(7).
C99, POSIX.1-2001, POSIX.1-2008.
La traduction française de cette page de manuel a été créée par Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan DOT rafin AT laposte DOT net>, Thierry Vignaud <tvignaud AT mandriva DOT com>, François Micaux, Alain Portal <aportal AT univ-montp2 DOT fr>, Jean-Philippe Guérard <fevrier AT tigreraye DOT org>, Jean-Luc Coulon (f5ibh) <jean-luc DOT coulon AT wanadoo DOT fr>, Julien Cristau <jcristau AT debian DOT org>, Thomas Huriaux <thomas DOT huriaux AT gmail DOT com>, Nicolas François <nicolas DOT francois AT centraliens DOT net>, Florentin Duneau <fduneau AT gmail DOT com>, Simon Paillard <simon DOT paillard AT resel DOT enst-bretagne DOT fr>, Denis Barbier <barbier AT debian DOT org>, David Prévot <david AT tilapin DOT org> et Cédric Boutillier <cedric DOT boutillier AT gmail DOT com>
Cette traduction est une documentation libre ; veuillez vous reporter à la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n’y a aucune RESPONSABILITÉ LÉGALE.
Si vous découvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message à debian-l10n-french.