IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

C Discussion :

Recherche d'une fonction


Sujet :

C

  1. #1
    Membre averti
    Inscrit en
    Mars 2007
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 13
    Par défaut Recherche d'une fonction
    Bonjour à tous,

    Je recherche s'il existe une fonction en C permettant de donner le signe d'un nombre donné, et si elle existe, dans quelle bibliothèque.

    En fait, ce serait l'équivalent en C de la fonction "sign" sous Matlab qui renvoie +1 quand le nombre est positif, 0 quand il est nul et -1 quand il est négatif

    Merci d'avance

  2. #2
    Expert confirmé

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 610
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 610
    Billets dans le blog
    2
    Par défaut
    peut-être me trompe-je, mais je ne crois pas..

    mais tu peux faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    #define sign(a)  ((a)/fabs((a)))

  3. #3
    Membre averti
    Inscrit en
    Mars 2007
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 13
    Par défaut
    Merci, je vais essayer ça de suite

  4. #4
    Membre averti
    Inscrit en
    Mars 2007
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 13
    Par défaut
    Ca marche

    Merci beaucoup

  5. #5
    Membre émérite Avatar de crocodilex
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    697
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 697
    Par défaut
    Citation Envoyé par souviron34
    peut-être me trompe-je, mais je ne crois pas..

    mais tu peux faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    #define sign(a)  ((a)/fabs((a)))
    Et que se passe-t-il si a=0 ?

  6. #6
    Expert confirmé

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 610
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 610
    Billets dans le blog
    2
    Par défaut
    ouais ok....

    On peut rajouter les tests..

    Mais signe de zéro ça va pas t'avancer beaucoup

    et sqrt par exemple (ou /) te fait de toutes façons un crash....

  7. #7
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Par défaut
    Citation Envoyé par souviron34
    peut-être me trompe-je, mais je ne crois pas..

    mais tu peux faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    #define sign(a)  ((a)/fabs((a)))
    Il peux y avoir des effets perverts. Une âme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    int nombre = 1;
    int signe;
     
    signe = sign(++nombre);
    Bon, là, gcc donne un avertissement. Et puis, c'est un cas d'école et on est sensé savoir quelles précautions on est sensé prendre avec les macros. Enfin bon, sign(0) engendre une division par 0, et là c'est un bug.

    Je passerais plus volontier par une fonction:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    int sign(double n)
    {
        return (n == 0.0) ? 0: (int) (n/fabs(n));
    }
    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

  8. #8
    Membre émérite Avatar de crocodilex
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    697
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 697
    Par défaut
    Faudrait faire ceci si tu veux l'équivalent matlab :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    #define sign(a)  ((a) ? ((a)/fabs((a))) : 0)

  9. #9
    Membre averti
    Profil pro
    Inscrit en
    Février 2007
    Messages
    64
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 64
    Par défaut
    poruquoi ne pas tout simplement faire une fonction ???

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    int my_sig(int i)
    {
      if (i < 0)
         return (-1);
      else if (i == 0)
         return (0);
      else if (i > 0)
         return (1);
    }
    je vien de coder ca tout de suite mais je n'ais pas essaier de compiler avec un main ^^ mais l'idee est la :p ou alors ce que tu demande est bien plus compliquer et je ne repond pas a ta question desoler.

  10. #10
    Membre expérimenté
    Inscrit en
    Décembre 2003
    Messages
    272
    Détails du profil
    Informations forums :
    Inscription : Décembre 2003
    Messages : 272
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    return x > 0. ? 1. : x < 0. ? -1. : 0. ;
    n'est pas plus efficace que cette division ?

    Sinon il y a surtout la macro "signbit" définie dans math.h.

  11. #11
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par PiXi-PiX
    poruquoi ne pas tout simplement faire une fonction ???
    Ne fonctionne que pour les int.

  12. #12
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par Ulmo
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    return x > 0. ? 1. : x < 0. ? -1. : 0. ;
    n'est pas plus efficace que cette division ?

    Sinon il y a surtout la macro "signbit" définie dans math.h.
    C'est portable ?

    http://www.opengroup.org/onlinepubs/...s/signbit.html
    First released in Issue 6. Derived from the ISO/IEC 9899:1999 standard.
    OK, c'est du C99...

    <math.h> de gcc (MinGW) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
     
    /* 7.12.3.6 The signbit macro */
    __CRT_INLINE int __cdecl __signbit (double x) {
      unsigned short stw;
      __asm__ ( "fxam; fstsw %%ax;": "=a" (stw) : "t" (x));
      return stw & 0x0200;
    }
     
    __CRT_INLINE int __cdecl __signbitf (float x) {
      unsigned short stw;
      __asm__ ("fxam; fstsw %%ax;": "=a" (stw) : "t" (x));
      return stw & 0x0200;
    }
     
    __CRT_INLINE int __cdecl __signbitl (long double x) {
      unsigned short stw;
      __asm__ ("fxam; fstsw %%ax;": "=a" (stw) : "t" (x));
      return stw & 0x0200;
    }
     
    #define signbit(x) (sizeof (x) == sizeof (float) ? __signbitf (x)	\
    		    : sizeof (x) == sizeof (double) ? __signbit (x)	\
    		    : __signbitl (x))
    Carrément le coprocesseur mathématique ! Hé hé !

  13. #13
    Membre averti
    Inscrit en
    Mars 2007
    Messages
    13
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 13
    Par défaut Problème résolu
    En réalité, j'ai réussi à contourner le cas où a=0. Je n'ai pas besoin en fait de la fonction retournant +1 ou -1 dans ce cas précis.

    Donc j'ai utilisé :

    #define sign(a) ((a)/fabs((a)))

    Merci àtous pour votre aide

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. recherche d'une fonction excel
    Par Zedr dans le forum Excel
    Réponses: 10
    Dernier message: 27/09/2007, 20h32
  2. A la recherche d'une fonction du genre time_sub
    Par fayred dans le forum SQL Procédural
    Réponses: 2
    Dernier message: 24/08/2007, 12h10
  3. Recherche d'une fonction guillemets
    Par too_Slow_ dans le forum Flash
    Réponses: 3
    Dernier message: 02/03/2007, 11h30
  4. [C] recherche d'une fonction
    Par Alice9 dans le forum MFC
    Réponses: 4
    Dernier message: 06/04/2006, 09h19
  5. Réponses: 17
    Dernier message: 14/02/2006, 00h21

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo