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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    202
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 202
    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

  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 317
    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 317
    Par défaut
    Utilise l'outil M-Lint

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

    Il faut que l'Editor soit actif

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    202
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 202
    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!!!

  4. #4
    Membre émérite

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

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2007
    Messages : 979
    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% ]
    ++

  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 317
    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 317
    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

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    202
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 202
    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.


  7. #7
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 317
    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 317
    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

  8. #8
    Membre émérite

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

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2007
    Messages : 979
    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 ?

    ++

  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 317
    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 317
    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

+ 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