Solveur linéaire : Options avancées
Cette section cible les utilisateurs avancés afin de les aider à comprendre les paramètres de chaque solveur. Les utilisateurs avancés qui veulent sélectionner manuellement le solveur à utiliser et pas seulement le type de solveur doivent changer leur mode utilisateur :
, puis fermer et rouvrir Flux pour appliquer ce changement. En mode avancé, la boîte d’options de résolution affiche beaucoup plus d’options pour les solveurs linéaires. Voici la liste des solveurs linéaires :Type | Nom du solveur | Parallélisé | Distribué |
N/A | Solveur automatique [défaut] | N/A | N/A |
Itératif | ICCG [défaut] | Non | Non |
IJCG | Non | Non | |
PETSc | Oui | Oui | |
GMRes | Non | Non | |
BICGStab | Non | Non | |
Direct | SuperLU | Non | Non |
Mumps(Local)[défaut] | Oui | Non | |
Mumps (Distributed) | Oui | Oui | |
N/A | Par routine utilisateur | N/A | N/A |
N/A | Solveur externe | N/A | N/A |
Vous pouvez définir des paramètres de distribution globalement via Calcul parallèle pour plus détails.
.Ces paramètres sont utilisés pour configurer Mumps et PETSc par défault, voirCi-dessous les détails de chaque paramètre solveur est fourni.
ICCG et IJCG
ICCG et IJCG sont des solveurs itératifs qui utilisent le gradient conjugué pour la résolution et la factorisation incomplète de Cholesky LDLT pour le préconditionnement. En Magnéto Harmonique, ICCG et IJCG utilisent le gradient bi-conjugué pour la résolution et la factorisation incomplète LDU pour le préconditionnement.
Options
Paramètre | Description |
---|---|
Précision pour le Gradient Conjugué |
Précision relative à satisfaire avant d’arrêter le processus itératif. Valeur par défaut : 1.0e-6 |
Nombre maximum d’itérations pour le Gradient Conjugué |
Nombre maximum d’itérations à effectuer avant d’arrêter le processus itératif. Deux options sont disponibles pour définir le nombre d’itérations :
Valeur par défaut : Fonction linéaire avec A = 1 et B = 1, qui correspond au nombre d’équations du problème. |
Tolérance pour le préconditionnement LDU |
Précision du préconditionneur. Valeur par défaut : 1.0e-7 |
Affiche l’évolution de la convergence |
Indicateur du niveau de verbosité du processus itératif. Définir à « oui » pour écrire un suivi du processus itératif au cours de la résolution. Valeur par défaut : “non” |
PETSc
PETSc est une librairie de solveurs itératifs parallèles et distribués. Une pré-sélection de solveur/préconditionneur a été faite selon la dimension et le type de problème traité. En 2D, les couples LGRMRES/ILU ou BCGS/ILU sont utilisés. En 3D le solveur par défaut est le TFQMR/ICC et si ce dernier échoue le BCGS/ILU est utilisé. Pour plus de détails, visitez la page web de PETSc.
OptionsAucune option n’est disponible pour la version actuelle.
GMRes
GMRes est un solveur itératif qui utilise la généralisation de la méthode de minimisation du résidu pour la résolution et la factorisation incomplète avec ILUT pour le préconditionnement.
OptionsParamètre | Description |
---|---|
Précision pour GMRes |
Précision relative à satisfaire avant d’arrêter le processus itératif. Valeur par défaut : 1.0e-6 |
Nombre maximum d’itérations pour GMRes |
Nombre maximum d’itérations à effectuer avant d’arrêter le processus itératif. Deux options sont disponibles pour définir le nombre d’itérations :
Valeur par défaut : Fonction linéaire avec A = 1 et B = 1, qui correspond au nombre d’équations du problème. |
Tolérance pour le préconditionnement ILUT |
Précision du préconditionneur. Valeur par défaut : 1.0e-6 |
Coefficient pour le niveau de remplissage lors du préconditionnement ILUT |
Facteur de remplissage du conditionneur ILUT. Valeur par défaut : 6.0 |
Dimension pour l’espace de Krylov |
Nombre de vecteurs à stocker afin de construire l’espace Krylov. Valeur par défaut : 120 |
Affiche l’évolution de la convergence |
Indicateur du niveau de verbosité du processus itératif. Définir à « oui » pour écrire un suivi du processus itératif au cours de la résolution. Valeur par défaut : “non” |
BiCGStab
BiCGStab est un solveur itératif qui utilise le Gradient Bi-Conjugué Stabilisé pour la résolution et la factorisation incomplète de Cholesky LDLT pour le préconditionnement. En Magnéto Harmonique, BiCGStab utilise la factorisation incomplète LDU pour le préconditionnement
OptionsParamètre | Description |
---|---|
Précision pour BiCGStab |
Précision relative à satisfaire avant d’arrêter le processus itératif. Valeur par défaut : 1.0e-6 |
Nombre maximum d’itérations pour BiCGStab |
Nombre maximum d’itérations à effectuer avant d’arrêter le processus itératif. Deux options sont disponibles pour définir le nombre d’itérations :
Valeur par défaut : Fonction linéaire avec A = 1 et B = 1, qui correspond au nombre d’équations du problème. |
Tolérance pour le préconditionnement de LDU (ou LDLT) |
Précision du préconditionneur. Valeur par défaut : 1.0e-7 |
Affiche l’évolution de la convergence |
Indicateur du niveau de verbosité du processus itératif. Définir à « oui » pour écrire un suivi du processus itératif au cours de la résolution. Valeur par défaut : “non” |
SuperLU
SuperLU est une méthode directe qui utilise l’algorithme d’élimination de Gauss.
OptionsParamètre | Description |
---|---|
Algorithme de renumérotation des colonnes |
Spécifie comment permuter les colonnes de la matrice pour préserver le caractère creux de la matrice. Les méthodes de réorganisation sont les suivantes :
Valeur par défaut : “Méthode de renumérotation automatique”. |
Pivotage partiel par ligne |
Spécifie la méthode de pivotage de la ligne. Trois choix sont possibles :
Valeur par défaut : 0.0 (pas de pivotage). |
Raffinement itératif |
Spécifie s’il faut effectuer le raffinement itératif. Valeur par défaut : “Sans raffinement itératif”. |
Mode symétrique |
Spécifie l’utilisation du mode symétrique. Le mode symétrique donne la préférence aux pivots diagonaux et utilise un algorithme de permutation de colonne (AT + A). Valeur par défaut : “Sans mode symétrique” |
Calcul du « pivot growth » |
Définit le calcul ou non du « pivot growth ». Valeur par défaut : “Sans calcul du pivot growth” |
Calcul du conditionnement |
Spécifie si le calcul du conditionnement doit être fait. Valeur par défaut : “Sans calcul du conditionnement” |
Mumps
Mumps est un solveur direct, basé sur une approche multifrontal.
Mumps (Local) est un solveur mono-process, mais multithread. Il n’y a qu’un seul processus alors que le nombre de threads est fixé par le nombre de cœurs choisi par l’utilisateur à partir du Superviseur de Flux.
Mumps (Distributed) est un solveur multi-processus et multithread. Le nombre de processus et de threads sont définis dans le superviseur de Flux, voir Calcul Parallèle pour plus de détails.
OptionsParamètre | Description |
---|---|
Niveau d’information |
Définit le niveau de verbosité pendant le processus de résolution. Quatre niveaux sont disponibles pour décider quelles informations seront affichées :
Valeur par défaut : “1- Messages d’erreurs seulement” |
Utilisation mémoire sur disque |
Définit les options concernant l’utilisation du disque. Quatre options sont disponibles :
Valeur par défaut : “Non” |
Méthode de reordering |
Spécifie la méthode de reordering à utiliser. Cinq méthodes peuvent être utilisées :
Valeur par défaut : “Automatique – Choix dans Mumps” |
Limitation de la mémoire RAM |
Définit la limitation d’utilisation de la mémoire RAM. Il permet à l’utilisateur de limiter la mémoire que Mumps peut utiliser (en MB). Valeur par défaut : Illimitée |
Options MPI |
Seulement pour MUMPS (Distribué). Définit les options MPI. Pour activer les calculs MPI, le nombre de MPI peut être spécifié avec le nombre de Thread. Valeur par défaut : “Non” |