remainder(3) Library Functions Manual remainder(3) NOM drem, dremf, dreml, remainder, remainderf, remainderl - Fonction reste en virgule flottante BIBLIOTHEQUE Bibliotheque de math (libm, -lm) SYNOPSIS #include double remainder(double x, double y); float remainderf(float x, float y); long double remainderl(long double x, long double y); /* Obsolete synonyms */ [[deprecated]] double drem(double x, double y); [[deprecated]] float dremf(float x, float y); [[deprecated]] long double dreml(long double x, long double y); Exigences de macros de test de fonctionnalites pour la glibc (consulter feature_test_macros(7)) : remainder() : _ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L || _XOPEN_SOURCE >= 500 || /* Depuis la glibc 2.19 : */ _DEFAULT_SOURCE || /* glibc <= 2.19 : */ _BSD_SOURCE || _SVID_SOURCE remainderf(), remainderl() : _ISOC99_SOURCE || _POSIX_C_SOURCE >= 200112L || /* Depuis la glibc 2.19 : */ _DEFAULT_SOURCE || /* glibc <= 2.19 : */ _BSD_SOURCE || _SVID_SOURCE drem(), dremf(), dreml() : /* Depuis la glibc 2.19 : */ _DEFAULT_SOURCE || /* glibc <= 2.19 : */ _BSD_SOURCE || _SVID_SOURCE DESCRIPTION Ces fonctions calculent le reste de la division de x par y. La valeur renvoyee est x-n*y, ou n est la valeur x / y, arrondie a l'entier le plus proche. Si la valeur absolue de x-n*y vaut 0,5, un n pair est choisi. Ces fonctions ne sont pas affectees par le mode d'arrondi en cours (voir fenv(3)). La fonction drem() fait precisement la meme chose. VALEUR RENVOYEE En cas de reussite, ces fonctions renvoient le reste en virgule flottante, x-n*y. Si la valeur de retour est nulle, elle a le signe de x. Si x ou y n'est pas un nombre, un NaN est renvoye. Si x est infini et y n'est pas un NaN, une erreur de domaine se produit et un NaN est renvoye. Si y est nul et x n'est pas un NaN, une erreur de domaine se produit et un NaN est renvoye. ERREURS Voir math_error(7) pour savoir comment determiner si une erreur s'est produite lors de l'appel d'une de ces fonctions. Les erreurs suivantes peuvent se produire : Erreur de domaine : x est infini et y n'est pas un NaN errno prend la valeur EDOM (mais consultez la section BOGUES). Une exception indiquant une virgule flottante incorrecte (FE_INVALID) est levee. Ces fonctions ne positionnent pas errno dans ce cas. Erreur de domaine : y est nul. errno prend la valeur EDOM. Une exception de virgule flottante non valable (FE_INVALID) est levee. ATTRIBUTS Pour une explication des termes utilises dans cette section, consulter attributes(7). +---------------------------------+--------------------------+---------+ |Interface | Attribut | Valeur | +---------------------------------+--------------------------+---------+ |drem(), dremf(), dreml(), | Securite des threads | MT-Safe | |remainder(), remainderf(), | | | |remainderl() | | | +---------------------------------+--------------------------+---------+ STANDARDS remainder() remainderf() remainder() C11, POSIX.1-2008. drem() dremf() dreml() None. HISTORIQUE remainder() remainderf() remainder() C99, POSIX.1-2001. drem() 4.3BSD. dremf() dreml() Tru64, glibc2. BOGUES Avant la glibc 2.15, l'appel remainder(nan(""), 0); renvoie un NaN, comme attendu, mais cause a tort une erreur de domaine. Depuis la glibc 2.15, un NaN silencieux (c'est-a-dire pas d'erreur de domaine) est renvoye. Avant la glibc 2.15, errno n'etait pas defini a EDOM pour une erreur de domaine qui se produit quand x est infini et y n'est pas un NaN. EXEMPLES L'appel << remainder(29.0, 3.0) >> renvoie -1. VOIR AUSSI div(3), fmod(3), remquo(3) TRADUCTION La traduction francaise de cette page de manuel a ete creee par Christophe Blaess , Stephan Rafin , Thierry Vignaud , Francois Micaux, Alain Portal , Jean-Philippe Guerard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas Francois , Florentin Duneau , Simon Paillard , Denis Barbier , David Prevot , Cedric Boutillier et Jean-Pierre Giraud Cette traduction est une documentation libre ; veuillez vous reporter a la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITE LEGALE. Si vous decouvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message a . Pages du manuel de Linux 6.06 31 octobre 2023 remainder(3)