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

C++ Discussion :

creation class matrice, T** contre vector<vector<T> >


Sujet :

C++

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    410
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 410
    Par défaut creation class matrice, T** contre vector<vector<T> >
    Salut,
    il y a un moi je voulais tester une class matrice avec des template histoire de faire un class qui peut travailler avec des int double et complex<..>. Seulement je l'ai implémenté du style:
    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
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    template<class T>
    class matrice
    {
    private:
        size_t nl;
        size_t nc;
        T** tab;
     
    public:
        //Constructors
        matrice();
     
        matrice(const size_t& li,const size_t& co,const T& val=T());
        matrice(const matrice<T>& mat);
     
        template<class U>
        matrice(const matrice<U>& mat);
     
        //Destructor
        ~matrice(){ Reset();}
     
        // Operators
        matrice<T>& matrice<T>::operator=(const matrice<T>& mat);
        matrice<T>& matrice<T>::operator=(const T& val);
        template<class U>
        matrice<T>& operator=(const matrice<U>& mat);
        T& operator()(const size_t& i, const size_t& j);
        const T& operator()(const size_t& i,const size_t& j) const;
     
        matrice<T>& operator+=(const matrice<T>& mat);
        matrice<T>& operator-=(const matrice<T>& mat);
        matrice<T>& operator*=(const matrice<T>& mat);
     
        matrice<T>& operator+=(const T& val);
        matrice<T>& operator-=(const T& val);
        matrice<T>& operator*=(const T& val);
     
        template<class U>
        friend std::ostream &operator<<(std::ostream &out,matrice<U> &mat);
     
        //Methods
        inline const size_t& Line() const{return nl;}
        inline const size_t& Column() const{return nc;}
     
        bool Allocate(const size_t& li,const size_t& co);
        void Reset();
     
        template<class U>
        void Initialize(const U& val);
     
        matrice<T>& Transpose();
     
        void Print(std::ostream& out) const;
    };
    Je me demandait si utiliser un vector<vector<T> > serait plus ou moins efficace que d'utiliser un T**?

    Certainement que cette question a été posée mais je vois pas de référence là dessus.

    Merci

  2. #2
    Membre Expert
    Avatar de poukill
    Profil pro
    Inscrit en
    Février 2006
    Messages
    2 155
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 2 155
    Par défaut
    Oh oui, le sujet des matrices a été très largement traité dans ce forum.

    En deux mots :
    1. T * data; suffit. L'accès peut être donné par i + n * j.
    2. Les vector de vector sont effectivement à éviter, sauf si tu as des réallocations fréquentes.


    Cherche dans le forum, tu trouveras ton bonheur !

  3. #3
    Membre chevronné

    Inscrit en
    Août 2007
    Messages
    300
    Détails du profil
    Informations forums :
    Inscription : Août 2007
    Messages : 300
    Par défaut
    Si vous pouvez utiliser Boost, vous devriez évaluer leur travail sur ce sujet. Pour ceux qui ne connaissent pas, Boost est une librairie de qualité exceptionnelle.

  4. #4
    r0d
    r0d est déconnecté
    Membre expérimenté

    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2004
    Messages
    4 294
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2004
    Messages : 4 294
    Billets dans le blog
    2
    Par défaut
    Sur le sujet, voir ce lien, à mon avis indispensable:
    http://jlecomte.ifrance.com/c++/c++-...oading-fr.html

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    410
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 410
    Par défaut
    Citation Envoyé par poukill Voir le message
    Oh oui, le sujet des matrices a été très largement traité dans ce forum.

    En deux mots :
    1. T * data;[/I] suffit. L'accès peut être donné par i + n * j.
    2. Les vector de vector sont effectivement à éviter, sauf si tu as des réallocations fréquentes.


    Cherche dans le forum, tu trouveras ton bonheur !
    ok merci. En fait je force la contiguïté de de mon tableau T** en fasant un truc du genre
    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
    template<class T>
    bool matrice<T>::Allocate(const size_t& li, const size_t& co)
    {
        if(tab!=NULL)
            Reset();
     
        nl=li;
        nc=co;
        tab=new T*[nl];
     
        if(tab==NULL)
            return false;
     
        tab[0]=new T[nl*nc];
     
        if(tab[0]==NULL)
        {
            delete[] tab;
            tab=NULL;
     
            return false;
        }
     
        for(size_t i=1;i<nl;i++)
            tab[i]=tab[i-1]+nc;
     
        Initialize(T());
     
        return true;
    }
    Apres je peux utiliser dessus une notation tab[i][j]; que j'appel dans mon oprateur ()

    Citation Envoyé par ac_wingless Voir le message
    Si vous pouvez utiliser Boost, vous devriez évaluer leur travail sur ce sujet. Pour ceux qui ne connaissent pas, Boost est une librairie de qualité exceptionnelle.
    je suis tombé dessus en effet. Mais ici le but de la manoeuvre n'est pas d'utiliser cette class, mais uniquement pédagogique, car je suis en train de passer du C au C++. A l'avenir si je dois utiliser ce genre de class matrice je passerai par boost meme si il me reste encore des choses à apprendre avant de passer à boost

  6. #6
    Membre Expert
    Avatar de poukill
    Profil pro
    Inscrit en
    Février 2006
    Messages
    2 155
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 2 155
    Par défaut
    Avec un T * data, je te propose mieux comme accès : tab(i,j) ...
    Et c'est plus performant.

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    410
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 410
    Par défaut
    Citation Envoyé par r0d Voir le message
    Sur le sujet, voir ce lien, à mon avis indispensable:
    http://jlecomte.ifrance.com/c++/c++-...oading-fr.html
    Merci je jetterai un oeil dans la journée

    Edit: j'ai jetté un oeil et c'est interessant. En gros je me suis pas trop votré dans ma façon de concevoir ma class.
    Citation Envoyé par poukill Voir le message
    Avec un T * data, je te propose mieux comme accès : tab(i,j) ...
    Et c'est plus performant.
    developpe je vois pas ce que ça apporterai de mieux, dans la mesure où je fais un masquage du T* data

  8. #8
    Membre Expert
    Avatar de poukill
    Profil pro
    Inscrit en
    Février 2006
    Messages
    2 155
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 2 155
    Par défaut
    Le mieux pour les performances c'est de faire un benchmark avec 2 implémentations différentes...
    Regarde ce post, tu y trouveras peut-être quelques tuyaux. Je pense pas que l'accès [][] soit le plus rapide (mais je peux me tromper )

Discussions similaires

  1. Tri d'une matrice (entrée sous forme de vector)
    Par MoiJF dans le forum Débuter
    Réponses: 6
    Dernier message: 27/04/2009, 05h36
  2. Creation Classe Matrice
    Par Mikolay dans le forum Débuter
    Réponses: 9
    Dernier message: 27/10/2008, 14h22
  3. Creation d'une classe Matrice
    Par parisjohn dans le forum Général Python
    Réponses: 1
    Dernier message: 20/07/2007, 17h46
  4. vector de vector
    Par Clark dans le forum SL & STL
    Réponses: 15
    Dernier message: 07/04/2006, 20h11
  5. [ Vector Fichier ] Vector dans fichier texte
    Par geegee dans le forum Langage
    Réponses: 5
    Dernier message: 21/05/2004, 13h56

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