Scroll to navigation

FMA(3) Manuel du programmeur Linux FMA(3)

NOM

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

SYNOPSIS

#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 (voir feature_test_macros(7)) :

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

DESCRIPTION

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

VALEUR RENVOYÉE

Ces fonctions renvoient la valeur de x * y + z, arrondis par la suite.

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 infinies 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 sous-passement (« underflow ») du résultat, une erreur d'intervalle se produit et un zéro signé est renvoyé.

ERREURS

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

Les erreurs suivantes peuvent se produire :

Une exception de virgule flottante incorrecte (FE_INVALID) est levée.
Une exception en virgule flottante de dépassement (FE_OVERFLOW) est levée.
Une exception en virgule flottante de sous-passement (FE_UNDERFLOW) est levée.

Ces fonctions ne positionnent pas errno.

VERSIONS

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

CONFORMITÉ

C99, POSIX.1-2001.

VOIR AUSSI

remainder(3), remquo(3)

COLOPHON

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

TRADUCTION

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

Christophe Blaess <URL:http://www.blaess.fr/christophe/> (1996-2003), Alain Portal <URL: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 à <perkamon-l10n-fr@lists.alioth.debian.org>.

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

6 octobre 2008