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

MATLAB Discussion :

Temps d'execution d'un programme


Sujet :

MATLAB

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    202
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 202
    Points : 96
    Points
    96
    Par défaut Temps d'execution d'un programme
    Salut, c'est encore moi.

    Je voulais savoir si quelqu'un pouvait me dire comment inclure dans un programme une sorte de compteur permettant de montrer le pourcentage d'execution de celui-ci....
    Comme j'ai un programme assez long à faire tourner, sans savoir s'il est juste, je veux voir un peu sa vitesse d'execution avant de me le faire corriger si besoin.

    Merci
    Moi j'aime bien Matlab...mais j'ai pas l'impression que ça soit réciproque......

  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
    Utilise l'outil M-Lint

    => Menu Tools > M-Lint > Show M-Lint Report

    Il faut que l'Editor soit actif
    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 régulier
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    202
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 202
    Points : 96
    Points
    96
    Par défaut
    Alors j'ai peut-être mal vu, mais j'ai l'impression que M-Lint me donne là où des erreurs potentielles se sont glissées...

    Mais ce que je souhaite, c'est un genre de petit compteur qui défilerait en me disant :

    25% du programme effectué
    ...
    50% du programme effectué
    ...
    75% du programme effectué

    Je ne sais pas si c'est possible!!!
    Moi j'aime bien Matlab...mais j'ai pas l'impression que ça soit réciproque......

  4. #4
    Membre éprouvé

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2007
    Messages
    979
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2007
    Messages : 979
    Points : 1 256
    Points
    1 256
    Par défaut
    Generalement c'est toi qui doit le faire ce compteur :

    Dans ta boucle principale :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    fin = 120;  % exemple.
     
    for i = 1:fin
      if mod(i,round(fin/10)) == 0  % affichage tout les 10%
       fprintf('Progress [ %2.0f%% ] \n', 100*i/fin);
      end
    end
    Resultats :

    Progress [ 10% ]
    Progress [ 20% ]
    Progress [ 30% ]
    Progress [ 40% ]
    Progress [ 50% ]
    Progress [ 60% ]
    Progress [ 70% ]
    Progress [ 80% ]
    Progress [ 90% ]
    Progress [ 100% ]
    ++
    AlloSchool, votre école sur internet.

  5. #5
    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 Ptinéwik Voir le message
    Alors j'ai peut-être mal vu,
    Désolé, je suis passé en vitesse et j'ai répondu un peu à coté

    Je voulais parler du Profiler...

    => Menu Tools > Open profiler puis Start Profiling

    Au moins ma mauvaise réponse t'aura peut être permis de découvrir le M-Lint
    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)

  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
    Citation Envoyé par mr_samurai Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    fin = 120;  % exemple.
     
    for i = 1:fin
      if mod(i,round(fin/10)) == 0  % affichage tout les 10%
       fprintf('Progress [ %2.0f%% ] \n', 100*i/fin);
      end
    end
    Ou :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    fin = 120;  % exemple.
     
    fprintf('Progress [ %2.0f%% ] \n', 0);
    for i = 1:fin
      if mod(i,round(fin/10)) == 0  % affichage tout les 10%
       fprintf('%c%c%c%c%c%c%c%2.0f%% ] \n',8,8,8,8,8,8,8, 100*i/fin);
       pause(.5)
      end
    end
    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 régulier
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    202
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 202
    Points : 96
    Points
    96
    Par défaut
    Merci à vous deux, c'est exactement ce que je voulais.

    Merci Dut pour le M-Lint, c'est vrai que ça m'a permis de le découvrir, même si j'utilisais un peu au moins les apparitions de couleur sur le côté de ma programmation. Mais là au moins, tout est marqué, pas besoin de galérer en se posant sur l'annonce d'erreur....

    En tout cas vraiment merci, et bonne journée.

    Moi j'aime bien Matlab...mais j'ai pas l'impression que ça soit réciproque......

  8. #8
    Membre éprouvé

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2007
    Messages
    979
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2007
    Messages : 979
    Points : 1 256
    Points
    1 256
    Par défaut
    Citation Envoyé par Dut Voir le message
    Je voulais parler du Profiler...
    => Menu Tools > Open profiler puis Start Profiling
    Au moins ma mauvaise réponse t'aura peut être permis de découvrir le M-Lint
    Salut Dut ,

    J'ai jamais utilisé le profiler de matlab, mais pour moi un profiler permet de savoir le pourcentage de temps d'executuion passé dans chaque fonction (ou partie du code, ou même ligne de code). Je ne comprend pas comment cela permet de savoir l'etat d'avancement de l'execution ?

    ++
    AlloSchool, votre école sur internet.

  9. #9
    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 mr_samurai Voir le message
    Je ne comprend pas comment cela permet de savoir l'etat d'avancement de l'execution ?
    Moi non plus ... je viens de relire le premier message, et il semble bien que je sois passé à coté du sujet

    Bon en même temps, une discussion qui fait mention à la fois du M-Lint, du Profiler, et d'un compteur de pourcentage d'exécution, c'est une excellente discussion
    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)

  10. #10
    Membre éprouvé

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2007
    Messages
    979
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2007
    Messages : 979
    Points : 1 256
    Points
    1 256
    Par défaut
    Exactement ,

    Avant cette discussion, je ne savais même pas que Matlab disposait d'un profiler.
    AlloSchool, votre école sur internet.

  11. #11
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    202
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 202
    Points : 96
    Points
    96
    Par défaut
    Alors du coup je vais ptètre paraitre un peu bête, mais autant j'ai bien compris à quoi servait M-Lint, autant je suis un peu largué sur le profiler.

    Sinon, j'ai trouvé autre chose pour le compteur, même si l'indication se retrouve en heure du coup (et oui, quand j'ai dis que le programme était long, je n'ai pas menti...)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    for 
        tic,
    'my program'
        a=toc;
        a*(n-i)/3600
    end
    Mais j'aime bien l'histoire des pourcentages aussi...
    Moi j'aime bien Matlab...mais j'ai pas l'impression que ça soit réciproque......

  12. #12
    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
    Le Profiler te permet d'optimiser le temps d'exécution de ton code en te montrant les lignes les plus gourmandes.
    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)

  13. #13
    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
    Une proposition de modification du code de DUT:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
        fin = 120;  % exemple.
     
        tt = 'Progress [  0%% ]';
        h = waitbar(0,tt);
        fprintf(tt);
     
        for i = 1:fin
          fprintf('\b\b\b\b\b\b%2.0f%% ]\n', 100*i/fin);
          waitbar(i/fin,h,sprintf('Progress [  %2.0f%% ] \n', 100*i/fin));
     
          pause(0.1);
        end

    Salutations,

    Gregoire

  14. #14
    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
    Effectivement, 8 est la valeur ascii du caractère backspace \b.

    Les deux codes suivant sont donc équivalents :
    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)

  15. #15
    Membre éprouvé

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2007
    Messages
    979
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2007
    Messages : 979
    Points : 1 256
    Points
    1 256
    Par défaut
    Citation Envoyé par paradize3 Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
          % ...
          waitbar(i/fin,h,sprintf('Progress [  %2.0f%% ] \n', 100*i/fin));
          % ....
    J'aime beaucoup la bare de progression , je me suis pas lever pour rien ce matin.

    Juste une question le caractére \r unix (retour chariot sans saut de ligne) ne marche pas sous matlab ?
    AlloSchool, votre école sur internet.

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 27/07/2007, 18h38
  2. Temps D'execution D'un Programme
    Par hamska2 dans le forum C
    Réponses: 14
    Dernier message: 09/05/2007, 18h14
  3. temps d'execution d'un programme multithread
    Par La taupe dans le forum C
    Réponses: 2
    Dernier message: 10/01/2007, 17h44
  4. Réponses: 5
    Dernier message: 19/06/2006, 22h54
  5. temps d'execution d'un programme
    Par Invité(e) dans le forum C
    Réponses: 8
    Dernier message: 17/05/2006, 13h12

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