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

Threads & Processus C++ Discussion :

Problème de taille et de maths.


Sujet :

Threads & Processus C++

  1. #1
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2015
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2015
    Messages : 29
    Par défaut Problème de taille et de maths.
    Bonjour je dois calculer une valeur approchée de pi en utilisant le polynome de chebyshev (http://pi314.net/fr/methana.php) en répéant la somme par 10 000 000 itérations.
    Mon programme devra ensuite être utiliser le multhreading (1,2,4 ou 8), je l'ai d'abord implanté en séquentiel en gardant à l'idée qu'il doit être adapté.

    Voici le code :

    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
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
     
    int main()
    {
     
    	std::uint64_t iteration = 10000000;
     
    	std::cout.precision(10);
     
     
    	// Suite U ------------------------------------------------------------------
    	long double *suiteU = new long double[2*iteration];
     
    	suiteU[1] = 99.0/100.L;
    	suiteU[2] = 4801.0/5000.L;
     
    	for(std::uint64_t i=3;i<2*iteration;i++)
    	{
    		suiteU[i] = (99.L/50.L) * suiteU[i-1] - suiteU[i-2];
    	}
     
     
    	// Suite V ------------------------------------------------------------------
    	long double *suiteV = new long double[2*iteration];
    	suiteV[0] = 99.L/4780.L;
    	suiteV[1] = -11414399.L/11424200.L;
     
    	for(std::uint64_t i=3;i<2*iteration;i++)
    	{
    		suiteV[i] = (99.L/2390.L) * suiteV[i-1] - suiteV[i-2];
    	}
     
    	// Calcul de PI -------------------------------------------------------------
    	long double pi;
     
    	for (std::uint64_t i = 1; i<=iteration;i++)
    	{
    			pi += (std::pow(-1,i-1) / (std::pow(10,2*i-1) * (2*i-1)))
    			* (4.L*suiteU[2*i-1]-suiteV[2*i-1]);
     
    	}
     
    	std::cout << 8*pi;
    	return 0;
    }
    Mon problème : Avec des double j'obtiens une valeur 3.96XXXXXXXXX, toujours le même résultat peu importe le nombre d'itérations.
    Je me suis donc dit que les double n'étaient pas assez précis pour les valeurs que je calcule.
    Cependant avec des long double j'obtiens la valeur "nan" pour pi...

    Je ne sais donc plus du tout comment faire, pourriez vous m'aiguiller ?

    Merci de m'avoir lu, bonne soirée.

    Teebus

  2. #2
    Membre Expert
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2012
    Messages
    1 711
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2012
    Messages : 1 711
    Par défaut
    Hello,

    Ta variable pi n'est pas initialisée.

    edit : au passage, 10^(2i-1) * (2i-1) , pour i = 10 000 000 ça fait beaucoup (ton dénominateur), je suis pas sur que ça rentre dans un double j'en suis même sur : ça rentre pas.

  3. #3
    Membre averti
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2015
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2015
    Messages : 29
    Par défaut
    Bonsoir, merci pour votre réponse.
    J'ai initialisé pi et je n'ai plus "nan" comme valeur ! Merci !!
    Cependant j'ai toujours le soucis du 3.96XXXXXXX quelque soit le nombre d'itérations.
    J'ai beau chercher je ne parviens pas à comprendre ce qui ne va pas et comment procéder, voyez vous une autre erreur dans mon code ?

    edit : résolu j'ai trouvé mon erreur, au niveau des valeurs v1 et v2 de la suiteV, merci beaucoup.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 02/02/2009, 17h21
  2. Problème de taille de tableau
    Par k-nine dans le forum C
    Réponses: 6
    Dernier message: 25/09/2005, 09h16
  3. [CSS] Problème de taille de div
    Par meda dans le forum Mise en page CSS
    Réponses: 6
    Dernier message: 24/08/2005, 14h30
  4. [swing][JComboBox]Problème de taille
    Par n!co dans le forum Composants
    Réponses: 8
    Dernier message: 06/03/2004, 10h53
  5. [langage] Problème de taille de fichier à mettre dans
    Par And_the_problem_is dans le forum Langage
    Réponses: 10
    Dernier message: 13/08/2002, 09h41

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