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 :

Optimisation de référencement matriciel


Sujet :

MATLAB

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Ingénierie en automatisation et systèmes intelligents
    Inscrit en
    Septembre 2008
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénierie en automatisation et systèmes intelligents
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2008
    Messages : 40
    Points : 38
    Points
    38
    Par défaut Optimisation de référencement matriciel
    Bonjour,

    J'ai une matrice carrée de données temporelles "dmat" où dmat(i,j) est le temps nécessaire pour aller de i à j.

    J'ai une matrice de référencement "ref" de L lignes et C colonnes.

    Chacune des lignes de "ref" représente un parcours. Le temps de parcours doit être calculé en boucle fermée, donc pour un parcours 1-2-3-4, il faut calculer [1-2][2-3][3-4][4-1].

    J'aimerais obtenir aussi rapidement que possible les temps de parcours associés à chacun des L parcours dans une matrice Lx1.

    En termes de boucle, le calcul se ferait ainsi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    temps = zeros(L,1);
     
    for i=1:L
    	for j=1:C
    		temps(i) = temps(i) + dmat(ref(i,j),ref(i,mod(j,C)+1);
    	end
    end
    J'ai réussi à convertir cela en calcul matriciel, mais le code est très complexe à comprendre. Il est toutefois plus rapide que cette boucle.

    J'attends vos propositions.

    Merci,

    Éric

  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 166
    Points
    53 166
    Par défaut
    Le plus simple serait de nous donner un petit exemple de tableaux avec des valeurs numériques
    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
    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,

    Je procéderais comme suit:
    - Transformation d'un parcours ref(i,:) en matrices d'indices (2 colonnes):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    idx= [ref(i,1:end-1);ref(i,2:end)]';
    - Extraction des éléments correspondants. Il faut utiliser sub2ind() pour obtenir un vecteur des distances parcourus, qu'il ne reste plus qu'à sommer.

    Le tout est vectorisé donc tournera vite.

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    Ingénierie en automatisation et systèmes intelligents
    Inscrit en
    Septembre 2008
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénierie en automatisation et systèmes intelligents
    Secteur : Industrie

    Informations forums :
    Inscription : Septembre 2008
    Messages : 40
    Points : 38
    Points
    38
    Par défaut
    Citation Envoyé par VV33D Voir le message
    Bonjour,

    Je procéderais comme suit:
    - Transformation d'un parcours ref(i,:) en matrices d'indices (2 colonnes):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    idx= [ref(i,1:end-1);ref(i,2:end)]';
    - Extraction des éléments correspondants. Il faut utiliser sub2ind() pour obtenir un vecteur des distances parcourus, qu'il ne reste plus qu'à sommer.

    Le tout est vectorisé donc tournera vite.
    Tu viens de me faire penser à quelque chose, je vous reviens là-dessus bientôt !

    --------------------------------------------------------------------------

    PS : J'adore MATLAB. Cependant, lorsqu'il est temps d'optimiser la rapidité d'exécution d'un code, on s'aperçoit rapidement qu'il est préférable d'utiliser nos proposes méthodes pour plusieurs cas propres au code. Il est alors possible d'utiliser toute la puissance de l'outil de calcul matriciel qu'est MATLAB au lieu de certaines boucles for intégrées dans certains outils de MATLAB en plus de toutes les vérifications effectuées pour la polyvalence et la robustesse de la fonction.

    Par exemple, je n'utilise pas repmat, meshgrid, ismember (mais plutôt ismembc), randi et j'en passe et maintenant c'est tout aussi vrai pour sub2ind.

    En effet, je viens de constater qu'utiliser sub2ind pour une indexation 2D est lent et inutile. Il suffit de faire le calcul (L-1)*J + I où I,J sont respectivement la ligne et la colonne en indexation 2D, tandis que L est le nombre de lignes de la matrice et alors l'indexation absolue est tout simplement (L-1)*J + I.

    Par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    X =
     1  2  3
     4  5  6
     7  8  9
    10 11 12
    L=4;

    Soit I=2; J=1;
    X(I,J) = X(2,1) = 4;
    X((J-1)*L+I) = X((1-1)*4+2) = X(2) = 4;

    Soit I=3; J=2;
    X(I,J) = X(3,2) = 8;
    X((J-1)*L+I) = X((2-1)*4+3) X(7) = 8;

    --------------------------------------------------------------------------

    Je te remercie, ta suggestion m'a fait penser à une technique toute bête. J'avais avant une boucle for que j'ai changée pour des calculs matriciels complexes, mais plus rapides, qui sont maintenant rendu des calculs matriciels simples et encore plus rapides !

Discussions similaires

  1. Réponses: 7
    Dernier message: 16/03/2011, 12h03
  2. Réponses: 0
    Dernier message: 11/03/2011, 11h06
  3. ASP.NET 4 optimise le référencement
    Par Gordon Fowler dans le forum Actualités
    Réponses: 1
    Dernier message: 07/01/2010, 14h07
  4. Optimiser le référencement
    Par elekaj34 dans le forum Référencement
    Réponses: 6
    Dernier message: 13/03/2009, 09h48
  5. optimisation de multplication matricielle 4x4
    Par kiroukou dans le forum Algorithmes et structures de données
    Réponses: 10
    Dernier message: 08/02/2005, 09h48

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