Arcane  v3.15.0.0
Documentation utilisateur
Chargement...
Recherche...
Aucune correspondance
Changelog Arcane v2.X.X

Cette page contient les nouveautés de chaque version de Arcane v2.X.X.


Arcane Version 2.22.0 (03 mars 2021)

Nouveautés/Améliorations:

  • Support des protections/reprises pour les maillages AMR
  • Modifications internes pour le support des accélérateurs, notamment le support des cartes graphiques (GPGPU).
  • Suppression des classes et familles d'entités pour les Arcane::DualNode et Arcane::Link. Ces classes peuvent être remplacées par l'utilisation de Arcane::DoF.
  • Support partiel des fichiers de maillage au format 'msh' version 4.1.

Changements:

  • [IMPORTANT] Cette version utilise par défaut les nouvelles structures de connectivités. Cela ne devrait normalement pas avoir d'impact sur les codes existants à condition qu'ils n'utilisent pas les classes internes de Arcane qui gèrent les entités (comme par exemple Arcane::ItemInternal).
  • Les statistiques d'exécution sur les temps passés dans les différents points d'entrée et modules qui sont affichées à la fin du calcul contiennent maintenant le cumul sur l'ensemble des exécutions (en cas d'utilisation de protection/reprise) et plus seulement les statistiques sur l'exécution courante.
  • Simplification des différents mécanismes pour initialiser et exécuter un code utilisant Arcane (voir Lancement d'un calcul)

Corrections:

  • Corrige problème potentiel en parallèle lors de la création du répertoire pour les protections. Il était possible pour certains processus de tenter d'accéder à ce répertoire avant sa création.
  • Corrige utilisation du script arcane_convert_mesh servant pour la conversion de maillages.
  • Ré-active la génération de la documentation des services et modules fournis par Arcane

Arcane Version 2.20.0 (07 janvier 2021)

Nouveautés/Améliorations:

Changements:

  • Unification de la documentation entre les parties CEA et la partie commune
  • Support des tests unitaires en parallèle (voir Tests unitaires en parallèle)
  • Modifications des classes Arcane::IData, Arcane::ISerializedData pour utiliser Arccore::Ref pour gérer les références
  • Début refonte de la création et gestion de la mémoire des variables pour pouvoir à terme permettre aux développeurs d'ajouter leurs propres variables.

Corrections:

  • Corrige plantage lors de l'utilisation de PTScotch lors d'un partitionnement en cas de redistribution mono-noeud.
  • Nomme correctement le fichier 'ArcaneConfigVersion.cmake' pour pouvoir utiliser un numéro de version pour Arcane dans la commande CMake find_package().

Arcane Version 2.19.0 (30 juin 2020)

Note
Suite aux modifications dans la sérialisation, il n'est en général pas possible de reprendre avec cette version de Arcane un calcul commencé avec une version antérieure.

Changements:

Nouveautés/Améliorations:

  • Nombreuses améliorations sur l'échange de messages:
    • Support de toutes les méthodes de Arcane::IParallelMng en mode hybride et en mode mémoire partagée. En particulier, il manquait certaines méthodes de sérialisation.
    • Support des tags utilisateurs dans les méthodes point à point (send/receive)
    • Utilisation de types spécifiques pour gérer les tags (Arccore::MessageTag) et les rangs (Arccore::MessageRank). Ces types remplacent le type 'Int32' utilisé précédemment.
    • Unification de la gestion des méthodes point à point. Les paramètres nécessaires sont gérés par la classe Arccore::PointToPointMessageInfo.
    • support des méthodes MPI utilisant un MPI_Message (MPI_Mprobe, MPI_Improbe, MPI_Imrecv, MPI_Mrecv). Ces méthodes permettent de garantir qu'un MPI_Recv correspond bien au MPI_Probe utilisé précédemment. Ces mécanismes sont aussi accessibles en mode hybride.
  • Support du partitionnement de maillage en mode mémoire partagée et hybride
  • Ajoute dans le partitionneur Metis un mode permettant d'utiliser un seul processus pour le partitionnement. Auparavant il était nécessaire d'utiliser au minumum deux processus (à cause d'un bug dans ParMetis)
  • Correction de l'algorithme permettant de garantir qu'il n'y a pas de partitions vides après utilisation de ParMetis.
  • Préparation de Arccore::ISerializer pour supporter à terme d'autres types de données (par exemple des 'Float32' ou 'Float16')
  • Enregistre un hash du nom de la variable lors des sérialisations. Cela permet de garantir qu'on est bien en train de désérialiser la bonne variable.
  • Amélioration diverses du lecteur/écrivain au format JSON
  • Génère dans les logs après un repartitionnement les informations sur les sous-domaines connectés à un sous-domaine.
  • Support de la compilation via l'outil 'spack'.
  • Dans le jeu de données, ajoute la possibilité de mettre un bloc <comment> en dessous de la racine. Cela est utile si un module n'est pas actif mais qu'on souhaite garder ses options. Il suffit alors de mettre ce bloc d'option entre les balises <comment> et </comment>.
  • [.Net] Génère des packages nuget pour l'utilisation du wrapping. Il est donc possible de directement référencer ces pacakges plutôt que d'aller chercher directement les .dll. L'utilisation de packages nuget permet aussi de gérer automatiquement les dépendances.
  • [.Net] Passage à la version 3.1 de '.Net Core'.

Les points suivants sont en cours de développement mais non finalisés:

  • Gestion de la création des maillages sous forme de service. A terme seul ce mode sera disponible. Il permettra notamment de pouvoir créér des structures de maillages spécifiques (par exemple cartésien)
  • Refonte de l’initialisation pour permettre d’utiliser Arcane sans passer par une boucle en temps

Arcane Version 2.18.0 (09 décembre 2019)

Cette version comporte les développements suivants:

  • Amélioration de l'implémentation de la classe Arcane::HPReal qui corrige quelques cas limites et ajoute le support de la multiplication et de la division
  • Création d'une classe universelle Arccore::Ref pour gérer la durée de vie des objets tels que les services. Cette classe permet de détruire automatiquement un objet lorsqu'il n'y a plus de référence dessus. Les services alloués dynamiquement utilisent maintenant cette classe. Par exemple:
    using namespace Arcane;
    ISubDomain* sd = ...;
    IDataReader* old_reader = sb.createInstance(...); // Obsolète
    Arccore::Ref<IDataReader> new_reader = sb.createReference(...); // Nouveau mécanisme.
    Interface de lecture des données d'une variable.
    Definition IDataReader.h:41
    Interface du gestionnaire d'un sous-domaine.
    Definition ISubDomain.h:74
    Classe utilitaire pour instantier un service d'une interface donnée.
    -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
    Via cette classe Arccore::Ref, il ne faut plus détruire explicitement un objet. La méthode Arccore::makeRef() permet de créer une référence à partir d'un pointeur alloué par 'operator new'.
  • Refonte partielle du mécanisme de lecture des options du jeu de données. Le but à terme est de pouvoir utiliser autre chose que XML pour l'entrée des données. Les modifications concernent essentiellement les classes de bases gérant les options et ne devraient pas avoir d'incidence sur le code utilisateur.
  • Détecte les options du jeu de données sous la racine qui ne sont pas lues et retourne une erreur. La variable d'environnement ARCANE_ALLOW_UNKNOWN_ROOT_ELEMENT permet si elle positionnée d'afficher un avertissement plutôt qu'une erreur.
  • [.Net] Passage à la version 3.0 de '.Net Core'.
  • [.Net] Support en C# des classes gérants les matériaux et les milieux et des variables scalaires sur les constituants.
  • [.Net] Support pour lancer les extensions utilisateur C# via l'outil dotnet à la place de mono ce qui permet de débugger le code C# via par exemple Visual Studio Code.
  • Passage à la version 6.38.0 de Lima, qui permet de lire les fichiers au format mli2. Ce format utilise une version récente de HDF5 et optimise notamment la taille des fichiers de maillage lorsqu'il y a un grand nombre de groupes vides.

Arcane Version 2.17.0 (09 octobre 2019)

Cette version comporte les développements suivants:

  • [.Net] Refonte de l'environnement .Net pour permettre de compiler soit avec mono, soit avec l'implémentation Microsoft dotnet.
  • [.Net] Uniformisation de l'initialisation avec ou sans l'utilisation du runtime .Net.
  • Ajout dans le répertoire 'samples' d'un exemple 'EOS' montrant comment rendre accessible en C# des services ou des classes C++.
  • Application stricte des règles de conversion XML pour la lecture de l'attribut active dans l'élément <module> indiquant si un module est actif ou non. Maintenant, seules les valeurs true, false, 0 ou 1 sont autorisées. Auparanvant, toute valeur autre que false était considérée comme true.
  • Support dans le profiling MPI via la bibliothèque OTF2 des cas avec équilibrage de charge et retour-arrière.
  • Possibilité de détruire les maillages additionnels via un la classe Arcane::IMeshMng:
    Arcane::IMesh* mesh_to_destroy = ...;
    sd->meshMng()->destroyMesh(mesh_to_destroy);
    virtual void destroyMesh(MeshHandle handle)=0
    Détruit le maillage associé à handle.
    virtual IMeshMng * meshMng() const =0
    Retourne le gestionnaire de maillage.
    Le pointeur mesh_to_destroy ne doit plus être utilisé après appel à la méthode de destruction.
  • Support dans Arcane::mesh::BasicParticleExchanger des particules qui ne sont pas dans des mailles (celles pour lequelles Arcane::Particle::cell() retournent une maille nulle)
  • Ajoute options dans le service 'BasicParticleExchanger' pour permettre de choisir le nombre de messages maximumum à effectuer avant de faire les réductions
  • Ajoute pour test une variable d'environnement ARCANE_VARIABLE_SHRINK_MEMORY qui si elle est positionnée à 1 redimensionne au plus juste la mémoire alloué par les variables après modification du nombre d'entités
  • Dans Aleph, détruit les communicateurs MPI dans le destructeur de AlephKernel. Cela avait désactivé pour des raisons de compatibilité avec PETSc et d'anciennes versions de MPI.

Arcane Version 2.16.0 (18 juillet 2019)

Cette version comporte les développements suivants:

  • Ajout du profiling interne pour les points d'entrée et les appels MPI. Le format des traces dépend de la valeur de la variable d'environnement qui active cette fonctionnalité : ARCANE_MESSAGE_PASSING_PROFILING=OTF2 ou JSON (cf doc variable environnement et analyse de performances).
  • Refonte du wrapper C#. Le wrapper est maintenant composé de plusieurs modules (Arcane.Core, Arcane.Hdf5 et Arcane.Services) et les méthodes wrappées utilisent maintenant les règles de codage du C#: elles commencent par une majuscule.
  • ajout d'une classe Arcane::MeshHandle pour gérer les maillages avant leur création effective. A terme cela permettra de supprimer des maillages et de les créer via des services.

Arcane Version 2.15.0 (13 juin 2019)

Cette version comporte les développements suivants:

  • Support pour les messages MPI de plus de 2Go. Cela ne concerne que les message de type MPI_Send/MPI_Recv et uniquement si on passe par Arcane::ISerializer.
  • Complète l'implémentation de Arcane::IParallelMng en mode mémoire partagée. Toutes les méthodes à part Arcane::IParallelMng::createSubParallelMng() sont implémentées. Les classes gérant ce mode de parallélisme sont renommées et commencent par SharedMemory au lieu de Thread.
  • Renommage des classes gérant les échanges de message en mode MPI+Mémoire partagée. Ces classes ont un nom qui commence par Hybrid au lieu de MpiThread.
  • Support de .NetCore en plus de mono pour la gestion des fichiers AXL. Les projets gérant les fichiers AXL peuvent donc utiliser soit le .NetFramework 4.5 (avec mono), soit .NetCoreApp 2.2 (avec .NetCore). Il est maintenant indispensable d'avoir l'outil msbuild pour compiler avec mono. Par défaut, c'est l'implémentation .NetCore qui est utilisée.
  • la classe Arccore::String considère maintenant que les arguments de type const char* sont encodés en UTF-8 et plus en ISO-8859-1.
  • la classe Arccore::String gère maintenant en interne les chaînes de caractères de plus de 2Go. Par conséquent, la méthode Arccore::String::len() devient obsolète et doit être remplacée par la méthode Arccore::String::length() qui retourne un Int64.
  • Il est maintenant possible de construire des instances de Arccore::String à partir de la classe std::string_view du C++17. Par conséquent, les méthodes de Arccore::String qui prenaient un const char* et une longueur en argument devient obsolètes et sont remplacées par des méthodes prenant des std::string_view en argument.
  • un mode reproductible pour ParMetis a été développé qui permet de garantir le même partitionnement entre deux exécutions en regroupant le graphe sur un seul processeur. Ce mode ne doit pas être utilisé lorsque le nombre de mailles est supérieur à quelques dizaines de millions.

Arcane Version 2.14.0 (04 mars 2019)

Cette version comporte les développements suivants:

  • intégration des développements IFPEN concernant les entités de type degré de liberté (classe Arcane::DoF).
  • possibilité de rediriger les sorties listing à la fois sur le flot standard (stdout) et dans un fichier avec la possibilité de ne pas avoir des niveaux de verbosité différents. Suite à ce changement, si la variable d'environnement ARCANE_PARALLEL_OUTPUT est positionnée alors le sous-domaine 0 écrit le listing dans un fichier comme les autres sous-domaine (les fichiers s'appellent output...). Pour spécifier qu'on souhaite écrire un fichier listing il faut positionner la variable d'environnement ARCANE_MASTER_HAS_OUTPUT_FILE ou appeler la méthode Arcane::ITraceMngPolicy::setIsMasterHasOutputFile() avant l'initilisation (par exemple en surchargeant Arcane::MainFactory).
  • passage en UTF-8 de toutes les sources (Arcane,Arccore,...)
  • déplacement des sources de 'arccore' dans son propre dépôt GIT et déplacement des sources de arcane/dof dans arcane/mesh

Arcane Version 2.13.0 (21 janvier 2019)

Cette version comporte les développements suivants:

  • [INCOMPATIBILITÉ] Modification des méthodes begin() et end() pour les classes tableaux et vues sur les tableaux (Arccore::ArrayView, Arccore::ConstArrayView, Arccore::Span, Arccore::Array) afin de retourner un itérateur et plus un pointeur. Si on souhaite récupérer un pointeur, il faut utiliser la méhode data() à la place.
  • [INCOMPATIBILITÉ] Interdit la création d'instances de la classe Arccore::Array. Il faut utiliser soit Arccore::UniqueArray, soit Arccore::SharedArray. La classe Arccore::Array doit être utilisée par référence en argument ou en retour de fonction.
  • Passage partiel des sources de Arcane UTF-8
  • Passage à la version 1.10+ de HDF5 (au lieu de 1.8)
  • Support des maillages au format MED (format utilisé par CEA/DEN notamment par la plateforme Salomé)
  • Modification du générateur 'axldoc' pour génèrer des fichiers Doxygen au format Markdown avec l'extension '.md' au lieu de fichiers .dox

Arcane Version 2.12.0 (11 décembre 2018)

Cette version comporte les développements suivants:

  • amélioration de la visualisation des variables avec les dernières versions de totalview et ajout de la visualisation pour les variables scalaires
  • création d'une classe Arccore::Span2 pour gérer les vues sur les tableaux 2D avec les tailles sur 64bits.
  • refonte interne des protections/reprises pour permettre de changer le nombre de sous-domaines en reprise.

Arcane Version 2.11.0 (18 octobre 2018)

Cette version comporte les développements suivants:

  • Support des tableaux (Arccore::Array) et chaînes de caractères (Arccore::String) dépassant 2Go. En interne, le nombre d'éléments est maintenant stocké sur 64bits au lieu de 32bits.
  • Ajout des classes 'LargeArrayView' et 'ConstLargeArrayView' qui sont identiques à 'ArrayView' et 'ConstArrayView' mais utilisent une taille sur 64 bits.

Arcane Version 2.10.1 (04 octobre 2018)

Cette version comporte les développements suivants:

  • Possibilité de spécifier plusieurs interfaces pour les services via la macro ARCANE_REGISTER_SERVICE(). Auparavant cela n'était possible que via les fichiers 'axl'.
  • Les services singletons qui implémentent plusieurs interfaces ne sont créés qu'une seule fois et les interfaces font donc référence à la même instance. Auparavant, il y a avait autant d'instances que d'interfaces.
  • Il est possible de spécifier dans le fichier 'axl' qu'un service est singleton (voir Descripteur de service).
  • Possibilité de spécifier des valeurs par défaut par catégorie via un nouvel élément defaultvalue dans les fichiers 'axl'. La catégorie utilisée lors de l'exécution peut être positionnée pour chaque code via la méthode Arcane::ICaseDocument::setDefaultCategory(). La page Structure du fichier indique comment ajouter ces valeurs par défaut.
  • Possibilité de charger des services singleton dans le jeu de données à la manière des modules via un nouvel élément services dans l'élément <arcane> (voir Élément <arcane>).

Arcane Version 2.10.0 (septembre 2018)

Cette version comporte les développements suivants:

  • Création d'une nouvelle composante 'Arccore' regroupant la partie de Arcane commune avec Alien. Cette composante contient une partie de 'arcane_utils' et 'arcane_mpi'. Par conséquent, les classes de base telles que Arccore::String, Arccore::ArrayView, Arccore::Array sont maintenant dans le namespace 'Arccore' au lieu de 'Arcane'. Via le mécanisme 'using' du C++ ces classes sont aussi disponibles dans le namespace Arcane et il ne devrait donc pas y avoir d'incompatibilité avec le code source existant. La seule condition est de ne pas déclarer explicitement les types Arcane mais d'utiliser le fichier d'en-tête 'arcane/utils/UtilsTypes.h'.
  • Utilisation de la bibliothèque 'libxml2' pour gérer le XML au lieu de la bibliothèque 'XercesC'. Cette modification a été effectuée pour deux fonctionnalités qui ne sont pas disponibles dans 'XercesC': le support de XInclude avec XmlSchema et l'encodage UTF-8 des chaînes de caractères.
  • Rend obsolète la construction de 'Arccore::Array'. Il faut explicitement utiliser soit 'Arccore::UniqueArray', soit 'Arccore::SharedArray'.
  • Sépare l'implémentation de Arccore::UniqueArray de celle de Arccore::SharedArray pour éviter de conserver des informations qui ne sont utiles que pour l'une ou l'autre de ces classes.
  • Possibilité de spécifier un nombre de threads compris en 1 et le nombre maximum de threads alloué lors d'une boucle parallèle Arcane::Parallel::ForEach. Cela se fait via la classe Arcane::ParallelLoopOptions.
  • Le fichier 'arcane.pc' généré pour pkg-config est obsolète et ne contient plus toutes les bibliothèques utilisées par Arcane. Pour avoir une fonctionnalité équivalente, il faut utiliser 'cmake' avec l'option '–find-package'.
  • Refonte de la gestion des itérateurs sur les classes tableaux (Arccore::Array, Arccore::ArrayView, Arccore::ConstArrayView). Les itérateurs actuels qui retournaient un pointeur sont déclarés obsolète et remplacés par un objet du type Arccore::ArrayIterator. Le fait de retourner un pointeur pouvait poser problème en cas d'héritage. Par exemple:
    class A { ... };
    class B : public A { ... };
    Arcane::Array<B*> array_of_b;
    for( A* a : array_of_b){
    // Plantage si sizeof(A)!=sizeof(B)
    }
    Classe de base des vecteurs 1D de données.
    Le nouvel itérateur est partagé entre les trois classes tableaux et est du type std::random_iterator. Suivant les cas d'utilisation, le code actuel peut-être changé comme suit:

Arcane Version 2.9.1 (juin 2018)

Cette version comporte les développements suivants:

  • Possiblité de changer les valeurs par défaut des options du jeu de données. Pour plus d'informations, se reporter à la section Gestion des valeurs par défaut.
  • Ajoute méthode valueIfPresentOrArgument() pour les options simples, énumérées ou étendues. Cela permet de remplacer le code suivant:
    Real x = 3.2;
    if (options()->myOption.isPresent())
    x = options()->myOptions();
    par le code suivant:
    Real x = options()->myOption.valueIfPresentOrArgument(3.2);
  • Support 64 bits pour l'échangeur de particule non bloquant (service NonBlockingParticleExchanger implémentant Arcane::IParticleExchanger). Cela permet de dépasser 2^31 particules lors d'un échange.
  • Ajoute méthode Arcane::ITimeLoopMng::stopReason() permettant de connaitre la raison de l'arrêt du code. En particulier, il est maintenant possible de savoir si on exécute la dernière itération lorsqu'un nombre maximum d'itération est spécifié.
  • Dans le jeu de données, dans la liste des modules à activer, il est maintenant possible de spécifier le nom (traduit ou nom) de l'élément XML du Module au lieu du nom du module. Par exemple, pour le module de protection/reprise de Arcane, dont le nom est 'ArcaneCheckoint', on a actuellement:
    <cas codename="ArcaneTest" xml:lang="fr" codeversion="1.0">
    <arcane>
    <modules>
    <module name="ArcaneCheckpoint" actif="true" />
    </modules>
    </arcane>
    ...
    <arcane-protections-reprises>
    <periode>3</periode>
    </arcane-protections-reprises>
    </cas>
    et maintenant il est possible de le remplacer par:
    <cas codename="ArcaneTest" xml:lang="fr" codeversion="1.0">
    <arcane>
    <modules>
    <module name="arcane-protections-reprises" actif="true" />
    </modules>
    </arcane>
    ...
    <arcane-protections-reprises>
    <periode>3</periode>
    </arcane-protections-reprises>
    </cas>

Arcane Version 2.8.0 (31 janvier 2018)

Cette version comporte les développements suivants:

  • Ajout pour les tests unitaires de deux macros ASSERT_NEARLY_ZERO et ASSERT_NEARLY_ZERO_EPSILON qui permettent de comparer avec zéro une valeur.
  • Détermination lors de la compilation des types 'Arcane::Int16', 'Arcane::Int32' et 'Arcane::Int64'. A cause de cela, le fichier 'ArcaneGlobal.h' n'inclut plus le fichier 'limits.h'.
  • Par défaut, les unités de longueur spécifiées dans les fichiers au format Lima (.unf, .mli, ...) sont maintenant toujours prises en compte. Auparavant, il fallait mettre la valeur 1 à l'attribut 'use-unit' (en anglais) ou 'utilise-unite' (en francais) dans l'élément <mesh> (en anglais) ou <maillage> (en francais). Pour retrouver le comportement d'avant, il faut mettre la valeur '0' à cet attribut. Par exemple en francais:

    <maillage utilise-unite="0">
    ...
    </maillage>

    ou en anglais:

    <mesh use-unit="0">
    ...
    </mesh>

Arcane Version 2.7.0 (20 octobre 2017)

Cette version comporte les développements suivants sur les matériaux et les milieux:

  • possibilité d'itérer uniquement sur les mailles pures ou impures d'un matériau ou d'un milieu.
  • nouveaux mécanismes pour boucler sur les matériaux et les milieux
  • début du support de la vectorisation sur les matériaux et les milieux. Pour l'instant ce supporte concerne seulement les variables scalaires et uniquement sur les milieux.

Pour plus d'informations sur ces notions, se référer à la page Boucles sur les entités des matériaux et des milieux.


Arcane Version 2.6.1 (18 septembre 2017)

Cette version comporte les développements visibles suivants:

  • dans les options du jeu de données, ne tolère plus les caractères invalides en fin de chaîne de caractères de l'option. Par exemple, la chaîne '12a3' était considérée comme valide pour une option de type entier et sa valeur était '12'. Maintenant une erreur est retournée dans ce cas.

Cette version comporte des développements internes visant à terme à supprimer les anciens mécanismes d'accès aux connectivités.


Arcane Version 2.6.0 (22 aout 2017)

Cette version met en service le nouveau mécanisme d'accès aux connectivités. L'ancien mécanisme reste accessible. Les deux mécanismes utilisants des gestions de la mémoire différents, les connectivités sont donc allouées à la fois avec le nouveau et l'ancien mécanisme ce qui se traduit par une augmentation de la mémoire d'environ 1ko par maille. Pour plus d'informations, se reporter à la page Gestion des connectivités des entités.


Arcane Version 2.5.2 (25 juillet 2017)

Cette version contient les développements suivants:


Arcane Version 2.5.1 (04 mai 2017)

Cette version contient uniquement des développements internes et n'ajoute pas de fonctionnalités directement accessibles aux utilisateurs.


Arcane Version 2.5.0 (15 mars 2017)

Cette version intègre les développements pour découpler la gestion des connectivités de celle des entités. Pour des raisons d'économie mémoire, le mécanisme actuel permet d'avoir toutes les connectivités disponibles pour chaque type entité. Potentiellement, cela signifie par exemple qu'une particule et une maille peuvent avoir les mêmes connectivités. Pour plus d'informations sur les nouveaux mécanismes, se reporter à la page suivante Gestion des connectivités des entités. Dans cette version 2.5.0, les nouvelles connectivités ne sont pas actives (ce qui correspond au mode de configuration '–with-legacy-connectivity' décrit dans la page du lien précédent) donc le comportement des codes utilisant Arcane ne devraient pas changer.

Les autres nouvelles fonctionnalités sont:


Arcane Version 2.4.2 (13 Janvier 2017)


Arcane Version 2.4.1 (01 Décembre 2016)

  • Support de la méthode Arcane::MeshMaterialVariableRef::synchronize() pour les variables uniquement sur les milieux.
  • Ajoute une méthode sur les variables matériaux pour remplir les valeurs partielles avec la valeur de la maille du composant supérieur. Cela permet de remplir les valeurs matériaux avec les valeurs milieux ou les valeurs milieux avec les valeurs globales. La méthode s'appelle Arcane::Materials::MeshMaterialVariableRef::fillPartialValuesWithSuperValues().
  • Ajoute les itérateurs STL constants pour la classe Arcane::ItemVectorView. Cela permet d'utiliser les algorithmes de la STL avec cette classe. Par exemple:
    using namespace Arcane;
    ItemGroup group1;
    ItemVectorView group_view = group1.view();
    for( Item item : v1.view() ){
    // Regarde si 'item' est dans le groupe 'group1'.
    auto iter = std::find(group_view.begin(),group_view().end,item);
    if (iter!=group_view.end()){
    // Trouvé.
    }
    }
    for( Item item : group1.view() ){
    info() << "Item=" << ItemPrinter(item);
    }
    Groupe d'entités de maillage.
    Definition ItemGroup.h:49
    ItemVectorView view() const
    Vue sur les entités du groupe.
    Definition ItemGroup.cc:582
    Classe utilitaire pour imprimer les infos sur une entité.
    Definition ItemPrinter.h:35
    Vue sur un vecteur d'entités.
    Vecteur d'entités.
    Definition ItemVector.h:59
    Classe de base d'un élément de maillage.
    Definition Item.h:83
  • Ajoute la possibilité de spécifier sa propre fonction de calcul des connectivités pour les Arcane::ItemPairGroup. La documentation de la classe ItemPairGroup contient un exemple d'un tel calcul
  • Ajoute dans les services de partitionnement plusieurs options:
    • pour Parmetis la possibilité d'écrire le graphe sur un fichier et de spécifier la tolérance,
    • pour PTScotch la possibilité d'écrire le graphe sur un fichier et de vérifier la cohérence du graphe.

Arcane Version 2.4.0 (Novembre 2016)

  • Support des variables uniquement sur les milieux. Ces variables s'utilisent comme les variables matériau mais n'ont de valeurs que sur les milieux et les mailles globales. Il ne faut donc pas les indexer avec des mailles matériaux (MatCell) sous peine de provoquer un accès mémoire illégal. La déclaration de ces variables se fait comme suit:
    using namespace Arcane;
    IMeshEnvironment* env = ...;
    ENUMERATE_ENVCELL(ienvcell,env){
    pressure[ienvcell] = 2.0;
    }
    Paramètres nécessaires à la construction d'une variable.
    #define ENUMERATE_ENVCELL(iname, env)
    Macro pour itérer sur toutes les mailles d'un milieu.
  • Support du repartitionnement et de l'équilibrage de charge en conservant les informations des matériaux. Les valeurs partielles des mailles matériaux et milieux sont aussi conservées.
  • Refonte interne de la gestion des échanges des entités lors d'un repartitionnement. Le but est de pouvoir ajouter plus facilement de nouvelles familles d'entités où de changer le traitement de l'un d'elle. Cette modification n'a aucun impact sur le code existant.

Arcane Version 2.3.9 (Septembre 2016)

  • Amélioration de la vectorisation {#arcanedoc_news_changelog_version239_simd}
  • Possibilité de choisir un allocateur spécifique (implémentant l'interface IMemoryAllocator) pour les classes Array et UniqueArray. Une implémentation gérant l'alignement (Arcane::AlignedMemoryAllocator) est disponible et permet de garantir que l'adresse de la mémoire allouée est un multiple d'une certaine valeur. Pour l'instant la seule valeur valide pour l'alignement est 64 et il faut utiliser l'allocateur Arcane::AlignedMemoryAllocator::Simd() pour récupérer cet l'allocateur avec cet alignement. En plus d'aligner la mémoire, cet allocateur garantit que la taille dela mémoire allouée est un multiple de l'alignement. Par exemple, le code suivant garantit un alignement:
    using namespace Arcane;
    UniqueArray<Real> x(AlignedMemoryAllocator::Simd());
    x.resize(25);
    // &x[0] est un multiple de 64.
    // Un réel faisant 8 octets, la capacité de x est un
    // multiple de (64 / 8), soit x.capacity()>=32 (car 32 est le
    // premier multiple de 8 supérieur à 25).
    Vecteur 1D de données avec sémantique par valeur (style STL).
    L'alignement de 64 octets permet d'utiliser tous les mécanismes de vectorisation disponibles à ce jour dans Arcane, soit SSE, AVX et AVX512.
  • Les variables tableaux 1D et 2D ainsi que les variables scalaires et tableau sur les entités du maillage sont maintenant toujours allouées avec l'allocateur Arcane::AlignedMemoryAllocator::Simd().
  • Les indices des entités d'un ItemGroup sont maintenant toujours alloués avec l'allocateur Arcane::AlignedMemoryAllocator::Simd(). A noter que ce n'est pas le cas de Arcane::ItemVector.
  • Les différentes macros utilisées pour gérer l'enumération avec la vectorisation (ENUMERATE_SIMD_CELL, ENUMERATE_SIMD_NODE, ...) nécessitent maintenant des tableaux alignés. Si ce n'est pas le cas, cela provoque une exception lors de l'exécution.
    using namespace Arcane;
    CellGroup cells = ...;
    CellVector vec_cells = ...;
    ENUMERATE_SIMD_CELL(ivcell,cells){ // OK car un CellGroup est toujours aligné
    }
    ENUMERATE_SIMD_CELL(ivcell,vec_cells){ // ERREUR car un CellVector n'est pas toujours aligné
    }
    #define ENUMERATE_SIMD_CELL(name, group)
    Enumérateur SIMD sur un groupe ou liste de mailles.
    Definition SimdItem.h:579
    ItemVectorT< Cell > CellVector
    Vecteur de mailles.
    Definition ItemTypes.h:599
  • L'utilisation des méthodes Parallel::Foreach() sur les groupes d'entités garantit que les itérations se feront sur des multiples de 8 valeurs. Il est ainsi valide d'écrire le code suivant:
    using namespace Arcane;
    CellGroup cells = ...;
    Parallel::Foreach(cells,[this](CellVectorView cvv){
    ENUMERATE_SIMD_CELL(ivcell,cvv){
    SimdCell cell = *ivcell;
    ...
    }
    }
    Vue sur un tableau typé d'entités.
    SimdItemT< Cell > SimdCell
    Vecteur SIMD de Cell.
    Definition SimdItem.h:504
  • Ajoute le support pour la vectorisation de type AVX512 et supprime la vectorisation spécifique aux processeurs Intel Knight Corner (KNC). L'AVX512 est supportée à partir des Xeon Skylake et sur les processeurs de XeonPhi à partir de l'Intel Knight Landing (KNL).
  • Autorise plusieurs types de vectorisation à la fois via les classes de vectorisation de Arcane. Par exemple, sur les machines haswell qui supportent l'AVX et le SSE les classes SSESimdReal et AVXSimdReal sont toujours disponibles. Dans les versions précédentes de Arcane, seul le type de vectorisation le plus performant était disponible (AVX512 > AVX > SSE).

Améliorations diverses {#arcanedoc_news_changelog_version239_misc}

  • Support de la sémantique std::move() du C++11 pour la classe UniqueArray. Cela permet entre autre de retourner des UniqueArray sans faire de recopie mémoire, d'implémenter std::swap() de manière optimisée.
  • Ajoute de versions optimisées pour échanger les valeurs de deux variables du maillage (scalaire ou tableau) via une méthode swapValues(). Cette méthode permet d'échanger juste les pointeurs contenant les zones mémoires des deux variables sans recopie. Par exemple
    using namespace Arcane;
    VariableCellReal temperature = ...;
    VariableCellReal old_temperature = ...;
    VariableCellArrayReal energy = ...; // Variable 1D sur les mailles
    VariableCellArrayReal old_energy = ...;
    old_temperature.swapValues(temperature);
    old_energy.swapValues(energy);
    MeshVariableArrayRefT< Cell, Real > VariableCellArrayReal
    Grandeur au centre des mailles de type tableau de réel.
  • Passage à la version 1.11.4 de hwloc.
  • [C#] Dans Arcane.Curves, support des courbes avec plusieurs valeurs par itération (courbes 2D).
  • Utilise le temps réel (elapsed) au lieu du temps CPU pour les statistiques de fin de calcul. Le temps réel est plus précis que le temps CPU et est indépendant du nombre de threads utilisés. Il est possible de remettre l'utilisation du temps CPU en positionnant la variable d'environnement ARCANE_USE_VIRTUAL_TIMER.