11#ifndef _HYODA_PLUGIN_MATERIALS_H_
12#define _HYODA_PLUGIN_MATERIALS_H_
14#include "arcane/IApplication.h"
15#include "arcane/IParallelMng.h"
17#include "arcane/AbstractService.h"
18#include "arcane/FactoryService.h"
20#include "arcane/IVariableMng.h"
21#include "arcane/SharedVariable.h"
22#include "arcane/CommonVariables.h"
24#include "arcane/IMesh.h"
25#include "arcane/IItemFamily.h"
27#include "arcane/materials/IMeshMaterialMng.h"
28#include "arcane/materials/IMeshMaterial.h"
29#include "arcane/materials/IMeshEnvironment.h"
30#include "arcane/materials/MeshMaterialModifier.h"
31#include "arcane/materials/MeshMaterialVariableRef.h"
32#include "arcane/materials/MaterialVariableBuildInfo.h"
33#include "arcane/materials/MeshEnvironmentBuildInfo.h"
34#include "arcane/materials/CellToAllEnvCellConverter.h"
35#include "arcane/materials/MatItemVector.h"
37#include "arcane/hyoda/Hyoda.h"
38#include "arcane/hyoda/HyodaArc.h"
39#include "arcane/hyoda/HyodaMix.h"
40#include "arcane/hyoda/HyodaIceT.h"
41#include "arcane/hyoda/IHyodaPlugin.h"
63 m_defaultMesh(m_sub_domain->defaultMesh()),
76 debug()<<
"\t[HyodaMats::drawGlobalCell] Cell #"<<cell.
localId();
78 hyoda()->meshIceT()->setColor(min,max,val,rgb);
80 glColor3d(rgb[0], rgb[1], rgb[2]);
81 glVertex2d(m_defaultMesh->nodesCoordinates()[node].x,
82 m_defaultMesh->nodesCoordinates()[node].y);
93 ARCANE_UNUSED(variable);
102 hyodaMix()->setCellOrigin(global_cell);
104 info()<<
"[HyodaMats::draw] aeCell #"
109 info() <<
"[HyodaMats::draw] all_env_cell.nbEnvironment()!=1";
112 info()<<
"\t[HyodaMats::draw] eCell #"
113 << (*ienvcell).globalCell().localId()
114 <<
", nbMaterial=" << (*ienvcell).nbMaterial();
116 if ((*ienvcell).nbMaterial()==1) drawGlobalCell((*ienvcell).globalCell(),
118 mat_density[(*ienvcell).globalCell()]);
122 if ((*ienvcell).nbMaterial()==2
123 && m_interface_normal[global_cell].abs()!=0.
124 && m_interface_distance[global_cell].size()==1
125 && m_interface_distance[global_cell].at(0)!=0.){
126 Int32 rtn=hyodaMix()->xCellPoints(global_cell,
127 m_interface_normal[global_cell],
128 m_interface_distance[global_cell].at(0),0);
129 info()<<
"\t[HyodaMats::draw] Cell #"
130 << global_cell.localId()
132 <<
", mat0="<< mat_density[(*ienvcell).cell(0)]
133 <<
", mat1="<< mat_density[(*ienvcell).cell(1)];
134 hyodaMix()->xCellDrawInterface((*ienvcell).globalCell(),0);
151 IMesh* m_defaultMesh;
#define ARCANE_REGISTER_SUB_DOMAIN_FACTORY(aclass, ainterface, aname)
Enregistre un service de fabrique pour la classe aclass.
AbstractService(const ServiceBuildInfo &)
Constructeur à partir d'un ServiceBuildInfo.
Interface du gestionnaire d'un sous-domaine.
Interface d'une variable.
@ PNoRestore
Indique que la variable ne doit pas être restaurée.
@ PNoDump
Indique que la variable ne doit pas être sauvegardée.
NodeConnectedListViewType nodes() const
Liste des noeuds de l'entité
constexpr Int32 localId() const
Identifiant local de l'entité dans le sous-domaine du processeur.
Maille arcane avec info matériaux et milieux.
__host__ __device__ Int32 nbEnvironment() const
Nombre de milieux présents dans la maille.
Cell globalCell() const
Maille globale.
Interface du gestionnaire des matériaux et des milieux d'un maillage.
static IMeshMaterialMng * getReference(const MeshHandleOrMesh &mesh_handle, bool create=true)
Récupère ou créé la référence associée à mesh.
Classe gérant un vecteur de réel de dimension 3.
ISubDomain * subDomain() const
Accès au ISubDomain associé.
Structure contenant les informations pour créer un service.
TraceMessageDbg debug(Trace::eDebugLevel=Trace::Medium) const
Flot pour un message de debug.
TraceMessage info() const
Flot pour un message d'information.
Paramètres nécessaires à la construction d'une variable.
MeshVariableScalarRefT< Cell, Real3 > VariableCellReal3
Grandeur au centre des mailles de type coordonnées.
MeshVariableArrayRefT< Cell, Real > VariableCellArrayReal
Grandeur au centre des mailles de type tableau de réel.
Active toujours les traces dans les parties Arcane concernant les matériaux.
CellMaterialVariableScalarRef< Real > MaterialVariableCellReal
Variable matériau de type Real
-*- tab-width: 2; indent-tabs-mode: nil; coding: utf-8-with-signature -*-
double Real
Type représentant un réel.
std::int32_t Int32
Type entier signé sur 32 bits.