1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
|
'''
Created on 11-May-2015
@author: deepa
'''
import numpy
from OCC.Graphic3d import Graphic3d_NOT_2D_ALUMINUM
from bolt import Bolt
from nut import Nut
import copy
from OCC.BRepPrimAPI import BRepPrimAPI_MakeSphere
from OCC.gp import gp_Pnt
from nutBoltPlacement import NutBoltArray
#from Connections.Shear.Finplate.nutBoltPlacement import NutBoltArray
class ColWebBeamWeb(object):
def __init__(self,column,beam,Fweld,plate,nutBoltArray):
self.column = column
self.beam = beam
self.weldLeft = Fweld
self.weldRight = copy.deepcopy(Fweld)
self.plate = plate
self.nutBoltArray = nutBoltArray
self.columnModel = None
self.beamModel = None
self.weldModelLeft = None
self.weldModelRight = None
self.plateModel = None
self.clearDist = 20.0 # This distance between edge of the column web/flange and beam cross section
def create_3dmodel(self):
self.creatColumGeometry()
self.createBeamGeometry()
self.createPlateGeometry()
self.createFilletWeldGeometry()
self.createNutBoltArray()
# Call for createModel
self.columnModel = self.column.createModel()
self.beamModel = self.beam.createModel()
self.plateModel = self.plate.createModel()
self.weldModelLeft = self.weldLeft.createModel()
self.weldModelRight = self.weldRight.createModel()
self.nutboltArrayModels = self.nutBoltArray.createModel()
def creatColumGeometry(self):
columnOrigin = numpy.array([0, 0, 0])
column_uDir = numpy.array([1.0, 0, 0])
wDir1 = numpy.array([0.0, 0, 1.0])
self.column.place(columnOrigin, column_uDir, wDir1)
def createBeamGeometry(self):
uDir = numpy.array([0, 1.0, 0])
wDir = numpy.array([1.0, 0, 0.0])
origin2 = self.column.secOrigin + (self.column.t/2 * self.column.uDir) + (self.column.length/2 * self.column.wDir) + (self.clearDist * self.column.uDir)
self.beam.place(origin2, uDir, wDir)
def createButtWeld(self):
pass
# plateThickness = 10
# uDir3 = numpy.array([0, 1.0, 0])
# wDir3 = numpy.array([1.0, 0, 0.0])
# origin3 = (self.column.secOrigin +
# self.column.t/2.0 * self.column.uDir +
# self.column.length/2.0 * self.column.wDir +
# self.beam.t/2.0 * (-self.beam.uDir)+
# self.weld.W/2.0 * (-self.beam.uDir))
# #origin3 = numpy.array([0, 0, 500]) + t/2.0 *wDir3 + plateThickness/2.0 * (-self.beam.uDir)
# self.weld.place(origin3, uDir3, wDir3)
def createPlateGeometry(self):
plateOrigin = (self.column.secOrigin +
self.column.t/2.0 * self.column.uDir +
self.column.length/2.0 * self.column.wDir +
self.beam.t/2.0 * (-self.beam.uDir)+
self.plate.T/2.0 * (-self.beam.uDir))
uDir = numpy.array([0, 1.0, 0])
wDir = numpy.array([1.0, 0, 0.0])
self.plate.place(plateOrigin, uDir, wDir)
def createFilletWeldGeometry(self):
uDir = numpy.array([1.0, 0.0, 0])
wDir = numpy.array([0.0, 0.0, 1.0])
filletWeld1Origin = (self.plate.secOrigin + self.plate.T/2.0 *self.weldLeft.vDir + self.weldLeft.L/2.0 * (-self.weldLeft.wDir) )
self.weldLeft.place(filletWeld1Origin, uDir, wDir)
uDir1 = numpy.array([0.0, -1.0, 0])
wDir1 = numpy.array([0.0, 0.0, 1.0])
filletWeld2Origin = (filletWeld1Origin + self.plate.T * (-self.weldLeft.vDir))
self.weldRight.place(filletWeld2Origin,uDir1,wDir1)
def createNutBoltArray(self):
nutboltArrayOrigin = self.plate.secOrigin + self.plate.T/2.0 * self.plate.uDir - self.plate.L/2.0 * self.plate.vDir
gaugeDir = self.plate.wDir
pitchDir = self.plate.vDir
boltDir = self.plate.uDir
self.nutBoltArray.place(nutboltArrayOrigin, gaugeDir, pitchDir,boltDir)
def get_models(self):
'''Returning 3D models
'''
return [self.columnModel,self.beamModel,
self.weldModelLeft,self.weldModelRight,
self.plateModel]+ self.nutBoltArray.getnutboltModels()
|