mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-19 07:30:36 +05:00
add and fix methods of GHS3D and BLSURF hypotheses
This commit is contained in:
parent
70f7bf5c7d
commit
570bbfb2ff
@ -87,6 +87,15 @@ Fine = 3
|
|||||||
VeryFine = 4
|
VeryFine = 4
|
||||||
Custom = 5
|
Custom = 5
|
||||||
|
|
||||||
|
# Optimization level of GHS3D
|
||||||
|
None_Optimization, Light_Optimization, Medium_Optimization, Strong_Optimization = 0,1,2,3
|
||||||
|
|
||||||
|
# Topology treatment way of BLSURF
|
||||||
|
FromCAD, PreProcess, PreProcessPlus = 0,1,2
|
||||||
|
|
||||||
|
# Element size flag of BLSURF
|
||||||
|
DefaultSize, DefaultGeom, Custom = 0,0,1
|
||||||
|
|
||||||
PrecisionConfusion = 1e-07
|
PrecisionConfusion = 1e-07
|
||||||
|
|
||||||
def IsEqual(val1, val2, tol=PrecisionConfusion):
|
def IsEqual(val1, val2, tol=PrecisionConfusion):
|
||||||
@ -2896,46 +2905,66 @@ class Mesh_Triangle(Mesh_Algorithm):
|
|||||||
print "Netgen 1D-2D algo doesn't support this hypothesis"
|
print "Netgen 1D-2D algo doesn't support this hypothesis"
|
||||||
return None
|
return None
|
||||||
|
|
||||||
## Sets PhysicalMesh
|
## Sets a way to define size of mesh elements to generate
|
||||||
# @param thePhysicalMesh is:
|
# @param thePhysicalMesh is: DefaultSize or Custom
|
||||||
# DefaultSize or Custom
|
# Parameter of BLSURF algo
|
||||||
def SetPhysicalMesh(self, thePhysicalMesh=1):
|
def SetPhysicalMesh(self, thePhysicalMesh=DefaultSize):
|
||||||
if self.params == 0:
|
if self.params == 0:
|
||||||
self.Parameters()
|
self.Parameters()
|
||||||
self.params.SetPhysicalMesh(thePhysicalMesh)
|
self.params.SetPhysicalMesh(thePhysicalMesh)
|
||||||
|
|
||||||
## Sets PhySize flag
|
## Sets size of mesh elements to generate
|
||||||
|
# Parameter of BLSURF algo
|
||||||
def SetPhySize(self, theVal):
|
def SetPhySize(self, theVal):
|
||||||
if self.params == 0:
|
if self.params == 0:
|
||||||
self.Parameters()
|
self.Parameters()
|
||||||
self.params.SetPhySize(theVal)
|
self.params.SetPhySize(theVal)
|
||||||
|
|
||||||
## Sets GeometricMesh
|
## Sets a way to define maximum angular deflection of mesh from CAD model
|
||||||
# @param theGeometricMesh is:
|
# @param theGeometricMesh is: DefaultGeom or Custom
|
||||||
# DefaultGeom or Custom
|
# Parameter of BLSURF algo
|
||||||
def SetGeometricMesh(self, theGeometricMesh=0):
|
def SetGeometricMesh(self, theGeometricMesh=0):
|
||||||
if self.params == 0:
|
if self.params == 0:
|
||||||
self.Parameters()
|
self.Parameters()
|
||||||
if self.params.GetPhysicalMesh() == 0: theGeometricMesh = 1
|
if self.params.GetPhysicalMesh() == 0: theGeometricMesh = 1
|
||||||
self.params.SetGeometricMesh(theGeometricMesh)
|
self.params.SetGeometricMesh(theGeometricMesh)
|
||||||
|
|
||||||
## Sets AngleMeshS flag
|
## Sets angular deflection (in degrees) of mesh from CAD model
|
||||||
|
# Parameter of BLSURF algo
|
||||||
def SetAngleMeshS(self, theVal=_angleMeshS):
|
def SetAngleMeshS(self, theVal=_angleMeshS):
|
||||||
if self.params == 0:
|
if self.params == 0:
|
||||||
self.Parameters()
|
self.Parameters()
|
||||||
if self.params.GetGeometricMesh() == 0: theVal = self._angleMeshS
|
if self.params.GetGeometricMesh() == 0: theVal = self._angleMeshS
|
||||||
self.params.SetAngleMeshS(theVal)
|
self.params.SetAngleMeshS(theVal)
|
||||||
|
|
||||||
## Sets Gradation flag
|
## Sets maximal allowed ratio between the lengths of two adjacent edges
|
||||||
|
# Parameter of BLSURF algo
|
||||||
def SetGradation(self, theVal=_gradation):
|
def SetGradation(self, theVal=_gradation):
|
||||||
if self.params == 0:
|
if self.params == 0:
|
||||||
self.Parameters()
|
self.Parameters()
|
||||||
if self.params.GetGeometricMesh() == 0: theVal = self._gradation
|
if self.params.GetGeometricMesh() == 0: theVal = self._gradation
|
||||||
self.params.SetGradation(theVal)
|
self.params.SetGradation(theVal)
|
||||||
|
|
||||||
|
## Sets topology usage way defining how mesh conformity is assured:
|
||||||
|
# FromCAD, PreProcess or PreProcessPlus
|
||||||
|
# FromCAD - mesh conformity is assured by conformity of a shape
|
||||||
|
# PreProcess or PreProcessPlus - by pre-processing a CAD model
|
||||||
|
# Parameter of BLSURF algo
|
||||||
|
def SetTopology(self, way):
|
||||||
|
if self.params == 0:
|
||||||
|
self.Parameters()
|
||||||
|
self.params.SetTopology(way)
|
||||||
|
|
||||||
|
## To respect geometrical edges or not
|
||||||
|
# Parameter of BLSURF algo
|
||||||
|
def SetDecimesh(self, toIgnoreEdges=False):
|
||||||
|
if self.params == 0:
|
||||||
|
self.Parameters()
|
||||||
|
self.params.SetDecimesh(toIgnoreEdges)
|
||||||
|
|
||||||
## Sets QuadAllowed flag
|
## Sets QuadAllowed flag
|
||||||
#
|
#
|
||||||
# Only for algoType == NETGEN || NETGEN_2D
|
# Only for algoType == NETGEN || NETGEN_2D || BLSURF
|
||||||
def SetQuadAllowed(self, toAllow=True):
|
def SetQuadAllowed(self, toAllow=True):
|
||||||
if self.algoType == NETGEN_2D:
|
if self.algoType == NETGEN_2D:
|
||||||
if toAllow: # add QuadranglePreference
|
if toAllow: # add QuadranglePreference
|
||||||
@ -2958,6 +2987,8 @@ class Mesh_Triangle(Mesh_Algorithm):
|
|||||||
#
|
#
|
||||||
# Only for algoType == NETGEN
|
# Only for algoType == NETGEN
|
||||||
def Parameters(self):
|
def Parameters(self):
|
||||||
|
if self.params:
|
||||||
|
return self.params
|
||||||
if self.algoType == NETGEN:
|
if self.algoType == NETGEN:
|
||||||
self.params = self.Hypothesis("NETGEN_Parameters_2D", [],
|
self.params = self.Hypothesis("NETGEN_Parameters_2D", [],
|
||||||
"libNETGENEngine.so", UseExisting=0)
|
"libNETGENEngine.so", UseExisting=0)
|
||||||
@ -3040,12 +3071,6 @@ class Mesh_Triangle(Mesh_Algorithm):
|
|||||||
if self.params is not None:
|
if self.params is not None:
|
||||||
self.params.SetNbSegPerRadius(theVal)
|
self.params.SetNbSegPerRadius(theVal)
|
||||||
|
|
||||||
## Sets Decimesh flag
|
|
||||||
def SetDecimesh(self, toAllow=False):
|
|
||||||
if self.params == 0:
|
|
||||||
self.Parameters()
|
|
||||||
self.params.SetDecimesh(toAllow)
|
|
||||||
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
@ -3087,17 +3112,17 @@ class Mesh_Tetrahedron(Mesh_Algorithm):
|
|||||||
self.Create(mesh, geom, "NETGEN_3D", "libNETGENEngine.so")
|
self.Create(mesh, geom, "NETGEN_3D", "libNETGENEngine.so")
|
||||||
pass
|
pass
|
||||||
|
|
||||||
elif algoType == GHS3D:
|
|
||||||
import GHS3DPlugin
|
|
||||||
self.Create(mesh, geom, "GHS3D_3D" , "libGHS3DEngine.so")
|
|
||||||
pass
|
|
||||||
|
|
||||||
elif algoType == FULL_NETGEN:
|
elif algoType == FULL_NETGEN:
|
||||||
if noNETGENPlugin:
|
if noNETGENPlugin:
|
||||||
print "Warning: NETGENPlugin module has not been imported."
|
print "Warning: NETGENPlugin module has not been imported."
|
||||||
self.Create(mesh, geom, "NETGEN_2D3D", "libNETGENEngine.so")
|
self.Create(mesh, geom, "NETGEN_2D3D", "libNETGENEngine.so")
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
elif algoType == GHS3D:
|
||||||
|
import GHS3DPlugin
|
||||||
|
self.Create(mesh, geom, "GHS3D_3D" , "libGHS3DEngine.so")
|
||||||
|
pass
|
||||||
|
|
||||||
self.algoType = algoType
|
self.algoType = algoType
|
||||||
|
|
||||||
## Defines "MaxElementVolume" hypothesis to give the maximun volume of each tetrahedron
|
## Defines "MaxElementVolume" hypothesis to give the maximun volume of each tetrahedron
|
||||||
@ -3120,23 +3145,30 @@ class Mesh_Tetrahedron(Mesh_Algorithm):
|
|||||||
self.params = self.Hypothesis("NETGEN_Parameters", [],
|
self.params = self.Hypothesis("NETGEN_Parameters", [],
|
||||||
"libNETGENEngine.so", UseExisting=0)
|
"libNETGENEngine.so", UseExisting=0)
|
||||||
return self.params
|
return self.params
|
||||||
else:
|
if (self.algoType == GHS3D):
|
||||||
|
self.params = self.Hypothesis("GHS3D_Parameters", [],
|
||||||
|
"libGHS3DEngine.so", UseExisting=0)
|
||||||
|
return self.params
|
||||||
|
|
||||||
print "Algo doesn't support this hypothesis"
|
print "Algo doesn't support this hypothesis"
|
||||||
return None
|
return None
|
||||||
|
|
||||||
## Sets MaxSize
|
## Sets MaxSize
|
||||||
|
# Parameter of FULL_NETGEN
|
||||||
def SetMaxSize(self, theSize):
|
def SetMaxSize(self, theSize):
|
||||||
if self.params == 0:
|
if self.params == 0:
|
||||||
self.Parameters()
|
self.Parameters()
|
||||||
self.params.SetMaxSize(theSize)
|
self.params.SetMaxSize(theSize)
|
||||||
|
|
||||||
## Sets SecondOrder flag
|
## Sets SecondOrder flag
|
||||||
|
# Parameter of FULL_NETGEN
|
||||||
def SetSecondOrder(self, theVal):
|
def SetSecondOrder(self, theVal):
|
||||||
if self.params == 0:
|
if self.params == 0:
|
||||||
self.Parameters()
|
self.Parameters()
|
||||||
self.params.SetSecondOrder(theVal)
|
self.params.SetSecondOrder(theVal)
|
||||||
|
|
||||||
## Sets Optimize flag
|
## Sets Optimize flag
|
||||||
|
# Parameter of FULL_NETGEN
|
||||||
def SetOptimize(self, theVal):
|
def SetOptimize(self, theVal):
|
||||||
if self.params == 0:
|
if self.params == 0:
|
||||||
self.Parameters()
|
self.Parameters()
|
||||||
@ -3145,29 +3177,72 @@ class Mesh_Tetrahedron(Mesh_Algorithm):
|
|||||||
## Sets Fineness
|
## Sets Fineness
|
||||||
# @param theFineness is:
|
# @param theFineness is:
|
||||||
# VeryCoarse, Coarse, Moderate, Fine, VeryFine or Custom
|
# VeryCoarse, Coarse, Moderate, Fine, VeryFine or Custom
|
||||||
|
# Parameter of FULL_NETGEN
|
||||||
def SetFineness(self, theFineness):
|
def SetFineness(self, theFineness):
|
||||||
if self.params == 0:
|
if self.params == 0:
|
||||||
self.Parameters()
|
self.Parameters()
|
||||||
self.params.SetFineness(theFineness)
|
self.params.SetFineness(theFineness)
|
||||||
|
|
||||||
## Sets GrowthRate
|
## Sets GrowthRate
|
||||||
|
# Parameter of FULL_NETGEN
|
||||||
def SetGrowthRate(self, theRate):
|
def SetGrowthRate(self, theRate):
|
||||||
if self.params == 0:
|
if self.params == 0:
|
||||||
self.Parameters()
|
self.Parameters()
|
||||||
self.params.SetGrowthRate(theRate)
|
self.params.SetGrowthRate(theRate)
|
||||||
|
|
||||||
## Sets NbSegPerEdge
|
## Sets NbSegPerEdge
|
||||||
|
# Parameter of FULL_NETGEN
|
||||||
def SetNbSegPerEdge(self, theVal):
|
def SetNbSegPerEdge(self, theVal):
|
||||||
if self.params == 0:
|
if self.params == 0:
|
||||||
self.Parameters()
|
self.Parameters()
|
||||||
self.params.SetNbSegPerEdge(theVal)
|
self.params.SetNbSegPerEdge(theVal)
|
||||||
|
|
||||||
## Sets NbSegPerRadius
|
## Sets NbSegPerRadius
|
||||||
|
# Parameter of FULL_NETGEN
|
||||||
def SetNbSegPerRadius(self, theVal):
|
def SetNbSegPerRadius(self, theVal):
|
||||||
if self.params == 0:
|
if self.params == 0:
|
||||||
self.Parameters()
|
self.Parameters()
|
||||||
self.params.SetNbSegPerRadius(theVal)
|
self.params.SetNbSegPerRadius(theVal)
|
||||||
|
|
||||||
|
## To mesh "holes" in a solid or not. Default is to mesh.
|
||||||
|
# Parameter of GHS3D
|
||||||
|
def SetToMeshHoles(self, toMesh):
|
||||||
|
if self.params == 0: self.Parameters()
|
||||||
|
self.params.SetToMeshHoles(toMesh)
|
||||||
|
|
||||||
|
## Set Optimization level:
|
||||||
|
# None_Optimization, Light_Optimization, Medium_Optimization, Strong_Optimization.
|
||||||
|
# Default is Medium_Optimization
|
||||||
|
# Parameter of GHS3D
|
||||||
|
def SetOptimizationLevel(self, level):
|
||||||
|
if self.params == 0: self.Parameters()
|
||||||
|
self.params.SetOptimizationLevel(level)
|
||||||
|
|
||||||
|
## Maximal size of memory to be used by the algorithm (in Megabytes).
|
||||||
|
# Advanced parameter of GHS3D
|
||||||
|
def SetMaximumMemory(self, MB):
|
||||||
|
if self.params == 0: self.Parameters()
|
||||||
|
self.params.SetMaximumMemory(MB)
|
||||||
|
|
||||||
|
## Initial size of memory to be used by the algorithm (in Megabytes) in
|
||||||
|
# automatic memory adjustment mode
|
||||||
|
# Advanced parameter of GHS3D
|
||||||
|
def SetInitialMemory(self, MB):
|
||||||
|
if self.params == 0: self.Parameters()
|
||||||
|
self.params.SetInitialMemory(MB)
|
||||||
|
|
||||||
|
## Path to working directory
|
||||||
|
# Advanced parameter of GHS3D
|
||||||
|
def SetWorkingDirectory(self, path):
|
||||||
|
if self.params == 0: self.Parameters()
|
||||||
|
self.params.SetWorkingDirectory(path)
|
||||||
|
|
||||||
|
## To keep working files or remove them. Log file remains in case of errors anyway
|
||||||
|
# Advanced parameter of GHS3D
|
||||||
|
def SetKeepFiles(self, toKeep):
|
||||||
|
if self.params == 0: self.Parameters()
|
||||||
|
self.params.SetKeepFiles(toKeep)
|
||||||
|
|
||||||
# Public class: Mesh_Hexahedron
|
# Public class: Mesh_Hexahedron
|
||||||
# ------------------------------
|
# ------------------------------
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user