14#define ARCANE_TRACE_ENUMERATOR
16#include "arcane/utils/List.h"
17#include "arcane/utils/OStringStream.h"
18#include "arcane/utils/ValueChecker.h"
19#include "arcane/utils/SimdOperation.h"
21#include "arcane/IUnitTest.h"
22#include "arcane/ITimeLoopMng.h"
23#include "arcane/ITimeLoopService.h"
24#include "arcane/ITimeLoop.h"
25#include "arcane/TimeLoopEntryPointInfo.h"
26#include "arcane/IMesh.h"
27#include "arcane/IItemFamily.h"
28#include "arcane/ItemPrinter.h"
29#include "arcane/IParallelMng.h"
30#include "arcane/IMeshModifier.h"
31#include "arcane/IMeshUtilities.h"
32#include "arcane/IMeshPartitioner.h"
33#include "arcane/VariableDependInfo.h"
35#include "arcane/Concurrency.h"
36#include "arcane/VariableView.h"
38#include "arcane/materials/IMeshMaterialMng.h"
39#include "arcane/materials/IMeshMaterial.h"
40#include "arcane/materials/IMeshEnvironment.h"
41#include "arcane/materials/IMeshBlock.h"
42#include "arcane/materials/MeshMaterialModifier.h"
43#include "arcane/materials/MeshMaterialVariableRef.h"
44#include "arcane/materials/MeshEnvironmentVariableRef.h"
45#include "arcane/materials/MaterialVariableBuildInfo.h"
46#include "arcane/materials/MeshBlockBuildInfo.h"
47#include "arcane/materials/MeshEnvironmentBuildInfo.h"
48#include "arcane/materials/MeshMaterialVariableDependInfo.h"
49#include "arcane/materials/CellToAllEnvCellConverter.h"
50#include "arcane/materials/MatCellVector.h"
51#include "arcane/materials/EnvCellVector.h"
52#include "arcane/materials/MatConcurrency.h"
53#include "arcane/materials/MeshMaterialIndirectModifier.h"
54#include "arcane/materials/MeshMaterialVariableSynchronizerList.h"
56#include "arcane/materials/MeshMaterialInfo.h"
58#include "arcane/tests/ArcaneTestGlobal.h"
59#include "arcane/tests/IMaterialEquationOfState.h"
60#include "arcane/tests/MeshMaterialTester_axl.h"
63#include "arcane/tests/StdMeshVariables.cc"
75using namespace Arcane;
101class MeshMaterialTesterModule
102:
public ArcaneMeshMaterialTesterObject
107 ~MeshMaterialTesterModule();
115 void buildInit()
override;
116 void compute()
override;
117 void startInit()
override;
118 void continueInit()
override;
141 Integer m_check_spectral_values_iteration;
144 void _computeDensity();
148 bool is_compute_mat);
153 void _checkTemporaryVectors(
const CellGroup& test_group);
154 void _checkSubViews(
const CellGroup& test_group);
155 void _dumpAverageValues();
156 void _dumpNoDumpRealValues();
159 void _setDependencies();
160 void _doDependencies();
168 void _checkArrayVariableSynchronize();
169 void _setOrCheckSpectralValues(
Int64 iteration,
bool is_check);
170 template<
typename VarType1,
typename VarType2,
typename VarType3>
void
171 _setOrCheckSpectralValues2(VarType1& var_real,VarType2& var_int32,
172 VarType3& var_scalar_int32,
Int64 iteration,
bool is_check);
173 void _checkFillPartialValues();
175 template<
typename VarType>
void _checkFillPartialValuesHelper(VarType& mat_var);
176 template<
typename VarType>
177 void _checkFillPartialValuesWithGlobal(
const VarType& var_type,
MeshComponentList components);
178 template<
typename VarType>
void
179 _checkFillPartialValuesWithSuper(
const VarType& var_type,
MeshComponentList components);
180 template<
typename VarType>
void
181 _fillVar(VarType& var_type,
Real base_value);
182 template<
typename VectorType>
void
183 _checkVectorCopy(VectorType& var_type);
185 void _initUnitTest();
187 void _testDumpProperties();
188 void _checkNullComponentItem();
197MeshMaterialTesterModule::
199: ArcaneMeshMaterialTesterObject(mbi)
212, m_mesh_partitioner(nullptr)
213, m_check_spectral_values_iteration(0)
220MeshMaterialTesterModule::
221~MeshMaterialTesterModule()
230void MeshMaterialTesterModule::
233 String time_loop_name(
"MeshMaterialTestLoop");
239 List<TimeLoopEntryPointInfo> clist;
240 clist.add(TimeLoopEntryPointInfo(
"MeshMaterialTester.buildInit"));
245 List<TimeLoopEntryPointInfo> clist;
246 clist.add(TimeLoopEntryPointInfo(
"MeshMaterialTester.startInit"));
247 clist.add(TimeLoopEntryPointInfo(
"MeshMaterialTester.continueInit"));
252 List<TimeLoopEntryPointInfo> clist;
253 clist.add(TimeLoopEntryPointInfo(
"MeshMaterialTester.compute"));
259 clist.add(
"MeshMaterialTester");
262 clist.add(
"ArcanePostProcessing");
263 clist.add(
"ArcaneCheckpoint");
273void MeshMaterialTesterModule::
279 info() <<
"MESH_MATERIAL_TESTER :: buildInit()";
283 m_material_mng->setModificationFlags(options()->modificationFlags());
285 m_material_mng->setMeshModificationNotified(
true);
288 if (parallelMng()->isParallel())
289 m_material_mng->setAllocateScalarEnvironmentVariableAsMaterial(
true);
291 if (subDomain()->isContinue() && options()->recreateFromDump()){
295 UniqueArray<MeshMaterialInfo*> materials_info;
297 for(
Integer i=0,n=options()->material().size(); i<n; ++i ){
298 String mat_name = options()->material[i].name;
299 info() <<
"Found material name=" << mat_name;
303 MeshBlockBuildInfo mbbi(
"BLOCK1",allCells());
304 UniqueArray<IMeshEnvironment*> saved_envs;
307 for(
Integer i=0,n=options()->environment().size(); i<n; ++i ){
308 String env_name = options()->environment[i].name;
309 info() <<
"Found environment name=" << env_name;
310 Materials::MeshEnvironmentBuildInfo env_build(env_name);
311 for(
Integer k=0,kn=options()->environment[i].material.size(); k<kn; ++k ){
312 String mat_name = options()->environment[i].material[k];
313 info() <<
"Add material " << mat_name <<
" for environment " << env_name;
314 env_build.addMaterial(mat_name);
320 info() <<
"Add environment " << env_name <<
" to block1";
321 mbbi.addEnvironment(env);
333 MeshBlockBuildInfo mbbi2(
"BLOCK2",allCells());
334 mbbi2.addEnvironment(saved_envs[0]);
338 info() <<
"Finished incremental creation of block";
340 if (nb_env2!=(nb_env1+1))
345 IMeshEnvironment* first_env = block2->
environments()[0];
346 IMeshEnvironment* second_env = block2->
environments()[1];
349 if (nb_env2!=nb_env1)
356 mm->
endCreate(subDomain()->isContinue());
358 info() <<
"List of materials:";
359 for( MeshMaterialInfo* m : materials_info ){
360 info() <<
"MAT=" << m->name();
361 for( String s : m->environmentsName() )
362 info() <<
" In ENV=" << s;
367 ConstArrayView<Materials::IMeshEnvironment*> envs = mm->
environments();
373 m_global_deltat.assign(1.0);
375 for(
Integer i=0, n=m_material_mng->materials().size(); i<n; ++i ){
376 IMeshMaterial* mat = m_material_mng->materials()[i];
378 m_density_post_processing.add(var);
383 info() <<
"Activating load balance test";
389template<
typename ContainerType>
void MeshMaterialTesterModule::
393 var[igencell] = value;
400void MeshMaterialTesterModule::
405 info() <<
"MESH_MATERIAL_TESTER :: startInit()";
406 m_material_mng->forceRecompute();
408 ValueChecker vc(A_FUNCINFO);
416 IParallelMng* pm = parallelMng();
421 if (cell_index>(total_nb_cell/2))
423 if (cell_index<(total_nb_cell/5)){
424 env1_indexes.
add(icell.itemLocalId());
426 if (cell_index<(total_nb_cell/3) && cell_index>(total_nb_cell/6)){
427 mat2_indexes.
add(icell.itemLocalId());
429 if ((cell_index%2)==0)
430 sub_group_indexes.
add(icell.itemLocalId());
435 Materials::MeshMaterialModifier modifier(m_material_mng);
436 modifier.setDoCopyBetweenPartialAndPure(
false);
437 modifier.setDoInitNewItems(
false);
438 modifier.setPersistantWorkBuffer(
false);
439 Materials::IMeshEnvironment* env = m_mat1->environment();
445 for(
Integer z=0; z<nb_cell; ++z ){
446 bool add_to_mat1 = (z<(nb_cell/2) && z>(nb_cell/4));
447 bool add_to_mat2 = (z>=(nb_cell/2) || z<(nb_cell/3));
449 mat1_indexes.
add(env1_indexes[z]);
452 mat2_indexes.
add(env1_indexes[z]);
455 modifier.addCells(m_mat1,mat1_indexes);
459 modifier.addCells(env->
materials()[1],mat2_indexes);
461 CellGroup test_group = defaultMesh()->cellFamily()->createGroup(
"SUB_GROUP_TEST",sub_group_indexes);
464 Materials::MeshMaterialModifier modifier(m_material_mng);
466 modifier.addCells(m_mat2,mat2_indexes);
469 const Integer spectral_size = 5;
470 m_mat_spectral1.resize(spectral_size);
471 m_mat_spectral2.resize(spectral_size*2);
472 m_env_spectral1.resize(spectral_size*3);
473 m_env_spectral2.resize(spectral_size*4);
478 m_mat_density.fillPartialValues(3.0);
479 m_env_int32.fillPartialValues(5);
480 m_mat_int32.fillPartialValues(8);
482 info() <<
"Liste des mailles de test_group";
484 info(6) <<
"Cell=" << ItemPrinter(*icell);
488 m_density[icell] = 1.0;
489 m_mat_density[icell] = 2.0;
490 Integer idx2 = icell.itemLocalId() % spectral_size;
491 m_mat_spectral1[icell][idx2] = 3.0 + (
Real)(icell.itemLocalId() * spectral_size);
496 m_density[icell] = 2.0;
500 info() <<
"GVAR_NAME = " << gvar.
name();
502 if (gvar[icell]!=2.0)
503 fatal() <<
"Bad value for global variable v=" << gvar[icell];
510 m_density[icell] = 1.5;
514 _checkTemporaryVectors(test_group);
515 _checkSubViews(test_group);
519 m_material_mng->dumpInfos(oss());
526 m_present_material.fill(0);
527 m_mat_density.fill(0.0);
530 constexpr IMeshMaterial* null_mat =
nullptr;
531 constexpr IMeshEnvironment* null_env =
nullptr;
535 IMeshEnvironment* env = *ienv;
536 info() <<
"ENV name=" << env->
name();
538 vc.areEqual(env->
isMaterial(),
false,
"IsEnvMatOK");
540 vc.areEqual(env->
asMaterial(),null_mat,
"ToEnvMatOK");
542 Materials::IMeshMaterial* mat = *imat;
543 info() <<
"MAT name=" << mat->
name();
545 vc.areEqual(mat->
isMaterial(),
true,
"IsMatMatOK");
547 vc.areEqual(mat->
asMaterial(),mat,
"ToMatMatOK");
549 MatCell mmcell = *icell;
551 m_mat_density[mmcell] = 200.0;
553 ComponentCell x1(mmcell);
555 ARCANE_FATAL(
"Bad convertsion MatCell -> ComponentCell");
557 if (x1._varIndex()!=x2._varIndex())
558 ARCANE_FATAL(
"Bad convertsion ComponentCell -> MatCell");
565 IMeshEnvironment* env = *ienv;
566 info() <<
"BLOCK_ENV name=" << env->
name();
568 Materials::IMeshMaterial* mat = *imat;
569 info() <<
"BLOCK_MAT name=" << mat->
name();
575 IMeshComponent* cmp = *icmp;
576 info() <<
"ENV COMPONENT name=" << cmp->
name();
581 IMeshComponent* cmp = *icmp;
582 info() <<
"MAT COMPONENT name=" << cmp->
name();
587 Materials::IMeshMaterial* mat = *imat;
588 info() <<
"MAT name=" << mat->
name()
589 <<
" density_var_name=" << m_mat_density.materialVariable()->materialVariable(mat)->name();
591 MatCell mmcell = *icell;
592 m_mat_density[mmcell] = 200.0;
599 IMeshEnvironment* env = *ienv;
600 info() <<
"Env name=" << env->
name();
602 EnvCell ev = *ienvcell;
603 info() <<
"EnvCell nb_mat=" << ev.nbMaterial() <<
" cell_uid=" << ItemPrinter(ev.
globalCell())
611 CellToAllEnvCellConverter all_env_cell_converter(m_material_mng);
615 if (!back_cell.
null()){
616 AllEnvCell all_env_back_cell = all_env_cell_converter[back_cell];
618 ComponentCell x1 = all_env_back_cell;
621 ARCANE_FATAL(
"Bad convertsion AllEnvCell -> ComponentCell");
623 ARCANE_FATAL(
"Bad convertsion ComponentCell -> EnvCell");
630 AllEnvCell all_env_cell = *iallenvcell;
633 Real env_density = 0.0;
635 MatCell mc = *imatcell;
636 env_density += m_mat_density[imatcell];
638 m_present_material[global_cell] = m_present_material[global_cell] | (1<<idx);
640 m_mat_density[ienvcell] = env_density;
647 AllEnvCell all_env_cell = *iallenvcell;
650 EnvCell ec = *ienvcell;
651 info() <<
"Cell nb_mat=" << ec.nbMaterial()
655 MatCell mc = *imatcell;
658 <<
" density=" << m_mat_density[imatcell]
663 for( ComponentCell mc : ec.
subItems()){
666 <<
" density=" << m_mat_density[mc]
675 ComponentCell ec = *ienvcell;
676 info() <<
"Cell nb_mat=" << ec.
nbSubItem()
682 const bool test_depend =
false;
685 m_mat_density.addDependCurrentTime(m_density);
686 m_mat_density.addDependCurrentTime(m_mat_density2);
687 m_mat_density.addDependPreviousTime(m_mat_density2);
688 m_mat_density.removeDepend(m_mat_density2);
689 m_mat_density.setComputeFunction(
this,&MeshMaterialTesterModule::startInit);
695 CellToAllEnvCellConverter all_env_cell_converter(m_material_mng);
698 IMeshMaterial* mm = *imat;
702 AllEnvCell all_env_cell = all_env_cell_converter[cell];
703 Real density = m_mat_density.matValue(all_env_cell,
id);
704 info() <<
"IndirectMatAccess Cell uid=" << cell.
uniqueId() <<
" mat_id=" <<
id <<
" density=" << density;
709 IMeshEnvironment* me = *ienv;
713 AllEnvCell all_env_cell = all_env_cell_converter[cell];
714 Real density = m_mat_density.envValue(all_env_cell,
id);
715 info() <<
"IndirectEnvAccess Cell uid=" << cell.
uniqueId() <<
" env_id=" <<
id <<
" density=" << density;
722 _dumpNoDumpRealValues();
726 _testDumpProperties();
727 _checkNullComponentItem();
733void MeshMaterialTesterModule::
734_checkNullComponentItem()
736 EnvCell null_env_cell;
739 info() <<
"NullEnvCell var_index =" << null_env_cell.
_varIndex();
741 info() <<
"NullEnvCell component_id =" << null_env_cell.
componentId();
742 info() <<
"NullEnvCell null =" << null_env_cell.
null();
743 info() <<
"NullEnvCell super_cell =" << null_env_cell.
superCell();
744 info() <<
"NullEnvCell level =" << null_env_cell.
level();
745 info() <<
"NullEnvCell nb_sub_item=" << null_env_cell.
nbSubItem();
746 info() <<
"NullEnvCell component_unique_id=" << null_env_cell.
componentUniqueId();
749 info() <<
"NullEnvCell all_env_cell =" << null_env_cell.
allEnvCell().
null();
755void MeshMaterialTesterModule::
758 IMesh* mesh = defaultMesh();
761 Int32 p0 = v0.variable()->property();
762 Int32 p1 = v1.globalVariable().variable()->property();
763 info() <<
"PROP1 = " << p0 <<
" " << p1;
767 Int32 p2 = v2.globalVariable().variable()->property();
768 Int32 p3 = v3.variable()->property();
769 info() <<
"PROP2 = " << p2 <<
" " << p3;
772 Int32 p4 = v4.globalVariable().variable()->property();
773 info() <<
"PROP4 = " << p4;
781 ARCANE_FATAL(
"Bad property value p0={0}. Should be Dump",p0);
783 ARCANE_FATAL(
"Bad property value p2={0}. Should be Dump",p2);
794 auto* x = options()->additionalEosService();
801 info() <<
"EOS: mat=" << mat->
name();
807 x->initEOS(mat,m_mat_pressure,m_mat_density,m_mat_internal_energy,m_mat_sound_speed);
809 x->applyEOS(mat,m_mat_density,m_mat_internal_energy,m_mat_pressure,m_mat_sound_speed);
817void MeshMaterialTesterModule::
820 IUnitTest* unit_test = options()->additionalTestService();
828void MeshMaterialTesterModule::
831 info() <<
"MESH_MATERIAL_TESTER :: continueInit()";
833 _dumpNoDumpRealValues();
840void MeshMaterialTesterModule::
843 info() <<
"SET_DEPENDENCIES";
845 m_mat_density.setMaterialComputeFunction(
this,&MeshMaterialTesterModule::_computeMaterialDepend);
847 m_mat_density.addMaterialDepend(m_pressure);
849 UniqueArray<VariableDependInfo> infos;
850 UniqueArray<MeshMaterialVariableDependInfo> mat_infos;
851 m_mat_density.materialVariable()->dependInfos(infos,mat_infos);
854 info() <<
"Global depend v=" << infos[k].variable()->fullName();
857 info() <<
"Material depend v=" << mat_infos[k].variable()->name();
880 test_var[iccell] = index;
885 Int32 total_full = 0;
886 Int32 total_pure = 0;
887 Int32 total_impure = 0;
890 Int32 v = test_var[iccell];
897 info() <<
"COMPONENT=" << component->
name() <<
" TOTAL PURE=" << total_pure <<
" IMPURE=" << total_impure
898 <<
" FULL=" << total_full;
906 total += test_var[imc];
908 vc.
areEqual(total,total_full,
"TotalFull1");
914 total += test_var[imc];
916 vc.
areEqual(total,total_impure,
"TotalImpure1");
921 total += test_var[imc];
923 vc.
areEqual(total,total_pure,
"TotalPure1");
928 total += test_var[imc];
930 vc.
areEqual(total,total_impure,
"TotalImpure2");
935 total += test_var[imc];
937 vc.
areEqual(total,total_pure,
"TotalPure2");
945 total += test_var[imc];
947 vc.
areEqual(total,total_full,
"TotalFull1");
953 total += test_var[imc];
955 vc.
areEqual(total,total_impure,
"TotalImpure1");
960 total += test_var[imc];
962 vc.
areEqual(total,total_pure,
"TotalPure1");
967 total += test_var[imc];
969 vc.
areEqual(total,total_impure,
"TotalImpure2");
974 total += test_var[imc];
976 vc.
areEqual(total,total_pure,
"TotalPure2");
983 total += test_var[imc];
985 vc.
areEqual(total,total_impure,
"TotalImpure3");
990 total += test_var[imc];
992 vc.
areEqual(total,total_pure,
"TotalPure3");
999void MeshMaterialTesterModule::
1002 m_pressure.fill(0.0);
1006 double v = (double)mat->
id();
1009 m_mat_density.update(mat);
1015 double v = (double)mat->
id();
1017 if (m_mat_density[imc]!=v)
1018 ARCANE_FATAL(
"Bad value for mat depend v={0} expected={1}",m_mat_density[imc],v);
1021 if (m_mat_density[imc]!=v)
1022 ARCANE_FATAL(
"Bad value for mat depend v={0} expected={1}",m_mat_density[imc],v);
1027 m_pressure.fill(1.0);
1028 m_pressure.setUpToDate();
1030 IMeshMaterial* mat = *imat;
1031 double v0 = (double)mat->
id();
1033 m_mat_density.update(mat);
1034 double v = 1.0 + v0;
1036 if (m_mat_density[imc]!=v)
1037 ARCANE_FATAL(
"Bad value (1) for global depend v={0} expected={1}",m_mat_density[imc],v);
1040 if (m_mat_density[imc]!=v)
1041 ARCANE_FATAL(
"Bad value (2) for global depend v={0} expected={1}",m_mat_density[imc],v);
1044 if (m_mat_density[imc]!=v)
1045 ARCANE_FATAL(
"Bad value (2) for global depend v={0} expected={1}",m_mat_density[imc],v);
1053void MeshMaterialTesterModule::
1056 info() <<
"Compute material depend mat=" << mat->
name();
1063 info() <<
"Cell=" << ItemPrinter(cell) <<
" density=" << m_mat_density[mc]
1065 <<
" pressure=" << m_pressure[cell];
1069 m_mat_density.setUpToDate(mat);
1075void MeshMaterialTesterModule::
1078 info() <<
"_dumpAverageValues()";
1080 IMeshEnvironment* env = *ienv;
1082 IMeshMaterial* mat = *imat;
1083 Real sum_density = 0.0;
1086 sum_density += m_mat_density[imatcell];
1088 info() <<
"SumMat ITER=" << m_global_iteration() <<
" MAT=" << mat->
name()
1089 <<
" density=" << sum_density;
1097void MeshMaterialTesterModule::
1100 info() <<
"_doSimd()";
1105 IMeshEnvironment* env = *ienv;
1106 auto out_var_tmp =
viewOut(var_tmp);
1109 out_var_tmp[ienvcell] = value;
1112 if (var_tmp[ienvcell]!=value)
1113 ARCANE_FATAL(
"Bad value v={0} expected={1}",var_tmp[ienvcell],value);
1121void MeshMaterialTesterModule::
1122_dumpNoDumpRealValues()
1126 info() << ostr.str();
1128 UniqueArray<IMeshMaterialVariable*> vars;
1129 m_material_mng->fillWithUsedVariables(vars);
1130 info() <<
"NB_USED_MATERIAL_VAR=" << vars.
size();
1132 info() <<
"USED_MATERIAL_VAR name=" << vars[i]->name();
1138template<
typename VectorType>
void MeshMaterialTesterModule::
1139_checkVectorCopy(VectorType& vec_cells)
1141 ValueChecker vc(A_FUNCINFO);
1145 VectorType vec_cells_copy(vec_cells);
1146 if (!vec_cells_copy.view()._isSamePointerData(vec_cells.view()))
1149 VectorType vec_cells_copy2(vec_cells);
1150 vc.areEqual(vec_cells_copy2.view()._matvarIndexes(),vec_cells.view()._matvarIndexes(),
"bad copy 2");
1152 VectorType move_vec_cells(std::move(vec_cells_copy2));
1153 vc.areEqual(move_vec_cells.view()._matvarIndexes().data(),vec_cells.view()._matvarIndexes().data(),
"bad move 1");
1158 VectorType clone_vec(vec_cells_copy.clone());
1159 vc.areEqual(clone_vec.view()._matvarIndexes(),vec_cells.view()._matvarIndexes(),
"bad clone 1");
1160 if (clone_vec.view()._constituentItemListView() != vec_cells.view()._constituentItemListView())
1162 if (clone_vec.view()._matvarIndexes().data()==vec_cells.view()._matvarIndexes().data())
1164 if (clone_vec.view()._isSamePointerData(vec_cells.view()))
1172void MeshMaterialTesterModule::
1173_checkTemporaryVectors(
const CellGroup& test_group)
1177 MatCellVector mat_cells(test_group,m_mat1);
1178 const MatCellVector& mcref(mat_cells);
1179 info() <<
"SET_DENSITY ON SUB GROUP for material";
1181 MatCell mc = *imatcell;
1185 MatCell mc = *imatcell;
1188 info() <<
"SET_DENSITY";
1190 MatCell mc = *imatcell;
1191 m_mat_density[mc] = 3.2;
1194 _checkVectorCopy(mat_cells);
1196 _checkVectorCopy(component_mat_cells);
1200 MatCellVector mat_cells(test_group.
view(),m_mat1);
1201 const MatCellVector& mcref(mat_cells);
1202 info() <<
"SET_DENSITY ON SUB GROUP for material";
1204 MatCell mc = *imatcell;
1208 MatCell mc = *imatcell;
1211 info() <<
"SET_DENSITY";
1213 MatCell mc = *imatcell;
1214 m_mat_density[mc] = 3.2;
1218 MatCell mc = *imatcell;
1219 m_mat_density[mc] = 3.2;
1225 IMeshEnvironment* env1 = m_mat1->environment();
1226 EnvCellVector env_cells(test_group,env1);
1227 const EnvCellVector& ecref(env_cells);
1228 info() <<
"SET_DENSITY ON SUB GROUP for environment";
1230 EnvCell mc = *ienvcell;
1233 info() <<
"SET_DENSITY";
1235 EnvCell mc = *ienvcell;
1236 m_mat_density[ienvcell] = 3.2;
1240 EnvCell mc = *ienvcell;
1241 m_mat_density[ienvcell] = 3.2;
1244 _checkVectorCopy(env_cells);
1246 _checkVectorCopy(component_env_cells);
1250 IMeshEnvironment* env1 = m_mat1->environment();
1251 EnvCellVector env_cells(test_group.
view(),env1);
1252 const EnvCellVector& ecref(env_cells);
1253 info() <<
"SET_DENSITY ON SUB GROUP for environment";
1255 EnvCell mc = *ienvcell;
1258 info() <<
"SET_DENSITY";
1260 EnvCell mc = *ienvcell;
1261 m_mat_density[ienvcell] = 3.2;
1271void MeshMaterialTesterModule::
1274 if (value!=expected_value){
1275 ARCANE_FATAL(
"Bad value v={0} expected={1}",value,expected_value);
1282Integer MeshMaterialTesterModule::
1288 var[imcell] = index;
1289 total += (
Integer)var[imcell];
1298Integer MeshMaterialTesterModule::
1304 var[iccell] = index;
1305 total += (
Integer)var[iccell];
1314Integer MeshMaterialTesterModule::
1317 std::atomic<Integer> new_total;
1318 auto func = [&](MatItemVectorView view)
1320 info() <<
"ParallelLoop with MatItemVectorView size=" << view.nbItem();
1322 new_total += (
Integer)var[iccell];
1334void MeshMaterialTesterModule::
1335_checkSubViews(
const CellGroup& test_group)
1337 IMeshEnvironment* env1 = m_mat1->environment();
1338 EnvCellVector env_cells(test_group.
view(),env1);
1339 MatCellVector mat_cells(test_group.
view(),m_mat1);
1343 ComponentItemVectorView test_group_view(env_cells.view());
1344 Integer nb_item = test_group_view.nbItem();
1345 for(
Integer i=0; i<20; ++i ){
1351 ComponentItemVectorView v2 = test_group_view._subView(begin,size);
1353 ComponentCell ccell = *iccell;
1354 info() <<
" ComponentCell c=" << ccell.
_varIndex();
1365 mat_test_sub_view[imcell] = index;
1370 mat_test_sub_view[iecell] = index;
1371 direct_total += index;
1375 direct_mat_total += (
Integer)mat_test_sub_view[imcell];
1377 info() <<
"DIRECT_ENV_TOTAL = " << direct_total
1378 <<
"DIRECT_MAT_TOTAL = " << direct_mat_total;
1382 ComponentItemVectorView test_group_view(env_cells.view());
1383 Integer nb_item = test_group_view.nbItem();
1385 for(
Integer block_size=1; block_size<20; ++block_size){
1387 for(
Integer begin=0; begin<nb_item; begin += block_size ){
1392 ComponentItemVectorView v2 = test_group_view.
_subView(begin,size);
1394 new_total += (
Integer)mat_test_sub_view[iccell];
1397 if (new_total!=direct_total){
1398 ARCANE_FATAL(
"Bad total v={0} expected={1} block_size={2}",
1399 new_total,direct_total,block_size);
1406 ComponentItemVectorView test_group_view(env_cells.view());
1408 ParallelLoopOptions options;
1411 Integer nb_item = test_group_view.nbItem();
1412 info() <<
"ParallelTest with lambda full_size=" << nb_item;
1416 std::atomic<Integer> new_total;
1418 auto func = [&](ComponentItemVectorView view)
1420 info() <<
"ParallelLoop with component size=" << view.nbItem();
1422 new_total += (
Integer)mat_test_sub_view[iccell];
1427 if (new_total!=direct_total){
1434 EnvItemVectorView env_test_group_view(env_cells.view());
1435 std::atomic<Integer> new_total;
1437 auto func = [&](EnvItemVectorView view)
1439 info() <<
"ParallelLoop with environment size=" << view.nbItem();
1441 new_total += (
Integer)mat_test_sub_view[iccell];
1446 if (new_total!=direct_total){
1453 MatItemVectorView mat_view(mat_cells.view());
1454 Integer ref_val = _fillTestVar(mat_view,mat_test_sub_view);
1455 Integer new_val = _checkParallelMatItem(mat_view,mat_test_sub_view);
1456 _checkEqual(ref_val,new_val);
1461 Integer ref_val = _fillTestVar(m_mat1,mat_test_sub_view);
1462 Integer new_val = _checkParallelMatItem(m_mat1->matView(),mat_test_sub_view);
1463 _checkEqual(ref_val,new_val);
1468 MatCellVector empty_mat_cells(
CellGroup(),m_mat1);
1469 MatItemVectorView mat_view(empty_mat_cells.view());
1470 Integer ref_val = _fillTestVar(mat_view,mat_test_sub_view);
1471 Integer new_val = _checkParallelMatItem(mat_view,mat_test_sub_view);
1472 _checkEqual(ref_val,new_val);
1480 ComponentItemVectorView test_group_view(env_cells.view());
1481 Integer nb_item = test_group_view.nbItem();
1482 info() <<
"NB_ITEM=" << nb_item;
1483 auto f0 = std::bind(std::mem_fn(&MeshMaterialTesterModule::_subViewFunctor),
this,std::placeholders::_1);
1487 [&](ComponentItemVectorView view){ this->_subViewFunctor(view); }
1495void MeshMaterialTesterModule::
1505void MeshMaterialTesterModule::
1508 ValueChecker vc(A_FUNCINFO);
1519 vc.areEqual(var[imatcell],values[index],
"Bad value for fillToArray()");
1525 var_tmp.fillFromArray(mat,values);
1527 vc.areEqual(values[index],var_tmp[imatcell],
"Bad value for fillFromArray()");
1533 std::map<Int32,MatCell> matvar_indexes;
1539 if (iterator_index==wanted_index){
1540 matvar_indexes.insert(std::make_pair(iterator_index,*imatcell));
1541 indexes.
add(iterator_index);
1545 info() <<
"Indexes=" << indexes;
1555 for(
Integer i=0; i<nb_index; ++i )
1556 vc.areEqual(var[matvar_indexes[i]],values[i],
"Bad value for fillToArray() (2)");
1560 var_tmp.fillFromArray(mat,values,indexes);
1561 for(
Integer i=0; i<nb_index; ++i )
1562 vc.areEqual(values[i],var_tmp[matvar_indexes[i]],
"Bad value for fillFromArray() (2)");
1569void MeshMaterialTesterModule::
1572 IUnitTest* unit_test = options()->additionalTestService();
1577 if (m_check_spectral_values_iteration!=0){
1578 info() <<
"Check spectral values after loadbalancing";
1579 _setOrCheckSpectralValues(m_check_spectral_values_iteration,
true);
1580 m_check_spectral_values_iteration = 0;
1587 _dumpAverageValues();
1599 using namespace Materials;
1601 mat_pressure.fill(0.0);
1603 FaceGroup xmin_group = defaultMesh()->faceFamily()->findGroup(
"XMIN");
1607 Real d = m_density[c];
1608 m_density[c] = d + 1.0;
1614 if (mat_pressure2.materialVariable()!=mat_pressure.materialVariable())
1621 mat_test_refersto.refersTo(mat_pressure);
1622 if (mat_test_refersto.materialVariable()!=mat_pressure.materialVariable())
1625 Real total_ref = 0.0;
1627 total += mat_test_refersto[imatcell];
1628 total_ref += mat_pressure[imatcell];
1630 if (total!=total_ref)
1637 MatCellVector mat_cells(ownCells(),m_mat1);
1638 const MatCellVector& mcref(mat_cells);
1640 applyGeneric(mcref,var,4.5);
1642 if (var[imatcell]!=4.5)
1645 applyGeneric(allCells(),var,3.2);
1647 if (var[icell]!=3.2)
1650 applyGeneric(m_mat1,var,7.6);
1652 if (var[imatcell]!=7.6)
1655 applyGeneric(m_mat1->environment(),var,4.2);
1657 if (var[imatcell]!=4.2)
1663 _checkFillPartialValues();
1665 IMeshMaterialVariable* nv = m_material_mng->findVariable(m_pressure.variable()->fullName());
1667 fatal() <<
"Can not find MeshVariable (F1)";
1669 IMeshMaterialVariable* nv2 = m_material_mng->findVariable(
"Pressure");
1671 fatal() <<
"Can not find MeshVariable (F2)";
1674 MatCell mmc = *imatcell;
1676 info() <<
"CELL IN MAT1 i=" << imatcell.index() <<
" vindex=" << mvi.
arrayIndex() <<
" i=" << mvi.
valueIndex();
1677 mat_pressure[mmc] += 0.2;
1682 MatCell mmc = *imatcell;
1686 mat_pressure[imatcell] -= 0.2;
1690 _checkFillArrayFromTo(m_mat1,mat_pressure);
1692 _checkFillArrayFromTo(m_mat2,mat_pressure);
1695 IMeshEnvironment* env = *ienv;
1697 EnvCell ev = *ienvcell;
1700 mat_pressure[ev] += 3.0;
1701 mat_pressure[ienvcell] += 3.0;
1704 ComponentCell cv = *icmpcell;
1706 info() <<
"CELL IN ENV WITH COMPONENT vindex=" << mvi.
arrayIndex() <<
" i=" << mvi.
valueIndex();
1707 mat_pressure[cv] += 3.0;
1708 EnvCell env_cell(cv);
1709 if (env_cell._varIndex()!=cv.
_varIndex())
1714 _checkArrayVariableSynchronize();
1716 for(
Integer i=0, n=m_material_mng->materials().size(); i<n; ++i ){
1717 IMeshMaterial* mat = m_material_mng->materials()[i];
1718 m_density_post_processing[i]->copy(m_mat_density.globalVariable());
1719 _copyPartialToGlobal(mat,*m_density_post_processing[i],m_mat_density);
1724 info() <<
"CheckRemove: Cells in MAT1=" << m_mat1->cells().size();
1726 MatCell mmc = *imatcell;
1728 info() <<
"CheckRemove: CELL IN MAT1 i=" << imatcell.index() <<
" vindex=" << mvi.
arrayIndex() <<
" i=" << mvi.
valueIndex()
1733 info() <<
"Cells in MAT2=" << m_mat2->cells().size();
1737 Int64 last_uid = m_nb_starting_cell() - (m_global_iteration()*30);
1738 info() <<
"LAST_UID_TO_REMOVE=" << last_uid;
1746 info() <<
"Removing cells n=" << remove_lids.
size();
1749 if (parallelMng()->isParallel()){
1757 MeshMaterialIndirectModifier mmim(m_material_mng);
1759 info() <<
"MESH_MATERIAL_TEST: UpdateGhostLayers";
1761 if ((m_global_iteration() % 2)==0){
1762 mmim.endUpdateWithSort();
1774 info() <<
"End removing cells nb_cell=" << mesh()->
nbCell();
1777 Integer iteration = m_global_iteration();
1779 if ((iteration%3)==0){
1780 info() <<
"Registering mesh partition";
1782 m_check_spectral_values_iteration = (iteration*2)+1;
1783 _setOrCheckSpectralValues(m_check_spectral_values_iteration,
false);
1789 Materials::IMeshMaterial* mat = *imat;
1791 MatCell mc = *icell;
1792 if (m_mat_density[mc] == 0.0)
1793 m_mat_density[mc] = 50.0;
1794 if (m_mat_internal_energy[mc] == 0.0)
1795 m_mat_internal_energy[mc] = 1.0;
1805void MeshMaterialTesterModule::
1806_checkFillPartialValues()
1809 info() <<
"Check MaterialVariableCellReal";
1811 _checkFillPartialValuesHelper(mat_var);
1813 info() <<
"Check EnvironmentVariableCellReal";
1815 _checkFillPartialValuesHelper(env_var);
1816 if (m_material_mng->isAllocateScalarEnvironmentVariableAsMaterial()){
1818 info() <<
"Ok for creating Material variable with same name as Environment variable";
1821 info() <<
"Check MaterialVariableCellReal";
1824 _checkFillPartialValuesHelper(mat_var2);
1826 info() <<
"Check EnvironmentVariableCellArrayReal";
1828 env_var2.resize(12);
1829 _checkFillPartialValuesHelper(env_var2);
1835template<
typename VarType>
void MeshMaterialTesterModule::
1836_checkFillPartialValuesHelper(VarType& mat_var)
1838 info() <<
"Check fillPartialValuesWithGlobalValues()";
1839 _fillVar(mat_var,3.0);
1840 mat_var.materialVariable()->fillPartialValuesWithGlobalValues();
1841 _checkFillPartialValuesWithGlobal(mat_var,m_material_mng->components());
1843 info() <<
"Check fillPartialValuesWithSuperValues(LEVEL_ALLENVIRONMENT)";
1844 _fillVar(mat_var,7.0);
1845 mat_var.fillPartialValuesWithSuperValues(LEVEL_ALLENVIRONMENT);
1846 _checkFillPartialValuesWithGlobal(mat_var,m_material_mng->components());
1848 info() <<
"Check fillPartialValuesWithSuperValues(LEVEL_ENVIRONMENT)";
1849 _fillVar(mat_var,-2.0);
1850 mat_var.fillPartialValuesWithSuperValues(LEVEL_ENVIRONMENT);
1851 _checkFillPartialValuesWithSuper(mat_var,m_material_mng->environmentsAsComponents());
1853 info() <<
"Check fillPartialValuesWithSuperValues(LEVEL_MATERIAl)";
1854 _fillVar(mat_var,-25.0);
1855 mat_var.fillPartialValuesWithSuperValues(LEVEL_MATERIAL);
1856 _checkFillPartialValuesWithSuper(mat_var,m_material_mng->materialsAsComponents());
1864void _setValue(
Real& var_ref,
Real value)
1872 var_ref[i] = value*((
Real)(i+1));
1876template<
typename VarType>
void MeshMaterialTesterModule::
1877_fillVar(VarType& var_type,
Real base_value)
1883 IMeshComponent* c = *ic;
1888 _setValue(var_type[iccell],(base_value + (
Real)index));
1896template<
typename VarType>
void MeshMaterialTesterModule::
1897_checkFillPartialValuesWithGlobal(
const VarType& var_type,
MeshComponentList components)
1899 ValueChecker vc(A_FUNCINFO);
1903 IMeshComponent* c = *ic;
1907 Cell c = (*iccell).globalCell();
1908 auto ref_value = var_type[c];
1909 auto my_value = var_type[iccell];
1910 vc.areEqual(my_value,ref_value,
"Bad fill value with global");
1918template<
typename VarType>
void MeshMaterialTesterModule::
1919_checkFillPartialValuesWithSuper(
const VarType& var_type,
MeshComponentList components)
1921 ValueChecker vc(A_FUNCINFO);
1925 IMeshComponent* c = *ic;
1929 ComponentCell c = (*iccell).superCell();
1930 auto ref_value = var_type[c];
1931 auto my_value = var_type[iccell];
1932 vc.areEqual(my_value,ref_value,
"Bad fill value with super");
1940template<
typename VarType1,
typename VarType2,
typename VarType3>
void MeshMaterialTesterModule::
1941_setOrCheckSpectralValues2(VarType1& var_real,VarType2& var_int32,VarType3& var_scalar_int32,
1942 Int64 iteration,
bool is_check)
1944 typedef std::function<void(
Int64,
Int64,ComponentItemLocalId)> FunctorType;
1946 Int32 spectral1_dim2 = var_real.globalVariable().arraySize();
1947 Int32 spectral2_dim2 = var_int32.globalVariable().arraySize();
1948 info() <<
"SET_OR_CHECK size1=" << spectral1_dim2 <<
" size2=" << spectral2_dim2;
1949 FunctorType set_func = [&](
Int64 uid,
Int64 iteration,ComponentItemLocalId var_index)
1951 Int64 component_idx = var_index.localId().arrayIndex();
1952 Int64 base = uid + iteration + (component_idx+1);
1953 for(
Integer i=0; i<spectral1_dim2; ++i )
1955 for(
Integer i=0; i<spectral2_dim2; ++i )
1956 var_int32[var_index][i] = (
Int32)(3 + (base * spectral2_dim2 + i*2 ));
1957 var_scalar_int32[var_index] = (
Int32)(3 + (base * spectral2_dim2));
1960 ValueChecker vc(A_FUNCINFO);
1961 vc.setThrowOnError(
false);
1963 FunctorType check_func = [&](
Int64 uid,
Int64 iteration,ComponentItemLocalId var_index)
1965 Int64 component_idx = var_index.localId().arrayIndex();
1966 Int64 base = uid + iteration + (component_idx+1);
1967 for(
Integer i=0; i<spectral1_dim2; ++i ){
1970 vc.areEqual(ref1,var_real[var_index][i],String::format(
"spectral1:{0}",var_real.name()));
1972 for(
Integer i=0; i<spectral2_dim2; ++i ){
1973 Int32 ref2 = (
Int32)(3 + (base * spectral2_dim2 + i*2 ));
1975 vc.areEqual(ref2,var_int32[var_index][i],String::format(
"spectral2:{0}",var_int32.name()));
1977 Int32 ref3 = (
Int32)(3 + (base * spectral2_dim2));
1978 vc.areEqual(ref3,var_scalar_int32[var_index],
"scalar1");
1979 if (vc.nbError()!=0){
1980 error() <<
"Error for cell uid=" << uid <<
" var_index=" << var_index;
1985 FunctorType func = (is_check) ? check_func : set_func;
1987 bool has_mat = var_real.materialVariable()->space()!=MatVarSpace::Environment;
1989 AllEnvCell all_env_cell = *iallenvcell;
1990 Cell global_cell = all_env_cell.
globalCell();
1993 func(cell_uid,iteration,ienvcell);
1996 func(cell_uid,iteration,imatcell);
2000 func(cell_uid,iteration,all_env_cell);
2007void MeshMaterialTesterModule::
2008_setOrCheckSpectralValues(
Int64 iteration,
bool is_check)
2010 _setOrCheckSpectralValues2(m_mat_spectral1,m_mat_spectral2,m_mat_int32,iteration,is_check);
2011 _setOrCheckSpectralValues2(m_env_spectral1,m_env_spectral2,m_env_int32,iteration,is_check);
2017void MeshMaterialTesterModule::
2018_checkArrayVariableSynchronize()
2020 info() <<
"_checkArrayVariableSynchronize(): SYNCHRONIZE_MATERIALS";
2021 m_material_mng->synchronizeMaterialsInCells();
2022 m_material_mng->checkMaterialsInCells();
2024 Int64 iteration = m_global_iteration();
2026 _setOrCheckSpectralValues(iteration,
false);
2029 if ((iteration % 2)==0){
2030 MeshMaterialVariableSynchronizerList mlist(m_material_mng);
2031 m_mat_spectral1.synchronize(mlist);
2032 m_mat_spectral2.synchronize(mlist);
2033 m_env_spectral1.synchronize(mlist);
2034 m_env_spectral2.synchronize(mlist);
2035 m_mat_int32.synchronize();
2036 m_env_int32.synchronize();
2040 m_mat_spectral1.synchronize();
2041 m_mat_spectral2.synchronize();
2042 m_env_spectral1.synchronize();
2043 m_env_spectral2.synchronize();
2044 m_mat_int32.synchronize();
2045 m_env_int32.synchronize();
2048 _setOrCheckSpectralValues(iteration,
true);
2054void MeshMaterialTesterModule::
2057 VariableCellReal tmp_cell_mat_density(VariableBuildInfo(defaultMesh(),
"TmpCellMatDensity"));
2058 VariableNodeReal tmp_node_mat_density(VariableBuildInfo(defaultMesh(),
"TmpNodeMatDensity"));
2064 Materials::MeshMaterialModifier modifier(m_material_mng);
2066 IMeshEnvironment* env = *ienv;
2068 IMeshMaterial* mat = *imat;
2069 mat_to_add_array.
clear();
2070 mat_to_remove_array.
clear();
2071 _fillDensity(*imat,tmp_cell_mat_density,tmp_node_mat_density,mat_to_add_array,mat_to_remove_array,
true);
2072 info() <<
"FILL_DENSITY_INFO ITER=" << m_global_iteration()
2073 <<
" mat=" << mat->
name()
2074 <<
" nb_to_add=" << mat_to_add_array.
size()
2075 <<
" nb_to_remove=" << mat_to_remove_array.
size();
2077 modifier.removeCells(mat,mat_to_remove_array);
2078 modifier.addCells(mat,mat_to_add_array);
2086 IMeshEnvironment* env = *ienv;
2088 _fillDensity(*imat,tmp_cell_mat_density,tmp_node_mat_density,mat_to_add_array,mat_to_remove_array,
false);
2094 m_material_mng->synchronizeMaterialsInCells();
2095 info() <<
"Synchronize density";
2096 m_mat_density.synchronize();
2102void MeshMaterialTesterModule::
2107 MatCell mc = *imatcell;
2109 global_density[global_cell] = partial_variable[mc];
2132 bool is_compute_mat)
2135 tmp_cell_mat_density.fill(0.0);
2136 tmp_node_mat_density.fill(0.0);
2137 info() <<
"FILL MAT=" << mat->
name();
2140 _copyPartialToGlobal(mat,tmp_cell_mat_density,m_mat_density);
2145 for( CellLocalId icell : inode->cellIds() )
2146 v += tmp_cell_mat_density[icell];
2147 v /= (
Real)inode->nbCell();
2149 tmp_node_mat_density[inode] = v;
2154 if (is_compute_mat){
2157 Real current_density = tmp_cell_mat_density[icell];
2158 Real new_density = 0.0;
2159 bool has_material = (m_present_material[cell] & (1<<mat_id));
2160 for( NodeLocalId inode : cell.
nodeIds() )
2161 new_density += tmp_node_mat_density[inode];
2163 if (new_density>=0.5 && !has_material && current_density==0.0){
2165 info() <<
"NEW CELL FOR MAT " << mat_id <<
" uid=" <<
ItemPrinter(cell) <<
" new=" << new_density;
2167 else if (new_density<0.4 && has_material && current_density>0.4){
2169 info() <<
"REMOVE CELL FOR MAT " << mat_id <<
" uid=" <<
ItemPrinter(cell) <<
" new=" << new_density
2170 <<
" old=" << current_density;
2172 tmp_cell_mat_density[icell] = new_density;
2181 Real new_density = 0.0;
2182 for( NodeLocalId inode : cell.
nodeIds() )
2183 new_density += tmp_node_mat_density[inode];
2185 tmp_cell_mat_density[icell] = new_density;
2193 m_mat_density[mc] = tmp_cell_mat_density[global_cell];
2197 StdMeshVariables<MeshMaterialVariableTraits> xm(meshHandle(),
"Base1",
"Base2");
2204void MeshMaterialTesterModule::
2208 info() <<
"I=" << a <<
" N=" << n;
2211 z += mat_pressure.materialVariable()->name().length();
2213 info() <<
"Z=" << z;
2229 info() <<
"CHECK CREATE N=" << n;
2233 mat_pressure.
fill(0.0);
2236 mat_pressure[mmc] += 0.2;
2244void MeshMaterialTesterModule::
2269 void _computeDensity(IMeshMaterial* mat)
2273 m_mat_density[mc] = 1.0;
2277 m_mat_density.setUpToDate(mat);
2298 MeshEnvironmentBuildInfo ebi1(
"ENV1");
2299 ebi1.addMaterial(
"MAT1");
2300 ebi1.addMaterial(
"MAT2");
2304 MeshEnvironmentBuildInfo ebi2(
"ENV2");
2305 ebi2.addMaterial(
"MAT2");
2309 MeshEnvironmentBuildInfo ebi3(
"ENV3");
2310 ebi3.addMaterial(
"MAT3");
2311 ebi3.addMaterial(
"MAT1");
2316 MeshBlockBuildInfo mb1(
"BLOCK1",allCells());
2317 mb1.addEnvironment(env1);
2318 mb1.addEnvironment(env2);
2319 IMeshBlock* block = material_mng->
createBlock(mb1);
2326 info() << env1->
id();
2329 info() << env2->
id();
2331 info() << env3->
id();
2334 info() << block->
id();
2342 MeshMaterialModifier modifier(material_mng);
2349 Int32 local_id = icell.itemLocalId();
2351 bool add_to_mat1 = (z<(nb_cell/2) && z>(nb_cell/4));
2352 bool add_to_mat2 = (z>=(nb_cell/2) || z<(nb_cell/3));
2354 mat1_indexes.
add(local_id);
2356 mat2_indexes.
add(local_id);
2359 modifier.addCells(env1->
materials()[0],mat1_indexes);
2361 modifier.addCells(env1->
materials()[1],mat2_indexes);
2368 IMesh* mesh = defaultMesh();
2369 MaterialVariableBuildInfo mvbinfo(material_mng,
"Density");
2378 IMeshEnvironment* env = *ienv;
2380 IMeshMaterial* mat = *imat;
2382 MatCell mc = *imatcell;
2387 EnvCell mmcell = *ienvcell;
2396 IMeshEnvironment* env = *ienv;
2398 IMeshMaterial* mat = *imat;
2400 MatCell mc = *imatcell;
2410 AllEnvCell all_env_cell = *iallenvcell;
2412 EnvCell env_cell = *ienvcell;
2415 MatCell mc = *imatcell;
2425 AllEnvCell all_env_cell = *iallenvcell;
2427 EnvCell env_cell = *ienvcell;
2430 MatCell mc = *imatcell;
2440 IMeshMaterial* mat = env1->
materials()[0];
2441 MatCellVector mat_cells(cells,mat);
2443 mat_density[imatcell] = 2.3;
2445 IMeshEnvironment* env = env1;
2446 EnvCellVector env_cells(cells,env);
2448 mat_density[imatcell] = 3.1;
2459 IMeshEnvironment* env = *ienv;
2461 IMeshMaterial* mat = *imat;
2463 ComponentCell cc = *iccell;
2465 mat_density[cc] = 3.1;
2469 ComponentCell cc = *iccell;
2471 mat_density[cc] = 2.5;
2479 ComponentCell cc = mc;
2495 Real init_val = 0.0;
2502 var[ienvcell] = init_val;
2507 var[imatcell] = init_val;
2516 mat_density.setMaterialComputeFunction(
this,&Sample::_computeDensity);
2518 mat_density.addMaterialDepend(mat_pressure);
2520 mat_density.addMaterialDepend(defaultMesh()->nodesCoordinates());
2521 mat_density.addMaterialDepend(m_global_time);
2524 IMeshMaterial* mat = *imat;
2526 mat_density.update(mat);
2534 IMeshEnvironment* env = env1;
2537 ENUMERATE_ENVCELL(ienvcell,view){
2538 mat_density[ienvcell] = 2.5;
2543 IMeshMaterial* mat = env1->
materials()[0];
2546 ENUMERATE_MATCELL(imatcell,view){
2547 mat_density[imatcell] = 2.5;
2552 auto func = [&](ComponentItemVectorView view)
2555 mat_density[iccell] = 2.5;
2564 ParallelLoopOptions options;
2579 auto in_volume =
viewIn(mat_volume);
2580 auto in_temperature =
viewIn(mat_temperature);
2582 auto out_pressure =
viewOut(mat_pressure);
2585 out_pressure[scell] = nr * in_temperature[scell] / in_volume[scell];
2597 mat_pressure[c] = mat_temperature[ienvcell];
2603 mat_pressure[c] = mat_temperature[ienvcell];
2609 mat_pressure[c] = mat_temperature[ienvcell];
2615 mat_pressure[c] = mat_temperature[ienvcell];
2621 mat_pressure[c] = mat_temperature[ienvcell];
2627 mat_pressure[c] = mat_temperature[ienvcell];
2640 mat_pressure[c] = mat_temperature[imatcell];
2646 mat_pressure[c] = mat_temperature[imatcell];
2652 mat_pressure[c] = mat_temperature[imatcell];
2658 mat_pressure[c] = mat_temperature[imatcell];
2664 mat_pressure[c] = mat_temperature[imatcell];
2670 mat_pressure[c] = mat_temperature[imatcell];
2677 ComponentCell c = *iccell;
2678 mat_pressure[c] = mat_temperature[iccell];
2683 ComponentCell c = *iccell;
2684 mat_pressure[c] = mat_temperature[iccell];
2689 ComponentCell c = *iccell;
2690 mat_pressure[c] = mat_temperature[iccell];
2695 ComponentCell c = *iccell;
2696 mat_pressure[c] = mat_temperature[iccell];
2701 ComponentCell c = *iccell;
2702 mat_pressure[c] = mat_temperature[iccell];
2707 ComponentCell c = *iccell;
2708 mat_pressure[c] = mat_temperature[iccell];
2721ARCANE_REGISTER_MODULE_MESHMATERIALTESTER(MeshMaterialTesterModule);
#define ARCANE_FATAL(...)
Macro envoyant une exception FatalErrorException.
#define ENUMERATE_COMPONENTITEM_LAMBDA(iter_type, iter, container)
Macro pour itérer sur les entités d'un composant via une fonction lambda du C++11.
void _applyEos(bool is_init)
Appelle le service d'EOS s'il est disponible.
MaterialVariableCellReal m_mat_nodump_real
Variable pour tester la bonne prise en compte du PNoDump.
void _checkCreation()
Test la création à la volée des variables, avec multi-threading.
MaterialVariableCellReal m_mat_not_used_real
Variable pour tester la bonne prise en compte de setUsed(false)
void _fillDensity(IMeshMaterial *mat, VariableCellReal &tmp_cell_mat_density, VariableNodeReal &tmp_node_mat_density, Int32Array &mat_to_add_array, Int32Array &mat_to_remove_array, bool is_compute_mat)
void _testComponentPart(IMeshMaterial *mat, IMeshEnvironment *env)
Teste les itérateurs par partie.
IMeshPartitioner * m_mesh_partitioner
Partitioner en cas d'équilibrage. Est géré par une option du JDD.
Integer size() const
Nombre d'éléments du vecteur.
constexpr Integer size() const noexcept
Retourne la taille du tableau.
void clear()
Supprime les éléments du tableau.
void resize(Int64 s)
Change le nombre d'éléments du tableau à s.
void add(ConstReferenceType val)
Ajoute l'élément val à la fin du tableau.
void clear()
Supprime tous les éléments de la collection.
constexpr Integer size() const noexcept
Nombre d'éléments du tableau.
Cell boundaryCell() const
Maille associée à cette face frontière (maille nulle si aucune)
Cell backCell() const
Maille derrière la face (maille nulle si aucune)
virtual Integer nbCell()=0
Nombre de mailles du maillage.
virtual void updateGhostLayers()=0
Mise à jour de la couche fantôme.
virtual void setDynamic(bool v)=0
Positionne la propriété indiquant si le maillage peut évoluer.
virtual void removeCells(Int32ConstArrayView cells_local_id)=0
Supprime des mailles.
virtual void endUpdate()=0
Notifie l'instance de la fin de la modification du maillage.
Interface d'un partitionneur de maillage.
virtual IMeshModifier * modifier()=0
Interface de modification associée.
virtual void setCheckLevel(Integer level)=0
Positionne le niveau de vérification du maillage.
virtual Integer checkLevel() const =0
Niveau actuel de vérification.
virtual char reduce(eReduceType rt, char v)=0
Effectue la réduction de type rt sur le réel v et retourne la valeur.
Interface du gestionnaire d'un sous-domaine.
virtual ITimeLoopMng * timeLoopMng()=0
Retourne le gestionnaire de la boucle en temps.
virtual ITimeLoop * createTimeLoop(const String &name)=0
Crée une boucle en temps de nom name.
virtual void registerTimeLoop(ITimeLoop *time_loop)=0
Enregistrement et choix de la boucle en temps.
virtual void setRequiredModulesName(const StringCollection &)=0
Positionne la liste des des modules obligatoires.
virtual void setOptionalModulesName(const StringCollection &)=0
Positionne la liste des des modules facultatifs.
static const char * WBuild
appelé lors de la lecture du jeu de données
static const char * WComputeLoop
appelé pendant la boucle de calcul
virtual void setEntryPoints(const String &where, const TimeLoopEntryPointInfoCollection &)=0
Positionne la liste des noms des points d'entrée pour le point d'appel where.
static const char * WInit
appelé pendant l'initialisation, l'initialisation d'une reprise ou d'un nouveau cas
Interface d'un service de test unitaire.
virtual void initializeTest()=0
Méthode appelée après lecture du jeu de données pour initialiser le test.
virtual void executeTest()=0
Méthode appelée pour exécuter le test.
Interface d'une variable.
@ PNoDump
Indique que la variable ne doit pas être sauvegardée.
ItemVectorView view() const
Vue sur les entités du groupe.
Integer size() const
Nombre d'éléments du groupe.
Classe utilitaire pour imprimer les infos sur une entité.
Int32 nbNode() const
Nombre de noeuds de l'entité
NodeLocalIdView nodeIds() const
Liste des noeuds de l'entité
constexpr Int32 localId() const
Identifiant local de l'entité dans le sous-domaine du processeur.
ItemUniqueId uniqueId() const
Identifiant unique sur tous les domaines.
constexpr bool null() const
true si l'entité est nul (i.e. non connecté au maillage)
__host__ __device__ Int32 nbEnvironment() const
Nombre de milieux présents dans la maille.
Variable scalaire sur les mailles d'un matériau du maillage. Pour l'instant, cette classe n'est insta...
void fill(const DataType &value)
Remplit les valeurs partielles et globales de la variable avec la valeur value.
GlobalVariableRefType & globalVariable()
Variable globale associée à cette variable matériau.
void fillToArray(IMeshMaterial *mat, ArrayView< DataType > values)
Remplit un tableau à partir des valeurs de la variable pour un matériau.
Vue sur un vecteur sur les entités d'un composant.
ComponentItemVectorView _subView(Integer begin, Integer size)
Créé une sous-vue de cette vue.
__host__ __device__ bool null() const
Indique s'il s'agit de la maille nulle.
__host__ __device__ Int32 componentId() const
Identifiant du composant dans la liste des composants de ce type.
Int64 componentUniqueId() const
Numéro unique de l'entité constituant.
__host__ __device__ Int32 nbSubItem() const
Nombre de sous-éléments.
__host__ __device__ CellComponentCellEnumerator subItems() const
Liste des sous-constituents de cette entité
Cell globalCell() const
Maille globale.
__host__ __device__ ComponentCell superCell() const
Maille de niveau supérieur dans la hiérarchie.
IMeshComponent * component() const
Constituant associé.
__host__ __device__ Int32 level() const
Niveau hiérarchique de l'entité
__host__ __device__ MatVarIndex _varIndex() const
Vecteur sur les entités d'un milieu.
Maille arcane d'un milieu.
IMeshEnvironment * environment() const
Milieu associé
__host__ __device__ AllEnvCell allEnvCell() const
Maille contenant les infos sur tous les milieux.
__host__ __device__ Int32 environmentId() const
Identifiant du milieu.
Interface d'un bloc d'un maillage.
virtual Int32 id() const =0
Identifiant du bloc. Il s'agit aussi de l'indice (en commencant par 0) de ce bloc dans la liste des b...
virtual ConstArrayView< IMeshEnvironment * > environments()=0
Liste des milieux de ce bloc.
virtual Integer nbEnvironment() const =0
Nombre de milieux dans le bloc.
Interface d'un composant (matériau ou milieu) d'un maillage.
virtual String name() const =0
Nom du composant.
virtual CellGroup cells() const =0
Groupe des mailles de ce matériau.
virtual Int32 id() const =0
Identifiant du composant.
virtual bool isEnvironment() const =0
Vrai si le composant est un milieu.
virtual IMeshMaterial * asMaterial()=0
Retourne le composant sous la forme d'un IMeshMaterial.
virtual ComponentImpurePartItemVectorView impureItems() const =0
Vue sur la liste des entités impures (partielles) partielles du composant.
virtual IMeshEnvironment * asEnvironment()=0
Retourne le composant sous la forme d'un IMeshMaterial.
virtual ComponentItemVectorView view() const =0
Vue associée à ce composant.
virtual bool hasSpace(MatVarSpace space) const =0
Indique si le composant est défini pour l'espace space.
virtual bool isMaterial() const =0
Vrai si le composant est un matériau.
virtual ComponentPurePartItemVectorView pureItems() const =0
Vue sur la liste des entités pures (associées à la maille globale) du composant.
Interface d'un milieu d'un maillage.
virtual EnvImpurePartItemVectorView impureEnvItems() const =0
Vue sur la liste des entités impures (partielles) partielles du milieu.
virtual ConstArrayView< IMeshMaterial * > materials()=0
Liste des matériaux de ce milieu.
virtual Integer nbMaterial() const =0
Nombre de matériaux dans le milieu.
virtual EnvItemVectorView envView() const =0
Vue associée à ce milieu.
virtual EnvPurePartItemVectorView pureEnvItems() const =0
Vue sur la liste des entités pures (associées à la maille globale) du milieu.
Interface du gestionnaire des matériaux et des milieux d'un maillage.
virtual MeshMaterialInfo * registerMaterialInfo(const String &name)=0
Enregistre les infos du matériau de nom name.
virtual void endCreate(bool is_continue=false)=0
Indique qu'on a fini de créer les milieux.
virtual IMeshBlock * createBlock(const MeshBlockBuildInfo &infos)=0
Créé un bloc.
virtual void removeEnvironmentToBlock(IMeshBlock *block, IMeshEnvironment *env)=0
Supprime un milieu à un bloc existant.
virtual void recreateFromDump()=0
Recréé les infos des matériaux et milieux à partir des infos de la protection.
virtual void addEnvironmentToBlock(IMeshBlock *block, IMeshEnvironment *env)=0
Ajoute un milieu à un bloc existant.
virtual IMeshEnvironment * createEnvironment(const MeshEnvironmentBuildInfo &infos)=0
Créé un milieu avec les infos infos.
virtual ConstArrayView< IMeshEnvironment * > environments() const =0
Liste des milieux.
static IMeshMaterialMng * getReference(const MeshHandleOrMesh &mesh_handle, bool create=true)
Récupère ou créé la référence associée à mesh.
Interface d'un matériau d'un maillage.
virtual MatImpurePartItemVectorView impureMatItems() const =0
Vue sur la liste des entités impures (partielles) partielles du matériau.
virtual MatItemVectorView matView() const =0
Vue associée à ce matériau.
virtual MatPurePartItemVectorView pureMatItems() const =0
Vue sur la liste des entités pures (associées à la maille globale) du matériau.
Vecteur sur les entités d'un matériau.
Représente un matériau d'une maille multi-matériau.
__host__ __device__ Int32 materialId() const
Identifiant du matériau.
__host__ __device__ EnvCell envCell() const
Maille milieu auquel cette maille matériau appartient.
IMeshMaterial * material() const
Materiau associé
Vue sur un vecteur sur les entités d'un matériau.
Représente un index sur les variables matériaux et milieux.
constexpr __host__ __device__ Int32 arrayIndex() const
Retourne l'indice du tableau de valeur dans la liste des variables.
constexpr __host__ __device__ Int32 valueIndex() const
Retourne l'indice dans le tableau de valeur.
Informations pour construire un module.
Options d'exécution d'une boucle parallèle en multi-thread.
void setGrainSize(Integer v)
Positionne la taille (approximative) d'un intervalle d'itération.
Vecteur 1D de données avec sémantique par valeur (style STL).
Vérification de la validité de certaines valeurs.
void areEqual(const T1 &value, const T2 &expected_value, const String &message)
Paramètres nécessaires à la construction d'une variable.
String name() const
Nom de la variable.
void arcaneParallelFor(Integer i0, Integer size, InstanceType *itype, void(InstanceType::*lambda_function)(Integer i0, Integer size))
Applique en concurrence la fonction lambda lambda_function sur l'intervalle d'itération [i0,...
__host__ __device__ Real2 min(Real2 a, Real2 b)
Retourne le minimum de deux Real2.
ItemGroupT< Cell > CellGroup
Groupe de mailles.
ItemGroupT< Face > FaceGroup
Groupe de faces.
MeshVariableScalarRefT< Cell, Real > VariableCellReal
Grandeur au centre des mailles de type réel.
MeshVariableScalarRefT< Node, Real > VariableNodeReal
Grandeur au noeud de type réel.
MeshVariableScalarRefT< Cell, Int32 > VariableCellInt32
Grandeur au centre des mailles de type entier 32 bits.
VariableRefScalarT< Int64 > VariableScalarInt64
Variable scalaire de type entier 64 bits.
auto viewOut(const ViewBuildInfo &vbi, CellMaterialVariableScalarRef< DataType > &var)
Vue en écriture pour les variables materiaux scalaire.
auto viewIn(const ViewBuildInfo &vbi, const CellMaterialVariableScalarRef< DataType > &var)
Vue en lecture pour les variables materiaux scalaire.
Real toReal(Real r)
Converti r en un Real.
Active toujours les traces dans les parties Arcane concernant les matériaux.
ComponentItemVector ComponentCellVector
Liste de ComponentCell issues d'un IMeshComponent.
ConstArrayView< IMeshComponent * > MeshComponentList
Liste de composants multi-matériaux du maillage.
CellEnvironmentVariableArrayRef< Real > EnvironmentVariableCellArrayReal
Variable milieu de type tableau de Real
CellMaterialVariableScalarRef< Int64 > MaterialVariableCellInt64
Variable matériau de type Int64
CellEnvironmentVariableScalarRef< Real > EnvironmentVariableCellReal
Variable milieu de type Real
CellMaterialVariableScalarRef< Real > MaterialVariableCellReal
Variable matériau de type Real
MatVarSpace
Espace de définition d'une variable matériau.
CellMaterialVariableScalarRef< Int32 > MaterialVariableCellInt32
Variable matériau de type Int32
CellMaterialVariableArrayRef< Real > MaterialVariableCellArrayReal
Variable matériau de type tableau de Real
void Foreach(const ItemVectorView &items_view, const ParallelLoopOptions &options, InstanceType *instance, void(InstanceType::*function)(ItemVectorViewT< ItemType > items))
@ ReduceSum
Somme des valeurs.
@ ReduceMax
Maximum des valeurs.
std::int64_t Int64
Type entier signé sur 64 bits.
Int32 Integer
Type représentant un entier.
UniqueArray< Int32 > Int32UniqueArray
Tableau dynamique à une dimension d'entiers 32 bits.
List< String > StringList
Tableau de chaînes de caractères unicode.
UniqueArray< Real > RealUniqueArray
Tableau dynamique à une dimension de réels.
double Real
Type représentant un réel.
Array< Int32 > Int32Array
Tableau dynamique à une dimension d'entiers 32 bits.
ArrayView< Real > RealArrayView
Equivalent C d'un tableau à une dimension de réels.
std::int32_t Int32
Type entier signé sur 32 bits.