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

Mathématiques Discussion :

[Matrice] Produit matriciel


Sujet :

Mathématiques

  1. #1
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Points : 8 873
    Points
    8 873
    Par défaut [Matrice] Produit matriciel
    Bonjour,

    voilà mon souci, je cherche sur papier depuis tout à l'heure un algorithme de deux matrices qui sont stockées sous forme d'un tableau unidimensionnel depuis tout à l'heure sans rien trouver de convaincant...

    En gros, le prototype est le suivant :
    fonction pdtMatriciel(e: Matrice m1, Matrice m2 ; s: Matrice res)
    Sachant que m1 et m2 sont déclaré de la sorte : Type matrice[UneLongueur].

    Un tel algorithme existe il pour des matrices de taille variable?
    En avez vous un à me proposer?

    C'est par l'adresse que vaut le bûcheron, bien plus que par la force. Homère

    Installation de Code::Blocks sous Debian à partir de Nightly Builds

  2. #2
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 942
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 942
    Points : 5 654
    Points
    5 654
    Par défaut
    Die,

    Rien à faire si tu ne passes pas les dimensions de tes matrices à ta fonction, qui ne peut pas les deviner.
    Il faut de même pouvoir renvoyer les dimensions de la matrice résultat.

    Je pense qu'une structure mieux pensée serait préférable.
    Si les cons volaient, il ferait nuit à midi.

  3. #3
    Rédacteur
    Avatar de pseudocode
    Homme Profil pro
    Architecte système
    Inscrit en
    Décembre 2006
    Messages
    10 062
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Architecte système
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2006
    Messages : 10 062
    Points : 16 081
    Points
    16 081
    Par défaut
    Citation Envoyé par droggo Voir le message
    Rien à faire si tu ne passes pas les dimensions de tes matrices à ta fonction, qui ne peut pas les deviner.
    Sauf si les dimensions sont stockées dans les premieres cellules du tableau, facon paquet tcp/ip.
    ALGORITHME (n.m.): Méthode complexe de résolution d'un problème simple.

  4. #4
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 942
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 942
    Points : 5 654
    Points
    5 654
    Par défaut
    Luo,
    Citation Envoyé par pseudocode Voir le message
    Sauf si les dimensions sont stockées dans les premieres cellules du tableau, facon paquet tcp/ip.
    Peut-être, mais comme la question est posée, je ne pense pas, sinon le problème serait résolu de lui-même, car ça montrerait qu'il y a eu une réflexion suffisante le concernant.
    Si les cons volaient, il ferait nuit à midi.

  5. #5
    Rédacteur
    Avatar de Zavonen
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 772
    Détails du profil
    Informations personnelles :
    Âge : 76
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 772
    Points : 1 913
    Points
    1 913
    Par défaut
    Voici un exemple en python:
    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
    class Matrice:
        def __init__(self,lignes,colonnes,L=[]):
            self.m=lignes
            self.n=colonnes
            if len(L)!=self.m*self.n:
                self.coeffs=self.m*self.n*[0]
            else:
                self.coeffs=L
        def coeff(self,i,j):
            return self.coeffs[i*self.n+j]
     
        def affiche(self):
            for i in range(0,self.m):
                for j in range(0,self.n):
                    print "%6.2f"%self.coeff(i,j),
                print
            print 
     
        def __mul__(self,other):
            if self.n != other.m:
                print "Multiplicaton impossible"
                return
            R=Matrice(self.m,other.n)
            for i  in range (0,R.m):
                for j in range (0,R.n):
                    c=0
                    for k in range(0,self.n):
                        c+=self.coeff(i,k)*other.coeff(k,j)
                    R.coeffs[i*R.n+j]=c
            return R
     
    def main():
        M=Matrice(2,2,[1,2,3,4])
        K=M*M
        K.affiche()
     
     
    if __name__ == '__main__':
        main()
    Ce qu'on trouve est plus important que ce qu'on cherche.
    Maths de base pour les nuls (et les autres...)

  6. #6
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Points : 8 873
    Points
    8 873
    Par défaut
    Euh oui, j'ai oublié de le préciser et je m'en excuse, Matrice est une classe (C++) dans laquelle j'ai des attributs nbLignes et nbColonnes

    En gros, je connais le nombres de lignes et de mes colonnes

    Désolé de l'oubli
    C'est par l'adresse que vaut le bûcheron, bien plus que par la force. Homère

    Installation de Code::Blocks sous Debian à partir de Nightly Builds

  7. #7
    Rédacteur
    Avatar de Zavonen
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 772
    Détails du profil
    Informations personnelles :
    Âge : 76
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 772
    Points : 1 913
    Points
    1 913
    Par défaut
    Essaie qqch comme ça :
    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
    #ifndef MATRIX_H
    #define MATRIX_H
     
     
    class Matrix
    {
        public:
            Matrix();
            Matrix(unsigned int,unsigned int);
            virtual ~Matrix();
           Matrix operator*(Matrix&);
     
        private:
        unsigned int nblignes;
        unsigned int nbcolonnes;
        double * coefficients;
     
    };
     
     
     
    #endif // MATRIX_H
    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
    #include "Matrix.h"
     
     
    Matrix::Matrix()
    {
        //ctor
    }
     
    Matrix::Matrix(unsigned int m, unsigned int n)
    {
        nblignes=m;
        nbcolonnes=n;
        coefficients=new double[m*n];
        //ctor
    }
     
    Matrix::~Matrix()
    {
        //dtor
        delete coefficients;
    }
     
    Matrix Matrix::operator* (Matrix &Other)
    {
        Matrix Result(nblignes,Other.nbcolonnes);
        for (unsigned int i=0; i<Result.nblignes;i++)
            for (unsigned int j=0; j<Result.nbcolonnes;j++)
            {
                int s=0;
                for (unsigned int k=0;k<nbcolonnes;k++)
                    s+=this->coefficients[i*nbcolonnes+k]*Other.coefficients[k*Other.nbcolonnes+j];
                Result.coefficients[i*Result.nbcolonnes+j]=s;
            }
        return Result;
     
    }
    Ce qu'on trouve est plus important que ce qu'on cherche.
    Maths de base pour les nuls (et les autres...)

  8. #8
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Points : 8 873
    Points
    8 873
    Par défaut
    ça fonctionne parfaitement

    @++
    C'est par l'adresse que vaut le bûcheron, bien plus que par la force. Homère

    Installation de Code::Blocks sous Debian à partir de Nightly Builds

  9. #9
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Je suis en bts ig et je suis pas tres forte en algo...je voudrais savoir comment on écrit un algo pour multiplier deux matrices carré =)
    Si quelqu'un pourrait m'aider, ça serait sympa ^^

    Merci

  10. #10
    Expert confirmé

    Inscrit en
    Août 2006
    Messages
    3 942
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 3 942
    Points : 5 654
    Points
    5 654
    Par défaut
    Hio,
    Citation Envoyé par Anna_star Voir le message
    Je suis en bts ig et je suis pas tres forte en algo...je voudrais savoir comment on écrit un algo pour multiplier deux matrices carré =)
    Si quelqu'un pourrait m'aider, ça serait sympa ^^

    Merci
    L'algo, c'est ce que tu as appris en maths pour multiplier 2 matrices.

    Ensuite, différents implémentations peuvent être plus ou moins efficaces pour un même algorithme, mais c'est une autre histoire.
    Si les cons volaient, il ferait nuit à midi.

  11. #11
    Rédacteur

    Avatar de millie
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    7 015
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 7 015
    Points : 9 818
    Points
    9 818
    Par défaut
    Si c'est toi qui développe la classe Matrice.

    Je conseille fortement de créer deux méthodes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    double getValue(unsigned int x, unsigned int y) const;
    void setValue(unsigned int x, unsigned int y, double value);
     
    //ou version avec l'operator ()
    double & operator()(unsigned int x, unsigned int y);
    double operator()(unsigned int x, unsigned int y) const;
    Qui positionne ou lit la valeur en (x,y).
    Je ne répondrai à aucune question technique en privé

  12. #12
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Points : 8 873
    Points
    8 873
    Par défaut
    Citation Envoyé par millie Voir le message
    Si c'est toi qui développe la classe Matrice.

    Je conseille fortement de créer deux méthodes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    double getValue(unsigned int x, unsigned int y) const;
    void setValue(unsigned int x, unsigned int y, double value);
     
    //ou version avec l'operator ()
    double & operator()(unsigned int x, unsigned int y);
    double operator()(unsigned int x, unsigned int y) const;
    Qui positionne ou lit la valeur en (x,y).
    Oui c'est moi qui la développe cette classe

    Je vais les implémenter

    [edit] Pour l'opérateur, ça marche comment les () ? J'aurai juste à faire :

    MaMatrice(2,3) ?

    [edit2] ça serait que pour les GET les opérateurs (), ou bien?
    C'est par l'adresse que vaut le bûcheron, bien plus que par la force. Homère

    Installation de Code::Blocks sous Debian à partir de Nightly Builds

  13. #13
    Rédacteur

    Avatar de millie
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    7 015
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2006
    Messages : 7 015
    Points : 9 818
    Points
    9 818
    Par défaut
    Tu utiliseras comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Matrice m(taillex, tailley);
    double d = m(0,0); //utilisation de l'opérateur () avec signature constante
    m(4,5) = 45; //utilisation de l'opérateur () avec signature non constante et renvoit d'une référence
    Je ne répondrai à aucune question technique en privé

  14. #14
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Points : 8 873
    Points
    8 873
    Par défaut
    C'est par l'adresse que vaut le bûcheron, bien plus que par la force. Homère

    Installation de Code::Blocks sous Debian à partir de Nightly Builds

  15. #15
    Rédacteur
    Avatar de Zavonen
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 772
    Détails du profil
    Informations personnelles :
    Âge : 76
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 772
    Points : 1 913
    Points
    1 913
    Par défaut
    Fortement conseillé à implémenter par surcharge d'opérateurs:
    somme, différence, produit (c'est fait)
    produit par un scalaire
    transposée
    et plus spécialement pour les carrées:
    déterminant
    inverse
    Le pb est que les opérateurs unaires sont en petit nombre et que C++, du moins je crois, ne permet la surcharge que des opérateurs existants.
    Ce qu'on trouve est plus important que ce qu'on cherche.
    Maths de base pour les nuls (et les autres...)

  16. #16
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Citation Envoyé par droggo Voir le message
    Hio,

    L'algo, c'est ce que tu as appris en maths pour multiplier 2 matrices.

    Ensuite, différents implémentations peuvent être plus ou moins efficaces pour un même algorithme, mais c'est une autre histoire.

    Oui je sais comment calculer 2 matrices mais je ne sais pas comment l'écrire en algo... donc si vous pourriez m'aider ?

  17. #17
    Expert éminent
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Points : 8 586
    Points
    8 586
    Par défaut
    C'est très instructif tout ça, mais pour éviter d'induire en erreur de futurs visiteurs du sujet, il serait bon de préciser que l'algorithme naïf de multiplication de matrices utilisé ici n'est pas optimal pour de grandes matrices. Le mieux qu'on ait actuellement en théorie est une méthode en O(n^2.38), et en pratique l'algorithme de Strassen en O(n^2.81) est utilisable pour les grandes matrices bien qu'il ait des problèmes de stabilité numérique. De plus on utilise généralement des algorithmes spécialisés pour des types de matrices particuliers.

    Autrement dit, si vous avez besoin de faire du calcul matriciel vraiment optimisé, utilisez les librairies spécialisées dans le domaine, n'essayez pas de réinventer la roue (sauf si vous faites de la recherche dans le domaine, mais vous n'avez sûrement pas lu ce sujet dans ce cas...).

    --
    Jedaï

  18. #18
    Rédacteur
    Avatar de Zavonen
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 772
    Détails du profil
    Informations personnelles :
    Âge : 76
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 772
    Points : 1 913
    Points
    1 913
    Par défaut
    Autrement dit, si vous avez besoin de faire du calcul matriciel vraiment optimisé, utilisez les librairies spécialisées dans le domaine, n'essayez pas de réinventer la roue (sauf si vous faites de la recherche dans le domaine, mais vous n'avez sûrement pas lu ce sujet dans ce cas...).
    Très heureux de lire çà.
    Un jour j'ai suggéré d'utiliser des librairies spécialisées pour écrire une interface, pour ne pas réinventer la roue. Quelqu'un m'a répondu qu'on était sur un forum d'algo, etc... etc... un puriste sans doute.
    Ce qu'on trouve est plus important que ce qu'on cherche.
    Maths de base pour les nuls (et les autres...)

  19. #19
    Expert éminent
    Avatar de Jedai
    Homme Profil pro
    Enseignant
    Inscrit en
    Avril 2003
    Messages
    6 245
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côte d'Or (Bourgogne)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Avril 2003
    Messages : 6 245
    Points : 8 586
    Points
    8 586
    Par défaut
    Citation Envoyé par Zavonen Voir le message
    Très heureux de lire çà.
    Un jour j'ai suggéré d'utiliser des librairies spécialisées pour écrire une interface, pour ne pas réinventer la roue. Quelqu'un m'a répondu qu'on était sur un forum d'algo, etc... etc... un puriste sans doute.
    Et bien il est logique que sur un forum d'algo, on ne cherche pas forcément les meilleures solution du point de vue pratique, mais plutôt à comprendre comment résoudre le problème par soi-même, néanmoins je soulignais plutôt qu'il y avait des domaines ou vraiment, sauf à être un spécialiste, il vaut mieux utiliser ce qui a déjà été fait sauf dans une optique purement pédagogique (et les interfaces en sont un autres exemple, comme tu le dis).

    --
    Jedaü

  20. #20
    Rédacteur
    Avatar de Zavonen
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 772
    Détails du profil
    Informations personnelles :
    Âge : 76
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 772
    Points : 1 913
    Points
    1 913
    Par défaut
    Le mieux qu'on ait actuellement en théorie est une méthode en O(n^2.38), et en pratique l'algorithme de Strassen en O(n^2.81)
    Que représente le paramètre n ici ?
    J'ai cru comprendre qu'on s'intéressait au produit de deux matrices rectangulaires.
    Ce qu'on trouve est plus important que ce qu'on cherche.
    Maths de base pour les nuls (et les autres...)

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. Taille maximale de matrices (dans un un produit matriciel)
    Par aladin68 dans le forum Général Python
    Réponses: 8
    Dernier message: 06/03/2014, 15h46
  2. Réponses: 4
    Dernier message: 11/06/2012, 14h04
  3. Réponses: 268
    Dernier message: 07/11/2007, 11h11
  4. Produit matriciel booléen en VB pour Excel
    Par v4np13 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 25/11/2006, 12h39
  5. Problème: produit matriciel
    Par v4np13 dans le forum Algorithmes et structures de données
    Réponses: 19
    Dernier message: 17/05/2005, 17h23

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