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 :

Afficher des heures en abscisse d'un graphique


Sujet :

MATLAB

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Décembre 2013
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2013
    Messages : 4
    Points : 5
    Points
    5
    Par défaut Afficher des heures en abscisse d'un graphique
    Bonjour,
    J'ai des fichiers .dat contenant des données représentant des températures en fonction du temps, dont la première colonne est l'heure de la mesure, et les autres colonnes les températures, comme dans cet exemple:

    00:00:01 19.01 19.34 19.98
    00:05:01 19.01 19.34 19.66
    00:10:01 19.12 19.34 19.98
    00:15:02 19.01 19.66 19.98
    00:20:01 19.01 19.34 19.98
    00:25:01 19.01 19.34 19.66
    00:30:01 19.12 19.34 19.98
    00:35:02 19.01 19.66 19.98
    00:45:01 19.01 19.66 19.98
    etc...
    (Les fichiers réels ont un nombre variable de lignes (entre 100 et 300), et 11 colonnes de températures au lieu de 3, voir pièce jointe)

    Je souhaite tracer ces températures en fonction de l'heure.

    Mon programme ressemble à ça:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    adresse = 'C:\Users\Jeremy\Desktop\Temperatures\20131102_rdc.dat';
     
    %% %% Collecte des données %%%%
    [heure, T1, T2, T3] = textread(adresse, '%8c %f %f %f');
     
    % Conversion de l'heure en nombre (Pour tracer en fonction de ces nombres)
    heurenum = datenum(heure, 'HH:MM:SS');
     
    %% %% Tracé %%%%
    plot(heurenum, T1, heurenum, T2, heurenum, T3)
    title('T = f(t)')
    xlabel('Heure')
    ylabel('Température')
    legend('T1', 'T2', 'T3')
    Le tracé fonctionne, mais en abscisse j'ai 7,3524*10^5 qui se répète (c'est la valeur retournée par datenum, qui en réalité n'est pas constante quand on affiche plus de chiffres après la virgule), or j'aimerais pouvoir y afficher à la place les heures telles qu'elles sont écrites dans la première colonne du fichier: en format hh:mm:ss.

    Pour cela j'ai essayé de rajouter ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    set(gca, 'XTickLabel', heure)
    Mais ça n'affiche que les 4 ou 5 premières heures réparties uniformément sur la largeur du graphique, au lieu de les afficher chacune en dessous du point de température correspondant.

    J'ai essayé aussi ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    set(gca, 'XTick', 1: (size(heure)), 'XTickLabel', heure)
    Mais dans ce cas ça n'affiche plus rien en abscisse.

    Auriez-vous une solution à m'indiquer s'il-vous-plaît ?
    Fichiers attachés Fichiers attachés

  2. #2
    Modérateur
    Avatar de le fab
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    1 882
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 882
    Points : 3 432
    Points
    3 432
    Par défaut
    salut

    va voir des fonctions comme tlabel ou Intelligent Dynamic Date Ticks

    sinon en gros il faut faire ce que tu fais ... mais en mettant un nombre raisonnable (5-10) de dateticks

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Décembre 2013
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2013
    Messages : 4
    Points : 5
    Points
    5
    Par défaut
    Merci beaucoup Le fab !
    La fonction tlabel marche parfaitement pour ce que je cherchais à faire

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

Discussions similaires

  1. [XL-2010] Graphique de TCD : Gestion des Heures sur axe des abscisses
    Par Viper7 dans le forum Excel
    Réponses: 5
    Dernier message: 11/12/2013, 18h53
  2. [PHP 5.3] fonction date - afficher des heures au délas de 24H
    Par Michel Rotta dans le forum Langage
    Réponses: 9
    Dernier message: 04/05/2011, 10h13
  3. [Dates] Afficher à des heures aléatoires ?
    Par kevinf dans le forum Langage
    Réponses: 20
    Dernier message: 02/12/2006, 23h30
  4. Réponses: 7
    Dernier message: 31/10/2006, 00h36
  5. Afficher des heures locales
    Par mrpowerboy dans le forum Applets
    Réponses: 3
    Dernier message: 27/09/2005, 17h57

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