1 # -*- coding: utf-8 -*-
4 from geomsmesh import geompy
6 from toreFissure import toreFissure
7 from ellipsoideDefaut import ellipsoideDefaut
8 from rotTrans import rotTrans
9 from genereMeshCalculZoneDefaut import genereMeshCalculZoneDefaut
11 # -----------------------------------------------------------------------------
12 # --- création élements géométriques fissure elliptique
14 def genereElemsFissureElliptique(shapeFissureParams):
20 centreDefaut = shapeFissureParams['centreDefaut']
21 vecteurDefaut = shapeFissureParams['vecteurDefaut']
22 demiGrandAxe = shapeFissureParams['demiGrandAxe']
23 demiPetitAxe = shapeFissureParams['demiPetitAxe']
24 orientation = shapeFissureParams['orientation']
25 tailleDefaut = shapeFissureParams['taille']
27 # --- ellipse incomplete : generatrice
29 allonge = demiGrandAxe/demiPetitAxe
30 rayonTore = demiPetitAxe/5.0
31 generatrice, FaceGenFiss, Pipe_1, FaceFissure, Plane_1, Pipe1Part = toreFissure(demiPetitAxe, allonge, rayonTore)
32 ellipsoide = ellipsoideDefaut(demiPetitAxe, allonge, rayonTore)
34 # --- positionnement sur le bloc defaut de generatrice, tore et plan fissure
36 pipe0 = rotTrans(Pipe_1, orientation, centreDefaut, vecteurDefaut)
37 gener1 = rotTrans(generatrice, orientation, centreDefaut, vecteurDefaut)
38 pipe1 = rotTrans(Pipe1Part, orientation, centreDefaut, vecteurDefaut)
39 facefis1 = rotTrans(FaceFissure, orientation, centreDefaut, vecteurDefaut)
40 plane1 = rotTrans(Plane_1, orientation, centreDefaut, vecteurDefaut)
41 ellipsoide1 = rotTrans(ellipsoide, orientation, centreDefaut, vecteurDefaut)
43 geompy.addToStudy( pipe0, 'pipe0' )
44 geompy.addToStudy( gener1, 'gener1' )
45 geompy.addToStudy( pipe1, 'pipe1' )
46 geompy.addToStudy( facefis1, 'facefis1' )
47 geompy.addToStudy( plane1, 'plane1' )
48 geompy.addToStudy( ellipsoide1, 'ellipsoide1' )
50 shapeDefaut = facefis1
51 xyz_defaut = geompy.PointCoordinates(centreDefaut)
52 coordsNoeudsFissure = genereMeshCalculZoneDefaut(facefis1, demiPetitAxe/10.0, demiPetitAxe/5.0)
54 return shapeDefaut, xyz_defaut, tailleDefaut, coordsNoeudsFissure, pipe0, gener1, pipe1, facefis1, plane1, ellipsoide1