1 // Copyright (C) 2007-2016 CEA/DEN, EDF R&D, 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 "GEOM_Gen.idl"
34 * NETGENPlugin: interfaces to NETGEN related hypotheses and algorithms
38 typedef sequence<string> string_array;
40 * NETGENPlugin_NETGEN_3D: interface of "Tetrahedron (Netgen)" algorithm
42 interface NETGENPlugin_NETGEN_3D : SMESH::SMESH_3D_Algo
47 * NETGENPlugin_NETGEN_2D: interface of "Netgen 1D-2D" algorithm
49 interface NETGENPlugin_NETGEN_2D : SMESH::SMESH_2D_Algo
54 * NETGENPlugin_NETGEN_2D3D: interface of "Netgen 1D-2D-3D" algorithm
56 interface NETGENPlugin_NETGEN_2D3D : SMESH::SMESH_3D_Algo
61 * NETGENPlugin_NETGEN_2D_ONLY: interface of "Netgen 2D" algorithm,
62 * generating 2D elements on a geometrical face taking
63 * into account pre-existing nodes on face boundaries
65 interface NETGENPlugin_NETGEN_2D_ONLY : SMESH::SMESH_2D_Algo
70 * NETGENPlugin_Remesher_2D: interface of "NETGEN Remesher" algorithm,
71 * generating 2D elements basing on an existing 2D mesh
73 interface NETGENPlugin_Remesher_2D : SMESH::SMESH_2D_Algo
78 * NETGENPlugin_Hypothesis: interface of "NETGEN parameters" hypothesis
80 interface NETGENPlugin_Hypothesis : SMESH::SMESH_Hypothesis
82 void SetMaxSize(in double value);
85 void SetMinSize(in double value);
88 void SetSecondOrder(in boolean value);
89 boolean GetSecondOrder();
91 void SetOptimize(in boolean value);
92 boolean GetOptimize();
94 void SetFineness(in long value);
97 void SetGrowthRate(in double value);
98 double GetGrowthRate();
100 void SetNbSegPerEdge(in double value);
101 double GetNbSegPerEdge();
103 void SetChordalErrorEnabled(in boolean value);
104 boolean GetChordalErrorEnabled();
105 void SetChordalError(in double value);
106 double GetChordalError();
108 void SetNbSegPerRadius(in double value);
109 double GetNbSegPerRadius();
111 void SetQuadAllowed(in boolean value);
112 boolean GetQuadAllowed();
114 void SetUseSurfaceCurvature(in boolean value);
115 boolean GetUseSurfaceCurvature();
117 void SetFuseEdges(in boolean value);
118 boolean GetFuseEdges();
120 void SetLocalSizeOnShape(in GEOM::GEOM_Object GeomObj, in double localSize)
121 raises (SALOME::SALOME_Exception);
122 void SetLocalSizeOnEntry(in string entry, in double localSize);
123 double GetLocalSizeOnEntry(in string entry);
124 string_array GetLocalSizeEntries();
125 void UnsetLocalSizeOnEntry(in string entry);
127 void SetMeshSizeFile(in string fileName);
128 string GetMeshSizeFile();
132 * NETGENPlugin_Hypothesis_2D: interface of "NETGEN 2D parameters" hypothesis
134 interface NETGENPlugin_Hypothesis_2D : NETGENPlugin_Hypothesis
139 * interface of "NETGEN 2D parameters" hypothesis used by NETGENPlugin_NETGEN_2D_ONLY algorithm
141 interface NETGENPlugin_Hypothesis_2D_ONLY : NETGENPlugin_Hypothesis_2D
146 * interface of "NETGEN 3D parameters" hypothesis used by NETGENPlugin_NETGEN_3D algorithm
148 interface NETGENPlugin_Hypothesis_3D : NETGENPlugin_Hypothesis
153 * interface of "NETGEN Remesher parameters" hypothesis used by NETGENPlugin_Remesher_2D algorithm
155 interface NETGENPlugin_RemesherHypothesis_2D : NETGENPlugin_Hypothesis_2D
158 * \brief Set/get ridge angle
160 void SetRidgeAngle(in double angle );
161 double GetRidgeAngle();
165 * NETGENPlugin_Hypothesis: interface of "NETGEN 2D simple parameters" hypothesis
167 interface NETGENPlugin_SimpleHypothesis_2D : SMESH::SMESH_Hypothesis
170 * Sets <number of segments> value
172 void SetNumberOfSegments(in short nb) raises (SALOME::SALOME_Exception);
174 * Returns <number of segments> value.
175 * Can be zero in case if LocalLength() has been set
177 short GetNumberOfSegments();
180 * Sets <segment length> value
182 void SetLocalLength(in double segmentLength);
184 * Returns <segment length> value.
185 * Can be zero in case if NumberOfSegments() has been set
187 double GetLocalLength();
190 * Sets <maximum element area> to be dependent on 1D discretization
192 void LengthFromEdges();
194 * Sets <maximum element area> value.
195 * Zero or negative value means same as LengthFromEdges().
197 void SetMaxElementArea(in double area);
199 * Returns <maximum element area> value.
200 * Can be zero in case of LengthFromEdges()
202 double GetMaxElementArea();
205 * Enables/disables generation of quadrangular faces
207 void SetAllowQuadrangles(in boolean toAllow);
209 * Returns true if generation of quadrangular faces is enabled
211 boolean GetAllowQuadrangles();
215 * NETGENPlugin_SimpleHypothesis_3D: interface of "NETGEN 3D simple parameters" hypothesis
217 interface NETGENPlugin_SimpleHypothesis_3D : NETGENPlugin_SimpleHypothesis_2D
220 * Sets <maximum element volume> to be dependent on 2D discretization
222 void LengthFromFaces();
224 * Sets <maximum element volume> value.
225 * Zero or negative value means same as LengthFromFaces().
227 void SetMaxElementVolume(in double volume);
230 * Returns <maximum element volume> value
231 * Can be zero in case of LengthFromFaces()
233 double GetMaxElementVolume();