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

Images Discussion :

[Débutant][imtransform] Optimisation de code


Sujet :

Images

  1. #1
    Membre à l'essai
    Étudiant
    Inscrit en
    Octobre 2007
    Messages
    25
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2007
    Messages : 25
    Points : 12
    Points
    12
    Par défaut [Débutant][imtransform] Optimisation de code
    Bonjour,

    Je suis sur du traitement d'images, plus précisément du face morphing.
    Mon programme est un peu long à s'exécuter à mon goût. J'ai déjà
    fait un PROFILE pour voir ce qui prenait le plus de temps, donc voilà
    ce qui me pose problème :

    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
     
    coeff =    [1 oeil_left(1)+diff_pt1(1)  oeil_left(1)+diff_pt1(1);...
                1 1                         oeil_left(3)+diff_pt1(2);]
              /...
               [1 oeil_left(1)              oeil_left(1);...
                1 1                         oeil_left(3);...
                1 1                         1];
     
    tform = maketform('affine', [coeff(1) coeff(3) 0; coeff(2) coeff(4) 0; 0 0 1]);
    tri = src(1:oeil_left(3), 1:oeil_left(1), :);
    tmp = imtransform(tri,tform);
    tmp_size = size(tmp);
     
    tmp_src(1:tmp_size(1) - 1, 1:tmp_size(2) - 1,:)=...
                        tmp(1:tmp_size(1) - 1, 1:tmp_size(2) - 1,:);
    Ce qui prend le plus de temps est l'appel à la fonction imtransform,
    comme c'est une fonction matlab, je doute que je puisse y faire grand
    chose

    Cependant, je dois répéter ce petit bout de code beaucoup de fois, et
    les matrices que j'utilise pour calculer coeff sont toutes différentes.

    Donc, au final, je me retrouve avec un fichier immense, avec ce petit bout
    de code, quasi recopier, une trentaine de fois.

    Est-ce qu'il y aurait moyen de réduire tout ça ?

    * Est-ce que ça vaut le coup que je passe tout le fichier en C ?
    * Je pourrais faire une grosse matrice regroupant tous mes "coeff"
    et seulement ensuite faire un seul appel à imtransform, du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    tform = maketform('affine', liste_coeff(:));
    tri = src(1:oeil_left(3), 1:oeil_left(1), :);
    tmp = imtransform(tri,tform(:));
    ça serait possible ? ou alors ça servirait à rien ?

    Merci,

    --
    Aurélie Barbier

  2. #2
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 302
    Points : 52 884
    Points
    52 884
    Par défaut
    Citation Envoyé par pootchi Voir le message
    Mon programme est un peu long à s'exécuter à mon goût.
    Combien de temps ?
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  3. #3
    Membre à l'essai
    Étudiant
    Inscrit en
    Octobre 2007
    Messages
    25
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2007
    Messages : 25
    Points : 12
    Points
    12
    Par défaut
    8.875sec en exécutant le bout de code 120 fois
    c'est imtransform qui prend 85% du temps

  4. #4
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 302
    Points : 52 884
    Points
    52 884
    Par défaut
    Tu pourrais nous montrer le premier tableau récapitulatif de PROFILE ?
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  5. #5
    Membre à l'essai
    Étudiant
    Inscrit en
    Octobre 2007
    Messages
    25
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2007
    Messages : 25
    Points : 12
    Points
    12
    Par défaut
    Voilà (je l'ai fait tourné un peu plus longtemps...)

    Nom : profile.JPG
Affichages : 63
Taille : 60,6 Ko

    --
    Aurélie Barbier

  6. #6
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 302
    Points : 52 884
    Points
    52 884
    Par défaut
    Je vois que REPMAT est appelé 2000 fois

    Peux-tu montrer la (ou les) ligne(s) de code où cette fonction apparait.

    Sinon, la fonction la plus couteuse (barre bleue foncée) est un fichier MEX (environ 7s). Ton code est donc quasi impossible à optimiser (sous MATLAB), à mon avis.
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  7. #7
    Membre à l'essai
    Étudiant
    Inscrit en
    Octobre 2007
    Messages
    25
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2007
    Messages : 25
    Points : 12
    Points
    12
    Par défaut
    Citation Envoyé par Dut Voir le message
    Je vois que REPMAT est appelé 2000 fois

    Peux-tu montrer la (ou les) ligne(s) de code où cette fonction apparait.
    C'est imtransform qui l'appelle à chaque fois

    Sinon, la fonction la plus couteuse (barre bleue foncée) est un fichier MEX (environ 7s). Ton code est donc quasi impossible à optimiser (sous MATLAB), à mon avis.
    Ouaip, c'est ce que je me disais...Je me demandais si en C ça serait mieux...?

    --
    Aurélie Barbier

  8. #8
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Freelance mécatronique - Conseil, conception et formation

    Informations forums :
    Inscription : Novembre 2006
    Messages : 20 302
    Points : 52 884
    Points
    52 884
    Par défaut
    Citation Envoyé par pootchi Voir le message
    Ouaip, c'est ce que je me disais...Je me demandais si en C ça serait mieux...?
    C'est déjà du C (a priori)

    => : Qu'est ce qu'un fichier MEX ?
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  9. #9
    Membre à l'essai
    Étudiant
    Inscrit en
    Octobre 2007
    Messages
    25
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2007
    Messages : 25
    Points : 12
    Points
    12
    Par défaut
    Citation Envoyé par Dut Voir le message
    C'est déjà du C (a priori)
    Yep, la fatigue, tout ça

    Bien, merci, je vais laisser mon code comme ça alors...

    --
    Aurélie Barbier

  10. #10
    Membre averti

    Inscrit en
    Août 2007
    Messages
    302
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 302
    Points : 352
    Points
    352
    Par défaut
    Hello,


    tu pourrais appeler imtransform avec une 'Nearest-neighbor interpolation' a la place de bilineaire (defaut), si ca te convient.

  11. #11
    Membre averti

    Inscrit en
    Août 2007
    Messages
    302
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 302
    Points : 352
    Points
    352
    Par défaut
    attention: les conseils suivants ne doivent etre applique que si a. les performances sont vraiment critiques b. tu es sur que ton algo est bien pense a un niveau "plus haut". c. tu as pas mal de temps a disposition!

    Par rapport a l'implementation en C, il est tres probable que celle proposee ne soit pas multi-thredees... Donc il est peut-etre possible de faire une meilleure implementation sur proc multi-core. (mais a verifier avant de se lancer!).

    Tu peux aussi aller voir les sources de resampsep (elles sont fournies avec la toolbox je crois). Il y a eventuellement des choses a optimiser dedans.... Ou a adapter a ton cas particulier.

    Voila,

    Bonne chance,

    Gregoire

  12. #12
    Membre à l'essai
    Étudiant
    Inscrit en
    Octobre 2007
    Messages
    25
    Détails du profil
    Informations personnelles :
    Âge : 37

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2007
    Messages : 25
    Points : 12
    Points
    12
    Par défaut
    Citation Envoyé par paradize3 Voir le message
    attention: les conseils suivants ne doivent etre applique que si a. les performances sont vraiment critiques b. tu es sur que ton algo est bien pense a un niveau "plus haut". c. tu as pas mal de temps a disposition!

    Par rapport a l'implementation en C, il est tres probable que celle proposee ne soit pas multi-thredees... Donc il est peut-etre possible de faire une meilleure implementation sur proc multi-core. (mais a verifier avant de se lancer!).

    Tu peux aussi aller voir les sources de resampsep (elles sont fournies avec la toolbox je crois). Il y a eventuellement des choses a optimiser dedans.... Ou a adapter a ton cas particulier.
    Ok, merci beaucoup pour ces indications. Comme c'est un projet de stage,
    ce n'est pas grave si je n'optimise pas, mais quand même

    Je vais donc réfléchir avant de me lancer dans cette optim

    Merci en tout cas !

    --
    Aurélie Barbier

Discussions similaires

  1. [MySQL] Optimisation de code pour un débutant
    Par neospirit dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 08/02/2011, 14h05
  2. optimiser le code
    Par bibi2607 dans le forum ASP
    Réponses: 3
    Dernier message: 03/02/2005, 14h30
  3. [Débutant(e)][optimisation]Objet Session
    Par plddcn dans le forum Servlets/JSP
    Réponses: 5
    Dernier message: 24/01/2005, 21h34
  4. syntaxe et optimisation de codes
    Par elitol dans le forum Langage SQL
    Réponses: 18
    Dernier message: 12/08/2004, 11h54
  5. optimisation du code et var globales
    Par tigrou2405 dans le forum ASP
    Réponses: 2
    Dernier message: 23/01/2004, 10h59

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