mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-16 16:30:36 +05:00
generation du materiel pour les cas cubeFin
This commit is contained in:
parent
4f325d7076
commit
a55e1001a6
130
src/Tools/blocFissure/materielCasTests/cubeFin.py
Normal file
130
src/Tools/blocFissure/materielCasTests/cubeFin.py
Normal file
@ -0,0 +1,130 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
|
||||
import sys
|
||||
import salome
|
||||
|
||||
salome.salome_init()
|
||||
theStudy = salome.myStudy
|
||||
|
||||
import salome_notebook
|
||||
notebook = salome_notebook.NoteBook(theStudy)
|
||||
|
||||
import os
|
||||
from blocFissure import gmu
|
||||
|
||||
###
|
||||
### GEOM component
|
||||
###
|
||||
|
||||
import GEOM
|
||||
from salome.geom import geomBuilder
|
||||
import math
|
||||
import SALOMEDS
|
||||
|
||||
|
||||
geompy = geomBuilder.New(theStudy)
|
||||
|
||||
O = geompy.MakeVertex(0, 0, 0)
|
||||
OX = geompy.MakeVectorDXDYDZ(1, 0, 0)
|
||||
OY = geompy.MakeVectorDXDYDZ(0, 1, 0)
|
||||
OZ = geompy.MakeVectorDXDYDZ(0, 0, 1)
|
||||
cubeFin = geompy.MakeBoxDXDYDZ(200, 200, 200)
|
||||
[DEPL,ENCASTR] = geompy.SubShapes(cubeFin, [27, 23])
|
||||
origCoin = geompy.MakeVertex(0, 160, 200)
|
||||
Disk_1 = geompy.MakeDiskPntVecR(origCoin, OY, 50)
|
||||
Translation_1 = geompy.MakeTranslation(origCoin, 0, 10, 0)
|
||||
Vector_1 = geompy.MakeVector(origCoin, Translation_1)
|
||||
Rotation_1 = geompy.MakeRotation(Disk_1, Vector_1, 90*math.pi/180.0)
|
||||
origMilieu = geompy.MakeVertex(0, 160, 100)
|
||||
Translation_2 = geompy.MakeTranslationTwoPoints(Rotation_1, origCoin, origMilieu)
|
||||
Scale_1 = geompy.MakeScaleAlongAxes(Translation_2, origMilieu, 0.984, 1, 1.2)
|
||||
Vertex_1 = geompy.MakeVertex(-10, 160, 210)
|
||||
Vertex_2 = geompy.MakeVertex(50, 160, 210)
|
||||
Vertex_3 = geompy.MakeVertex(50, 160, -10)
|
||||
Vertex_4 = geompy.MakeVertex(-10, 160, -10)
|
||||
Line_1 = geompy.MakeLineTwoPnt(Vertex_1, Vertex_2)
|
||||
Line_2 = geompy.MakeLineTwoPnt(Vertex_2, Vertex_3)
|
||||
Line_3 = geompy.MakeLineTwoPnt(Vertex_3, Vertex_4)
|
||||
Line_4 = geompy.MakeLineTwoPnt(Vertex_4, Vertex_1)
|
||||
cubeFin_Transverse = geompy.MakeFaceWires([Line_1, Line_2, Line_3, Line_4], 1)
|
||||
Vertex_5 = geompy.MakeVertex(55, 160, 100)
|
||||
Line_1_vertex_3 = geompy.GetSubShape(Line_1, [3])
|
||||
Line_3_vertex_2 = geompy.GetSubShape(Line_3, [2])
|
||||
Arc_1 = geompy.MakeArc(Line_1_vertex_3, Vertex_5, Line_3_vertex_2)
|
||||
Face_1 = geompy.MakeFaceWires([Line_1, Line_3, Line_4, Arc_1], 1)
|
||||
cubeFin_Coin = geompy.MakeCommonList([Rotation_1, Face_1], True)
|
||||
cubeFin_milieu = geompy.MakeCommonList([Scale_1, cubeFin_Transverse], True)
|
||||
O_1 = geompy.MakeVertex(0, 0, 0)
|
||||
OX_1 = geompy.MakeVectorDXDYDZ(1, 0, 0)
|
||||
OY_1 = geompy.MakeVectorDXDYDZ(0, 1, 0)
|
||||
OZ_1 = geompy.MakeVectorDXDYDZ(0, 0, 1)
|
||||
geompy.addToStudy( O, 'O' )
|
||||
geompy.addToStudy( OX, 'OX' )
|
||||
geompy.addToStudy( OY, 'OY' )
|
||||
geompy.addToStudy( OZ, 'OZ' )
|
||||
geompy.addToStudy( cubeFin, 'cubeFin' )
|
||||
geompy.addToStudyInFather( cubeFin, DEPL, 'DEPL' )
|
||||
geompy.addToStudyInFather( cubeFin, ENCASTR, 'ENCASTR' )
|
||||
geompy.addToStudy( origCoin, 'origCoin' )
|
||||
geompy.addToStudy( Disk_1, 'Disk_1' )
|
||||
geompy.addToStudy( Translation_1, 'Translation_1' )
|
||||
geompy.addToStudy( Vector_1, 'Vector_1' )
|
||||
geompy.addToStudy( Rotation_1, 'Rotation_1' )
|
||||
geompy.addToStudy( origMilieu, 'origMilieu' )
|
||||
geompy.addToStudy( Translation_2, 'Translation_2' )
|
||||
geompy.addToStudy( Scale_1, 'Scale_1' )
|
||||
geompy.addToStudy( Vertex_1, 'Vertex_1' )
|
||||
geompy.addToStudy( Vertex_2, 'Vertex_2' )
|
||||
geompy.addToStudy( Vertex_3, 'Vertex_3' )
|
||||
geompy.addToStudy( Vertex_4, 'Vertex_4' )
|
||||
geompy.addToStudy( Line_1, 'Line_1' )
|
||||
geompy.addToStudy( Line_2, 'Line_2' )
|
||||
geompy.addToStudy( Line_3, 'Line_3' )
|
||||
geompy.addToStudy( Line_4, 'Line_4' )
|
||||
geompy.addToStudy( cubeFin_Transverse, 'cubeFin_Transverse' )
|
||||
geompy.addToStudyInFather( Line_1, Line_1_vertex_3, 'Line_1:vertex_3' )
|
||||
geompy.addToStudy( Vertex_5, 'Vertex_5' )
|
||||
geompy.addToStudyInFather( Line_3, Line_3_vertex_2, 'Line_3:vertex_2' )
|
||||
geompy.addToStudy( Arc_1, 'Arc_1' )
|
||||
geompy.addToStudy( Face_1, 'Face_1' )
|
||||
geompy.addToStudy( cubeFin_Coin, 'cubeFin_Coin' )
|
||||
geompy.addToStudy( cubeFin_milieu, 'cubeFin_milieu' )
|
||||
geompy.addToStudy( O_1, 'O' )
|
||||
geompy.addToStudy( OX_1, 'OX' )
|
||||
geompy.addToStudy( OY_1, 'OY' )
|
||||
geompy.addToStudy( OZ_1, 'OZ' )
|
||||
geompy.Export(cubeFin_Transverse, os.path.join(gmu.pathBloc, "materielCasTests/cubeFin_Transverse.brep"), "BREP")
|
||||
geompy.Export(cubeFin_Coin, os.path.join(gmu.pathBloc, "materielCasTests/cubeFin_Coin.brep"), "BREP")
|
||||
geompy.Export(cubeFin_milieu, os.path.join(gmu.pathBloc, "materielCasTests/cubeFin_milieu.brep"), "BREP")
|
||||
|
||||
###
|
||||
### SMESH component
|
||||
###
|
||||
|
||||
import SMESH, SALOMEDS
|
||||
from salome.smesh import smeshBuilder
|
||||
|
||||
smesh = smeshBuilder.New(theStudy)
|
||||
cubeFin_1 = smesh.Mesh(cubeFin)
|
||||
Regular_1D = cubeFin_1.Segment()
|
||||
Nb_Segments_1 = Regular_1D.NumberOfSegments(20)
|
||||
Nb_Segments_1.SetDistrType( 0 )
|
||||
Quadrangle_2D = cubeFin_1.Quadrangle(algo=smeshBuilder.QUADRANGLE)
|
||||
Hexa_3D = cubeFin_1.Hexahedron(algo=smeshBuilder.Hexa)
|
||||
isDone = cubeFin_1.Compute()
|
||||
DEPL_1 = cubeFin_1.GroupOnGeom(DEPL,'DEPL',SMESH.FACE)
|
||||
ENCASTR_1 = cubeFin_1.GroupOnGeom(ENCASTR,'ENCASTR',SMESH.FACE)
|
||||
|
||||
## Set names of Mesh objects
|
||||
smesh.SetName(Regular_1D.GetAlgorithm(), 'Regular_1D')
|
||||
smesh.SetName(Quadrangle_2D.GetAlgorithm(), 'Quadrangle_2D')
|
||||
smesh.SetName(Hexa_3D.GetAlgorithm(), 'Hexa_3D')
|
||||
smesh.SetName(DEPL_1, 'DEPL')
|
||||
smesh.SetName(ENCASTR_1, 'ENCASTR')
|
||||
smesh.SetName(cubeFin_1.GetMesh(), 'cubeFin')
|
||||
smesh.SetName(Nb_Segments_1, 'Nb. Segments_1')
|
||||
|
||||
cubeFin_1.ExportMED( os.path.join(gmu.pathBloc, "materielCasTests/cubeFin.med"), 0, SMESH.MED_V2_2, 1 )
|
||||
|
||||
if salome.sg.hasDesktop():
|
||||
salome.sg.updateObjBrowser(1)
|
@ -11,3 +11,4 @@ from blocFissure.materielCasTests import ellipse_probleme
|
||||
from blocFissure.materielCasTests import disque_perce
|
||||
from blocFissure.materielCasTests import ellipse_disque
|
||||
from blocFissure.materielCasTests import vis
|
||||
from blocFissure.materielCasTests import cubeFin
|
||||
|
Loading…
Reference in New Issue
Block a user