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 :

Lecture de fichier vtu


Sujet :

MATLAB

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    21
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations forums :
    Inscription : Juin 2009
    Messages : 21
    Par défaut Lecture de fichier vtu
    bonjour à tous ....

    comme le dit le sujet je voudrais faire une animation qui serait une succéssion de fichier vtk qui sont déjà en ma possession ....

    Maleureusement je ne sais pas comment faire car je n'arrive pas à acceder au doc que je trouve sur le net !

    Je vaudrais faire une routine matlab qui récupère ces fichiers et qui les colle les uns aux autre avec un délai d'environ 3~4 secondes entre chaque !

    Ainsi ma question est double !
    Est-ce que vous pensait que cela est possible ? Si oui comment ?

    Merci par avance !

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    21
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations forums :
    Inscription : Juin 2009
    Messages : 21
    Par défaut
    petite correction les fichier sont en vtu !!!
    Je ne connais pas la différence !

  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 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
    Tu pourrais attacher 2 ou 3 fichier vtu à un message.

    Met les dans une archive zip ou rar

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    21
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations forums :
    Inscription : Juin 2009
    Messages : 21
    Par défaut
    voilà les vtu
    Fichiers attachés Fichiers attachés

  5. #5
    Modérateur

    Homme Profil pro
    Ingénieur en calculs scientifiques
    Inscrit en
    Août 2007
    Messages
    4 639
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Ingénieur en calculs scientifiques

    Informations forums :
    Inscription : Août 2007
    Messages : 4 639
    Par défaut
    Salut,
    Citation Envoyé par Cehune Voir le message
    petite correction les fichier sont en vtu !!!
    Je ne connais pas la différence !
    La différence se situe dans la présentation des données. Les fichiers vtu utilisent
    le format xml qui permet de décrire plus de chose que le format vtk.
    pour plus d'info sur les formats définit par vtk :
    http://www.vtk.org/VTK/img/file-formats.pdf

    Ouvres un de tes fichiers, tu verras qu'il est constitué de champs délimités par des balises :
    tu as :
    les coordonnées de tes points,
    des cellules définis par 3 points
    une valeur scalaire asociée à chaque cellule (qui définit généralement la couleur)
    une valeur 5 pour chaque cellule car tes cellules sont des triangles (cf doc citée plus haut)
    une valeur pour chacun de tes triangles (la variable se nomme U, donc j'imagine que c'est une grandeur physique?)

    je n'ai pas trouvé de script tout fait qui te permette de lire de tel fichier, mais ça ne doit pas être compliqué en utilisant les fonctions de lecture de fichiers (par exemple dans la faq pour passer un certain nombre de ligne : http://matlab.developpez.com/faq/?pa...#fileio_entete )

    Je vaudrais faire une routine matlab qui récupère ces fichiers et qui les colle les uns aux autre avec un délai d'environ 3~4 secondes entre chaque !
    Qu'est ce que tu appelles : "les colle les uns aux autres"?
    C'est bien un affichage que tu veux faire?

    rmq : si c'est un affichage, pourquoi ne pas utiliser un logiciel comme par exemple paraview qui est entre autre dédié à ce type de fichier?
    Pour une bonne utilisation des balises code c'est ici!
    Petit guide du voyageur MATLABien : Le forum La faq Les tutoriels Les sources


    La nature est un livre écrit en langage mathématique. Galilée.

  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 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
    Un début de réponse avec la XML Toolbox : Gestion des fichiers XML avec la XML toolbox

    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
    d = dir('*.vtu');
     
    figure
    p = patch('vertices',[nan nan],'faces',nan, ...
        'facevertexcdata',nan,'cdatamapping','scaled', ...
        'facecolor','interp');
     
    for n = 1:numel(d)
     
        V = xml_parseany(fileread(d(n).name));
     
        Position = str2num(V.UnstructuredGrid{1}.Piece{1}.Points{1}.DataArray{1}.CONTENT);
        connectivity = str2num(V.UnstructuredGrid{1}.Piece{1}.Cells{1}.DataArray{1}.CONTENT)+1;
        U = str2num(V.UnstructuredGrid{1}.Piece{1}.PointData{1}.DataArray{1}.CONTENT);
     
        set(p,'vertices',Position,'faces',connectivity, ...
            'facevertexcdata',U);
     
        title(sprintf('Pas : %d',n))
        drawnow
        pause(4)
     
    end
    C'est l'idée...

    Si tu veux en faire une animation AVI :


  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    21
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations forums :
    Inscription : Juin 2009
    Messages : 21
    Par défaut
    Merci megalan pour la doc vtu !
    La variable se nomme U, donc j'imagine que c'est une grandeur physique?
    En effet, je travaille sur la modélisation des thermométries dans un réservoir pétrolier axisymétrique dans le but de mieux comprendre le comportement des fluides et de la matrice rocheuse pendant la production.

    Nous avons déjà utiliser la commande 'patch' mais le rendu n'est pas très agréables de plus les cartographies de pression et de température sont souvent incomplètes... aussi nous avons décidé de passer par un affichage avec paraview ... dont le rendu est bien plus plaisant (avis personnel bien sur !)
    Qu'est ce que tu appelles : "les colle les uns aux autres"?
    C'est bien un affichage que tu veux faire?
    Oui je voudrais faire une vidéo qui affiche pas à pas les différents pas de temps.... je vais essayer de voir avec la doc avifile !

  8. #8
    Modérateur

    Homme Profil pro
    Ingénieur en calculs scientifiques
    Inscrit en
    Août 2007
    Messages
    4 639
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Ingénieur en calculs scientifiques

    Informations forums :
    Inscription : Août 2007
    Messages : 4 639
    Par défaut
    Citation Envoyé par Cehune Voir le message
    aussi nous avons décidé de passer par un affichage avec paraview ... dont le rendu est bien plus plaisant (avis personnel bien sur !)
    Tout à fait d'accord avec toi!
    Pour une bonne utilisation des balises code c'est ici!
    Petit guide du voyageur MATLABien : Le forum La faq Les tutoriels Les sources


    La nature est un livre écrit en langage mathématique. Galilée.

  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 Dut Voir le message
    C'est l'idée...
    Arf... je n'avais pas vu que les noeuds apparaissaient plusieurs fois... le rendu n'était donc pas optimale

    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
    d = dir('*.vtu');
     
    for n = 1:numel(d)
     
        V = xml_parseany(fileread(d(n).name));
     
        Position = str2num(V.UnstructuredGrid{1}.Piece{1}.Points{1}.DataArray{1}.CONTENT);
        connectivity = str2num(V.UnstructuredGrid{1}.Piece{1}.Cells{1}.DataArray{1}.CONTENT)+1;
        U = str2num(V.UnstructuredGrid{1}.Piece{1}.PointData{1}.DataArray{1}.CONTENT);
     
        [vertices{n},a,b] = unique(Position,'rows');
        faces{n} = b(connectivity);
        fvcdata{n} = U(a);
     
    end
     
    r = [min(min([fvcdata{:}])) max(max([fvcdata{:}]))];
     
    figure
     
    p = patch('vertices',[nan nan],'faces',nan, ...
        'facevertexcdata',nan,'cdatamapping','scaled', ...
        'facecolor','interp');
     
    set(gca,'clim',r)
    colorbar
     
    for n=1:numel(vertices)
     
        set(p,'vertices',vertices{n},'faces',faces{n}, ...
            'facevertexcdata',fvcdata{n});
        drawnow
        title(sprintf('Pas : %d',n))
        pause(1)
     
    end

  10. #10
    Membre averti
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    21
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations forums :
    Inscription : Juin 2009
    Messages : 21
    Par défaut
    J'ai un petit soucis avec ton code Dut ....
    Aurait tu une idée sur le problème ?


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    ??? Undefined function or method 'xml_parseany' for nput arguments of type
    'char'.
     
    Error in ==> dut at 7
        V = xml_parseany(fileread(d(n).name));

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

Discussions similaires

  1. [Windows]lecture des fichier lnk (raccourcis)
    Par Tiaps dans le forum API standards et tierces
    Réponses: 10
    Dernier message: 21/10/2009, 19h27
  2. [jsp]lecture de fichier
    Par antigone dans le forum Servlets/JSP
    Réponses: 9
    Dernier message: 04/09/2003, 11h05
  3. [AS400][Intranet][PC] Lecture de "fichiers" AS400
    Par lando dans le forum Autres SGBD
    Réponses: 4
    Dernier message: 16/07/2003, 11h11
  4. Lecture de fichier
    Par Watcha dans le forum x86 16-bits
    Réponses: 13
    Dernier message: 04/03/2003, 20h43
  5. Lecture de fichiers ".WAV"...
    Par 0x4e84 dans le forum Langage
    Réponses: 2
    Dernier message: 03/09/2002, 09h43

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