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 :

Problème allocation dynamique UPC Threads


Sujet :

C

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    188
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 188
    Points : 140
    Points
    140
    Par défaut Problème allocation dynamique UPC Threads
    Bonjour ,
    me voila de retour avec un nouveau problème auquel je ne trouve des solutions .
    alors en résumé :

    je fait une allocation dynamique en UPC ( parallelisme ) mais je constate en mettant un printf dans cette fonction que seul le THREAD 0 a une affinité avec la boucle upc_forall et aucun d'autre donc si comme si il a tout les éléments de la matrice et donc aucune parallélisation .

    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
     
    shared float** malloc_matrice_2d(int vsize,int hsize)
     {
     
      int i = 0;
      shared float **matrix;
      shared float *imptr;
     
      matrix=(shared float **)upc_all_alloc(THREADS,(vsize*hsize/THREADS)*upc_elemsizeof(**matrix));
      if (matrix==NULL) printf("upc_all_alloc : probleme d'allocation memoire");
     
     
      imptr=(shared float*)upc_all_alloc(THREADS,hsize*vsize*upc_elemsizeof(*imptr));
      if (imptr==NULL) printf("upc_all_alloc : probleme d'allocation memoire");
     
     
       upc_forall(i=0;i<vsize;i++ , imptr+=hsize ; &matrix[i][0] ) 
     	{
    	printf("MYTHREAD : %d \n" , MYTHREAD );
     	matrix[i]=imptr;
     
     }
      		return matrix;
     
     }
    et le resultat est simplement
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    MYTHREAD : 0 
    MYTHREAD : 0 
    MYTHREAD : 0 
    MYTHREAD : 0 
    MYTHREAD : 0 
     
    .....
    si vous avez des propositions ou des solutions je vous remercie d'avance .

  2. #2
    Expert éminent sénior
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par spax Voir le message
    je fait une allocation dynamique en UPC ( parallelisme ) mais je constate en mettant un printf dans cette fonction que seul le THREAD 0 a une affinité avec la boucle upc_forall et aucun d'autre donc si comme si il a tout les éléments de la matrice et donc aucune parallélisation .
    .
    Il ne peut y avoir de parallélisation que si le code 'relâche' le CPU de temps en temps. C'est le cas lors d'un appel à une fonction d'E/S comme printf(). Si les autres threads sont 'blancs' (boucles sans suspension), Ils prennent 100% du CPU. Point.

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    188
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 188
    Points : 140
    Points
    140
    Par défaut
    Je n'ai pas tres bien compris tu peut déveloper un peu ? merci et si tu a des suggéstion par rapport au code aussi ca sera génial . merci

  4. #4
    Expert éminent sénior
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 67
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Points : 20 985
    Points
    20 985
    Par défaut
    Citation Envoyé par spax Voir le message
    Je n'ai pas tres bien compris tu peut déveloper un peu ? merci et si tu a des suggéstion par rapport au code aussi ca sera génial . merci
    Ajouter des suspensions (sleep(1), par exemple, c'est POSIX.1), dans tous les threads.
    .

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    188
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 188
    Points : 140
    Points
    140
    Par défaut
    Bonjour encore , bien je vois pas pourquoi il faut relacher le CPU vu que ici on parle pas de THREAD en monoproc mais plutot que chaque thread est un processeur indépendant . le probleme que je vois est plutot au niveau de l'allocation : comme si le premier thread ( proc ) est le propriétaire de toute la matrice alors que moi je voulais plutot la distribuée par bloque sur plusieur .

    le sleep ne change rien en fait .

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

Discussions similaires

  1. problème allocation dynamique dans C++
    Par mido1951 dans le forum C++
    Réponses: 16
    Dernier message: 23/04/2013, 21h38
  2. problème allocation dynamique tableau 2d
    Par virtual_bug dans le forum C++
    Réponses: 16
    Dernier message: 17/04/2012, 11h21
  3. Problème allocation dynamique ?
    Par Dark_Alex69 dans le forum C
    Réponses: 15
    Dernier message: 20/11/2007, 15h44
  4. problème allocation dynamique
    Par josef24 dans le forum Débuter
    Réponses: 6
    Dernier message: 12/11/2007, 12h31
  5. Question sur les problèmes d'allocation dynamique
    Par slylafone dans le forum C++
    Réponses: 23
    Dernier message: 25/10/2004, 14h18

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