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

GTK+ avec C & C++ Discussion :

Les threads et le multiprocessing


Sujet :

GTK+ avec C & C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Expert confirmé
    Avatar de gerald3d
    Homme Profil pro
    Conducteur de train
    Inscrit en
    Février 2008
    Messages
    2 308
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Conducteur de train
    Secteur : Transports

    Informations forums :
    Inscription : Février 2008
    Messages : 2 308
    Billets dans le blog
    5
    Par défaut Les threads et le multiprocessing
    Bonjour.

    Le nouveau problème qui m'amène aujourd'hui est, vous l'aurez compris, les threads. Vaste sujet qui fait couler beaucoup d'encre, enfin plutôt taper beaucoup de touches clavier .

    Je travaille actuellement sur un soft de traitement d'image. L'interface est bien entendu géré par GTK+. Cette interface est pour ainsi dire terminée. Vient maintenant le temps de passer aux choses sérieuses. Il faut lancer les calculs. C'est là que le problème survient.

    Je vous donne un exemple de traitement. Soit 45 images de 3040x2014 en RVB. Il faut que je détermine une image résultante qui sera pour chaque pixel la valeur moyenne avec calcul itératif en prenant en compte l'écart typique (méthode Kappa-Sigma clipping).

    Vous comprenez bien qu'il est hors de question pour moi de charger en mémoire les 45 images en mémoire pour lancer ensuite le calcul. J'ai donc dans l'idée de partager le travail. Je divise la taille image en portions égales. Chaque portion sera lancée dans un thread. Je limite le nombre de threads à 10 par exemple (arbitraire). Bien entendu cette méthode pose un inconvénient. Rien n'est parfait. Pour chaque portion il faut charger depuis le disque chaque image, sauvegarder la nouvelle portion, libérer la mémoire de l'image entière et ainsi de suite.

    Voila ma question. Je tiens à pouvoir utiliser le maximum de puissance disponible. Les gthread utilisent-ils les multiprocesseurs, si la machine sur laquelle le soft tourne en est doté? Je sais déjà que le multiprocessing est géré par le noyau mais comme il existe par exemple la librairie openMP je me pose des questions.

  2. #2
    Membre Expert
    Homme Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 259
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 259
    Par défaut
    Les gthreads sont un simple wrapper autour des pthreads sous linux, donc oui, le noyau répartira les threads sur les différents processeurs/coeurs disponibles automatiquement. OpenMP va être une surcouche au dessus de tout ça pour simplifier la conception de programmes parallèles.

  3. #3
    Expert confirmé
    Avatar de gerald3d
    Homme Profil pro
    Conducteur de train
    Inscrit en
    Février 2008
    Messages
    2 308
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Conducteur de train
    Secteur : Transports

    Informations forums :
    Inscription : Février 2008
    Messages : 2 308
    Billets dans le blog
    5
    Par défaut
    Merci Teuf13 pour ces précisions. Je ne travaillerai donc qu'avec les gthread. Ca va me simplifier la vie.

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

Discussions similaires

  1. Aide sur les Threads
    Par themoye dans le forum MFC
    Réponses: 24
    Dernier message: 06/03/2005, 15h02
  2. Les Threads... J'en remet une couche :)
    Par Higestromm dans le forum C++
    Réponses: 5
    Dernier message: 17/11/2004, 12h19
  3. Gestion des message windows dans les threads
    Par billyboy dans le forum Windows
    Réponses: 5
    Dernier message: 06/10/2003, 17h25
  4. Question simple sur les threads :)
    Par momox dans le forum C++Builder
    Réponses: 2
    Dernier message: 15/06/2003, 04h13
  5. question sur les variables globales et les thread posix
    Par souris_sonic dans le forum POSIX
    Réponses: 5
    Dernier message: 13/06/2003, 13h59

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