Arcane  v3.15.0.0
Documentation développeur
Chargement...
Recherche...
Aucune correspondance
UnstructuredMeshUtilities.h
1// -*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
2//-----------------------------------------------------------------------------
3// Copyright 2000-2024 CEA (www.cea.fr) IFPEN (www.ifpenergiesnouvelles.com)
4// See the top-level COPYRIGHT file for details.
5// SPDX-License-Identifier: Apache-2.0
6//-----------------------------------------------------------------------------
7/*---------------------------------------------------------------------------*/
8/* UnstructuredMeshUtilities.h (C) 2000-2024 */
9/* */
10/* Fonctions utilitaires sur un maillage. */
11/*---------------------------------------------------------------------------*/
12#ifndef ARCANE_MESH_UNSTRUCTUREDMESHUTILITIES_H
13#define ARCANE_MESH_UNSTRUCTUREDMESHUTILITIES_H
14/*---------------------------------------------------------------------------*/
15/*---------------------------------------------------------------------------*/
16
17#include "arcane/utils/TraceAccessor.h"
18#include "arcane/core/IMeshUtilities.h"
19
20/*---------------------------------------------------------------------------*/
21/*---------------------------------------------------------------------------*/
22
23namespace Arcane
24{
25
26/*---------------------------------------------------------------------------*/
27/*---------------------------------------------------------------------------*/
28
29class IMesh;
30class ItemPairGroup;
31class ItemPairGroupImpl;
32class BasicItemPairGroupComputeFunctor;
33
34/*---------------------------------------------------------------------------*/
35/*---------------------------------------------------------------------------*/
40: public TraceAccessor
41, public IMeshUtilities
42{
43 public:
44
45 explicit UnstructuredMeshUtilities(IMesh* mesh);
47
48 public:
49
50 void changeOwnersFromCells() override;
51
56 bool allow_null) override;
57
78 const VariableNodeReal3& nodes_coord) override;
79
82 Real3* n1,Real3* n2) override;
83
85 Integer nb_layer) override;
86
87 bool writeToFile(const String& file_name,const String& service_name) override;
88
90 bool initial_partition) override;
91
94
95 private:
96
97 IMesh* m_mesh;
98 BasicItemPairGroupComputeFunctor* m_compute_adjacency_functor;
99
100 private:
101
102 Real3 _round(Real3 value);
103 Real3 _broadcastFarthestNode(Real distance,const Node& node,
105};
106
107/*---------------------------------------------------------------------------*/
108/*---------------------------------------------------------------------------*/
109
110}
111
112/*---------------------------------------------------------------------------*/
113/*---------------------------------------------------------------------------*/
114
115#endif
116
Interface d'un partitionneur de maillage.
Interface d'une classe proposant des fonctions utilitaires sur maillage.
Tableau de listes d'entités.
Lecteur des fichiers de maillage via la bibliothèque LIMA.
Definition Lima.cc:149
Noeud d'un maillage.
Definition Item.h:564
Classe gérant un vecteur de réel de dimension 3.
Definition Real3.h:132
Fonctions utilitaires sur un maillage.
Real3 computeDirection(const NodeGroup &node_group, const VariableNodeReal3 &nodes_coord, Real3 *n1, Real3 *n2) override
Real3 computeNormal(const FaceGroup &face_group, const VariableNodeReal3 &nodes_coord) override
Calcule la normale d'un groupe de face.
~UnstructuredMeshUtilities() override
Libère les ressources.
void partitionAndExchangeMeshWithReplication(IMeshPartitionerBase *partitioner, bool initial_partition) override
Repartitionne et échange le maillage en gérant la réplication.
void mergeNodes(Int32ConstArrayView nodes_local_id, Int32ConstArrayView nodes_to_merge_local_id) override
Fusionne des noeuds.
void computeAdjency(ItemPairGroup adjency_array, eItemKind link_kind, Integer nb_layer) override
Calcul des adjacences, rangées dans adjacency_array.
bool writeToFile(const String &file_name, const String &service_name) override
Ecrit le maillage dans un fichier.
void changeOwnersFromCells() override
Positionne les nouveaux propriétaires des noeuds, arêtes et faces à partir des mailles.
void localIdsFromConnectivity(eItemKind item_kind, IntegerConstArrayView items_nb_node, Int64ConstArrayView items_connectivity, Int32ArrayView local_ids, bool allow_null) override
Recherche les identifiants locaux des entités à partir de leur connectivité.
Vue modifiable d'un tableau d'un type T.
Vue constante d'un tableau de type T.
Chaîne de caractères unicode.
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
eItemKind
Genre d'entité de maillage.