Version: 6.3.1
Public Member Functions | Data Fields

smeshDC.Mesh_RadialQuadrangle1D2D Class Reference

Defines a Radial Quadrangle 1D2D algorithm. More...

Inheritance diagram for smeshDC.Mesh_RadialQuadrangle1D2D:
Inheritance graph
[legend]

Public Member Functions

def __init__
 Private constructor.
def Get2DHypothesis
 Return 2D hypothesis holding the 1D one.
def OwnHypothesis
 Private method creating a 1D hypothesis and storing it in the LayerDistribution hypothesis.
def NumberOfLayers
 Defines "NumberOfLayers" hypothesis, specifying the number of layers.
def CompareNumberOfLayers
 Checks if the given "NumberOfLayers" hypothesis has the same parameters as the given arguments.
def LocalLength
 Defines "LocalLength" hypothesis, specifying the segment length.
def NumberOfSegments
 Defines "NumberOfSegments" hypothesis, specifying the number of layers.
def Arithmetic1D
 Defines "Arithmetic1D" hypothesis, specifying the distribution of segments with a length that changes in arithmetic progression.
def StartEndLength
 Defines "StartEndLength" hypothesis, specifying distribution of segments as geometric length increasing.
def AutomaticLength
 Defines "AutomaticLength" hypothesis, specifying the number of segments.
def FindHypothesis
 Finds a hypothesis in the study by its type name and parameters.
def FindAlgorithm
 Finds the algorithm in the study by its type name.
def GetSubMesh
 If the algorithm is global, returns 0;
else returns the submesh associated to this algorithm.
def GetAlgorithm
 Returns the wrapped mesher.
def GetCompatibleHypothesis
 Gets the list of hypothesis that can be used with this algorithm.
def GetName
 Gets the name of the algorithm.
def SetName
 Sets the name to the algorithm.
def GetId
 Gets the id of the algorithm.
def Create
 Private method.
def Assign
 Private method.
def CompareHyp
def CompareEqualHyp
def Hypothesis
 Private method.
def MainShapeEntry
 Returns entry of the shape to mesh in the study.
def ViscousLayers
 Defines "ViscousLayers" hypothesis to give parameters of layers of prisms to build near mesh boundary.

Data Fields

 distribHyp
 nbLayers
 mesh
 geom
 subm
 algo

Detailed Description

Defines a Radial Quadrangle 1D2D algorithm.

Definition at line 5933 of file smeshDC.py.


Constructor & Destructor Documentation

def smeshDC.Mesh_RadialQuadrangle1D2D.__init__ (   self,
  mesh,
  geom = 0 
)

Private constructor.

Definition at line 5936 of file smeshDC.py.

05937                                     :
05938         Mesh_Algorithm.__init__(self)
05939         self.Create(mesh, geom, "RadialQuadrangle_1D2D")
05940 
05941         self.distribHyp = None #self.Hypothesis("LayerDistribution2D", UseExisting=0)
05942         self.nbLayers = None


Member Function Documentation

def smeshDC.Mesh_RadialQuadrangle1D2D.Arithmetic1D (   self,
  start,
  end 
)

Defines "Arithmetic1D" hypothesis, specifying the distribution of segments with a length that changes in arithmetic progression.

Parameters:
startthe length of the first segment
endthe length of the last segment

Definition at line 6006 of file smeshDC.py.

06007                                        :
06008         hyp = self.OwnHypothesis("Arithmetic1D", [start, end])
06009         hyp.SetLength(start, 1)
06010         hyp.SetLength(end  , 0)
06011         return hyp

def smeshDC.Mesh_Algorithm.Assign (   self,
  algo,
  mesh,
  geom 
) [inherited]

Private method.

Definition at line 4403 of file smeshDC.py.

04404                                       :
04405         if geom is None:
04406             raise RuntimeError, "Attemp to create " + algo + " algoritm on None shape"
04407         self.mesh = mesh
04408         name = ""
04409         if not geom:
04410             self.geom = mesh.geom
04411         else:
04412             self.geom = geom
04413             AssureGeomPublished( mesh, geom )
04414             try:
04415                 name = GetName(geom)
04416                 pass
04417             except:
04418                 pass
04419             self.subm = mesh.mesh.GetSubMesh(geom, algo.GetName())
04420         self.algo = algo
04421         status = mesh.mesh.AddHypothesis(self.geom, self.algo)
04422         TreatHypoStatus( status, algo.GetName(), name, True )
04423         return

def smeshDC.Mesh_RadialQuadrangle1D2D.AutomaticLength (   self,
  fineness = 0 
)

