1. NOM

fma, fmaf, fmal - Multiplication et addition en virgule flottante

2. SYNOPSIS

 
Sélectionnez
#include <math.h>
double fma(double x, double y, double z);
float fmaf(float x, float y, float z);
long double fmal(long double x, long double y, long double z);



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)) :

fma(), fmaf(), fmal() :
    _XOPEN_SOURCE >= 600 || _ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L
ou cc -std=c99

3. DESCRIPTION

La fonction fma() calcule x * y + z. Le résultat est arrondi à la fin suivant le mode d'arrondi (consultez fenv(3)).

4. VALEUR RENVOYÉE

Ces fonctions renvoient la valeur de x * y + z, arrondie comme une seule opération ternaire. Si x ou y est un NaN, un NaN est renvoyé. Si x fois y est exactement un infini et z est un infini de signe opposé, une erreur de domaine se produit et NaN est renvoyé. Si x ou y est une valeur infinie et si l'autre vaut 0 et si z n'est pas un NaN, une erreur de domaine est produite et un NaN est renvoyé. Si x ou y est une valeur infinie et si l'autre vaut 0 et si z est un NaN, une erreur de domaine est produite et un NaN est renvoyé. Si x fois y n'est pas une valeur infinie fois zéro (ou vice versa) et si z est un NaN, un NaN est renvoyé. En cas de dépassement pour le résultat, une erreur d'intervalle se produit et un infini du bon signe est renvoyé. En cas de soupassement (« underflow ») du résultat, une erreur d'intervalle se produit et un zéro signé est renvoyé.

5. ERREURS

Consultez math_error(7) pour savoir comment déterminer qu'une erreur est survenue lors de l'appel de ces fonctions.

Les erreurs suivantes peuvent se produire :

  • Erreur de domaine : x * y + z ou x * y n'est pas correct et z n'est pas un NaN Une exception indiquant une virgule flottante incorrecte (FE_INVALID) est levée.
  • Erreur d'intervalle : dépassement pour le résultat Une exception en virgule flottante de dépassement (FE_OVERFLOW) est levée.
  • Erreur d'intervalle : soupassement (« underflow ») du résultat Une exception en virgule flottante de soupassement (FE_UNDERFLOW) est levée.

Ces fonctions ne positionnent pas errno.

6. VERSIONS

Ces fonctions ont été introduites dans la glibc dans sa version 2.1.

7. CONFORMITÉ

C99, POSIX.1-2001.

8. VOIR AUSSI

remainder(3), remquo(3)

9. COLOPHON

Cette page fait partie de la publication 3.52 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/.

10. 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 à <>.

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