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 :

Comment tenant compte des données déjà generés?


Sujet :

MATLAB

  1. #1
    Candidat au Club
    Homme Profil pro
    Inscrit en
    Octobre 2013
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Octobre 2013
    Messages : 7
    Points : 4
    Points
    4
    Par défaut Comment tenant compte des données déjà generés?
    Bonjour à tous,

    J'ai une bête question que j'arrive pas à résoudre, j'aimerais bien la partager dans le forum en espérant que quelqu'un d'entre vous connait la solution.

    J'ai deux matrices:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    m1 = [A,B,C;4,3,1] ;
    m2 = [B,B,A;NaN,NaN,NaN];
    Entre m1(:,1) et m1(:,2) existe une correspondance que j'essaye de respecter pour la nouvelle colonne m2 (:,2). I.e, le but c'est de modifier la deuxième colonne m2 en tenant compte des valeurs m1, tel que:

    Quelqu'un aurait une idée?

    Merci!

  2. #2
    Membre éprouvé
    Inscrit en
    Août 2010
    Messages
    1 124
    Détails du profil
    Informations forums :
    Inscription : Août 2010
    Messages : 1 124
    Points : 1 277
    Points
    1 277
    Par défaut
    Bonjour,

    Tout d'abord attention, vu tes notations, il s'agit de la 2eme ligne.
    Ce que tu essayes d'implémenter via m1 est un "dictionnaire", dans lequel tu veux get() les éléments de la 1ere ligne de m2.

    Tu as deux solutions:
    - Utiliser les nouveaux conteneurs de Matlab dans les dernières release.
    - Recoder la fonctionnalité toi même. Pour cela, et avec le stockage mémoire que tu proposes (ie une matrice à 2 lignes, ne contenant donc que du numérique), le plus efficace est d'utiliser ismember avec tous ses arguments de sortie
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    % comparaison des clefs du dictionnaire -> indices
    [~,Locb] = ismember(m2(1,:),m1(1,:));
    % accès aux valeurs
    m2(2,:)= m1(2,Locb);
    Attention, ce code ne traite pas le cas de doublons dans m1(1,: ), ni le cas ou un élément de m2(1,: ) n'est pas dans m1(1,: )

  3. #3
    Candidat au Club
    Homme Profil pro
    Inscrit en
    Octobre 2013
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Octobre 2013
    Messages : 7
    Points : 4
    Points
    4
    Par défaut
    Merci pour cette claire réponse.

    La fonction "ismember" fonctionne parfaitement.

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

Discussions similaires

  1. [XL-2007] Ecrire des données en tenant compte des filtres actifs
    Par clao260 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 10/12/2012, 20h13
  2. Réponses: 1
    Dernier message: 18/09/2011, 17h26
  3. Réponses: 2
    Dernier message: 28/01/2006, 14h54
  4. [Debutant] comment faire passer des donnée ???
    Par cyrill.gremaud dans le forum AWT/Swing
    Réponses: 1
    Dernier message: 17/01/2006, 22h28
  5. Réponses: 13
    Dernier message: 03/12/2005, 17h09

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