Defines "AutomaticLength" hypothesis, specifying the number of segments.

Parameters:
finenessdefines the quality of the mesh within the range [0-1]

Definition at line 6024 of file smeshDC.py.

06025                                          :
06026         hyp = self.OwnHypothesis("AutomaticLength")
06027         hyp.SetFineness( fineness )
06028         return hyp
06029 
06030 
06031 # Public class: Mesh_UseExistingElements
# --------------------------------------
def smeshDC.Mesh_Algorithm.CompareEqualHyp (   self,
  hyp,
  args 
) [inherited]

Definition at line 4428 of file smeshDC.py.

04429                                          :
04430         return True

def smeshDC.Mesh_Algorithm.CompareHyp (   self,
  hyp,
  args 
) [inherited]

Definition at line 4424 of file smeshDC.py.

04425                                     :
04426         print "CompareHyp is not implemented for ", self.__class__.__name__, ":", hyp.GetName()
04427         return False

def smeshDC.Mesh_RadialQuadrangle1D2D.CompareNumberOfLayers (   self,
  hyp,
  args 
)

Checks if the given "NumberOfLayers" hypothesis has the same parameters as the given arguments.

Definition at line 5977 of file smeshDC.py.

05978                                               :
05979         return IsEqual(hyp.GetNumberOfLayers(), args[0])

def smeshDC.Mesh_Algorithm.Create (   self,
  mesh,
  geom,
  hypo,
  so = "libStdMeshersEngine.so" 
) [inherited]

Private method.

Definition at line 4392 of file smeshDC.py.

04393                                                                    :
04394         if geom is None:
04395             raise RuntimeError, "Attemp to create " + hypo + " algoritm on None shape"
04396         algo = self.FindAlgorithm(hypo, mesh.smeshpyD)
04397         if algo is None:
04398             algo = mesh.smeshpyD.CreateHypothesis(hypo, so)
04399             pass
04400         self.Assign(algo, mesh, geom)
04401         return self.algo

def smeshDC.Mesh_Algorithm.FindAlgorithm (   self,
  algoname,
  smeshpyD 
) [inherited]

Finds the algorithm in the study by its type name.

Finds only the algorithms, which have been created in smeshpyD engine.

Returns:
SMESH.SMESH_Algo

Definition at line 4327 of file smeshDC.py.

04328                                                 :
04329         study = smeshpyD.GetCurrentStudy()
04330         #to do: find component by smeshpyD object, not by its data type
04331         scomp = study.FindComponent(smeshpyD.ComponentDataType())
04332         if scomp is not None:
04333             res,hypRoot = scomp.FindSubObject(SMESH.Tag_AlgorithmsRoot)
04334             # Check if the root label of the algorithms exists
04335             if res and hypRoot is not None:
04336                 iter = study.NewChildIterator(hypRoot)
04337                 # Check all published algorithms
04338                 while iter.More():
04339                     algo_so_i = iter.Value()
04340                     attr = algo_so_i.FindAttribute("AttributeIOR")[1]
04341                     if attr is not None:
04342                         anIOR = attr.Value()
04343                         algo_o_i = salome.orb.string_to_object(anIOR)
04344                         if algo_o_i is not None:
04345                             # Check if this is an algorithm
04346                             algo_i = algo_o_i._narrow(SMESH.SMESH_Algo)
04347                             if algo_i is not None:
04348                                 # Checks if the algorithm belongs to the current engine
04349                                 if smeshpyD.GetObjectId(algo_i) > 0:
04350                                     # Check if this is the required algorithm
04351                                     if algo_i.GetName() == algoname:
04352                                         # found!!!
04353                                         return algo_i
04354                                     pass
04355                                 pass
04356                             pass
04357                         pass
04358                     iter.Next()
04359                     pass
04360                 pass
04361             pass
04362         return None

def smeshDC.Mesh_Algorithm.FindHypothesis (   self,
  hypname,
  args,
  CompareMethod,
  smeshpyD 
) [inherited]

Finds a hypothesis in the study by its type name and parameters.

Finds only the hypotheses created in smeshpyD engine.

Returns:
SMESH.SMESH_Hypothesis

Definition at line 4285 of file smeshDC.py.

