复杂形态钢结构设计培训班

首页 结构乌托邦-公众号 【OpenSees】浅析约束处理方法(一):Plain、Penalty

【OpenSees】浅析约束处理方法(一):Plain、Penalty

“Plain、Penalty罚数法
OpenSees分析模块有约束处理方法ConstraintHandler、自由度编排方式DOF_Numberer、迭代算法SolutionAlgorithm、线性方程求解器Solver、收敛准则ConvergenceTest五部分组成。其中,迭代算法的推送可见:
【OpenSEES】浅析Newton迭代(一):减少刚度重构工作量与减少迭代次数谁更有意义?
【OpenSEES】浅析Newton迭代(二):基于LineSearch优化迭代算法

【OpenSEES】浅析Newton迭代(三):基于Krylov优化迭代算法

为处理模型中的单点约束(如fix)及多点约束(如rigidDiaphragm、EqualDOF),必须通过ConstraintHandler定义约束处理方法。OpenSees具有四种约束处理方法:PlainPenalty(罚数法)Lagrange(拉格朗日乘子法)Transformation。采用任意一种约束处理方法,在特定的情景下均可能出现求解问题

本期推送将通过算例,在浅析PlainPenalty(罚数法)的同时,复现可能会引发错误的环节。点击“阅读原文”可查看与本推送相关的测试算例。下期推送将浅析Lagrange(拉格朗日乘子法)、Transformation约束处理方法。

测试模型简介

算例如图2所示:杆件由柔性杆(element elasticBeamColumn 1 1 2 20 29000 1400 1)和刚性杆约束(rigidLink -beam 2 3)组成,一段支座固接,一段支座为滑动支座。因此,节点2和节点3应具有相同的水平位移和转角,节点2和节点3之前的垂直位移差等于转角乘以刚性杆长度。体系刚度矩阵如图1所示。

图1 测试算例与体系刚度矩阵

Plain

Plain命令主页如图2所示,可知Plain仅可处理”fix”及”equalDOF”两类约束,无法处理”rigidLink”多点约束。若仍采用Plain处理上述约束,则刚度矩阵如图2所示。可知,此时矩阵奇异,无法完成矩阵求解。

图2 Plain处理后的刚度矩阵与求解结果

若仍计划求解上述算例,可通过相对刚性的elasticBeamColumn替代rigidLink约束,如根据柔性杆弹模放大1E4倍定义刚性杆(element elasticBeamColumn 2 2 3 20 29000 E4 1400 1),此时进行求解将获得如图3所示的有效结果。

图3 通过刚性单元实现约束并通过Plain约束处理完成求解


Penalty罚数法

Penalty(罚数法)在不改变矩阵维度的前提下,通过在刚度矩阵中引入大刚度弹簧实现约束,其命令主页如图4所示。可知,弹簧刚度(罚数)应足够大以满足约束需求,但也不应过大避免方程组病态。理论上可为每个约束定义不同的罚数,但OpenSess仅允许用户分别对所有单点约束及所有多点约束定义相同的罚数,这为罚数的取值带来一定的挑战。本例中罚数取值为1E4倍的柔性杆线刚度,刚度矩阵如图4所示,其中红色项为用于处理约束的罚数赋予项,可见矩阵维度未改变。

图4 Penalty罚数法与其处理后的刚度矩阵

由于微小的位移变化将引起大刚度弹簧力的显著变化,因此在Penalty中采用与力相关的收敛准则(如能量收敛准则NormUnbalance等)并不明智,将出现如图5所示的收敛问题。

图5 Penalty罚数法与力相关的收敛准则

此时将收敛准则修改为仅与位移相关收敛准则(如NormDispIncr等)则迭代收敛并获得有效的求解结果。

图6 Penalty罚数法与仅位移相关的收敛准则
  • 小结

  • Plain仅适用于处理“fix”“equalDOF”约束问题;
  • Penalty引入罚数实现约束,罚数应足够大以满足约束需求,但也不应过大避免方程组病态;

  • 由于罚数的存在,Penalty应使用仅与位移相关的收敛准则
点击“阅读原文”可查看与本推送相关的测试算例。下期推送将浅析Lagrange(拉格朗日乘子法)Transformation约束处理方法。

