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 :

Message d'erreur Windows et exécution d'OpenMP


Sujet :

Threads & Processus C++

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2007
    Messages : 97
    Points : 47
    Points
    47
    Par défaut Message d'erreur Windows et exécution d'OpenMP
    Bonjour

    J'essaye de paralléliser mon programme grâce à OpenMP.

    Voici ce que je fais :

    #pragma parallel for
    for(int i = 0; i<2000; i++) {
    for (int j = i+1; j<2000; j++ {
    //traitements indépendants d'une itération à l'autre
    }
    }
    Voila mon problème : lorsque je lance le programme, je constate que mes deux processeurs sont au maximum (ce qui n'est pas le cas quand je n'utilise pas OpenMP) mais au bout de 30sec, ça plante.
    Je suis sous windows et voici le message d'erreur :

    MonProgramme.exe a rencontré un problème et doit fermer. Nous vous prions de nous excuser pour le désagrément encouru.

    ...

    Veuillez signaler ce problème à Microsoft
    ...
    Et pendant ce temps, le programme semble continuer à s'exécuter mais "sans OpenMP", les processeurs étant de nouveau chacun peu sollicités.
    Il finit par s'arrêter "à la fin" mais ne termine pas son exécution...

    Voila qu'en pensez-vous ? A quoi cela peut-il être du ?
    J'ai besoin de vos conseils s'il vous plait ...

    Merci

  2. #2
    Modérateur
    Avatar de bruno_pages
    Homme Profil pro
    ingénieur informaticien à la retraite
    Inscrit en
    Juin 2005
    Messages
    3 534
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : ingénieur informaticien à la retraite
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juin 2005
    Messages : 3 534
    Points : 6 723
    Points
    6 723
    Par défaut
    Bonjour,

    si la parallélisation du premier for lance 2000 exécutions concurrentes on peut comprendre que cela va mal se passer, est-ce le cas ?

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2007
    Messages : 97
    Points : 47
    Points
    47
    Par défaut
    Qu'entendez-vous par là ?

    Que devrais-je modifier dans ce cas ?


    Merci

  4. #4
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 379
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 379
    Points : 41 573
    Points
    41 573
    Par défaut
    Rien, c'est bruno_pages qui a oublié comment OpenMP déterminait le nombre de threads simultanés (OPENMP_NUM_THREADS et compagnie).

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2007
    Messages : 97
    Points : 47
    Points
    47
    Par défaut
    Oui, ok .

    Mais d'où pensez-vous que mon problème peut venir ? De la structure de mes boucles imbriquées ? Seraient-elles, de part leur conception non parallélisables ?

    Et dans ce cas, quelle a la (une) solution ? Remanier le code entièrement ?

  6. #6
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 379
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 379
    Points : 41 573
    Points
    41 573
    Par défaut
    Le peu que tu as montré me parait parallélisable.

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2007
    Messages : 97
    Points : 47
    Points
    47
    Par défaut
    Même si dans le code, je fais des vecteurs (qui vont être soumis à différents calculs) avec les indices i et j ?
    Je veux dire, je ne comprends pas pourquoi il se crashe; j'ai fait un test avec une multiplication matricielle et ça tourne sans problème.

  8. #8
    Modérateur
    Avatar de bruno_pages
    Homme Profil pro
    ingénieur informaticien à la retraite
    Inscrit en
    Juin 2005
    Messages
    3 534
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : ingénieur informaticien à la retraite
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juin 2005
    Messages : 3 534
    Points : 6 723
    Points
    6 723
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Rien, c'est bruno_pages qui a oublié comment OpenMP déterminait le nombre de threads simultanés (OPENMP_NUM_THREADS et compagnie).
    la question était justement de savoir si d'aventure nanath02 avait modifié le nombre de thread support en en autorisant un grand nombre, ou s'il laissait le système sagement décider en fonction du nombre de processeurs

  9. #9
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 379
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 379
    Points : 41 573
    Points
    41 573
    Par défaut
    Ben il n'en aurait jamais mis 2000 de toute façon...

  10. #10
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2007
    Messages : 97
    Points : 47
    Points
    47
    Par défaut
    Vous n'auriez pas une idée quant au comportement de mon programme ?

  11. #11
    Modérateur
    Avatar de bruno_pages
    Homme Profil pro
    ingénieur informaticien à la retraite
    Inscrit en
    Juin 2005
    Messages
    3 534
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : ingénieur informaticien à la retraite
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Juin 2005
    Messages : 3 534
    Points : 6 723
    Points
    6 723
    Par défaut
    Citation Envoyé par Médinoc Voir le message
    Ben il n'en aurait jamais mis 2000 de toute façon...
    qui sait ? j'ai déjà vu bien pire que cela ...

    P.S. attention, cette discussion vire au troll !

  12. #12
    Membre averti Avatar de uriotcea
    Homme Profil pro
    Ingénieur / physicien
    Inscrit en
    Septembre 2003
    Messages
    1 301
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur / physicien
    Secteur : Service public

    Informations forums :
    Inscription : Septembre 2003
    Messages : 1 301
    Points : 444
    Points
    444
    Par défaut
    Salut,

    Compte tenu de ta second boucle j'aurais privatisé 'i' cas ou

    #pragma parallel for private(i)

    Sinon, en mode debug la solution saute souvent au yeux

  13. #13
    Membre chevronné
    Avatar de Joel F
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Septembre 2002
    Messages
    918
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Service public

    Informations forums :
    Inscription : Septembre 2002
    Messages : 918
    Points : 1 921
    Points
    1 921
    Par défaut
    Ne dépasse tu pas simplement les bornes de tes tableaux dans ta boucle interne ?

Discussions similaires

  1. [AC-2003] Message d'erreur suite à l'exécution d'un formulaire
    Par rafalemirage dans le forum IHM
    Réponses: 12
    Dernier message: 10/02/2011, 17h00
  2. Message d'erreur Windows - L'écriture décallée a échoué
    Par olive_le_malin dans le forum Windows XP
    Réponses: 2
    Dernier message: 21/01/2008, 14h14
  3. Message d'erreur bizarre à l'exécution
    Par khtarius dans le forum Fortran
    Réponses: 5
    Dernier message: 23/04/2007, 09h51
  4. [ASP] message d'erreur (impossible d'excuter un projet ...)
    Par haganidjamel dans le forum Delphi .NET
    Réponses: 6
    Dernier message: 06/09/2005, 17h28
  5. Message d'erreur Windows lors de l'exécution de l'appli D6-
    Par kolac dans le forum Bases de données
    Réponses: 4
    Dernier message: 07/12/2004, 17h55

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