|
TRUST 1.9.8
HPC thermohydraulic platform
|
Classe Matrice_Morse Represente une matrice M (creuse), non necessairement carree. More...
#include <Matrice_Morse.h>
Public Member Functions | |
| Matrice_Morse () | |
| template<typename _SIZE_> | |
| Matrice_Morse (int n, _SIZE_ nnz) | |
| Constructeur d'une matrice Morse carree d'ordre n et pouvant stocker au maximum nnz elements non nuls. | |
| template<typename _SIZE_> | |
| Matrice_Morse (int n, int m, _SIZE_ nnz) | |
| Constructeur d'une matrice Morse avec n lignes et m colonnes pouvant stocker au maximum nnz elements non nuls. | |
| Matrice_Morse (const Matrice_Morse &) | |
| Constructeur par copie d'une Matrice_Morse. | |
| Matrice_Morse (int, int, const IntLists &, const DoubleLists &, const DoubleVect &) | |
| Sortie & | imprimer (Sortie &s) const override |
| Sortie & | imprimer_formatte (Sortie &s) const override |
| Sortie & | imprimer_formatte (Sortie &s, int symetrie) const |
| Sortie & | imprimer_image (Sortie &s) const |
| Sortie & | imprimer_image (Sortie &s, int symetrie) const |
| void | WriteFileMTX (const Nom &) const |
| int | largeur_de_bande () const |
| Calcule la largeur de bande d'une matrice morse. | |
| void | remplir (const IntLists &, const DoubleLists &, const DoubleVect &) |
| void | remplir (const IntLists &, const DoubleLists &) |
| void | remplir (const int, const int, const int, const int, const Matrice_Morse &) |
| Remplissage d'une matrice morse par une matrice morse plus petite. | |
| template<typename _SIZE_> | |
| void | dimensionner (int n, _SIZE_ nnz) |
| Size the matrix with n lines and n columns and nnz zero-values coefficients. | |
| template<typename _SIZE_> | |
| void | dimensionner (int n, int m, _SIZE_ nnz) |
| Size the matrix with n lines, m columns with nnz zero-values coefficients. | |
| void | dimensionner (const IntTab &) |
| Redimensionne la matrice creuse en ajoutant eventuellement des coefficients non nuls. | |
| int | ordre () const override |
| Renvoie l'ordre de la matrice: - le nombre de lignes si la matrice est carree. | |
| int | nb_lignes () const override |
| Return local number of lines (=size on the current proc). | |
| int | nb_colonnes () const override |
| Return local number of columns (=size on the current proc). | |
| auto | nb_coeff () const |
| void | set_nb_columns (const int) |
| void | set_symmetric (const int) |
| int | get_symmetric () const |
| auto & | get_set_tab1 () |
| auto & | get_set_tab2 () |
| auto & | get_set_coeff () |
| const auto & | get_tab1 () const |
| const auto & | get_tab2 () const |
| const auto & | get_coeff () const |
| int | nb_vois (int i) const |
| void | clean () override |
| Remplit la matrice avec des zeros. | |
| double & | operator() (int i, int j) |
| double | operator() (int i, int j) const |
| double | coef (int i, int j) const |
| double & | coef (int i, int j) |
| Matrice_Morse & | operator= (const Matrice_Morse &) |
| Operateur d'affectation d'une Matrice_Morse dans une autre Matrice_Morse. | |
| Matrice_Morse & | operator+= (const Matrice_Morse &) |
| NE FAIT RIEN. | |
| Matrice_Morse & | operator*= (double) |
| Operateur de multiplication (de tous les elements) d'une matrice par un scalaire. | |
| void | scale (const double x) override |
| void | get_stencil (Stencil &stencil) const override |
| void | get_stencil_and_coefficients (Stencil &stencil, StencilCoeffs &coefficients) const override |
| void | get_stencil_and_coeff_ptrs (Stencil &stencil, std::vector< const double * > &coeff_ptr) const override |
| Matrice_Morse & | operator/= (double) |
| Operateur de division (de tous les elements) d'une matrice par un scalaire. | |
| Matrice_Morse & | operator*= (const DoubleVect &) |
| Operateur de multiplication d'une matrice par un vecteur: scaling des lignes de la matrice par les coefficients. | |
| Matrice_Morse | operator- () const |
| Operateur de negation unaire, renvoie l'opposee de la matrice: - A Appelle operator*(double,const Matrice_Morse&). | |
| virtual int | inverse (const DoubleVect &, DoubleVect &, double) const |
| Calcule la solution du systeme lineaire: A * solution = secmem. | |
| virtual int | inverse (const DoubleVect &, DoubleVect &, double, int) const |
| Matrice_Morse & | affecte_prod (const Matrice_Morse &A, const Matrice_Morse &B) |
| Affecte le produit de 2 matrices Morse A et B a l'objet (this). | |
| void | compacte (int elim_coeff_nul=0) |
| Method to check/clean the Matrice_Morse matrix: -Suppress coefficient defined several times. | |
| DoubleVect & | ajouter_multvect_ (const DoubleVect &, DoubleVect &) const override |
| Operation de multiplication-accumulation (saxpy) matrice vecteur. | |
| ArrOfDouble & | ajouter_multvect_ (const ArrOfDouble &, ArrOfDouble &, ArrOfInt &) const |
| DoubleTab & | ajouter_multTab_ (const DoubleTab &, DoubleTab &) const override |
| Operation de multiplication-accumulation (saxpy) matrice matrice (matrice X representee par un tableau). | |
| DoubleVect & | ajouter_multvectT_ (const DoubleVect &, DoubleVect &) const override |
| Operation de multiplication-accumulation (saxpy) matrice vecteur, par la matrice transposee. | |
| ArrOfDouble & | ajouter_multvectT_ (const ArrOfDouble &, ArrOfDouble &, ArrOfInt &) const |
| virtual Matrice_Morse & | transpose (const Matrice_Morse &a) |
| *this = a transposee. | |
| virtual Matrice_Morse & | diagmulmat (const DoubleVect &x) |
| virtual Matrice_Morse & | partie_sup (const Matrice_Morse &a) |
| void | unite () |
| Initialisation a la matrice unite (modif MT). | |
| void | construire_sous_bloc (int nl0, int nc0, int nl1, int nc1, Matrice_Morse &result) const |
| void | formeC () |
| void | formeF () |
| bool | has_same_morse_matrix_structure (const Matrice_Morse &) const |
| bool | check_morse_matrix_structure () const |
| bool | check_sorted_morse_matrix_structure () const |
| void | assert_check_morse_matrix_structure () const |
| void | assert_check_sorted_morse_matrix_structure () const |
| void | sort_stencil () |
| bool & | constant_stencil () const |
| bool | is_sorted_stencil () const |
| bool | is_diagonal () |
| void | set_tab1_int32 () const |
| const IntVect & | get_tab1_int32 () const |
| void | set_tab1 (const IntVect &tab1_int32) |
| Public Member Functions inherited from Matrice_Base | |
| virtual DoubleVect & | ajouter_multvect (const DoubleVect &x, DoubleVect &r) const |
| Operation de multiplication-accumulation (saxpy) matrice vecteur. | |
| virtual DoubleVect & | ajouter_multvectT (const DoubleVect &x, DoubleVect &r) const |
| Operation de multiplication-accumulation (saxpy) matrice vecteur. | |
| virtual DoubleTab & | ajouter_multTab (const DoubleTab &, DoubleTab &r) const |
| NON CODE Operation de multiplication-accumulation (saxpy) matrice matrice. | |
| virtual DoubleVect & | multvect_ (const DoubleVect &, DoubleVect &) const |
| virtual DoubleVect & | multvect (const DoubleVect &, DoubleVect &) const |
| Multiplication d'un vecteur par la matrice. | |
| virtual DoubleVect & | multvectT_ (const DoubleVect &, DoubleVect &) const |
| virtual DoubleVect & | multvectT (const DoubleVect &, DoubleVect &) const |
| Multiplication d'un vecteur par la matrice transposee. | |
| virtual DoubleTab & | multTab (const DoubleTab &, DoubleTab &r) const |
| NON CODE Multiplication d'une matrice representee par un tableau par la matrice. | |
| virtual void | get_symmetric_stencil (Stencil &stencil) const |
| virtual void | get_symmetric_stencil_and_coefficients (Stencil &stencil, StencilCoeffs &coefficients) const |
| int | get_stencil_size () const |
| virtual void | build_stencil () |
| void | set_stencil (const Stencil &stencil) |
| bool | is_stencil_up_to_date () const |
| Public Member Functions inherited from Objet_U | |
| ~Objet_U () override | |
| Destructeur, supprime l'objet de la liste d'objets enregistres dans "memoire". | |
| int | numero () const |
| Renvoie l'indice de l'objet dans Memoire::data. | |
| virtual int | duplique () const =0 |
| virtual Sortie & | printOn (Sortie &) const |
| Ecriture de l'objet sur un flot de sortie Methode a surcharger. | |
| virtual Entree & | readOn (Entree &) |
| Lecture d'un Objet_U sur un flot d'entree Methode a surcharger. | |
| virtual unsigned | taille_memoire () const =0 |
| virtual int | est_egal_a (const Objet_U &) const |
| Renvoie 1 si l'objet x et *this sont une seule et meme instance (meme adresse en memoire). | |
| virtual const Nom & | le_nom () const |
| Donne le nom de l'Objet_U Methode a surcharger : renvoie "neant" dans cette implementation. | |
| virtual void | nommer (const Nom &) |
| Donne un nom a l'Objet_U Methode virtuelle a surcharger. | |
| virtual int | reprendre (Entree &) |
| Reprise d'un Objet_U sur un flot d'entree Methode a surcharger. | |
| virtual int | sauvegarder (Sortie &) const |
| Sauvegarde d'un Objet_U sur un flot de sortie Methode a surcharger. | |
| int | get_object_id () const |
| Renvoie l'identifiant unique de l'objet object_id_. | |
| virtual const Type_info * | get_info () const |
| Donne des informations sur le type de l'Objet_U. | |
| const Nom & | que_suis_je () const |
| renvoie la chaine identifiant la classe. | |
| const char * | le_type () const |
| Donne le nom du type de l'Objet_U. | |
| virtual int | change_num (const int *const) |
| Change le numero interne de l'Objet_U. | |
| virtual int | lire_motcle_non_standard (const Motcle &motlu, Entree &is) |
| Lecture des parametres de type non simple d'un objet_U a partir d'un flot d'entree. | |
| virtual int | associer_ (Objet_U &) |
| Associe l'Objet_U a un autre Objet_U Methode virtuelle a surcharger. | |
| const Interprete & | interprete () const |
| Interprete & | interprete () |
| Public Member Functions inherited from Process | |
| virtual | ~Process () |
Public Attributes | |
| int | sorted_ |
Protected Member Functions | |
| template<typename _TAB_T_, typename _VALUE_T_> | |
| void | get_stencil_coeff_templ (Stencil &stencil, _TAB_T_ &coeffs_span) const |
| Protected Member Functions inherited from Objet_U | |
| Objet_U () | |
| Constructeur par defaut : attribue un numero d'identifiant unique a l'objet (object_id_), et enregistre l'objet en "memoire". | |
| Objet_U (const Objet_U &) | |
| Constructeur par copie. | |
| const Objet_U & | operator= (const Objet_U &) |
| Operateur= : ne fait rien (on conserve le numero et l'identifiant). | |
| virtual void | set_param (Param &) const |
Protected Attributes | |
| IntVect | tab1_ |
| IntVect | tab2_ |
| DoubleVect | coeff_ |
| int | morse_matrix_structure_has_changed_ =-1 |
| int | m_ |
| int | symetrique_ |
| Protected Attributes inherited from Matrice_Base | |
| bool | is_stencil_up_to_date_ = false |
| Stencil | stencil_ |
Friends | |
| Matrice_Morse | operator+ (const Matrice_Morse &A, const Matrice_Morse &B) |
| Fonction (hors classe) amie de la classe Matrice_Morse Addition de 2 matrices au format Morse. | |
| Matrice_Morse | operator* (double x, const Matrice_Morse &A) |
| Fonction (hors classe) amie de la classe Matrice_Morse Scaling de la matrice par un scalaire: multiplie tous. | |
Additional Inherited Members | |
| Static Public Member Functions inherited from Objet_U | |
| static const Nom & | nom_du_cas () |
| Renvoie une reference constante vers le nom du cas. | |
| static Nom & | get_set_nom_du_cas () |
| Renvoie une reference non constante vers le nom du cas (pour pouvoir le modifier). | |
| static const Type_info * | info () |
| Donne des informations sur le type de l'Objet_U. | |
| static const Objet_U & | self_cast (const Objet_U &) |
| methode ajoutee pour caster en python | |
| static Objet_U & | self_cast (Objet_U &) |
| Static Public Member Functions inherited from Process | |
| static int | me () |
| renvoie mon rang dans le groupe de communication courant. | |
| static int | nproc () |
| renvoie le nombre de processeurs dans le groupe courant Voir Comm_Group::nproc() et PE_Groups::current_group() | |
| static bool | is_parallel () |
| static void | exit (int exit_code=-1) |
| Routine de sortie de TRUST dans une region Kokkos. | |
| static double | mp_sum (double) |
| Calcule la somme de x sur tous les processeurs du groupe courant. | |
| static float | mp_sum (float) |
| static trustIdType | mp_sum (trustIdType) |
| Calcule la somme de x sur tous les processeurs du groupe courant. | |
| static double | mp_max (double) |
| static double | mp_min (double) |
| static int | mp_max (int) |
| renvoie le plus grand int i sur l'ensemble des processeurs du groupe courant. | |
| static int | mp_min (int) |
| renvoie le plus petit int i sur l'ensemble des processeurs du groupe courant. | |
| static double | mp_sum_as_double (int v) |
| static trustIdType | mppartial_sum (trustIdType i) |
| Calul de la somme partielle de i sur les processeurs 0 a me()-1 (renvoie 0 sur le processeur 0). | |
| template<typename T> | |
| static void | mp_sum_for_each (T &arg1, T &arg2) |
| C++14 compatible mp_sum_for_each: combine multiple mp_sum calls into one collective operation Usage: mp_sum_for_each(a, b); mp_sum_for_each(a, b, c); mp_sum_for_each(a, b, c, d); mp_sum_for_each(a, b, c, d, e); All arguments must be of the same type (double or int) and are modified in place. Supports 2-5 parameters. | |
| template<typename T> | |
| static void | mp_sum_for_each (T &arg1, T &arg2, T &arg3) |
| template<typename T> | |
| static void | mp_sum_for_each (T &arg1, T &arg2, T &arg3, T &arg4) |
| template<typename T> | |
| static void | mp_sum_for_each (T &arg1, T &arg2, T &arg3, T &arg4, T &arg5) |
| template<typename T> | |
| static void | mp_max_for_each (T &arg1, T &arg2) |
| C++14 compatible mp_max_for_each: combine multiple mp_max calls into one collective operation. | |
| template<typename T> | |
| static void | mp_max_for_each (T &arg1, T &arg2, T &arg3) |
| template<typename T> | |
| static void | mp_max_for_each (T &arg1, T &arg2, T &arg3, T &arg4) |
| template<typename T> | |
| static void | mp_max_for_each (T &arg1, T &arg2, T &arg3, T &arg4, T &arg5) |
| template<typename T> | |
| static void | mp_min_for_each (T &arg1, T &arg2) |
| C++14 compatible mp_min_for_each: combine multiple mp_min calls into one collective operation. | |
| template<typename T> | |
| static void | mp_min_for_each (T &arg1, T &arg2, T &arg3) |
| template<typename T> | |
| static void | mp_min_for_each (T &arg1, T &arg2, T &arg3, T &arg4) |
| template<typename T> | |
| static void | mp_min_for_each (T &arg1, T &arg2, T &arg3, T &arg4, T &arg5) |
| template<typename _TYPE_> | |
| static void | mp_sum_for_each_item (TRUSTArray< _TYPE_ > &x, int n=-1) |
| template<typename _TYPE_> | |
| static void | mp_max_for_each_item (TRUSTArray< _TYPE_ > &x, int n=-1) |
| template<typename _TYPE_> | |
| static void | mp_min_for_each_item (TRUSTArray< _TYPE_ > &x, int n=-1) |
| static bool | mp_and (bool) |
| Calcule le 'et' logique de b sur tous les processeurs du groupe courant. | |
| static bool | mp_or (bool) |
| static int | check_int_overflow (trustIdType) |
| static int | je_suis_maitre () |
| renvoie 1 si on est sur le processeur maitre du groupe courant (c'est a dire me() == 0), 0 sinon. | |
| static KOKKOS_INLINE_FUNCTION void | Kokkos_exit (const char *) |
| Routine de sortie de TRUST dans une region Kokkos. | |
| static int | node_master () |
| renvoie 1 si on est sur le processeur maitre du noeud numa, 0 sinon. | |
| static void | exit (const Nom &message, int exit_code=-1) |
| static bool | is_sequential () |
| static void | barrier () |
| Synchronise tous les processeurs du groupe courant (attend que tous les processeurs soient arrives a la barriere). | |
| static void | abort () |
| Routine de sortie de Trio-U sur une erreur abort(). | |
| static Sortie & | Journal (int message_level=0) |
| Renvoie un objet statique de type Sortie qui sert de journal d'evenements. | |
| static double | ram_processeur () |
| static void | imprimer_ram_totale (int all_process=0) |
| static bool | force_single_file (const int ranks, const Nom &filename) |
| Static Public Attributes inherited from Objet_U | |
| static double | precision_geom = 1e-10 |
| static constexpr bool | HAS_POINTER = false |
| static int | dimension =0 |
| static int | format_precision_geom =11 |
| static int | axi =0 |
| static int | bidim_axi =0 |
| static int | DEACTIVATE_SIGINT_CATCH =0 |
| static Type_info | info_obj |
| static bool | disable_TU =false |
| Flag to disable or not the writing of the .TU files. | |
| static bool | stat_per_proc_perf_log =false |
| Flag to enable the writing of the statistics detailed per processor in _csv.TU file. | |
| Static Public Attributes inherited from Process | |
| static int | exception_sur_exit =0 |
| static int | multiple_files =5120 |
Classe Matrice_Morse Represente une matrice M (creuse), non necessairement carree.
On utilise 3 tableaux tab1(n+1), tab2(nnz) et coeff_(nnz): On note Vi = { j differents de i / M(i,j) est non nul } tab1[i] = rang dans tab2 de la ieme ligne pour tab1[i] <= j < tab1[i+1], tab2[j] decrit Vi et coeff_[j] = M(i,tab2[j]) tab1 et tab2 sont des rangs au sens fortran: 1 <= tab2[i] <= n tab1[n+1] = nnz+1 Remarque: dans ce commentaire le [] est a prendre au sens fortran: tab1[1] designe la premiere valeur de tab1
C'est aussi le format decrit dans la page Wikipedia : https://fr.wikipedia.org/wiki/Matrice_creuse
Definition at line 49 of file Matrice_Morse.h.
| Matrice_Morse::Matrice_Morse | ( | ) |
Definition at line 255 of file Matrice_Morse.cpp.
| Matrice_Morse::Matrice_Morse | ( | int | n, |
| _SIZE_ | nnz ) |
Constructeur d'une matrice Morse carree d'ordre n et pouvant stocker au maximum nnz elements non nuls.
Egalement constructeur par defaut car les 2 parametres ont une valeur par defaut.
| (int | n) l'ordre de la matrice carree a construire |
| (int | nnz) le nombre d'elements non nuls que pourra stocker la matrice. |
Definition at line 248 of file Matrice_Morse.cpp.
| Matrice_Morse::Matrice_Morse | ( | int | n, |
| int | m, | ||
| _SIZE_ | nnz ) |
Constructeur d'une matrice Morse avec n lignes et m colonnes pouvant stocker au maximum nnz elements non nuls.
| (int | n) le nombre de ligne de la matrice |
| (int | m) le nombre de colonne de la matrice |
| (int | nnz) le nombre d'elements non nuls que pourra stocker la matrice. |
Definition at line 273 of file Matrice_Morse.cpp.
| Matrice_Morse::Matrice_Morse | ( | const Matrice_Morse & | acopier | ) |
Constructeur par copie d'une Matrice_Morse.
Copie de chaque membre donne du paramtre.
| (Matrice_Morse& | acopier) la matrice morse a copier |
Definition at line 228 of file Matrice_Morse.cpp.
| Matrice_Morse::Matrice_Morse | ( | int | n, |
| int | nnz, | ||
| const IntLists & | voisins, | ||
| const DoubleLists & | valeurs, | ||
| const DoubleVect & | terme_diag ) |
Definition at line 281 of file Matrice_Morse.cpp.
| Matrice_Morse & Matrice_Morse::affecte_prod | ( | const Matrice_Morse & | a, |
| const Matrice_Morse & | b ) |
Affecte le produit de 2 matrices Morse A et B a l'objet (this).
Operation: this = A * B
| (Matrice_Morse& | A) une matrice au format Morse |
| (Matrice_Morse& | B) une matrice au format Morse |
Definition at line 1327 of file Matrice_Morse.cpp.
|
overridevirtual |
Operation de multiplication-accumulation (saxpy) matrice matrice (matrice X representee par un tableau).
Operation: RESU = RESU + A*X
| (DoubleTab& | x) la matrice a multiplier |
| (DoubleTab& | resu) la matrice resultat de l'operation |
Implements Matrice_Base.
Reimplemented in Matrice_Morse_Diag, and Matrice_Morse_Sym.
Definition at line 972 of file Matrice_Morse.cpp.
| ArrOfDouble & Matrice_Morse::ajouter_multvect_ | ( | const ArrOfDouble & | x, |
| ArrOfDouble & | resu, | ||
| ArrOfInt & | est_reel_pas_com ) const |
Definition at line 943 of file Matrice_Morse.cpp.
|
overridevirtual |
Operation de multiplication-accumulation (saxpy) matrice vecteur.
Operation: resu = resu + A*x
Implements Matrice_Base.
Reimplemented in Matrice_Morse_Diag, and Matrice_Morse_Sym.
Definition at line 877 of file Matrice_Morse.cpp.
| ArrOfDouble & Matrice_Morse::ajouter_multvectT_ | ( | const ArrOfDouble & | x, |
| ArrOfDouble & | resu, | ||
| ArrOfInt & | est_reel_pas_com ) const |
Definition at line 1026 of file Matrice_Morse.cpp.
|
overridevirtual |
Operation de multiplication-accumulation (saxpy) matrice vecteur, par la matrice transposee.
Operation: resu = resu + A^{T}*x
| (DoubleVect& | x) le vecteur a multiplier |
| (DoubleVect& | resu) le vecteur resultat de l'operation |
Implements Matrice_Base.
Reimplemented in Matrice_Morse_Diag, and Matrice_Morse_Sym.
Definition at line 1011 of file Matrice_Morse.cpp.
| void Matrice_Morse::assert_check_morse_matrix_structure | ( | ) | const |
Definition at line 1937 of file Matrice_Morse.cpp.
| void Matrice_Morse::assert_check_sorted_morse_matrix_structure | ( | ) | const |
Definition at line 1952 of file Matrice_Morse.cpp.
| bool Matrice_Morse::check_morse_matrix_structure | ( | ) | const |
Definition at line 1815 of file Matrice_Morse.cpp.
| bool Matrice_Morse::check_sorted_morse_matrix_structure | ( | ) | const |
Definition at line 1871 of file Matrice_Morse.cpp.
|
overridevirtual |
Remplit la matrice avec des zeros.
Reimplemented from Matrice_Base.
Definition at line 1788 of file Matrice_Morse.cpp.
|
inline |
Definition at line 130 of file Matrice_Morse.h.
|
inline |
Definition at line 129 of file Matrice_Morse.h.
| void Matrice_Morse::compacte | ( | int | elim_coeff_nul = 0 | ) |
Method to check/clean the Matrice_Morse matrix: -Suppress coefficient defined several times.
-elim_coeff_nul=0, on ne supprime pas les coefficients nuls de la matrice -elim_coeff_nul=1, on supprime les coefficients nuls de la matrice -elim_coeff_nul=2, on supprime les coefficients nuls et quasi-nuls de la matrice
Definition at line 520 of file Matrice_Morse.cpp.
|
inline |
Definition at line 188 of file Matrice_Morse.h.
| void Matrice_Morse::construire_sous_bloc | ( | int | nl0, |
| int | nc0, | ||
| int | nl1, | ||
| int | nc1, | ||
| Matrice_Morse & | result ) const |
Definition at line 1970 of file Matrice_Morse.cpp.
|
virtual |
Definition at line 808 of file Matrice_Morse.cpp.
| void Matrice_Morse::dimensionner | ( | const IntTab & | Ind | ) |
Redimensionne la matrice creuse en ajoutant eventuellement des coefficients non nuls.
Parametre : const IntTab &Ind Signification : tableau de taille nc * 2 ou nc est le nombre de couples (i,j) pour les indices des nouveaux coefficients
Definition at line 322 of file Matrice_Morse.cpp.
| void Matrice_Morse::dimensionner | ( | int | n, |
| _SIZE_ | nnz ) |
Size the matrix with n lines and n columns and nnz zero-values coefficients.
Definition at line 305 of file Matrice_Morse.cpp.
| void Matrice_Morse::dimensionner | ( | int | n, |
| int | m, | ||
| _SIZE_ | nnz ) |
Size the matrix with n lines, m columns with nnz zero-values coefficients.
Definition at line 470 of file Matrice_Morse.cpp.
| void Matrice_Morse::formeC | ( | ) |
Definition at line 1748 of file Matrice_Morse.cpp.
| void Matrice_Morse::formeF | ( | ) |
Definition at line 1761 of file Matrice_Morse.cpp.
|
inline |
Definition at line 112 of file Matrice_Morse.h.
|
inline |
Definition at line 108 of file Matrice_Morse.h.
|
inline |
Definition at line 98 of file Matrice_Morse.h.
|
inline |
Definition at line 103 of file Matrice_Morse.h.
|
overridevirtual |
Reimplemented from Matrice_Base.
Reimplemented in Matrice_Morse_Sym.
Definition at line 1465 of file Matrice_Morse.cpp.
|
overridevirtual |
Reimplemented from Matrice_Base.
Definition at line 1556 of file Matrice_Morse.cpp.
|
overridevirtual |
Reimplemented from Matrice_Base.
Reimplemented in Matrice_Morse_Sym.
Definition at line 1575 of file Matrice_Morse.cpp.
|
inlineprotected |
Definition at line 1531 of file Matrice_Morse.cpp.
|
inline |
Definition at line 96 of file Matrice_Morse.h.
|
inline |
Definition at line 110 of file Matrice_Morse.h.
|
inline |
Definition at line 202 of file Matrice_Morse.h.
|
inline |
Definition at line 111 of file Matrice_Morse.h.
| bool Matrice_Morse::has_same_morse_matrix_structure | ( | const Matrice_Morse & | A | ) | const |
Definition at line 1137 of file Matrice_Morse.cpp.
Reimplemented from Matrice_Base.
Definition at line 61 of file Matrice_Morse.cpp.
Reimplemented from Matrice_Base.
Reimplemented in Matrice_Morse_Sym.
Definition at line 78 of file Matrice_Morse.cpp.
Definition at line 83 of file Matrice_Morse.cpp.
Definition at line 140 of file Matrice_Morse.cpp.
Definition at line 145 of file Matrice_Morse.cpp.
|
virtual |
Calcule la solution du systeme lineaire: A * solution = secmem.
La methode utilisee est GMRES preconditionnee avec ILUT. ATTENTION: cette methode n'a vraisemblablement jamais ete testee en parallele
| (DoubleVect& | secmem) le second membre du systeme lineaire |
| (DoubleVect& | solution) la solution du systeme |
| (double | coeff_seuil) |
| Erreur | dans ilut 'matrix may be wrong' dixit SAAD |
| Erreur | dans ilut : debordement dans L |
| Erreur | dans ilut : debordement dans U |
| Valeur | illegale de lfil : sans doute ecrasement memoire |
| Ligne | vide rencontree |
| Pivot | nul rencontre ! au pas |
| Il | s'est passe quelque chose de bizarre : je prefere tout arreter. |
Reimplemented in Matrice_Morse_Sym.
Definition at line 1170 of file Matrice_Morse.cpp.
|
virtual |
Reimplemented in Matrice_Morse_Sym.
Definition at line 1179 of file Matrice_Morse.cpp.
| bool Matrice_Morse::is_diagonal | ( | ) |
Definition at line 2043 of file Matrice_Morse.cpp.
| bool Matrice_Morse::is_sorted_stencil | ( | ) | const |
Definition at line 2020 of file Matrice_Morse.cpp.
| int Matrice_Morse::largeur_de_bande | ( | ) | const |
Calcule la largeur de bande d'une matrice morse.
Definition at line 1796 of file Matrice_Morse.cpp.
|
inline |
Definition at line 92 of file Matrice_Morse.h.
|
inlineoverridevirtual |
Return local number of columns (=size on the current proc).
Implements Matrice_Base.
Definition at line 91 of file Matrice_Morse.h.
|
inlineoverridevirtual |
Return local number of lines (=size on the current proc).
Implements Matrice_Base.
Definition at line 90 of file Matrice_Morse.h.
|
inline |
Definition at line 114 of file Matrice_Morse.h.
|
inline |
Definition at line 269 of file Matrice_Morse.h.
|
inline |
Definition at line 244 of file Matrice_Morse.h.
| Matrice_Morse & Matrice_Morse::operator*= | ( | const DoubleVect & | x | ) |
Operateur de multiplication d'une matrice par un vecteur: scaling des lignes de la matrice par les coefficients.
correspondants du vecteur passe en parametre. A *= x, effectue les scaling suivants: A(i,:) = A(i,:) * x(i), pour toutes les lignes i de A
| (DoubleVect& | x) vecteur de scaling |
Definition at line 1310 of file Matrice_Morse.cpp.
| Matrice_Morse & Matrice_Morse::operator*= | ( | double | x | ) |
Operateur de multiplication (de tous les elements) d'une matrice par un scalaire.
Operation: A = x * A
| (double | x) le parametre de scaling |
Definition at line 1454 of file Matrice_Morse.cpp.
| Matrice_Morse & Matrice_Morse::operator+= | ( | const Matrice_Morse & | A | ) |
NE FAIT RIEN.
| (Matrice_Morse&) | une matrice morse |
Definition at line 1427 of file Matrice_Morse.cpp.
| Matrice_Morse Matrice_Morse::operator- | ( | ) | const |
Operateur de negation unaire, renvoie l'opposee de la matrice: - A Appelle operator*(double,const Matrice_Morse&).
Definition at line 1416 of file Matrice_Morse.cpp.
| Matrice_Morse & Matrice_Morse::operator/= | ( | double | x | ) |
Operateur de division (de tous les elements) d'une matrice par un scalaire.
Operation: A = A / x
| (double | x) le parametre de scaling |
| division | par zero impossible |
Definition at line 1607 of file Matrice_Morse.cpp.
| Matrice_Morse & Matrice_Morse::operator= | ( | const Matrice_Morse & | a | ) |
Operateur d'affectation d'une Matrice_Morse dans une autre Matrice_Morse.
| (Matrice_Morse& | a) la partie droite de l'affectation |
Definition at line 739 of file Matrice_Morse.cpp.
|
overridevirtual |
Renvoie l'ordre de la matrice: - le nombre de lignes si la matrice est carree.
- 0 sinon
Implements Matrice_Base.
Definition at line 505 of file Matrice_Morse.cpp.
|
virtual |
Definition at line 826 of file Matrice_Morse.cpp.
| void Matrice_Morse::remplir | ( | const int | ideb, |
| const int | jdeb, | ||
| const int | n, | ||
| const int | m, | ||
| const Matrice_Morse & | mat ) |
Remplissage d'une matrice morse par une matrice morse plus petite.
Definition at line 1700 of file Matrice_Morse.cpp.
| void Matrice_Morse::remplir | ( | const IntLists & | voisins, |
| const DoubleLists & | valeurs ) |
Definition at line 1657 of file Matrice_Morse.cpp.
| void Matrice_Morse::remplir | ( | const IntLists & | voisins, |
| const DoubleLists & | valeurs, | ||
| const DoubleVect & | terme_diag ) |
Definition at line 1613 of file Matrice_Morse.cpp.
|
overridevirtual |
Implements Matrice_Base.
Reimplemented in Matrice_Morse_Sym.
Definition at line 1460 of file Matrice_Morse.cpp.
| void Matrice_Morse::set_nb_columns | ( | const int | nb_col | ) |
Definition at line 291 of file Matrice_Morse.cpp.
| void Matrice_Morse::set_symmetric | ( | const int | symmetric | ) |
Definition at line 296 of file Matrice_Morse.cpp.
|
inline |
Definition at line 210 of file Matrice_Morse.h.
|
inline |
Definition at line 193 of file Matrice_Morse.h.
| void Matrice_Morse::sort_stencil | ( | ) |
Definition at line 2011 of file Matrice_Morse.cpp.
|
virtual |
*this = a transposee.
| (Matrice_Morse& | a) la matrice a transposee |
Definition at line 754 of file Matrice_Morse.cpp.
| void Matrice_Morse::unite | ( | ) |
Initialisation a la matrice unite (modif MT).
Definition at line 491 of file Matrice_Morse.cpp.
| void Matrice_Morse::WriteFileMTX | ( | const Nom & | name | ) | const |
Definition at line 197 of file Matrice_Morse.cpp.
|
friend |
Fonction (hors classe) amie de la classe Matrice_Morse Scaling de la matrice par un scalaire: multiplie tous.
les elements de la matrice par un scalaire. Operation: renvoie x*A
| (double | x) valeur du scaling |
| (Matrice_Morse& | B) une matrice au format Morse |
Definition at line 1405 of file Matrice_Morse.cpp.
|
friend |
Fonction (hors classe) amie de la classe Matrice_Morse Addition de 2 matrices au format Morse.
Operation: renvoie (A+B)
| (Matrice_Morse& | A) une matrice au format Morse |
| (Matrice_Morse& | B) une matrice au format Morse |
Definition at line 1053 of file Matrice_Morse.cpp.
|
protected |
Definition at line 227 of file Matrice_Morse.h.
|
protected |
Definition at line 231 of file Matrice_Morse.h.
|
mutableprotected |
Definition at line 230 of file Matrice_Morse.h.
|
mutable |
Definition at line 192 of file Matrice_Morse.h.
|
protected |
Definition at line 232 of file Matrice_Morse.h.
|
protected |
Definition at line 225 of file Matrice_Morse.h.
|
protected |
Definition at line 226 of file Matrice_Morse.h.