general crack dialog, another error detection

This commit is contained in:
Paul RASCLE 2016-03-04 16:29:26 +01:00
parent 39ef405afe
commit d54b8e1c78
3 changed files with 13 additions and 3 deletions

View File

@ -4,6 +4,8 @@ import logging
from geomsmesh import geompy from geomsmesh import geompy
import math import math
from distance2 import distance2 from distance2 import distance2
import traceback
from fissError import fissError
# ----------------------------------------------------------------------------- # -----------------------------------------------------------------------------
# --- zone de defaut extraite du maillage # --- zone de defaut extraite du maillage
@ -60,5 +62,12 @@ def creeZoneDefautMaillage(maillagesSains, shapeDefaut, tailleDefaut,
verticesShapes.append(vertices) verticesShapes.append(vertices)
pass pass
if (nb == 0) :
texte = "La zone à remailler n'est pas détectée correctement.<br>"
texte += "Cause possible :<ul>"
texte += "<li>La distance d'influence est trop petite. "
texte += "L'ordre de grandeur minimal correspond à la taille des mailles du maillage sain dans la zone à remailler.</li></ul>"
raise fissError(traceback.extract_stack(),texte)
dmoyen = math.sqrt(cumul/nb) # ~ taille de l'arête moyenne du maillage global dmoyen = math.sqrt(cumul/nb) # ~ taille de l'arête moyenne du maillage global
return origShapes, verticesShapes, dmoyen return origShapes, verticesShapes, dmoyen

View File

@ -55,10 +55,11 @@ def peauInterne(fichierMaillage, shapeDefaut, nomZones):
if i == "Entity_Hexa": if i == "Entity_Hexa":
nbhexa+=info[i] nbhexa+=info[i]
if (nbelem == 0) or (nbhexa < nbelem) : if (nbelem == 0) or (nbhexa < nbelem) :
texte = "La zone a remailler est incorrecte : " 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>Il n'y a pas que des Hexaèdres linéaires dans la zone à remailler (mailles quadratiques, tetraèdres non traités)</li></ul>" 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>"
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 ])

View File

@ -27,7 +27,7 @@ def restreintFaceFissure(shapeDefaut, facesDefaut, pointInterne):
try: try:
facesPartShapeDefautSorted, minSurf, maxSurf = sortFaces(facesPartShapeDefaut) # la face de fissure dans le volume doit être la plus grande facesPartShapeDefautSorted, minSurf, maxSurf = sortFaces(facesPartShapeDefaut) # la face de fissure dans le volume doit être la plus grande
except: except:
texte = "Restriction de la face de fissure au domaine solide impossible. " texte = "Restriction de la face de fissure au domaine solide impossible.<br>"
texte += "Causes possibles :<ul>" texte += "Causes possibles :<ul>"
texte += "<li>La face de fissure est tangente à la paroi solide." texte += "<li>La face de fissure est tangente à la paroi solide."
texte += "Elle doit déboucher franchement, sans que la surface dehors ne devienne plus grande que la surface dans le solide.</li>" texte += "Elle doit déboucher franchement, sans que la surface dehors ne devienne plus grande que la surface dans le solide.</li>"