精彩回顾:

【会议总结】OpenSEES Days Eurasia 2019 in PolyU

【PBSD】【OpenSees】在2019日本E-Defense盲测比赛的表现

【YJK】弹性时程分析如何考虑周期折减系数
  • PBSD

【PBSD】2019年更新历史——结构抗震性能设计软件PBSD

【PBSD】超限工程好助手:结构抗震性能设计软件PBSD功能简介

【PBSD】功能介绍及应用教学回顾[含视频]

【PBSD】【PERFORM-3D】YTP导模工具使用手册

【PBSD】【OpenSEES】【YTO】智能化的结构弹塑性分析全套解决方案

【PBSD】V1.0.5.0版正式发布:免费地震动工具箱之教学视频

【PBSD】地震动工具箱:多频段选波方法详解

【PBSD】一键弹塑性报告功能演示

【PBSD】【PERFORM-3D】性能前馈集中塑性铰单元的定义、优势与测试

【PBSD】性能前馈集中塑性单元PFLPH与纤维单元力学性能对比

【PBSD】【PERFORM-3D】弹塑性模型刚度调整

【PBSD】人工波生成功能测试 [开源]

【PBSD】弹性时程分析的实现与功能测试

【PBSD】【OpenSEES】2019年精选推送集锦

【广东省性能设计规程】与国家高规对比浅谈反应谱的修正与完善

【广东省性能设计规程】性能设计基本方法与PBSD的实现
  • OpenSees

【OpenSEES】OpenSEES历史版本下载:v1.7.2-v3.1.0

【OpenSees】浅析两类纤维单元:位移元与应力元

【OpenSEES】24类纤维截面剖分TCL函数

【OpenSees】浅析纤维单元的数值积分方法

【OpenSees】浅析分布塑性铰单元的数值积分方法

【OpenSees】应力元纤维单元的Localization Issues

【OpenSees】宏观梁柱单元的强度软化模拟

【OpenSEES】浅析纤维单元(一)

【OpenSEES】浅析纤维单元(二)

【OpenSEES】浅析纤维单元(三)

【OpenSees】新版Ibarra-Medina-Krawinkler(IMK)模型的前世今生

【OpenSees】浅析剪力墙宏观单元:MVLEM

【OpenSees】浅析剪力墙宏观单元:SFI-MVLEM

【OpenSees】浅析剪力墙宏观单元:分层壳单元

【OpenSEES】浅析迭代(一)

【OpenSEES】浅析迭代(二):基于LineSearch优化迭代算法

【OpenSEES】浅析迭代(三):基于Krylov优化迭代算法

【OpenSees】SecAggregator为DispBC赋予剪切刚度乃无用功

【OpenSEES】PM截面分析实例

【OpenSees】如何利用应变控制截面分析的进程

【OpenSEES】低周往复加载实例:荷载位移双控

【OpenSees】SDOF非线性动力时程分析的实现与算例

  • WSAP

【WSAP】结构力学求解器(一):二阶效应分析[开源]
【WSAP】结构力学求解器(二):模态分析[开源]
【WSAP】结构力学求解器(三):杆端释放[开源]
  • 编程与工具

【编程】Python效率测试与调用.Net的基本方法

【编程】分段解析法及多软件反应谱求解结果对比探究[开源]

【编程】基于神经网络预测加速度反应谱——SRP第一课

【编程】基于C#绘制反应谱曲线——SRP第一课

【工具】PC端文字识别小工具2.0[Mini_OCR]

【工具】OpenSEES_XML分析结果提取工具[开源]

【工具】OSRun [OpenSees运行辅助工具][开源]

【工具】FSV [OpenSees纤维截面可视化工具][开源]



本文来自网络,不代表钢构人的立场,转载请注明出处。搜索工程类文章,就用钢构人网站。 https://www.ganggouren.com/2020/11/2430fc8a1c/
上一篇
下一篇

作者: ganggouren

为您推荐

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

联系我们

联系我们

17717621528

在线咨询: QQ交谈

邮箱: 1356745727@qq.com

工作时间:周一至周五,9:00-17:30,节假日休息
关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部