Cosmétique python3

This commit is contained in:
GERALD NICOLAS 2021-01-26 16:00:53 +01:00
parent ee8255184a
commit 4203b2933f
6 changed files with 81 additions and 80 deletions

View File

@ -17,6 +17,7 @@
# #
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
# #
"""Cas standard"""
import os import os
from .geomsmesh import geompy, smesh from .geomsmesh import geompy, smesh
@ -48,6 +49,7 @@ class casStandard(fissureGenerique):
- les numéros d'arêtes (edges géométriques) correspondant au fond de fissure - les numéros d'arêtes (edges géométriques) correspondant au fond de fissure
- les paramètres de maillage de la fissure - les paramètres de maillage de la fissure
""" """
referencesMaillageFissure = None
# --------------------------------------------------------------------------- # ---------------------------------------------------------------------------
def __init__ (self, dicoParams, references = None, numeroCas = 0): def __init__ (self, dicoParams, references = None, numeroCas = 0):

View File

@ -17,21 +17,20 @@
# #
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
# #
"""Construit les arêtes débouchantes"""
import logging import logging
from .geomsmesh import geompy from .geomsmesh import geompy
from .geomsmesh import geomPublish from .geomsmesh import geomPublish
from .geomsmesh import geomPublishInFather #from .geomsmesh import geomPublishInFather
from . import initLog from . import initLog
import GEOM import GEOM
from .sortEdges import sortEdges from .sortEdges import sortEdges
def construitEdgesRadialesDebouchantes(idisklim, idiskout, gptsdisks, raydisks, def construitEdgesRadialesDebouchantes(idisklim, idiskout, gptsdisks, raydisks,
facesPipePeau, edgeRadFacePipePeau, nbsegCercle): facesPipePeau, edgeRadFacePipePeau, nbsegCercle):
""" """construction des listes d'edges radiales sur chaque extrémité débouchante"""
construction des listes d'edges radiales sur chaque extrémité débouchante
"""
logging.info('start') logging.info('start')
# --- listes de nappes radiales en filling à chaque extrémité débouchante # --- listes de nappes radiales en filling à chaque extrémité débouchante
@ -95,7 +94,7 @@ def construitEdgesRadialesDebouchantes(idisklim, idiskout, gptsdisks, raydisks,
vs = geompy.ExtractShapes(obj, geompy.ShapeType["VERTEX"], False) vs = geompy.ExtractShapes(obj, geompy.ShapeType["VERTEX"], False)
if len(vs) > 2: if len(vs) > 2:
eds = geompy.ExtractShapes(obj, geompy.ShapeType["EDGE"], False) eds = geompy.ExtractShapes(obj, geompy.ShapeType["EDGE"], False)
[edsorted, minl,maxl] = sortEdges(eds) [edsorted, _, maxl] = sortEdges(eds)
edge = edsorted[-1] edge = edsorted[-1]
else: else:
maxl = geompy.BasicProperties(edge)[0] maxl = geompy.BasicProperties(edge)[0]
@ -118,7 +117,7 @@ def construitEdgesRadialesDebouchantes(idisklim, idiskout, gptsdisks, raydisks,
logging.debug(" edges issues de la partition: %s", ednouv) logging.debug(" edges issues de la partition: %s", ednouv)
for ii, ed in enumerate(ednouv): for ii, ed in enumerate(ednouv):
geomPublish(initLog.debug, ed, "ednouv%d"%ii) geomPublish(initLog.debug, ed, "ednouv%d"%ii)
[edsorted, minl,maxl] = sortEdges(ednouv) [edsorted, _, maxl] = sortEdges(ednouv)
logging.debug(" longueur edge trouvée: %s", maxl) logging.debug(" longueur edge trouvée: %s", maxl)
edge = edsorted[-1] edge = edsorted[-1]
else: else:
@ -134,7 +133,7 @@ def construitEdgesRadialesDebouchantes(idisklim, idiskout, gptsdisks, raydisks,
logging.debug("nombre vertex candidats %s", len(vxnouv)) logging.debug("nombre vertex candidats %s", len(vxnouv))
if len(vxnouv) >= 2: if len(vxnouv) >= 2:
eds = [geompy.MakeEdge(vxnouv[j],vxnouv[(j+1)%len(vxnouv)]) for j in range(len(vxnouv))] eds = [geompy.MakeEdge(vxnouv[j],vxnouv[(j+1)%len(vxnouv)]) for j in range(len(vxnouv))]
[edsorted2, minl,maxl] = sortEdges(eds) [edsorted2, _, maxl] = sortEdges(eds)
edge = edsorted2[-1] edge = edsorted2[-1]
logging.debug("lg edge: %s", maxl) logging.debug("lg edge: %s", maxl)
else: else:

View File

@ -183,7 +183,8 @@ def construitFissureGenerale(maillagesSains,
# 0, 1 ou plus edges de la face de fissure externe au pipe # 0, 1 ou plus edges de la face de fissure externe au pipe
nbFacesFilling = len(partitionsPeauFissFond) nbFacesFilling = len(partitionsPeauFissFond)
logging.info("nbFacesFilling : {} ".format(nbFacesFilling)) texte = "nbFacesFilling : {} ".format(nbFacesFilling)
logging.info(texte)
ptEdgeFond = [ list() for i in range(nbFacesFilling)] # pour chaque face [points edge fond de fissure aux débouchés du pipe] ptEdgeFond = [ list() for i in range(nbFacesFilling)] # pour chaque face [points edge fond de fissure aux débouchés du pipe]
fsPipePeau = [ list() for i in range(nbFacesFilling)] # pour chaque face [faces du pipe débouchantes] fsPipePeau = [ list() for i in range(nbFacesFilling)] # pour chaque face [faces du pipe débouchantes]
@ -231,9 +232,8 @@ def construitFissureGenerale(maillagesSains,
# --- identification des faces et edges de fissure externe pour maillage # --- identification des faces et edges de fissure externe pour maillage
(faceFissureExterne, edgesPipeFissureExterneC, (faceFissureExterne, edgesPipeFissureExterneC, wirePipeFissureExterne, edgesPeauFissureExterneC) = \
wirePipeFissureExterne, edgesPeauFissureExterneC) = identifieFacesEdgesFissureExterne(fsFissuExt, edFisExtPe, identifieFacesEdgesFissureExterne(fsFissuExt, edFisExtPe, edFisExtPi, edgesPipeFiss)
edFisExtPi, edgesPipeFiss)
# --- preparation maillage du pipe : # --- preparation maillage du pipe :
# - détections des points a respecter : jonction des edges/faces constituant la face de fissure externe au pipe # - détections des points a respecter : jonction des edges/faces constituant la face de fissure externe au pipe
@ -322,12 +322,13 @@ def construitFissureGenerale(maillagesSains,
putName(meshBoiteDefaut, "boiteDefaut") putName(meshBoiteDefaut, "boiteDefaut")
logging.info("meshBoiteDefaut fini") logging.info("meshBoiteDefaut fini")
faceFissure = meshBoiteDefaut.GetMesh().UnionListOfGroups( [ group_faceFissOutPipe, group_faceFissInPipe ], 'FACE1' ) faceFissure = meshBoiteDefaut.GetMesh().UnionListOfGroups( [ group_faceFissOutPipe, group_faceFissInPipe ], \
'FACE1' )
maillageSain = enleveDefaut(maillageSain, zoneDefaut, zoneDefaut_skin, maillageSain = enleveDefaut(maillageSain, zoneDefaut, zoneDefaut_skin,
zoneDefaut_internalFaces, zoneDefaut_internalEdges) zoneDefaut_internalFaces, zoneDefaut_internalEdges)
putName(maillageSain, nomFicSain+"_coupe") putName(maillageSain, nomFicSain+"_coupe")
extrusionFaceFissure, normfiss = shapeSurFissure(facesPortFissure) _, normfiss = shapeSurFissure(facesPortFissure)
maillageComplet = RegroupeSainEtDefaut(maillageSain, meshBoiteDefaut, maillageComplet = RegroupeSainEtDefaut(maillageSain, meshBoiteDefaut, \
None, None, 'COMPLET', normfiss) None, None, 'COMPLET', normfiss)
logging.info("conversion quadratique") logging.info("conversion quadratique")

View File

@ -17,6 +17,7 @@
# #
# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com # See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
# #
"""Maillage du pipe"""
import logging import logging
@ -25,9 +26,7 @@ from .geomsmesh import smesh
import SMESH import SMESH
def construitMaillagePipe(gptsdisks, idisklim, nbsegCercle, nbsegRad): def construitMaillagePipe(gptsdisks, idisklim, nbsegCercle, nbsegRad):
""" """maillage effectif du pipe"""
maillage effectif du pipe
"""
logging.info('start') logging.info('start')
meshPipe = smesh.Mesh(None, "meshPipe") meshPipe = smesh.Mesh(None, "meshPipe")
fondFissGroup = meshPipe.CreateEmptyGroup(SMESH.EDGE, "FONDFISS") fondFissGroup = meshPipe.CreateEmptyGroup(SMESH.EDGE, "FONDFISS")
@ -39,13 +38,13 @@ def construitMaillagePipe(gptsdisks, idisklim, nbsegCercle, nbsegRad):
faceCircPipe0Group = meshPipe.CreateEmptyGroup(SMESH.FACE, "faceCircPipe0") faceCircPipe0Group = meshPipe.CreateEmptyGroup(SMESH.FACE, "faceCircPipe0")
faceCircPipe1Group = meshPipe.CreateEmptyGroup(SMESH.FACE, "faceCircPipe1") faceCircPipe1Group = meshPipe.CreateEmptyGroup(SMESH.FACE, "faceCircPipe1")
mptsdisks = [] # vertices maillage de tous les disques mptsdisks = list() # vertices maillage de tous les disques
mEdges = [] # identifiants edges maillage fond de fissure mEdges = list() # identifiants edges maillage fond de fissure
mEdgeFaces = [] # identifiants edges maillage edge face de fissure externe mEdgeFaces = list() # identifiants edges maillage edge face de fissure externe
mFaces = [] # identifiants faces maillage fissure mFaces = list() # identifiants faces maillage fissure
mVols = [] # identifiants volumes maillage pipe mVols = list() # identifiants volumes maillage pipe
mptdsk = None mptdsk = list()
for idisk in range(idisklim[0], idisklim[1]+1): # boucle sur les disques internes for idisk in range(idisklim[0], idisklim[1]+1): # boucle sur les disques internes
# ----------------------------------------------------------------------- # -----------------------------------------------------------------------
@ -54,10 +53,10 @@ def construitMaillagePipe(gptsdisks, idisklim, nbsegCercle, nbsegRad):
gptdsk = gptsdisks[idisk] gptdsk = gptsdisks[idisk]
if idisk > idisklim[0]: if idisk > idisklim[0]:
oldmpts = mptdsk oldmpts = mptdsk
mptdsk = [] # vertices maillage d'un disque mptdsk = list() # vertices maillage d'un disque
for k in range(nbsegCercle): for k in range(nbsegCercle):
points = gptdsk[k] points = gptdsk[k]
mptids = [] mptids = list()
for j, pt in enumerate(points): for j, pt in enumerate(points):
if j == 0 and k > 0: if j == 0 and k > 0:
id = mptdsk[0][0] id = mptdsk[0][0]
@ -72,23 +71,25 @@ def construitMaillagePipe(gptsdisks, idisklim, nbsegCercle, nbsegRad):
# --- groupes edges cercles debouchants # --- groupes edges cercles debouchants
if idisk == idisklim[0]: if idisk == idisklim[0]:
pts = [] pts = list()
for k in range(nbsegCercle): for k in range(nbsegCercle):
pts.append(mptdsk[k][-1]) pts.append(mptdsk[k][-1])
edges = [] edges = list()
for k in range(len(pts)): nb_pts = len(pts)
k1 = (k+1)%len(pts) for k in range(nb_pts):
k1 = (k+1)%nb_pts
idEdge = meshPipe.AddEdge([pts[k], pts[k1]]) idEdge = meshPipe.AddEdge([pts[k], pts[k1]])
edges.append(idEdge) edges.append(idEdge)
edgeCircPipe0Group.Add(edges) edgeCircPipe0Group.Add(edges)
if idisk == idisklim[1]: if idisk == idisklim[1]:
pts = [] pts = list()
for k in range(nbsegCercle): for k in range(nbsegCercle):
pts.append(mptdsk[k][-1]) pts.append(mptdsk[k][-1])
edges = [] edges = list()
for k in range(len(pts)): nb_pts = len(pts)
k1 = (k+1)%len(pts) for k in range(nb_pts):
k1 = (k+1)%nb_pts
idEdge = meshPipe.AddEdge([pts[k], pts[k1]]) idEdge = meshPipe.AddEdge([pts[k], pts[k1]])
edges.append(idEdge) edges.append(idEdge)
edgeCircPipe1Group.Add(edges) edgeCircPipe1Group.Add(edges)
@ -97,7 +98,7 @@ def construitMaillagePipe(gptsdisks, idisklim, nbsegCercle, nbsegRad):
# --- groupes faces debouchantes # --- groupes faces debouchantes
if idisk == idisklim[0]: if idisk == idisklim[0]:
faces = [] faces = list()
for j in range(nbsegRad): for j in range(nbsegRad):
for k in range(nbsegCercle): for k in range(nbsegCercle):
k1 = k+1 k1 = k+1
@ -111,7 +112,7 @@ def construitMaillagePipe(gptsdisks, idisklim, nbsegCercle, nbsegRad):
faceCircPipe0Group.Add(faces) faceCircPipe0Group.Add(faces)
if idisk == idisklim[1]: if idisk == idisklim[1]:
faces = [] faces = list()
for j in range(nbsegRad): for j in range(nbsegRad):
for k in range(nbsegCercle): for k in range(nbsegCercle):
k1 = k+1 k1 = k+1
@ -141,24 +142,24 @@ def construitMaillagePipe(gptsdisks, idisklim, nbsegCercle, nbsegRad):
ide2 = meshPipe.AddEdge([oldmpts[0][-1], mptdsk[0][-1]]) ide2 = meshPipe.AddEdge([oldmpts[0][-1], mptdsk[0][-1]])
mEdgeFaces.append(ide2) mEdgeFaces.append(ide2)
edgeFaceFissGroup.Add([ide2]) edgeFaceFissGroup.Add([ide2])
idFaces = [] idFaces = list()
idVols = [] idVols = list()
for j in range(nbsegRad): for j in range(nbsegRad):
idf = meshPipe.AddFace([oldmpts[0][j], mptdsk[0][j], mptdsk[0][j+1], oldmpts[0][j+1]]) idf = meshPipe.AddFace([oldmpts[0][j], mptdsk[0][j], mptdsk[0][j+1], oldmpts[0][j+1]])
faceFissGroup.Add([idf]) faceFissGroup.Add([idf])
idFaces.append(idf) idFaces.append(idf)
idVolCercle = [] idVolCercle = list()
for k in range(nbsegCercle): for k in range(nbsegCercle):
k1 = k+1 k1 = k+1
if k == nbsegCercle-1: if k == nbsegCercle-1:
k1 = 0 k1 = 0
if j == 0: if j == 0:
idv = meshPipe.AddVolume([mptdsk[k][j], mptdsk[k][j+1], mptdsk[k1][j+1], idv = meshPipe.AddVolume([mptdsk[k][j], mptdsk[k][j+1], mptdsk[k1][j+1], \
oldmpts[k][j], oldmpts[k][j+1], oldmpts[k1][j+1]]) oldmpts[k][j], oldmpts[k][j+1], oldmpts[k1][j+1]])
else: else:
idv = meshPipe.AddVolume([mptdsk[k][j], mptdsk[k][j+1], mptdsk[k1][j+1], mptdsk[k1][j], idv = meshPipe.AddVolume([mptdsk[k][j], mptdsk[k][j+1], mptdsk[k1][j+1], mptdsk[k1][j], \
oldmpts[k][j], oldmpts[k][j+1], oldmpts[k1][j+1], oldmpts[k1][j]]) oldmpts[k][j], oldmpts[k][j+1], oldmpts[k1][j+1], oldmpts[k1][j]])
idVolCercle.append(idv) idVolCercle.append(idv)
idVols.append(idVolCercle) idVols.append(idVolCercle)
@ -172,16 +173,16 @@ def construitMaillagePipe(gptsdisks, idisklim, nbsegCercle, nbsegRad):
nb, new_mesh, new_group = meshPipe.MakeBoundaryElements(SMESH.BND_2DFROM3D, "pipeBoundaries") nb, new_mesh, new_group = meshPipe.MakeBoundaryElements(SMESH.BND_2DFROM3D, "pipeBoundaries")
edgesCircPipeGroup = [edgeCircPipe0Group, edgeCircPipe1Group] edgesCircPipeGroup = [edgeCircPipe0Group, edgeCircPipe1Group]
meshPipeGroups = dict(fondFissGroup = fondFissGroup, meshPipeGroups = dict(fondFissGroup = fondFissGroup, \
nodesFondFissGroup = nodesFondFissGroup, nodesFondFissGroup = nodesFondFissGroup, \
faceFissGroup = faceFissGroup, faceFissGroup = faceFissGroup, \
edgeFaceFissGroup = edgeFaceFissGroup, edgeFaceFissGroup = edgeFaceFissGroup, \
edgeCircPipe0Group = edgeCircPipe0Group, edgeCircPipe0Group = edgeCircPipe0Group, \
edgeCircPipe1Group = edgeCircPipe1Group, edgeCircPipe1Group = edgeCircPipe1Group, \
faceCircPipe0Group = faceCircPipe0Group, faceCircPipe0Group = faceCircPipe0Group, \
faceCircPipe1Group = faceCircPipe1Group, faceCircPipe1Group = faceCircPipe1Group, \
pipeFissGroup = pipeFissGroup, pipeFissGroup = pipeFissGroup, \
edgesCircPipeGroup = edgesCircPipeGroup edgesCircPipeGroup = edgesCircPipeGroup \
) )
return (meshPipe, meshPipeGroups, edgesCircPipeGroup) return (meshPipe, meshPipeGroups, edgesCircPipeGroup)

View File

@ -34,8 +34,8 @@ from .checkDecoupePartition import checkDecoupePartition
# liste de partitions face externe - fissure : partitionPeauFissFond (None quand pas d'intersection) # liste de partitions face externe - fissure : partitionPeauFissFond (None quand pas d'intersection)
def construitPartitionsPeauFissure(facesDefaut, fissPipe): def construitPartitionsPeauFissure(facesDefaut, fissPipe):
""" """partition peau défaut - face de fissure prolongée - wire de fond de fissure prolongée.
partition peau défaut - face de fissure prolongée - wire de fond de fissure prolongée.
Il peut y avoir plusieurs faces externes, dont certaines sont découpées par la fissure. Il peut y avoir plusieurs faces externes, dont certaines sont découpées par la fissure.
@param facesDefaut liste de faces externes @param facesDefaut liste de faces externes
@param fissPipe partition face de fissure etendue par pipe prolongé @param fissPipe partition face de fissure etendue par pipe prolongé
@ -43,18 +43,18 @@ def construitPartitionsPeauFissure(facesDefaut, fissPipe):
""" """
logging.info('start') logging.info('start')
partitionsPeauFissFond = [] partitionsPeauFissFond = list()
ipart = 0 ipart = 0
for filling in facesDefaut: for filling in facesDefaut:
part = geompy.MakePartition([fissPipe, filling], [], [], [], geompy.ShapeType["FACE"], 0, [], 0) part = geompy.MakePartition([fissPipe, filling], list(), list(), list(), geompy.ShapeType["FACE"], 0, list(), 0)
isPart = checkDecoupePartition([fissPipe, filling], part) isPart = checkDecoupePartition([fissPipe, filling], part)
if isPart: # on recrée la partition avec toutes les faces filling en outil pour avoir une face de fissure correcte if isPart: # on recrée la partition avec toutes les faces filling en outil pour avoir une face de fissure correcte
otherFD = [fd for fd in facesDefaut if fd != filling] otherFD = [fd for fd in facesDefaut if fd != filling]
if otherFD: if otherFD:
fissPipePart = geompy.MakePartition([fissPipe], otherFD, [], [], geompy.ShapeType["FACE"], 0, [], 0) fissPipePart = geompy.MakePartition([fissPipe], otherFD, list(), list(), geompy.ShapeType["FACE"], 0, list(), 0)
else: else:
fissPipePart = fissPipe fissPipePart = fissPipe
part = geompy.MakePartition([fissPipePart, filling], [], [], [], geompy.ShapeType["FACE"], 0, [], 0) part = geompy.MakePartition([fissPipePart, filling], list(), list(), list(), geompy.ShapeType["FACE"], 0, list(), 0)
partitionsPeauFissFond.append(part) partitionsPeauFissFond.append(part)
geomPublish(initLog.debug, part, 'partitionPeauFissFond%d'%ipart ) geomPublish(initLog.debug, part, 'partitionPeauFissFond%d'%ipart )
else: else:

View File

@ -29,9 +29,7 @@ from .putName import putName
def mailleFacesFissure(faceFissureExterne, edgesPipeFissureExterneC, edgesPeauFissureExterneC, def mailleFacesFissure(faceFissureExterne, edgesPipeFissureExterneC, edgesPeauFissureExterneC,
meshPipeGroups, areteFaceFissure, rayonPipe, nbsegRad): meshPipeGroups, areteFaceFissure, rayonPipe, nbsegRad):
""" """maillage faces de fissure"""
maillage faces de fissure
"""
logging.info('start') logging.info('start')
logging.info("Maillage de {}".format(faceFissureExterne.GetName())) logging.info("Maillage de {}".format(faceFissureExterne.GetName()))
@ -48,7 +46,7 @@ def mailleFacesFissure(faceFissureExterne, edgesPipeFissureExterneC, edgesPeauFi
putName(algo2d, "algo2d_faceFiss") putName(algo2d, "algo2d_faceFiss")
putName(hypo2d, "hypo2d_faceFiss") putName(hypo2d, "hypo2d_faceFiss")
logging.info('Récupération des arêtes de {}'.format(edgesPipeFissureExterneC.GetName())) logging.info("Récupération des arêtes de '{}'".format(edgesPipeFissureExterneC.GetName()))
algo1d = meshFaceFiss.UseExisting1DElements(geom=edgesPipeFissureExterneC) algo1d = meshFaceFiss.UseExisting1DElements(geom=edgesPipeFissureExterneC)
hypo1d = algo1d.SourceEdges([ meshPipeGroups['edgeFaceFissGroup'] ],0,0) hypo1d = algo1d.SourceEdges([ meshPipeGroups['edgeFaceFissGroup'] ],0,0)
putName(algo1d.GetSubMesh(), "edgeFissPeau") putName(algo1d.GetSubMesh(), "edgeFissPeau")