首页/文章/ 详情

利用python实现二分法求解边坡安全系数

11月前浏览5584
摘要:利用python实现二分法求解边坡安全系数。

1.问题来源

本例为陈育民、徐鼎平主编《FLAC、FLAC3D基础与工程实例》(第二版)第十四章案例,案例详见下图:

2.代码

代码思路参考徐文刚,余旭荣,年廷凯等.基于FLAC3D的三维边坡稳定性强度折减法计算效率改进算法及其应用[J].吉林大学学报(地球科学版),2021,51(05):1347-1355.利用python自编强度折减法代码可避免重复计算自重应力场,有效缩短计算时长。























































import itasca as itimport mathit.command("python-reset-state false")
G1 = 3e7K1 = 1e8dens1 = 2000.0grav = -10.0ten1 = 1e6dial1 = 20.0coh1 = 12380fri1 = 20.0it.command("""           model new           model largestrain off           zone create brick point 0 0 0 0 point 1 2 0 0 point 2 0 0.5 0 point 3 0 0 3 size 3 1 3           zone create brick point 0 2 0 0 point 1 20 0 0 point 2 2 0.5 0 point 3 2 0 3 size 17 1 3 ratio 1.03 1 1           zone create brick point 0 2 0 3 point 1 20 0 3 point 2 2 0.5 3 point 3 12 0 13 point 4 20 0.5 3 point 5 12 0.5 13 point 6 20 0 13 point 7 20 0.5 13 size 17 1 17 ratio 1.03 1 1           zone cmodel assign elastic           zone property bulk 1e10 shear 3e9 density {}           zone face skin break-angle 60           zone face apply velocity-normal 0 range group 'South' or 'North'           zone face apply velocity-normal 0 range group 'East' or 'West'           zone face apply velocity (0,0,0) range group 'Bottom'           model gravity 0,0,{}           model solve           zone gridpoint initialize displacement (0,0,0)           zone gridpoint initialize velocity (0,0,0)           model save 'ini.f3sav' """.format(dens1,grav))
ait1 = 0.02k11 = 1.0k12 = 2.0ks = (k11+k12)/2.0
while k12 - k11 > ait1:    coh1 = 12380.0/ks    fri1 = math.atan(math.tan(20.0*math.pi/180.0)/ks)*180.0/math.pi    dial1 = fri1    it.command("""               model restore 'ini.f3sav'               zone cmodel assign mohr-coulomb               zone property bulk {} shear {} density {} cohesion {} friction {} dilation {} tension {}               model solve ratio 9.8e-6 or cycles 10000""".format(K1,G1,dens1,coh1,fri1,dial1,ten1))    if it.zone.mech_ratio() < 1.0e-5:        k11 = ks        k12 = k12    else:        k12 = ks        k11 = k11    ks = (k11+k12)/2.0print(ks)
3.结果查看

图3-1 位移云图


图3-2 最大剪应变云图

图3-3 塑性区

最终计算得到安全系数ks=1.0390625,与书上结果一致,本代码在FLAC3D6.0、FLAC3D7.0、FLAC3D9.0中均能得到一样的结果

来源:FLAC3D小技巧
pythonFLAC3D
著作权归作者所有,欢迎分享,未经许可,不得转载
首次发布时间:2023-12-13
最近编辑:11月前
FLAC3D小技巧
硕士 专注FLAC3D中的小技巧分享...
获赞 36粉丝 209文章 40课程 0
点赞
收藏
未登录
还没有评论
课程
培训
服务
行家
VIP会员 学习 福利任务 兑换礼品
下载APP
联系我们
帮助与反馈