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

Algorithmes et structures de données Discussion :

calcul de la valeur de pi à l'aide d'un algorithme


Sujet :

Algorithmes et structures de données

  1. #1
    Débutant
    Inscrit en
    Octobre 2007
    Messages
    285
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 285
    Points : 97
    Points
    97
    Par défaut calcul de la valeur de pi à l'aide d'un algorithme
    l'exo est le suivant:
    ecrire un algorithmequi calcule et affiche la valeur de pi à l'aide de la serie
    pi/4=1-1/3+1/5-1/7...........
    mon essai est le suivant:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    algorithme:serie
    variables:s,n,a,i,s':entiers
    debut:
    s=0
    k=1
      pour i allant de 1 à n faire 
        k=k*(-1)
        s=s+k/(a+2)
      finpour 
     s'=s*4
     ecrire(s')
    fin
    donc comme d'habitude j'attend vos corrections et commentaires pour que je puisse voir mes faiblaisses et meme mes points forts
    merci d'avance a tous ceux qui m 'aident à m'ameliorer !

  2. #2
    Rédacteur

    Avatar de millie
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    7 015
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 7 015
    Points : 9 818
    Points
    9 818
    Par défaut
    En fait, si tu veux utiliser cette série (basée sur arctan), je te conseille d'utiliser non pas directement arctan(1) mais : 4arctan(1/5) -arctan(1/239)

    Le développement limité converge plus vite
    Je ne répondrai à aucune question technique en privé

  3. #3
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Points : 16 081
    Points
    16 081
    Par défaut
    si tu deroules ton algo, tu vas calculer:

    s = 0 - 1/3 + 1/4 - 1/5 + 1/7 ...

    au lieu de

    s = 1 - 1/3 + 1/5 - 1/7 + 1/9 ...

    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  4. #4
    Futur Membre du Club
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 9
    Points : 7
    Points
    7
    Par défaut
    Salut,

    Moi, je ferais k = -k plutôt que k = k * (-1), cela me semble plus rapide de faire un changement de signe plutôt que de faire une multiplication.

    Ensuite, il faut initialiser s à 1 et non 0 sinon, comme le dit s-ehtp, tu n'aurais pas la bonne suite.

    enfin, tu n'es pas obligé d'utiliser s' à la fin et tu peux écrire directement s = s * 4

    Voila

    Xavier

  5. #5
    Débutant
    Inscrit en
    Octobre 2007
    Messages
    285
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 285
    Points : 97
    Points
    97
    Par défaut
    merci pour vos corrections.mais j'ai une question,pour faire le calcul de pi/4 j'ai utiliser i allant de 1 à n,j ai donc supposé que pi/4 est fini.mais en fait,elle ne l'est pas!que dois-je donc faire?pi/4=1-1/3+1/5-1/7...................

  6. #6
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Points : 16 081
    Points
    16 081
    Par défaut
    Citation Envoyé par s-ehtp Voir le message
    merci pour vos corrections.mais j'ai une question,pour faire le calcul de pi/4 j'ai utiliser i allant de 1 à n,j ai donc supposé que pi/4 est fini.mais en fait,elle ne l'est pas!que dois-je donc faire?pi/4=1-1/3+1/5-1/7...................
    Arreter ta boucle lorsque tu as atteint une précision suffisante. Par exemple quand ton nouveau terme "1/a" est inferieur a ta précision. Ou lorsque "s" ne varie plus beaucoup entre 2 tours de boucle. A toi de voir...
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  7. #7
    Débutant
    Inscrit en
    Octobre 2007
    Messages
    285
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 285
    Points : 97
    Points
    97
    Par défaut
    je vais donc proceder par une boucle repeter.
    repeter instructions
    i=i+1
    jusqu'a 1/(a+2) inferieur à epsilon
    en fait si je procede par la boucle pour,je sais pas comment faire entrer cette condition?

  8. #8
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Points : 16 081
    Points
    16 081
    Par défaut
    Citation Envoyé par s-ehtp Voir le message
    je vais donc proceder par une boucle repeter.
    ca me semble une bonne idée.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    repeter instructions
    i=i+1
    jusqu'a 1/(a+2) inferieur à epsilon
    sauf que pour avoir toutes les fractions impaires, c'est pas "1/(a+2)" qu'il faut calculer... ou alors c'est pas "i=i+1" qu'il faut faire.
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  9. #9
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 690
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 690
    Points : 30 986
    Points
    30 986
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par pseudocode Voir le message
    Arreter ta boucle lorsque tu as atteint une précision suffisante. Par exemple quand ton nouveau terme "1/a" est inferieur a ta précision. Ou lorsque "s" ne varie plus beaucoup entre 2 tours de boucle. A toi de voir...
    Ou par exemple quand la "n" ième valeur calculée est identique à la précédente => cela signifie que ton calcul a atteint la précision maximale possible de ton processeur (c'est mon prof de C qui m'avait expliqué ça lors d'un exo sur un calcul de limite)...
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  10. #10
    Expert éminent
    Avatar de PRomu@ld
    Homme Profil pro
    Ingénieur de Recherche
    Inscrit en
    Avril 2005
    Messages
    4 155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Ingénieur de Recherche
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2005
    Messages : 4 155
    Points : 6 486
    Points
    6 486
    Par défaut
    Ou par exemple quand la "n" ième valeur calculée est identique à la précédente => cela signifie que ton calcul a atteint la précision maximale possible de ton processeur (c'est mon prof de C qui m'avait expliqué ça lors d'un exo sur un calcul de limite)...
    En fait, c'est pas exactement ça. Si tu as une implémentation de la bibliothèque standard qui est faite en 32 bits mais qui est exéctuée sur un processeur 64 bits ça revient exactement au même que d'être éxécuté sur un processeur 32 bits.

    De plus, si tu fais tes calculs avec une bibliothèque en précision arbitraire (comme GMP ou NTL), l'assertion ne colle plus.

    Mais au delà de l'aspect C, ici nous sommes dans le forum algo, ce genre de considération (limitation du proc ou co-proc) est trop complexe pour être utilisée, il vaut mieux travailler jusqu'à un epsilon donné ce qui permet une meilleure flexibilité.

  11. #11
    Débutant
    Inscrit en
    Octobre 2007
    Messages
    285
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 285
    Points : 97
    Points
    97
    Par défaut
    Citation Envoyé par pseudocode Voir le message
    ca me semble une bonne idée.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    repeter instructions
    i=i+1
    jusqu'a 1/(a+2) inferieur à epsilon
    sauf que pour avoir toutes les fractions impaires, c'est pas "1/(a+2)" qu'il faut calculer... ou alors c'est pas "i=i+1" qu'il faut faire.
    est tu peux me montrer comment faire?dois je indiquer que ce a+2 est impair?

  12. #12
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Points : 16 081
    Points
    16 081
    Par défaut
    Citation Envoyé par s-ehtp Voir le message
    dois je indiquer que ce a+2 est impair?
    Non. Tu dois te debrouiller pour qu'il soit impair.

    Au fait, il sort d'ou ce "a" ? Il est defini comme un entier mais il n'est jamais affecté a aucune valeur ??
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  13. #13
    Rédacteur

    Avatar de Matthieu Brucher
    Profil pro
    Développeur HPC
    Inscrit en
    Juillet 2005
    Messages
    9 810
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : Développeur HPC
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2005
    Messages : 9 810
    Points : 20 970
    Points
    20 970
    Par défaut
    Un autre souci est la précision finale. Il vaut mieux commencer par additionner les petits termes et remonter que faire le contraire.

  14. #14
    Rédacteur

    Homme Profil pro
    Comme retraité, des masses
    Inscrit en
    Avril 2007
    Messages
    2 978
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 83
    Localisation : Suisse

    Informations professionnelles :
    Activité : Comme retraité, des masses
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 2 978
    Points : 5 179
    Points
    5 179
    Par défaut Calcul de pi
    Salut !

    Tu trouveras tout un choix d'algorithmes sous "fr.wikipedia.org/wiki/Pi"

    Amuse-toi bien!
    Jean-Marc Blanc
    Calcul numérique de processus industriels
    Formation, conseil, développement

    Point n'est besoin d'espérer pour entreprendre, ni de réussir pour persévérer. (Guillaume le Taiseux)

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

Discussions similaires

  1. [V5] Aide sur l'erreur #calcul ou aucune valeur retournée.
    Par littlegekko dans le forum Deski
    Réponses: 2
    Dernier message: 08/09/2011, 15h55
  2. Calcul rapide des valeurs propres d'une matrice creuse
    Par gsagnol dans le forum Mathématiques
    Réponses: 3
    Dernier message: 21/12/2007, 23h37
  3. [XSLT] calcul d'une valeur absolue
    Par FlyByck dans le forum XSL/XSLT/XPATH
    Réponses: 2
    Dernier message: 15/01/2007, 14h01
  4. [VB2005]Calcul de deux valeurs de TextBox
    Par Jiyuu dans le forum Windows Forms
    Réponses: 5
    Dernier message: 07/01/2007, 22h55
  5. Faire du calcul avec la valeur d'un élément/attribut
    Par camboui dans le forum XML/XSL et SOAP
    Réponses: 4
    Dernier message: 03/11/2005, 16h10

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