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 :

Temps d'execution négatif avec <time.h>


Sujet :

C++

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2011
    Messages
    338
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2011
    Messages : 338
    Points : 0
    Points
    0
    Par défaut Temps d'execution négatif avec <time.h>
    Salut! J'utilise <time.h> pour calculer le temps d’exécution d'un code en c++ qui fait des calculs, voila la partie qui nous intéresse:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    clock_t start = std::clock();
     /* L E    C O D E   Q U I   F A I T    D E S   C A L C U L S*/
    cout<<"-------------------------------- " << (std::clock() - start)/(long double)CLOCKS_PER_SEC <<"s --------------------------------" << endl;
    Le problème ici c'est que des fois ça retourne une valeur négative du genre:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    --------------------------------  -1480,88s  --------------------------------
    Comment régler ça svp ?

    (Je veux avoir le temps exact et par seconde)

  2. #2
    Membre actif

    Profil pro
    Inscrit en
    Avril 2010
    Messages
    356
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2010
    Messages : 356
    Points : 206
    Points
    206
    Par défaut
    Je ne vois pas d'erreur qui pourrait faire ça dans ton code et je soupçonne que l'erreur est autre part. Pourrais-tu nous donner un code complet (que nous pouvons exécuter) qui reproduit le problème ?

    PS : utiliser static_cast<T> plutôt que (T) est souvent une bonne idée.

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2011
    Messages
    338
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2011
    Messages : 338
    Points : 0
    Points
    0
    Par défaut
    Citation Envoyé par NoIdea Voir le message
    Je ne vois pas d'erreur qui pourrait faire ça dans ton code et je soupçonne que l'erreur est autre part. Pourrais-tu nous donner un code complet (que nous pouvons exécuter) qui reproduit le problème ?

    PS : utiliser static_cast<T> plutôt que (T) est souvent une bonne idée.
    Désolé, le est code confidentiel je ne peux pas le publié en ce moment.
    Mais, dans le code précédent il y a tous ce qu'il faut normalement ça manque que <time.h>

  4. #4
    Expert confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Juin 2012
    Messages
    1 711
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juin 2012
    Messages : 1 711
    Points : 4 442
    Points
    4 442
    Par défaut
    Hello,
    Citation Envoyé par mohsenuss91 Voir le message
    Désolé, le est code confidentiel je ne peux pas le publié en ce moment.
    Mais, dans le code précédent il y a tous ce qu'il faut normalement ça manque que <time.h>
    http://ideone.com/QxjdEH

    Comme déjà dit, le problème vient d'ailleurs.

  5. #5
    Nouveau Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2011
    Messages
    338
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2011
    Messages : 338
    Points : 0
    Points
    0
    Par défaut
    Citation Envoyé par Iradrille Voir le message
    Hello,

    http://ideone.com/QxjdEH

    Comme déjà dit, le problème vient d'ailleurs.
    J'ai même essayé avec <chrono>:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    auto start = std::chrono::system_clock::now();
     
    /* calculs*/
     
    auto elapsed = std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now() - start);
     
    std::cout << elapsed.count() <<" s" <<end;
    mais ça me donne en résultat que la partie entiére en secondes ( pas de virgules)

    Comment faire pour avoir le résultat complet (avec les virgules) en secondes svp!

  6. #6
    Membre chevronné Avatar de Ehonn
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2012
    Messages
    788
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2012
    Messages : 788
    Points : 2 160
    Points
    2 160
    Par défaut
    Il faut demander à duration d'utiliser la bonne réprésentation (premier type template).
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    auto elapsed = std::chrono::duration<double>(std::chrono::system_clock::now() - start);
    Par défaut la période (le deuxième type template) de duration est std::ratio<1> (ce sont donc des secondes). Si tu veux des millisecondes (par exemple) il faudra lui donner std::milli.

    http://en.cppreference.com/w/cpp/chrono/duration

Discussions similaires

  1. Profile du code incoherent avec le temps d'execution
    Par isangoma dans le forum Code::Blocks
    Réponses: 1
    Dernier message: 24/07/2014, 09h59
  2. Réponses: 10
    Dernier message: 09/02/2010, 20h08
  3. Réponses: 6
    Dernier message: 27/07/2007, 18h38
  4. Problème avec temps d'execution
    Par RR instinct dans le forum Installation
    Réponses: 7
    Dernier message: 22/08/2006, 09h13
  5. limit et temps d'execution avec oracle et PHP
    Par dor_boucle dans le forum Oracle
    Réponses: 20
    Dernier message: 10/12/2005, 14h31

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