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 :

programation multi threads


Sujet :

C

  1. #1
    Membre éprouvé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    1 299
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 299
    Par défaut programation multi threads
    Bonjour, j'ai fait un prgm qui résoud N systèmes d'équations différentielles non linéaires où N est une donnée de l'utilisateur. Après avoir codé une version séquentielle, j'en ai codé une autre en parallèle en utilisant MPI (sur une grappe de 26 processeurs). Comme j'ai 2 bi-processeurs sur mon PC, j'aimerais apprendre à coder en multi-thread. J'ai donc lu la page suivante http://emmanuel-delahaye.developpez.com/pthreads.htm ainsi que qq poly téléchargés du net. Mais j'ai trois questions de fond :

    1) avec MPI l'exécutable est copié sur les n processeurs où n est donné comme option lors de l'exécution (mpirun -np n executable). Est-ce que par défaut, un prgm multi-thread prendra tous les processeurs du PC ou dois-je le lui dire (n'en prends que 3 sur mes 4 par exemple) ?

    2) avec MPI l'exécutable est copié sur les n processeurs. Mais en multi-thread, j'ai l'impression qu'il n' y a qu'un seul exécutable. Je prends l'exemple ci-dessous (issus de http://emmanuel-delahaye.developpez.com/pthreads.htm) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    pthread_create (&ta, NULL, task_a, NULL);
    pthread_create (&tb, NULL, task_b, NULL);
    Comment est-ce que le PC gère : le thrad ta est en train de se lancer, donc lancer le thread tb sur un au tre processeur ?
    Avec MPI, chaque processeur a un rang et donc je faisais

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    if(rang == 0)
    blabla
    else if (rang == k)
    blabla
    3) Enfin, question de pratique : le nombre de système que je dois résoudre (N) est une donnée de l'utilisateur.

    Si je fais

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    for(i=0;i<N;++i)
    lancer le thread numéro i
    est-ce qu'ils vont tous s'exécuter en parallèle ? Est-ce la même chose que décrire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    pthread_create (&t1, NULL, task_1, NULL);
    pthread_create (&t2, NULL, task_2, NULL);
    ...
    pthread_create (&tN, NULL, task_N, NULL);
    Merci.

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

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 395
    Par défaut
    1) et 2)
    MPI : Multi-processus, chacun possédant un thread.

    Multithreading: Un seul processus avec N threads. À moins d'utiliser des fonctions système (comme SetProcessAffinityMask() sous Windows), tu n'as aucun moyen de spécifier sur quel(s) processeur(s) vont s'exécuter les threads. En théorie, s'il au moins autant de threads que de processeurs, il les prendra tous.

    3) Oui.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  3. #3
    Membre éprouvé
    Profil pro
    Inscrit en
    Décembre 2004
    Messages
    1 299
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 299
    Par défaut
    OK merci.

Discussions similaires

  1. programation multi thread
    Par Battant dans le forum Général Java
    Réponses: 13
    Dernier message: 25/05/2011, 23h27
  2. Tri multi-threadé
    Par Tifauv' dans le forum C
    Réponses: 8
    Dernier message: 28/06/2007, 09h00
  3. [VB6][active x] faire du multi-thread avec vb
    Par pecheur dans le forum VB 6 et antérieur
    Réponses: 9
    Dernier message: 20/05/2003, 12h01
  4. [Kylix] exception qtinft.dll et multi-threading
    Par leclaudio25 dans le forum EDI
    Réponses: 3
    Dernier message: 27/03/2003, 18h09

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