pi=3.1415926node
H_water=3.6 !槽內水深spring
R_water=2.3 !半槽寬數組
rou_water=1000 !水體密度get
M_water=rou_water*(2*R_water*(H_water-R_water)+0.5*pi*R_water**2)ast
!控制點------截面槽底中心處節點
node_control=8450
coord_y_control=ny(node_control)
coord_x_control=nx(node_control)
coord_z_control=nz(node_control)
coord_y_water=coord_y_control+H_waterfile
/prep7
!定義mass21單元
et,99,mass21
!定義彈簧單元
et,98,combin14
!初始實常數
nr=100rsa
!讀入地震波
*SET,NT,200 !地震加速度步數
*SET,DT,0.01 !地震加速度步長
*DIM,accel_x,,NT
*DIM,accel_y,,NT
*DIM,accel_z,,NT
*VREAD,accel_x,'accel_x','txt'
(F12.9)
*VREAD,accel_y,'accel_y','txt'
(F12.9)
*VREAD,accel_z,'accel_z','txt'
(F12.9)程序
!***********************************附加質量(開始)**********************************im
!將附加質量的渡槽底面的全部節點編爲一個數組di
allsel
CMSEL,S,bottom_areas,AREA
NSLA,S,1
*get,n_bottom,node,,count
*dim,node_bottom,array,n_bottom
*get,nmin,node,,num,min
node_bottom(1)=nmin
*do,i,2,n_bottom
*get,nnum,node,nmin,nxth
nmin=nnum
node_bottom(i)=nmin
*enddo
allsel
!將附加質量的渡槽左壁面的全部節點編爲一個數組
CMSEL,S,left_areas,AREA
NSLA,S,1
nsel,U,loc,x,coord_x_control-0.001,coord_x_control+0.001
*get,n_left,node,,count
*dim,node_left,array,n_left
*get,nmin,node,,num,min
node_left(1)=nmin
*do,i,2,n_left
*get,nnum,node,nmin,nxth
nmin=nnum
node_left(i)=nmin
*enddo
allsel
!將附加質量的渡槽右壁面的全部節點編爲一個數組
CMSEL,S,right_areas,AREA
NSLA,S,1
nsel,U,loc,x,coord_x_control-0.001,coord_x_control+0.001
*get,n_right,node,,count
*dim,node_right,array,n_right
*get,nmin,node,,num,min
node_right(1)=nmin
*do,i,2,n_right
*get,nnum,node,nmin,nxth
nmin=nnum
node_right(i)=nmin
*enddo
allsel
!附加渡槽底面節點質量(豎向地震做用衝擊動水壓力)
*do,i,1,n_bottom
nnum=node_bottom(i)
m_wv=0.4*M_water/R_water*ARNODE(nnum)
type,99
nr=nr+1
r,nr,0,0,m_wv
real,nr
e,nnum
*enddo
!附加渡槽左壁面節點質量(橫向地震做用衝擊動水壓力)
*if,(H_water/R_water),le,1.5,then
*do,i,1,n_left
nnum=node_left(i)
coord_y=ny(nnum)-coord_y_control
m_wh=0.5*M_water/R_water*(coord_y/H_water+0.5*(coord_y/H_water)**2)
m_wh=m_wh*sqrt(3)*tanh(sqrt(3)*R_water/H_water)*ARNODE(nnum)
!確保附加的節點位於水面如下
*if,coord_y,le,H_water,then
type,99
nr=nr+1
r,nr,m_wh,0,0
real,nr
e,nnum
*endif
*enddo
*else
*do,i,1,n_left
nnum=node_left(i)
m_wh=0.5*M_water/H_water*ARNODE(nnum)
coord_y=ny(nnum)-coord_y_control
!確保附加的節點位於水面如下
*if,coord_y,le,H_water,then
type,99
nr=nr+1
r,nr,m_wh,0,0
real,nr
e,nnum
*endif
*enddo
*endif
!附加渡槽右壁面節點質量(橫向地震做用衝擊動水壓力)
*if,(H_water/R_water),lt,1.5,then
*do,i,1,n_right
nnum=node_right(i)
coord_y=ny(nnum)-coord_y_control
m_wh=0.5*M_water/R_water*(coord_y/H_water+0.5*(coord_y/H_water)**2)
m_wh=m_wh*sqrt(3)*tanh(sqrt(3)*R_water/H_water)*ARNODE(nnum)
!確保附加的節點位於水面如下
*if,coord_y,le,H_water,then
type,99
nr=nr+1
r,nr,m_wh,0,0
real,nr
e,nnum
*endif
*enddo
*else
*do,i,1,n_right
nnum=node_right(i)
m_wh=0.5*M_water/H_water*ARNODE(nnum)
coord_y=ny(nnum)-coord_y_control
!確保附加的節點位於水面如下
*if,coord_y,le,H_water,then
type,99
nr=nr+1
r,nr,m_wh,0,0
real,nr
e,nnum
*endif
*enddo
*endif
!***********************************附加質量(結束)**********************************
!***********************************施加彈簧(開始)**********************************
g_=9.81
temp=(H_water-R_water)/R_water
M1=M_water*(0.571-1.276/((1+temp)**0.627)*(tanh(0.331*temp))**0.932)
w1_quadratic=1.323+0.228*(tanh(1.505*temp))**0.768-0.105*(tanh(1.105*temp))**4.659
w1_quadratic=w1_quadratic*g_/R_water
K1=M1*w1_quadratic
h1=H_water*(1-(temp**0.664)*(0.394+0.097*sinh(1.534*temp))/cosh(1.534*temp))
!計算槽壁施加彈簧點的x座標
*if,h1,ge,R_water,then
coord_x_spring_0=R_water
*else
coord_x_spring_0=sqrt(R_water**2+(R_water-h1)**2)
*endif
!尋找按高度施加彈簧的節點
coord_y_spring_0=coord_y_control+h1
allsel
CMSEL,S,left_areas,AREA
CMSEL,A,right_areas,AREA
NSLA,S,1
node_find=node(coord_x_spring_0,coord_y_spring_0,coord_z_control)
coord_y_spring_1=ny(node_find)
NSEL,R,loc,Y,coord_y_spring_1-0.001,coord_y_spring_1+0.001
*get,n_spring,node,,count
*dim,node_spring,array,n_spring
*do,i,1,n_spring
nmin=node(0,0,100000)!選擇距離(0,0,100000)最近的點
node_spring(i)=nmin
NSEL,U,node,,nmin!去掉剛選出的節點,從新選擇
*enddo
allsel
*get,node_max,node,,num,max
dist1=0
*do,i,1,n_spring,2
nnum1=node_spring(i)
node1_x=nx(nnum1)
node1_y=ny(nnum1)
node1_z=nz(nnum1)
nnum2=node_spring(i+1)
node2_x=nx(nnum2)
*if,i,eq,n_spring-1,then
dist2=0
*else
nnum3=node_spring(i+2)
node3_z=nz(nnum3)
dist2=node1_z-node3_z
*endif
!建立中間節點
node_max=node_max+1
n,node_max,(node1_x+node2_x)*0.5,node1_y,node1_z
d,node_max,uy
d,node_max,uz
type,99
nr=nr+1
r,nr,M1*0.5*(dist2+dist1),0,0
real,nr
e,node_max
!建立彈簧(模擬對流動水壓力)
type,98
nr=nr+1
r,nr,K1*0.5*(dist2+dist1)
real,nr
e,nnum1,node_max
e,node_max,nnum2
dist1=dist2
*enddo
!***********************************施加彈簧(結束)**********************************
!**********************施加地震加速度和麪荷載形式的動水壓力(開始)******************************
!查找槽底槽壁節點對應的渡槽截面中間點
allsel
nsel,s,loc,x,coord_x_control-0.001,coord_x_control+0.001
nsel,r,loc,y,coord_y_control-0.001,coord_y_control+0.001
*dim,node_bottom_near,array,n_bottom,2
*do,i,1,n_bottom
nnum=node_bottom(i)
nnum_near=nnear(nnum)
node_bottom_near(i,1)=nnum_near
*enddo
*dim,node_left_near,array,n_left,2
*do,i,1,n_left
nnum=node_left(i)
nnum_near=nnear(nnum)
node_left_near(i,1)=nnum_near
*enddo
*dim,node_right_near,array,n_right,2
*do,i,1,n_right
nnum=node_right(i)
nnum_near=nnear(nnum)
node_right_near(i,1)=nnum_near
*enddo
/solu
ANTYPE,TRANS
TRNOPT,FULL
OUTRES,ALL,ALL
allsel
!第一步計算
t=1
time,DT*t
acel,accel_x(t),accel_y(t),accel_z(t)
kbc,0
nsubst,1
rescontrol,DEFINE,last,last !最後時間步重啓
parsav,all,aqueduct_parameter,sav !參數保存
solve
!rescontrol,file_summary
finish
*do,t,2,5
!從結果提取控制點加速度
/POST1
SET,t-1,1
*do,i,1,n_bottom
*get,node_bottom_near(i,2),node,node_bottom_near(i,1),a,x
*enddo
*do,i,1,n_left
*get,node_left_near(i,2),node,node_left_near(i,1),a,y
*enddo
*do,i,1,n_right
*get,node_right_near(i,2),node,node_right_near(i,1),a,y
*enddo
parsav,all,aqueduct_parameter,sav !參數保存
!再次進入求解模塊
/solu
ANTYPE,,REST,t-1,last,0
parres,new,aqueduct_parameter,sav !恢復參數
!依據渡槽寬高比施加槽底動水壓力荷載(橫向地震做用下槽底的衝擊動水壓力)
*if,(H_water/R_water),lt,1.5,then
*do,i,1,n_bottom
a_wh=node_bottom_near(i,2)
nnum=node_bottom(i)
coord_x_pbh=coord_x_control-nx(nnum)
p_bh=0.5*M_water/R_water*a_wh
p_bh=p_bh*0.5*sqrt(3)*sinh(sqrt(3)*coord_x_pbh/H_water)/cosh(sqrt(3)*R_water/H_water)
F,nnum,FY,p_bh*ARNODE(nnum)
*enddo
*else
*do,i,1,n_bottom
nnum=node_bottom(i)
coord_x_pbh=coord_x_control-nx(nnum)
p_bh=0.5*M_water/H_water/R_water*coord_x_pbh
F,nnum,FY,p_bh*ARNODE(nnum)
*enddo
*endif
!左槽壁(豎向地震槽壁動水壓力)
sign_left=(nx(node_left(1))-coord_x_control)/abs(nx(node_left(1))-coord_x_control)
*do,i,1,n_left
a_wv=node_left_near(i,2)
nnum=node_left(i)
coord_y=ny(nnum)-coord_y_control
*if,coord_y,le,H_water,then
p_wv=0.4*M_water/R_water*a_wv*cos(pi*0.5*coord_y/H_water)
F,nnum,FX,p_wv*ARNODE(nnum)*sign_left
*endif
*enddo
!右槽壁(豎向地震槽壁動水壓力)
sign_right=(nx(node_right(1))-coord_x_control)/abs(nx(node_right(1))-coord_x_control)
*do,i,1,n_right
a_wv=node_right_near(i,2)
nnum=node_right(i)
coord_y=ny(nnum)-coord_y_control
*if,coord_y,le,H_water,then
p_wv=0.4*M_water/R_water*a_wv*cos(pi*0.5*coord_y/H_water)
F,nnum,FX,p_wv*ARNODE(nnum)*sign_right
*endif
*enddo
time,DT*t
acel,accel_x(t),accel_y(t),accel_z(t)
nsubst,1
allsel
solve
finish
*enddo
!**********************施加地震加速度和麪荷載形式的動水壓力(結束)******************************