mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-14 02:30:33 +05:00
cosmétique
This commit is contained in:
parent
cfe12004b6
commit
b922e849a4
@ -31,8 +31,8 @@ from .fusionMaillageAttributionDefaut import fusionMaillageDefaut
|
|||||||
# --- peau interne du defaut dans le maillage sain
|
# --- peau interne du defaut dans le maillage sain
|
||||||
|
|
||||||
def peauInterne(fichierMaillage, shapeDefaut, nomZones):
|
def peauInterne(fichierMaillage, shapeDefaut, nomZones):
|
||||||
"""
|
"""Retrouve les groupes de défaut dans le maillage sain modifié par CreateHoleSkin (CreeZoneDefautMaillage)
|
||||||
Retrouve les groupes de défaut dans le maillage sain modifié par CreateHoleSkin (CreeZoneDefautMaillage)
|
|
||||||
On récupère le volume et la peau de la zone de défaut, les éventuelles faces et arêtes internes de cette zone.
|
On récupère le volume et la peau de la zone de défaut, les éventuelles faces et arêtes internes de cette zone.
|
||||||
Remarque : intérêt du passage par fichierMaillage plutôt que par maillageSain ?
|
Remarque : intérêt du passage par fichierMaillage plutôt que par maillageSain ?
|
||||||
"""
|
"""
|
||||||
@ -40,51 +40,62 @@ def peauInterne(fichierMaillage, shapeDefaut, nomZones):
|
|||||||
([maillageSain], status) = smesh.CreateMeshesFromMED(fichierMaillage)
|
([maillageSain], status) = smesh.CreateMeshesFromMED(fichierMaillage)
|
||||||
|
|
||||||
groups = maillageSain.GetGroups()
|
groups = maillageSain.GetGroups()
|
||||||
|
#print ("groupes :")
|
||||||
|
#for grp in groups:
|
||||||
|
#print ("\t{}".format(grp.GetName()))
|
||||||
zoneDefaut = None
|
zoneDefaut = None
|
||||||
for grp in groups:
|
for grp in groups:
|
||||||
logging.debug("groupe %s",grp.GetName())
|
logging.debug("groupe %s",grp.GetName())
|
||||||
if grp.GetName() == nomZones + "_vol":
|
if grp.GetName() == nomZones + "_vol":
|
||||||
zoneDefaut = grp
|
zoneDefaut = grp
|
||||||
break
|
break
|
||||||
|
#print ("zoneDefaut = {}".format(zoneDefaut))
|
||||||
zoneDefaut_skin = None
|
zoneDefaut_skin = None
|
||||||
for grp in groups:
|
for grp in groups:
|
||||||
if grp.GetName() == nomZones + "_skin":
|
if grp.GetName() == nomZones + "_skin":
|
||||||
zoneDefaut_skin = grp
|
zoneDefaut_skin = grp
|
||||||
break
|
break
|
||||||
|
#print ("zoneDefaut_skin = {}".format(zoneDefaut_skin))
|
||||||
zoneDefaut_internalFaces = None
|
zoneDefaut_internalFaces = None
|
||||||
for grp in groups:
|
for grp in groups:
|
||||||
if grp.GetName() == nomZones + "_internalFaces":
|
if grp.GetName() == nomZones + "_internalFaces":
|
||||||
zoneDefaut_internalFaces = grp
|
zoneDefaut_internalFaces = grp
|
||||||
break
|
break
|
||||||
|
#print ("zoneDefaut_internalFaces = {}".format(zoneDefaut_internalFaces))
|
||||||
zoneDefaut_internalEdges = None
|
zoneDefaut_internalEdges = None
|
||||||
for grp in groups:
|
for grp in groups:
|
||||||
if grp.GetName() == nomZones + "_internalEdges":
|
if grp.GetName() == nomZones + "_internalEdges":
|
||||||
zoneDefaut_internalEdges = grp
|
zoneDefaut_internalEdges = grp
|
||||||
break
|
break
|
||||||
|
#print ("zoneDefaut_internalEdges = {}".format(zoneDefaut_internalEdges))
|
||||||
|
|
||||||
# --- Le groupe ZoneDefaut ne doit contenir que des Hexaèdres"
|
# --- Le groupe ZoneDefaut ne doit contenir que des Hexaèdres"
|
||||||
|
|
||||||
info=maillageSain.GetMeshInfo(zoneDefaut)
|
info = maillageSain.GetMeshInfo(zoneDefaut)
|
||||||
keys = list(info.keys()); keys.sort()
|
#print ("info = {}".format(info))
|
||||||
nbelem=0
|
nbelem = 0
|
||||||
nbhexa=0
|
nbhexa = 0
|
||||||
for i in keys:
|
for entity_type in info:
|
||||||
#print " %s : %d" % ( i, info[i] )
|
#print (". {} : {})".format(entity_type, info[entity_type]))
|
||||||
nbelem+=info[i]
|
nbelem += info[entity_type]
|
||||||
if "Entity_Hexa" in str(i):
|
if ("Entity_Hexa" == str(entity_type)):
|
||||||
nbhexa+=info[i]
|
nbhexa += info[entity_type]
|
||||||
if (nbelem == 0) or (nbhexa < nbelem) :
|
nbhexa += info[entity_type]
|
||||||
|
#print ("==> nbelem = {}, nbhexa = {}".format(nbelem,nbhexa))
|
||||||
|
|
||||||
|
if ( (nbelem == 0) or (nbhexa < nbelem) ):
|
||||||
|
print ("==> nbelem = {}, nbhexa = {}".format(nbelem,nbhexa))
|
||||||
texte = "La zone a remailler est incorrecte.<br>"
|
texte = "La zone a remailler est incorrecte.<br>"
|
||||||
texte += "Causes possibles :<ul>"
|
texte += "Causes possibles :<ul>"
|
||||||
texte += "<li>Les mailles à enlever dans le maillage sain n'ont pas été détectées.</li>"
|
texte += "<li>Les mailles à enlever dans le maillage sain n'ont pas été détectées.</li>"
|
||||||
texte += "<li>Certaines faces du maillage sain sont à l'envers : les normales aux faces en paroi de volume doivent être sortantes.</li>"
|
texte += "<li>Certaines faces du maillage sain sont à l'envers : les normales aux faces en paroi de volume doivent être sortantes.</li>"
|
||||||
texte += "<li>Il n'y a pas que des Hexaèdres réglés linéaires dans la zone à remailler (notamment mailles quadratiques, tetraèdres non traités)</li></ul>"
|
texte += "<li>Il n'y a pas que des hexaèdres réglés linéaires dans la zone à remailler (notamment mailles quadratiques, tetraèdres non traités)</li></ul>"
|
||||||
raise fissError(traceback.extract_stack(),texte)
|
raise fissError(traceback.extract_stack(),texte)
|
||||||
|
|
||||||
nbAdded, maillageSain, DefautBoundary = maillageSain.MakeBoundaryElements( SMESH.BND_2DFROM3D, 'DefBound', '', 0, [ zoneDefaut ])
|
nbAdded, maillageSain, DefautBoundary = maillageSain.MakeBoundaryElements( SMESH.BND_2DFROM3D, 'DefBound', '', 0, [ zoneDefaut ])
|
||||||
internal = maillageSain.GetMesh().CutListOfGroups( [ DefautBoundary ], [ zoneDefaut_skin ], 'internal' )
|
internal = maillageSain.GetMesh().CutListOfGroups( [ DefautBoundary ], [ zoneDefaut_skin ], 'internal' )
|
||||||
internalBoundary = smesh.CopyMesh( internal, 'internalBoundary', 0, 0)
|
internalBoundary = smesh.CopyMesh( internal, 'internalBoundary', 0, 0)
|
||||||
|
|
||||||
maillageDefautCible = smesh.CopyMesh(zoneDefaut_skin, 'maillageCible', 0, 0)
|
maillageDefautCible = smesh.CopyMesh(zoneDefaut_skin, 'maillageCible', 0, 0)
|
||||||
listOfCorner = lookForCorner(maillageDefautCible)
|
listOfCorner = lookForCorner(maillageDefautCible)
|
||||||
logging.debug("listOfCorner = {}".format(listOfCorner))
|
logging.debug("listOfCorner = {}".format(listOfCorner))
|
||||||
|
Loading…
Reference in New Issue
Block a user