Salome HOME
general crack dialog, another error detection
authorPaul RASCLE <paul.rascle@edf.fr>
Fri, 4 Mar 2016 14:09:50 +0000 (15:09 +0100)
committerPaul RASCLE <paul.rascle@edf.fr>
Fri, 4 Mar 2016 14:09:50 +0000 (15:09 +0100)
src/Tools/blocFissure/gmu/peauInterne.py
src/Tools/blocFissure/gmu/restreintFaceFissure.py

index b1915042e9066a2338b5b0d80e6a93ee01375c28..8d6643a5c8ae3130280fce6d7fb89212e3e51fa4 100644 (file)
@@ -3,6 +3,8 @@
 import logging
 from geomsmesh import smesh
 import SMESH
+import traceback
+from fissError import fissError
 
 from listOfExtraFunctions import lookForCorner
 from fusionMaillageAttributionDefaut import fusionMaillageDefaut
@@ -40,6 +42,24 @@ def peauInterne(fichierMaillage, shapeDefaut, nomZones):
     if grp.GetName() == nomZones + "_internalEdges":
       zoneDefaut_internalEdges = grp
       break
+    
+  # --- Le groupe ZoneDefaut ne doit contenir que des Hexaèdres"
+  
+  info=maillageSain.GetMeshInfo(zoneDefaut)
+  keys = info.keys(); keys.sort()
+  nbelem=0
+  nbhexa=0
+  for i in keys:
+    #print "  %s  :  %d" % ( i, info[i] )
+    nbelem+=info[i]
+    if i == "Entity_Hexa":
+      nbhexa+=info[i]
+  if (nbelem == 0) or (nbhexa < nbelem) :
+    texte = "La zone a remailler est incorrecte : "
+    texte += "Causes possibles :<ul>"
+    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>"
+    raise fissError(traceback.extract_stack(),texte)
 
   nbAdded, maillageSain, DefautBoundary = maillageSain.MakeBoundaryElements( SMESH.BND_2DFROM3D, 'DefBound', '', 0, [ zoneDefaut ])
   internal = maillageSain.GetMesh().CutListOfGroups( [ DefautBoundary ], [ zoneDefaut_skin ], 'internal' )
index c2a055f8ff1af58fc5d984df34e00ae00ba97901..7e1d1e0e4e081e9f0b49e0faab09c7bd557ae355 100644 (file)
@@ -28,8 +28,11 @@ def restreintFaceFissure(shapeDefaut, facesDefaut, pointInterne):
       facesPartShapeDefautSorted, minSurf, maxSurf = sortFaces(facesPartShapeDefaut) # la face de fissure dans le volume doit être la plus grande
     except:
       texte = "Restriction de la face de fissure au domaine solide impossible. "
-      texte += "Cause possible : 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. "
+      texte += "Causes possibles :<ul>"
+      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 += "<li>le prémaillage de la face de fissure est trop grossier, les mailles à enlever dans le maillage sain "
+      texte += "n'ont pas toutes été détectées.</li></ul>"
       raise fissError(traceback.extract_stack(),texte)
     logging.debug("surfaces faces fissure étendue, min %s, max %s", minSurf, maxSurf)
     facesPortFissure = facesPartShapeDefautSorted[-1]