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 :

Plot matrices (X,Y,Z et la valeur) [Débutant]


Sujet :

MATLAB

  1. #1
    Candidat au Club
    Homme Profil pro
    Doctorant acoustique
    Inscrit en
    Août 2012
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Doctorant acoustique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2012
    Messages : 15
    Points : 4
    Points
    4
    Par défaut Plot matrices (X,Y,Z et la valeur)
    Bonjour,

    Voilà mon problème :
    J'ai 4 matrices (5x9x4) :
    - Les 3 premières sont des coordonnées X,Y et Z
    - La dernière contient des valeurs prises à ces mêmes coordonnées

    Je souhaite donc visualiser en 3D ma surface de mesurage (dans mon cas j'ai un parallélépipède) avec un code de couleur qui varie en fonction de la valeur contenue dans la 4ème matrice.

    J'ai testé plot3, surface, contour3, colormap mais ces commandes servent à "ploter" 3 matrices, les 2 premières étant les coordonnées X et Y et la 3ème contenant la valeur.

    Merci d'avance pour votre aide

  2. #2
    Candidat au Club
    Homme Profil pro
    Doctorant acoustique
    Inscrit en
    Août 2012
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Doctorant acoustique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2012
    Messages : 15
    Points : 4
    Points
    4
    Par défaut
    Un détail qui a son importance :
    Les données que je possède sont les valeurs sur la surface de mon volume, en quelque sorte l'intérieur est creux.
    Je veux donc juste visualiser l'extérieur d'une boite où la couleur de celle-ci dépend de la valeur à ce point.

    Merci

  3. #3
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 318
    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 318
    Points : 52 958
    Points
    52 958
    Par défaut
    Pourrais-tu attacher un fichier mat (mis dans une archive zip ou rar) contenant ces matrices pour faire quelques tests ?

  4. #4
    Expert confirmé
    Avatar de duf42
    Homme Profil pro
    Formateur en informatique
    Inscrit en
    Novembre 2007
    Messages
    3 111
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Formateur en informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2007
    Messages : 3 111
    Points : 4 661
    Points
    4 661
    Par défaut
    Bonjour,

    La fonction surf permet de spécifier 4 matrices où la 4ème matrice définit la couleur de chaque point.
    Ca peut être une piste pour ton problème.

    Duf

  5. #5
    Candidat au Club
    Homme Profil pro
    Doctorant acoustique
    Inscrit en
    Août 2012
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Doctorant acoustique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2012
    Messages : 15
    Points : 4
    Points
    4
    Par défaut
    Bonjour,

    Merci pour votre réponse et désolé du retard, je teste la fonction surf et si ça ne marche pas, j'enverrai les fichiers mat.

    Bonne journée.

  6. #6
    Candidat au Club
    Homme Profil pro
    Doctorant acoustique
    Inscrit en
    Août 2012
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Doctorant acoustique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2012
    Messages : 15
    Points : 4
    Points
    4
    Par défaut
    Bonjour,

    Encore désolé, j'ai dû travailler sur autre chose et j'ai mis ce problème de coté.

    A Dut, j'ai mis en PJ mon fichier de données. La 1ère colonne contient les X, la 2ème les Y et la 3ème les Z, représentant donc les coordonnées de mes points de mesures. En faisant un plot3 c'est plus parlant.
    Les colonnes suivantes sont mes données à ces points.

    J'aimerai donc visualiser la colonne 4 en fonction de X,Y et Z.

    A duf42, j'ai testé la fonction surf. Mais apparemment cette fonction dessine Z en fonction de X et Y, et C permet d'ajuster la couleur.

    Dans mon cas j'ai un parallélipipède qui représente ma surface de mesurage, j'ai plusieurs points de mesures aux coordonnées (X,Y,Z) qui sont sur la surface et pas à l'intérieur.
    Je voudrai donc qu'aux valeurs les plus élevées, la zone autour du point soit plus rouge qu'aux points les moins élevées qui seraient plus bleus par exemple.

    Merci d'avance.
    Fichiers attachés Fichiers attachés

  7. #7
    Candidat au Club
    Homme Profil pro
    Doctorant acoustique
    Inscrit en
    Août 2012
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Doctorant acoustique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2012
    Messages : 15
    Points : 4
    Points
    4
    Par défaut
    duf42, je viens de penser que la fonction surf pourrait être une solution en effet, mais ca nécessiterait des "bidoullages" que je ne sais pas faire.

    Mon parallélépipède est constitué de 5 plans. Et, si je comprends bien la fonction surf, je peux dessiner 1 plan comme je le souhaite. il suffit que je garde les coordonnées d'un seul plan, puis dans Z je mets mes données à ces points.

    Je peux ensuite faire de même pour les 4 plans suivants.

    Le dernier problème serait ensuite de représenter l'ensemble de ces plans sur un même graphique et positionner l'ensemble de manière correcte. Mais ça, je ne sais pas le faire.

    Qu'en pensez-vous?

  8. #8
    Candidat au Club
    Homme Profil pro
    Doctorant acoustique
    Inscrit en
    Août 2012
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Doctorant acoustique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2012
    Messages : 15
    Points : 4
    Points
    4
    Par défaut
    Bonjour,

    J'ai testé la fonction surf sur un seul plan.

    Ce n'est pas ce que je recherche, même si ce n'est pas loin.
    Le résultat est des pics de couleur rouge aux valeurs élevées et des creux bleues aux valeurs faibles. Les couleurs sont bonnes mais je ne veux pas de pics et creux.

    Je ne sais pas quoi essayer d'autres là

  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 318
    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 318
    Points : 52 958
    Points
    52 958
    Par défaut
    La grille de mesure n'est pas régulièrement distribuée sur le domaine.

    Est-ce normal ou bien dû au fait que toutes les mesures ne sont pas contenues dans le fichier que tu nous as donné ?

  10. #10
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 318
    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 318
    Points : 52 958
    Points
    52 958
    Par défaut
    Si les données fournies sont complètes, voici un début de solution (largement améliorable) :
    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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    load dir
     
    x = dir_huile(:,1);
    y = dir_huile(:,2);
    z = dir_huile(:,3);
    C = dir_huile(:,4); 
     
    figure(1)
    clf
    plot3(x, y, z,'r*')
    hold on
     
    % MIN X
    idx = find(x == min(x));
     
    subx = x(idx);
    suby = y(idx);
    subz = z(idx);
    subC = C(idx);
     
    npoints = 30;
    subxi = linspace(min(subx),max(subx),npoints);
    subyi = linspace(min(suby),max(suby),npoints);
    subzi = linspace(min(subz),max(subz),npoints);
     
    subxi = ones(npoints)*min(x);
    [subyi,subzi] = meshgrid(subyi,subzi);
     
    subCi = griddata(suby,subz,subC,subyi,subzi);
     
    surf(subxi,subyi,subzi,subCi)
     
    % MAX X
    idx = find(x == max(x));
     
    subx = x(idx);
    suby = y(idx);
    subz = z(idx);
    subC = C(idx);
     
    npoints = 30;
    subxi = linspace(min(subx),max(subx),npoints);
    subyi = linspace(min(suby),max(suby),npoints);
    subzi = linspace(min(subz),max(subz),npoints);
     
    subxi = ones(npoints)*max(x);
    [subyi,subzi] = meshgrid(subyi,subzi);
     
    subCi = griddata(suby,subz,subC,subyi,subzi);
     
    surf(subxi,subyi,subzi,subCi)
     
    % MIN Y
    idx = find(y == min(y));
     
    subx = x(idx);
    suby = y(idx);
    subz = z(idx);
    subC = C(idx);
     
    npoints = 30;
    subxi = linspace(min(subx),max(subx),npoints);
    subyi = linspace(min(suby),max(suby),npoints);
    subzi = linspace(min(subz),max(subz),npoints);
     
    subyi = ones(npoints)*min(y);
    [subxi,subzi] = meshgrid(subxi,subzi);
     
    subCi = griddata(subx,subz,subC,subxi,subzi);
     
    surf(subxi,subyi,subzi,subCi)
     
    % MAX Y
    idx = find(y == max(y));
     
    subx = x(idx);
    suby = y(idx);
    subz = z(idx);
    subC = C(idx);
     
    npoints = 30;
    subxi = linspace(min(subx),max(subx),npoints);
    subyi = linspace(min(suby),max(suby),npoints);
    subzi = linspace(min(subz),max(subz),npoints);
     
    subyi = ones(npoints)*max(y);
    [subxi,subzi] = meshgrid(subxi,subzi);
     
    subCi = griddata(subx,subz,subC,subxi,subzi);
     
    surf(subxi,subyi,subzi,subCi)
     
    % MAX Z
    idx = find(z == max(z));
     
    subx = x(idx);
    suby = y(idx);
    subz = z(idx);
    subC = C(idx);
     
    npoints = 30;
    subxi = linspace(min(subx),max(subx),npoints);
    subyi = linspace(min(suby),max(suby),npoints);
    subzi = linspace(min(subz),max(subz),npoints);
     
    subzi = ones(npoints)*max(z);
    [subxi,subyi] = meshgrid(subxi,subyi);
     
    subCi = griddata(subx,suby,subC,subxi,subyi);
     
    surf(subxi,subyi,subzi,subCi)
     
    axis equal vis3d
    Le pas de la grille d'interpolation a été choisi arbitrairement.
    Images attachées Images attachées  

  11. #11
    Candidat au Club
    Homme Profil pro
    Doctorant acoustique
    Inscrit en
    Août 2012
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Doctorant acoustique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2012
    Messages : 15
    Points : 4
    Points
    4
    Par défaut
    Au vu de la PJ, ca a l'air d'être très prometteur

    L'ensemble des mesures est présent dans le fichier que je t'ai donné. En fait, j'ai des micros placés en quinconce, ce qui cause des trous en mettant les données sous forme de matrice.
    J'essayais de palier ce problème en utilisant la fonction griddata (c'était plutot mal parti pour le moment ^^').

    Je vais regarder en détails le code que tu as fait. Je te remercie beaucoup pour ton aide.

    Je tiens au courant.

  12. #12
    Candidat au Club
    Homme Profil pro
    Doctorant acoustique
    Inscrit en
    Août 2012
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Doctorant acoustique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2012
    Messages : 15
    Points : 4
    Points
    4
    Par défaut
    Bonjour Dut,

    J'ai testé ton code, et regardé de plus près ce qu'il faisait en détails.

    Apparemment c'est exactement la réponse à mon problème.

    Si j'ai bien compris, tu commences par rechercher le min de l'axe X afin de construire la grille [Y;Z] en Xmin. Tu définis un nombre de points (ici 30) pour créer une grille plus fine que ma grille de mesures.

    Tu utilises "meshgrid" pour créer cette grille de nouvelles coordonnées puis "griddata" pour interpoler mes données et remplir une nouvelle grille de données.

    La fonction "surf" permet ensuite de "ploter" le résultat.

    Tu réalises ça pour Xmin Xmax Ymin Ymax et Zmax, la fonction "hold on" permettant de tout mettre sur une seule figure.

    Je me permets d'expliquer pour qu'un débutant comme moi puisse comprendre

    Merci pour votre aide à duf42 et à toi.

  13. #13
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 318
    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 318
    Points : 52 958
    Points
    52 958
    Par défaut
    Exactement.

    A toi maintenant d'améliorer ce code en adaptant le pas de la grille et le type d'interpolation utilisée dans griddata à ton problème physique

    Il est également possible de le compacter car de nombreuses lignes sont similaires.

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

Discussions similaires

  1. Plot matrice avec 'NaN'
    Par odjapo dans le forum MATLAB
    Réponses: 5
    Dernier message: 13/08/2014, 12h48
  2. [Débutant] Séparation d'une matrice en deux en fonction des valeurs de la première colonne.
    Par linpro.lalaland dans le forum MATLAB
    Réponses: 6
    Dernier message: 17/07/2014, 15h51
  3. signification de plot matrice
    Par gigi_dev dans le forum MATLAB
    Réponses: 1
    Dernier message: 13/09/2012, 09h14
  4. [Débutant] plot matrice 3d
    Par ayoub_m dans le forum MATLAB
    Réponses: 1
    Dernier message: 24/05/2012, 14h52
  5. plot matrice 3d
    Par j_ere_my dans le forum MATLAB
    Réponses: 4
    Dernier message: 16/07/2009, 15h53

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