04286                                                                      :
04287         study = smeshpyD.GetCurrentStudy()
04288         #to do: find component by smeshpyD object, not by its data type
04289         scomp = study.FindComponent(smeshpyD.ComponentDataType())
04290         if scomp is not None:
04291             res,hypRoot = scomp.FindSubObject(SMESH.Tag_HypothesisRoot)
04292             # Check if the root label of the hypotheses exists
04293             if res and hypRoot is not None:
04294                 iter = study.NewChildIterator(hypRoot)
04295                 # Check all published hypotheses
04296                 while iter.More():
04297                     hypo_so_i = iter.Value()
04298                     attr = hypo_so_i.FindAttribute("AttributeIOR")[1]
04299                     if attr is not None:
04300                         anIOR = attr.Value()
04301                         hypo_o_i = salome.orb.string_to_object(anIOR)
04302                         if hypo_o_i is not None:
04303                             # Check if this is a hypothesis
04304                             hypo_i = hypo_o_i._narrow(SMESH.SMESH_Hypothesis)
04305                             if hypo_i is not None:
04306                                 # Check if the hypothesis belongs to current engine
04307                                 if smeshpyD.GetObjectId(hypo_i) > 0:
04308                                     # Check if this is the required hypothesis
04309                                     if hypo_i.GetName() == hypname:
04310                                         # Check arguments
04311                                         if CompareMethod(hypo_i, args):
04312                                             # found!!!
04313                                             return hypo_i
04314                                         pass
04315                                     pass
04316                                 pass
04317                             pass
04318                         pass
04319                     iter.Next()
04320                     pass
04321                 pass
04322             pass
04323         return None

def smeshDC.Mesh_RadialQuadrangle1D2D.Get2DHypothesis (   self)

Return 2D hypothesis holding the 1D one.

Definition at line 5944 of file smeshDC.py.

05945                              :
05946         return self.distribHyp

def smeshDC.Mesh_Algorithm.GetAlgorithm (   self) [inherited]

Returns the wrapped mesher.

Definition at line 4369 of file smeshDC.py.

04370                           :
04371         return self.algo

def smeshDC.Mesh_Algorithm.GetCompatibleHypothesis (   self) [inherited]

Gets the list of hypothesis that can be used with this algorithm.

Definition at line 4373 of file smeshDC.py.

04374                                      :
04375         mylist = []
04376         if self.algo:
04377             mylist = self.algo.GetCompatibleHypothesis()
04378         return mylist

def smeshDC.Mesh_Algorithm.GetId (   self) [inherited]

Gets the id of the algorithm.

Definition at line 4388 of file smeshDC.py.

04389                    :
04390         return self.algo.GetId()

def smeshDC.Mesh_Algorithm.GetName (   self) [inherited]

Gets the name of the algorithm.

Definition at line 4380 of file smeshDC.py.

04381                      :
04382         GetName(self.algo)

def smeshDC.Mesh_Algorithm.GetSubMesh (   self) [inherited]

If the algorithm is global, returns 0;
else returns the submesh associated to this algorithm.

Definition at line 4365 of file smeshDC.py.

04366                         :
04367         return self.subm

def smeshDC.Mesh_Algorithm.Hypothesis (   self,
  hyp,
  args = [],
  so = "libStdMeshersEngine.so",
  UseExisting = 0,
  CompareMethod = "" 
) [inherited]

Private method.

Definition at line 4432 of file smeshDC.py.

04434                                                     :
04435         hypo = None
04436         if UseExisting:
04437             if CompareMethod == "": CompareMethod = self.CompareHyp
04438             hypo = self.FindHypothesis(hyp, args, CompareMethod, self.mesh.smeshpyD)
04439             pass
04440         if hypo is None:
04441             hypo = self.mesh.smeshpyD.CreateHypothesis(hyp, so)
04442             a = ""
04443             s = "="
04444             i = 0
04445             n = len(args)
04446             while i<n:
04447                 a = a + s + str(args[i])
04448                 s = ","
04449                 i = i + 1
04450                 pass
04451             self.mesh.smeshpyD.SetName(hypo, hyp + a)
04452             pass
04453         geomName=""
04454         if self.geom:
04455             geomName = GetName(self.geom)
04456         status = self.mesh.mesh.AddHypothesis(self.geom, hypo)
04457         TreatHypoStatus( status, GetName(hypo), geomName, 0 )
04458         return hypo

def smeshDC.Mesh_RadialQuadrangle1D2D.LocalLength (   self,
  l,
  p = 1e-07 
)

Defines "LocalLength" hypothesis, specifying the segment length.

Parameters:
lthe length of segments
pthe precision of rounding

Definition at line 5983 of file smeshDC.py.

05984                                      :
05985         hyp = self.OwnHypothesis("LocalLength", [l,p])
05986         hyp.SetLength(l)
05987         hyp.SetPrecision(p)
05988         return hyp

def smeshDC.Mesh_Algorithm.MainShapeEntry (   self) [inherited]

Returns entry of the shape to mesh in the study.

