Provided by: manpages-fr-dev_3.65d1p1-1_all bug

NOM

       frexp, frexpf, frexpl - Conversion de réel en fraction normalisée

SYNOPSIS

       #include <math.h>

       double frexp(double x, int *exp);
       float frexpf(float x, int *exp);
       long double frexpl(long double x, int *exp);

       Effectuez l'édition des liens avec l'option -lm.

   Exigences    de    macros    de   test   de   fonctionnalités   pour   la   glibc   (consultez
   feature_test_macros(7)) :

       frexpf(), frexpl() :
           _BSD_SOURCE || _SVID_SOURCE || _XOPEN_SOURCE >= 600 || _ISOC99_SOURCE ||
           _POSIX_C_SOURCE >= 200112L
           ou cc -std=c99

DESCRIPTION

       La  fonction frexp() est utilisée pour convertir le nombre x en une fraction normalisée et
       un exposant qui est stocké dans exp.

VALEUR RENVOYÉE

       La fonction frexp() renvoie la fraction normalisée.  Si  l'argument  x  est  non  nul,  la
       fraction normalisée est x multiplié par 2^exp. La valeur absolue de la fraction normalisée
       est comprise dans l'intervalle compris entre  1/2  (inclus)  et  1  (exclu),  c'est-à-dire
       [1/2, 1[.

       Si x est nul, la fraction normalisée vaut zéro et exp prend la valeur zéro.

       Si  x  est  un  NaN (pas un nombre : « Not a Number »), un NaN est renvoyé et la valeur de
       *exp n'est pas spécifiée.

       Si x est une valeur infinie positive (resp. négative), une valeur infinie positive  (resp.
       négative) est renvoyée et la valeur de *exp n'est pas spécifiée.

ERREURS

       Aucune erreur ne se produit.

ATTRIBUTS

   Multithreading (voir pthreads(7))
       Les fonctions frexp(), frexpf() et frexpl() sont sûres dans un contexte multithread.

CONFORMITÉ

       C99,  POSIX.1-2001. La variante renvoyant un double est également conforme à SVr4, BSD 4.3
       et C89.

EXEMPLE

       Le programme ci-dessous affiche les résultats suivants :

           $ ./a.out 2560
           frexp(2560, &e) = 0.625: 0.625 * 2^12 = 2560
           $ ./a.out -4
           frexp(-4, &e) = -0.5: -0.5 * 2^3 = -4

   Source du programme

       #include <math.h>
       #include <float.h>
       #include <stdio.h>
       #include <stdlib.h>

       int
       main(int argc, char *argv[])
       {
           double x, r;
           int exp;

           x = strtod(argv[1], NULL);
           r = frexp(x, &exp);

           printf("frexp(%g, &e) = %g: %g * %d^%d = %g\n",
                  x, r, r, FLT_RADIX, exp, x);
           exit(EXIT_SUCCESS);
       }

VOIR AUSSI

       ldexp(3), modf(3)

COLOPHON

       Cette page fait partie de la publication 3.65 du projet man-pages Linux.  Une  description
       du  projet  et  des  instructions  pour  signaler  des  anomalies  peuvent être trouvées à
       l'adresse http://www.kernel.org/doc/man-pages/.

TRADUCTION

       Depuis   2010,   cette   traduction   est   maintenue   à   l'aide   de    l'outil    po4a
       <http://po4a.alioth.debian.org/>  par l'équipe de traduction francophone au sein du projet
       perkamon <http://perkamon.alioth.debian.org/>.

       Christophe   Blaess   <http://www.blaess.fr/christophe/>   (1996-2003),    Alain    Portal
       <http://manpagesfr.free.fr/>  (2003-2006).  Florentin  Duneau  et  l'équipe francophone de
       traduction de Debian (2006-2009).

       Veuillez     signaler     toute     erreur     de     traduction     en     écrivant     à
       <debian-l10n-french@lists.debian.org>   ou   par   un  rapport  de  bogue  sur  le  paquet
       manpages-fr.

       Vous pouvez toujours avoir accès à la version anglaise de  ce  document  en  utilisant  la
       commande « man -L C <section> <page_de_man> ».

                                           6 août 2013                                   FREXP(3)