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 :

Générer des doublons


Sujet :

MATLAB

  1. #1
    Futur Membre du Club
    Femme Profil pro
    Doctorante
    Inscrit en
    Novembre 2012
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations professionnelles :
    Activité : Doctorante

    Informations forums :
    Inscription : Novembre 2012
    Messages : 6
    Points : 5
    Points
    5
    Par défaut Générer des doublons
    Bonjour bonjour,

    Je m'arrache les cheveux.... Tout ce que je trouve sur internet c'est pour supprimer les doublons, ahah, moi je suis bête, je veux en créer!!

    Je veux identifier les flotteurs présents dans les tourbillons d'une trajectoire.
    Pour chaque trajectoire, je récupère la date de tous les pas de temps de cette trajectoire, ce qui me donne par exemple un vecteur monotone
    (exemple minuscule pour pouvoir mieux visualiser)
    Je veux ensuite tous les flotteurs qui sont sur chaque pas de temps, mais sans faire une boucle for parce que j'ai beaucoup de données à traiter...
    Du coup j'utilise:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    [aa,bb] = ismember(date_ALM22042,map);
    Comme length(date_flotteurs) = 1499, je vais avoir aa et bb de taille [1 1499]. aa contient beaucoup de 0 parce que le vecteur map est petit (du coup je vire toutes les lignes avec des 0). Mais si j'ai 2 fois une occurence d'une date de la trajectoire dans mon set date_flotteur, j'ai par exemple
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    bb = [ 1021
             1023
             1022
             2021]
    J'ai un autre vecteur qui contient le numéro des tourbillons, chaque ligne correspond à chaque valeur de date
    And the question is: comment je peux créer un autre vecteur de tourbillon, eddy2, qui contient les valeurs de eddy en répétant cas valeurs quand la date correspondante a été répétée?? Et tout ça bien sur sans faire de boucle for...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    eddy2 = [65
                 22
                 74
                 65]
    Si quelqu'un a une idée (ou sait où trouver de la doc...), il me sauvera de la chauvitude ^^ !
    (et recevra une bonne de reconnaissance)

  2. #2
    Rédacteur/Modérateur

    Avatar de Jerome Briot
    Homme Profil pro
    Freelance mécatronique - Conseil, conception et formation
    Inscrit en
    Novembre 2006
    Messages
    20 302
    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 302
    Points : 53 165
    Points
    53 165
    Par défaut
    Comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    [ubb, a, b] = unique(bb);
     
    eddy2 = eddy(b);
    Ingénieur indépendant en mécatronique - Conseil, conception et formation
    • Conception mécanique (Autodesk Fusion 360)
    • Impression 3D (Ultimaker)
    • Développement informatique (Python, MATLAB, C)
    • Programmation de microcontrôleur (Microchip PIC, ESP32, Raspberry Pi, Arduino…)

    « J'étais le meilleur ami que le vieux Jim avait au monde. Il fallait choisir. J'ai réfléchi un moment, puis je me suis dit : "Tant pis ! J'irai en enfer" » (Saint Huck)

  3. #3
    Futur Membre du Club
    Femme Profil pro
    Doctorante
    Inscrit en
    Novembre 2012
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations professionnelles :
    Activité : Doctorante

    Informations forums :
    Inscription : Novembre 2012
    Messages : 6
    Points : 5
    Points
    5
    Par défaut
    Merci beaucoup!
    En effet avec unique ça marche (j'en étais restée à la première fonctionnalité sans aller voir plus loin...)

    Cette méthode est aussi plus facile que l'autre solution que j'ai trouvée finalement...

    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
    map_traj = [1020 1021 1022 1023]; % le petit vecteur des maps connues
    eddy_traj = [17 55 42 39] % le numéro des tourbillons associés
     
    map_float = [1022 1023 1020 1020 1021 1023] % le grand vecteur des maps
    eddy_float = [ 42 39 17 18  55 39] % le numéro des tourbillons associés
     
    a = dataset(map_traj',eddy_traj','varnames',{'key1','eddy'})
     
    b = dataset(map_float',eddy_float','varnames',{'key1','eddyf'})
     
     c = join(b,a,'key1')
     
     c = 
     
        key1    eddyf    eddy
        1022    42       42  
        1023    39       39  
        1020    17       17  
        1020    18       17  
        1021    55       55  
        1023    39       39  
     
    % la colonne eddy répète les valeurs de eddy_traj comme je voulais et je peux identifier les tourbillons communs!!
    Donc merci Dut, comme promis je t'envoie une dose de reconnaissance (j'espère que tu vas la recevoir!)

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

Discussions similaires

  1. 1 Table, Des doublons, ne rertenir que certains d'entre eux
    Par Dragano dans le forum Langage SQL
    Réponses: 3
    Dernier message: 26/01/2005, 12h06
  2. Générer des fichiers PDF
    Par bobbafet dans le forum C++Builder
    Réponses: 5
    Dernier message: 29/11/2004, 23h53
  3. [Java] Générer des rapports à la crystal reports
    Par Vessaz dans le forum Autres outils décisionnels
    Réponses: 4
    Dernier message: 11/10/2004, 19h07
  4. Effacer des doublons
    Par ben53 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 12/07/2004, 17h56
  5. Réponses: 2
    Dernier message: 07/07/2004, 17h44

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