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 :

Comment fonctionnent sin() et cos() de math.h?


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    199
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 199
    Par défaut Comment fonctionnent sin() et cos() de math.h?
    Salut,

    Je suis amené à appeler souvent les fonctions sinus et cosinus de la librairie math.h et j'aurais aimé savoir comment elles calculent? Existe t'il des algo qui permettent de gagner de la vitesse quitte à perde (un peu) en précision?

    merci d'avance

  2. #2
    Expert confirmé

    Inscrit en
    Novembre 2005
    Messages
    5 145
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 5 145
    Par défaut
    Citation Envoyé par f56bre
    Salut,

    Je suis amené à appeler souvent les fonctions sinus et cosinus de la librairie math.h et j'aurais aimé savoir comment elles calculent?
    Certains processeurs ont des instructions pour. Pour les autres, je connais deux familles d'algorithmes:
    - CORDIC
    - approximation polynomiale par morceau

    Existe t'il des algo qui permettent de gagner de la vitesse quitte à perde (un peu) en précision?
    Faire une table et se limiter au contenu de cette table ou interpoler linérairement peut gagner ou pas. Suivant la taille de la table, le processeur et une quantité d'autres facteurs. Le seul moyen d'être sûr est de mesurer.

  3. #3
    Modérateur
    Avatar de ToTo13
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Janvier 2006
    Messages
    5 793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Santé

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 793
    Par défaut
    Bonjour,

    il y a les développements et certaines fonctions d'approximation (pour la fonction sqrt).

    Pour gagner du temps : si tu appeles souvent les mêmes valeurs ou des valeurs entières en degrès, remplit un tableau avec ces valeurs en début de soft et pioche dedans (c'est le cas pour un de mes soft...).
    Consignes aux jeunes padawans : une image vaut 1000 mots !
    - Dans ton message respecter tu dois : les règles de rédaction et du forum, prévisualiser, relire et corriger TOUTES les FAUTES (frappes, sms, d'aurteaugrafe, mettre les ACCENTS et les BALISES) => ECRIRE clairement et en Français tu DOIS.
    - Le côté obscur je sens dans le MP => Tous tes MPs je détruirai et la réponse tu n'auras si en privé tu veux que je t'enseigne.(Lis donc ceci)
    - ton poste tu dois marquer quand la bonne réponse tu as obtenu.

  4. #4
    Membre éclairé Avatar de TNT89
    Inscrit en
    Juillet 2007
    Messages
    358
    Détails du profil
    Informations personnelles :
    Âge : 35

    Informations forums :
    Inscription : Juillet 2007
    Messages : 358
    Par défaut
    Bonjour,

    Je m'excuse de remonter le post mais j'aurais besoin de savoir si les processeurs intègre des solutions en "dur" pour le calcul de exp, cos, sin...
    Je viens d'essayer de produire un code à peu près optimisé en C++ à partir de la métaprogrammation et il ne peut tenir la comparaison avec la bibliothèque (je me fait battre d'un bon coefficient 2)...

    Le code que j'applique :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    exp(x) = Sum(x^n/n!,{n,0,Inf})
           ~  ( ( ( (x/n + 1) * x/(n-1) + 1) * x/(n-2) + 1) * x/(n-3) + 1) * ...
    Je passe à côté de quelque chose?

  5. #5
    Inactif  
    Avatar de Mac LAK
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    3 893
    Détails du profil
    Informations personnelles :
    Âge : 51
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Octobre 2004
    Messages : 3 893
    Par défaut
    Citation Envoyé par TNT89 Voir le message
    Je m'excuse de remonter le post mais j'aurais besoin de savoir si les processeurs intègre des solutions en "dur" pour le calcul de exp, cos, sin...
    Oui, cela s'appelle le coprocesseur mathématique, coprocesseur arithmétique ou encore FPU (Floating-point unit). De plus, sur certains types de calculs, ton compilateur peut même générer du code SIMD qui vont accélérer les calculs par un facteur significatif (tu peux avoir un facteur 8 par rapport à un calcul "simple" utilisant le FPU sur certaines opérations).

    Les processeurs de type Pentium actuels intègrent aussi bien un FPU que des registres SIMD (appelés "SSE" chez Intel)... Vouloir battre des fonctions câblées avec du logiciel "pur" est franchement illusoire, je préfère te prévenir.

    La seule solution que je connais pouvant battre les circuits dédiés est le précalcul de tables : c'est monstrueusement efficace sur les fonctions trigonométriques, par exemple, car elles sont comme tu le sais périodiques.
    C'est nettement moins simple avec des fonctions non-périodiques comme la racine carrée ou les logarithmes / exponentielles, mais en fonction de ton besoin et du domaine d'application, cela reste possible.
    Mac LAK.
    ___________________________________________________
    Ne prenez pas la vie trop au sérieux, de toutes façons, vous n'en sortirez pas vivant.

    Sources et composants Delphi sur mon site, L'antre du Lak.
    Pas de question technique par MP : posez-la dans un nouveau sujet, sur le forum adéquat.

    Rejoignez-nous sur : Serveur de fichiers [NAS] Le Tableau de bord projets Le groupe de travail ICMO

  6. #6
    Membre éclairé Avatar de TNT89
    Inscrit en
    Juillet 2007
    Messages
    358
    Détails du profil
    Informations personnelles :
    Âge : 35

    Informations forums :
    Inscription : Juillet 2007
    Messages : 358
    Par défaut
    Merci de ta réponse!

    Pour les FPU et le multi-core : comment ça se passe? Chaque cœur a son unité? et pour les threads? (pour les Intel I7 par exemple...).

Discussions similaires

  1. [JSF] comment fonctionne <h:message> ?
    Par anitshka dans le forum JSF
    Réponses: 5
    Dernier message: 29/06/2005, 17h36
  2. Comment fonctionne TXmlDocumment ????
    Par almisuifre dans le forum C++Builder
    Réponses: 8
    Dernier message: 18/02/2005, 12h54
  3. comment fonctionne une interface graphique???
    Par elekis dans le forum Langages de programmation
    Réponses: 2
    Dernier message: 27/10/2004, 23h10
  4. Comment fonctionne le ClassExplorer ?
    Par borisd dans le forum C++Builder
    Réponses: 7
    Dernier message: 30/09/2004, 17h44
  5. Comment fonctionne le CVS ?
    Par mathieu dans le forum CVS
    Réponses: 6
    Dernier message: 23/03/2004, 11h26

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