Definition at line 4460 of file smeshDC.py.

04461                             :
04462         entry = ""
04463         if not self.mesh or not self.mesh.GetMesh(): return entry
04464         if not self.mesh.GetMesh().HasShapeToMesh(): return entry
04465         study = self.mesh.smeshpyD.GetCurrentStudy()
04466         ior  = salome.orb.object_to_string( self.mesh.GetShape() )
04467         sobj = study.FindObjectIOR(ior)
04468         if sobj: entry = sobj.GetID()
04469         if not entry: return ""
04470         return entry

def smeshDC.Mesh_RadialQuadrangle1D2D.NumberOfLayers (   self,
  n,
  UseExisting = 0 
)

Defines "NumberOfLayers" hypothesis, specifying the number of layers.

Parameters:
nnumber of layers
UseExistingif ==true - searches for the existing hypothesis created with the same parameters, else (default) - creates a new one

Definition at line 5968 of file smeshDC.py.

05969                                               :
05970         if self.distribHyp:
05971             self.mesh.GetMesh().RemoveHypothesis( self.geom, self.distribHyp )
05972         self.nbLayers = self.Hypothesis("NumberOfLayers2D", [n], UseExisting=UseExisting,
05973                                         CompareMethod=self.CompareNumberOfLayers)
05974         self.nbLayers.SetNumberOfLayers( n )
05975         return self.nbLayers

def smeshDC.Mesh_RadialQuadrangle1D2D.NumberOfSegments (   self,
  n,
  s = [] 
)

Defines "NumberOfSegments" hypothesis, specifying the number of layers.

Parameters:
nthe number of layers
sthe scale factor (optional)

Definition at line 5992 of file smeshDC.py.

05993                                        :
05994         if s == []:
05995             hyp = self.OwnHypothesis("NumberOfSegments", [n])
05996         else:
05997             hyp = self.OwnHypothesis("NumberOfSegments", [n,s])
05998             hyp.SetDistrType( 1 )
05999             hyp.SetScaleFactor(s)
06000         hyp.SetNumberOfSegments(n)
06001         return hyp

def smeshDC.Mesh_RadialQuadrangle1D2D.OwnHypothesis (   self,
  hypType,
  args = [],
  so = "libStdMeshersEngine.so" 
)

Private method creating a 1D hypothesis and storing it in the LayerDistribution hypothesis.

Returns the created hypothesis

Definition at line 5949 of file smeshDC.py.

05950                                                                           :
05951         #print "OwnHypothesis",hypType
05952         if self.nbLayers:
05953             self.mesh.GetMesh().RemoveHypothesis( self.geom, self.nbLayers )
05954         if self.distribHyp is None:
05955             self.distribHyp = self.Hypothesis("LayerDistribution2D", UseExisting=0)
05956         else:
05957             self.mesh.GetMesh().AddHypothesis( self.geom, self.distribHyp )
05958         study = self.mesh.smeshpyD.GetCurrentStudy() # prevents publishing own 1D hypothesis
05959         self.mesh.smeshpyD.SetCurrentStudy( None )
05960         hyp = self.mesh.smeshpyD.CreateHypothesis(hypType, so)
05961         self.mesh.smeshpyD.SetCurrentStudy( study ) # enables publishing
05962         self.distribHyp.SetLayerDistribution( hyp )
05963         return hyp

def smeshDC.Mesh_Algorithm.SetName (   self,
  name 
) [inherited]

Sets the name to the algorithm.

Definition at line 4384 of file smeshDC.py.

04385                            :
04386         self.mesh.smeshpyD.SetName(self.algo, name)

def smeshDC.Mesh_RadialQuadrangle1D2D.StartEndLength (   self,
  start,
  end 
)

Defines "StartEndLength" hypothesis, specifying distribution of segments as geometric length increasing.

Parameters:
startfor the length of the first segment
endfor the length of the last segment

Definition at line 6016 of file smeshDC.py.

06017                                         :
06018         hyp = self.OwnHypothesis("StartEndLength", [start, end])
06019         hyp.SetLength(start, 1)
06020         hyp.SetLength(end  , 0)
06021         return hyp


Field Documentation

Definition at line 4276 of file smeshDC.py.

Definition at line 5936 of file smeshDC.py.

Reimplemented in smeshDC.Mesh_Segment.

Definition at line 4276 of file smeshDC.py.

Definition at line 4276 of file smeshDC.py.

Definition at line 5936 of file smeshDC.py.

Definition at line 4276 of file smeshDC.py.

Copyright © 2007-2011 CEA/DEN, EDF R&D, OPEN CASCADE
Copyright © 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS