1 // Copyright (C) 2007-2023 CEA, EDF, OPEN CASCADE
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License, or (at your option) any later version.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
23 // File : NETGENPlugin_Algorithm.idl
24 // Author : Julia DOROVSKIKH
26 #ifndef _SMESH_NETGENALGORITHM_IDL_
27 #define _SMESH_NETGENALGORITHM_IDL_
29 #include "SALOME_Exception.idl"
30 #include "SMESH_Hypothesis.idl"
31 #include "SMESH_Group.idl"
32 #include "GEOM_Gen.idl"
35 * NETGENPlugin: interfaces to NETGEN related hypotheses and algorithms
39 typedef sequence<string> string_array;
41 * NETGENPlugin_NETGEN_3D: interface of "Tetrahedron (Netgen)" algorithm
43 interface NETGENPlugin_NETGEN_3D : SMESH::SMESH_3D_Algo
48 * NETGENPlugin_NETGEN_3D: interface of "Remote Tetrahedron (Netgen)" algorithm
50 interface NETGENPlugin_NETGEN_3D_Remote : NETGENPlugin::NETGENPlugin_NETGEN_3D
55 * NETGENPlugin_NETGEN_2D: interface of "Netgen 1D-2D" algorithm
57 interface NETGENPlugin_NETGEN_2D : SMESH::SMESH_2D_Algo
62 * NETGENPlugin_NETGEN_2D3D: interface of "Netgen 1D-2D-3D" algorithm
64 interface NETGENPlugin_NETGEN_2D3D : SMESH::SMESH_3D_Algo
69 * NETGENPlugin_NETGEN_2D_ONLY: interface of "Netgen 2D" algorithm,
70 * generating 2D elements on a geometrical face taking
71 * into account pre-existing nodes on face boundaries
73 interface NETGENPlugin_NETGEN_2D_ONLY : SMESH::SMESH_2D_Algo
78 * NETGENPlugin_Remesher_2D: interface of "NETGEN Remesher" algorithm,
79 * generating 2D elements basing on an existing 2D mesh
81 interface NETGENPlugin_Remesher_2D : SMESH::SMESH_2D_Algo
86 * NETGENPlugin_Hypothesis: interface of "NETGEN parameters" hypothesis
88 interface NETGENPlugin_Hypothesis : SMESH::SMESH_Hypothesis
90 void SetMaxSize(in double value);
93 void SetMinSize(in double value);
96 void SetSecondOrder(in boolean value);
97 boolean GetSecondOrder();
99 void SetOptimize(in boolean value);
100 boolean GetOptimize();
102 void SetFineness(in long value);
105 void SetGrowthRate(in double value);
106 double GetGrowthRate();
108 void SetNbSegPerEdge(in double value);
109 double GetNbSegPerEdge();
111 void SetChordalErrorEnabled(in boolean value);
112 boolean GetChordalErrorEnabled();
113 void SetChordalError(in double value);
114 double GetChordalError();
116 void SetNbSegPerRadius(in double value);
117 double GetNbSegPerRadius();
119 void SetQuadAllowed(in boolean value);
120 boolean GetQuadAllowed();
122 void SetUseSurfaceCurvature(in boolean value);
123 boolean GetUseSurfaceCurvature();
125 void SetFuseEdges(in boolean value);
126 boolean GetFuseEdges();
128 void SetLocalSizeOnShape(in GEOM::GEOM_Object GeomObj, in double localSize)
129 raises (SALOME::SALOME_Exception);
130 void SetLocalSizeOnEntry(in string entry, in double localSize);
131 double GetLocalSizeOnEntry(in string entry);
132 string_array GetLocalSizeEntries();
133 void UnsetLocalSizeOnEntry(in string entry);
135 void SetMeshSizeFile(in string fileName);
136 string GetMeshSizeFile();
138 void SetNbSurfOptSteps(in short nb );
139 short GetNbSurfOptSteps();
141 void SetNbVolOptSteps(in short nb );
142 short GetNbVolOptSteps();
144 void SetElemSizeWeight(in double size );
145 double GetElemSizeWeight();
147 void SetWorstElemMeasure(in short val );
148 short GetWorstElemMeasure();
150 void SetNbThreads(in short val );
151 short GetNbThreads();
153 void SetUseDelauney(in boolean toUse);
154 boolean GetUseDelauney();
156 void SetCheckOverlapping(in boolean toCheck );
157 boolean GetCheckOverlapping();
159 void SetCheckChartBoundary(in boolean toCheck );
160 boolean GetCheckChartBoundary();
164 * NETGENPlugin_Hypothesis_2D: interface of "NETGEN 2D parameters" hypothesis
166 interface NETGENPlugin_Hypothesis_2D : NETGENPlugin_Hypothesis
171 * interface of "NETGEN 2D parameters" hypothesis used by NETGENPlugin_NETGEN_2D_ONLY algorithm
173 interface NETGENPlugin_Hypothesis_2D_ONLY : NETGENPlugin_Hypothesis_2D
178 * interface of "NETGEN 3D parameters" hypothesis used by NETGENPlugin_NETGEN_3D algorithm
180 interface NETGENPlugin_Hypothesis_3D : NETGENPlugin_Hypothesis
185 * interface of "NETGEN Remesher parameters" hypothesis used by NETGENPlugin_Remesher_2D algorithm
187 interface NETGENPlugin_RemesherHypothesis_2D : NETGENPlugin_Hypothesis_2D
190 * \brief Set/get ridge angle
192 void SetRidgeAngle(in double angle );
193 double GetRidgeAngle();
195 void SetEdgeCornerAngle(in double angle );
196 double GetEdgeCornerAngle();
198 void SetChartAngle(in double angle );
199 double GetChartAngle();
201 void SetOuterChartAngle(in double angle );
202 double GetOuterChartAngle();
204 void SetRestHChartDistFactor(in double f );
205 double GetRestHChartDistFactor();
207 void SetRestHChartDistEnable(in boolean enable );
208 boolean GetRestHChartDistEnable();
210 void SetRestHLineLengthFactor(in double f );
211 double GetRestHLineLengthFactor();
213 void SetRestHLineLengthEnable(in boolean enable );
214 boolean GetRestHLineLengthEnable();
216 void SetRestHCloseEdgeFactor(in double f );
217 double GetRestHCloseEdgeFactor();
219 void SetRestHCloseEdgeEnable(in boolean enable );
220 boolean GetRestHCloseEdgeEnable();
222 void SetRestHSurfCurvFactor(in double f );
223 double GetRestHSurfCurvFactor();
225 void SetRestHSurfCurvEnable(in boolean enable );
226 boolean GetRestHSurfCurvEnable();
228 void SetRestHEdgeAngleFactor(in double f );
229 double GetRestHEdgeAngleFactor();
231 void SetRestHEdgeAngleEnable(in boolean enable );
232 boolean GetRestHEdgeAngleEnable();
234 void SetRestHSurfMeshCurvFactor(in double f );
235 double GetRestHSurfMeshCurvFactor();
237 void SetRestHSurfMeshCurvEnable(in boolean enable );
238 boolean GetRestHSurfMeshCurvEnable();
240 void SetKeepExistingEdges(in boolean toKeep );
241 boolean GetKeepExistingEdges();
243 void SetMakeGroupsOfSurfaces(in boolean toMake );
244 boolean GetMakeGroupsOfSurfaces();
246 void SetLoadMeshOnCancel(in boolean toLoad );
247 boolean GetLoadMeshOnCancel();
249 void SetFixedEdgeGroup( in SMESH::SMESH_GroupBase edgeGroup );
250 SMESH::SMESH_GroupBase GetFixedEdgeGroup( in SMESH::SMESH_Mesh mesh );
254 * NETGENPlugin_Hypothesis: interface of "NETGEN 2D simple parameters" hypothesis
256 interface NETGENPlugin_SimpleHypothesis_2D : SMESH::SMESH_Hypothesis
259 * Sets <number of segments> value
261 void SetNumberOfSegments(in long nb) raises (SALOME::SALOME_Exception);
263 * Returns <number of segments> value.
264 * Can be zero in case if LocalLength() has been set
266 long GetNumberOfSegments();
269 * Sets <segment length> value
271 void SetLocalLength(in double segmentLength);
273 * Returns <segment length> value.
274 * Can be zero in case if NumberOfSegments() has been set
276 double GetLocalLength();
279 * Sets <maximum element area> to be dependent on 1D discretization
281 void LengthFromEdges();
283 * Sets <maximum element area> value.
284 * Zero or negative value means same as LengthFromEdges().
286 void SetMaxElementArea(in double area);
288 * Returns <maximum element area> value.
289 * Can be zero in case of LengthFromEdges()
291 double GetMaxElementArea();
294 * Enables/disables generation of quadrangular faces
296 void SetAllowQuadrangles(in boolean toAllow);
298 * Returns true if generation of quadrangular faces is enabled
300 boolean GetAllowQuadrangles();
304 * NETGENPlugin_SimpleHypothesis_3D: interface of "NETGEN 3D simple parameters" hypothesis
306 interface NETGENPlugin_SimpleHypothesis_3D : NETGENPlugin_SimpleHypothesis_2D
309 * Sets <maximum element volume> to be dependent on 2D discretization
311 void LengthFromFaces();
313 * Sets <maximum element volume> value.
314 * Zero or negative value means same as LengthFromFaces().
316 void SetMaxElementVolume(in double volume);
319 * Returns <maximum element volume> value
320 * Can be zero in case of LengthFromFaces()
322 double GetMaxElementVolume();