首页/文章/ 详情

教你Matlab有限元编程对悬臂梁进行受力分析-附源码及教程

4月前浏览6643

导读:大家好,我是SimPC博士,主要从事工程结构抗震及减隔震研究,玻璃成型热工设备流动及传热研究,玻璃材料力学性能研究。精通有限元等数值算法的实现,有限元软件二次开发,数据处理,偏微分方程求解,优化算法,GUI界面开发等。有多项科研成果,其中SCI论文4篇,EI3篇,专利2篇。


近日我注册并认证了仿真秀专栏,将在仿真秀官网和App给平台用户带来Matlab有限元编程、复杂函数拟合和matlab绘图相关内容。此外还会带来隔震建筑Abaqus建模仿真分析等内容。本次案例主要以受均布荷载和集中荷载的变截面悬臂梁为研究对象,通过matlab编制四节点和八节点四边形单元有限元程序来对悬臂梁进行受力分析。

一、问题概述

如图1-1 所示,某变截面悬臂梁长度为2m,截面面积由0.6m至0.2m线性变化,受作用在自由端节点的集中荷载2P=kN和竖直方向均布荷载q=1kN/m作用,按平面应力问题分析,求解自由端节点挠度。变截面悬臂梁采用C30混凝土,弹性模量为E= 4 3 10 MPa,泊松比为。编制四节点和八节点四边形单元有限元程序,最终得到梁的变形。
图1-1 变截面悬臂梁

二、求解思路

对于本问题采用基于MATLAB 编制有限元分析程序进行求解,其基本组成部分包括前处理模块、分析主程序模块和后处理模块。在前处理模块中,实现节点坐标输入、单元节点编号、网络划分以及边界条件输入等工作;在分析主程序模块中,求解整体刚度方程;在后处理模块中,实现结果显示、数据输出等工作。本文主要针对四节点四边形单元与八节点四边形单元理论和对应的计算程序进行讲解。
有限元法的基本步骤:
  • 几何域离散,获得标准化的单元;

  • 通过能量原理(虚功原理或最小势能原理,获得单元刚度方程;

  • 单元的集成(装配);

  • 处理位移边界条件;

  • 计算支反力;

  • 计算单元的其他物理量(应力应变)。
这几步中,最核心的内容是单元研究,具体包括:
  • 节点描述

  • 场描述

  • 单元刚度方程。
接下来的内容主要以单元的描述为核心内容结合matlab代码,为大家讲解本案例有限元matlab编程过程。  
1、平面问题的平衡方程、几何方程、物理方程
平面问题的弹性力学基础理论是推导有限元方程的基础,所以先罗列出平面问题的平衡方程、几何方程、物理方程,具体如公式(1)-(3)所示。至于这些方程的推导过程大家可以参考任意弹性力学课本,都会进行详细的讲解。
2、等参单元
在有限元方法中,若要离散边界为曲线或曲面的求解域,需要建立将形状规则的单元变换为边界为曲线或曲面的单元的方法,在有限元法中对应此问题所采用的变换方法是等参变换,即单元几何形状的变换和单元内长函数采用相同数目的节点及相同的插值函数进行变换。同样我们今天要讲的四边形单元也从其对应的等参单元的基础理论讲起。
四边形单元可以由自然坐标系中的矩形单元映射而成,映射关系如图2-1所示。

图2-1 平面四节点矩形单元的映射关系

在自然坐标系下,矩形单元是规则化的,当自然坐标系中的单元取为双线性单元时(也即为四节点四边形单元),平面四节点矩形单元如图2-2所示,单元有4个节点,8个自由度。单元的形函数定义如下:
        (4)
其中, 为自然坐标系下的节点坐标值。
单元从自然坐标系到物理坐标系的映射为

在进行映射变换时候,要求单元两个坐标系下的节点编号要对应。
单元的节点变量用型函数进行插值,有
                   (7)
function N=ShapeFun(s,t)            N1=1/4*(1-s)*(1-t);N2=1/4*(1 s)*(1-t);N3=1/4*(1 s)*(1 t);N4=1/4*(1-s)*(1 t);N=[N1 0 N2 0 N3 0 N4 0;0 N1 0 N2 0 N3 0 N4];end

同理平面八节点矩形单元如图2-3所示,单元共有8个节点,16个自由度。单元的形函数定义如下:

    (8)
        (9)
  (10)
其中, 为自然坐标系下的节点坐标值。
单元从自然坐标系到物理坐标系的映射为
     (11)
         (12)
在进行映射变换时候,要求单元两个坐标系下的节点编号要对应。
单元的节点变量用型函数进行插值,有
                              (13)
function N=ShapeFun(s,t)            
%% 四边形八结点等参单元形函数矩阵 % 角点N1=1/4*(1-s)*(1 t)*(-s t-1); N2=1/4*(1-s)*(1-t)*(-s-t-1); N3=1/4*(1 s)*(1-t)*(s-t-1); N4=1/4*(1 s)*(1 t)*(s t-1); % 边中点 N5=1/2*(1-t^2)*(1-s); N7=1/2*(1-t^2)*(1 s); N6=1/2*(1-s^2)*(1-t); N8=1/2*(1-s^2)*(1 t); N=[N1 0 N2 0 N3 0 N4 0 N5 0 N6 0 N7 0 N8 0;0 N1 0 N2 0 N3 0 N4 0 N5 0 N6 0 N7 0 N8];

图2-2 平面四节点矩形单元

图2-3 平面四节点矩形单元
等参单元中除了完成如公式(5)(6)(10)(11)的坐标映射外,还需要完成坐标偏导数的映射和面积/体积的映射,因为在最终推导出的单元刚度矩阵表达式,即一个积分函数中会包含坐标的偏导项和坐标的面积积分项,如公式(x)所示,所以接下来我们研究坐标偏导项的映射关系。根据链式求导法则,形函数对自然坐标系的导数为  
              (14)
写成矩阵的形式就是
         (15)
其中,J被称为Jacobi矩阵。反过来,形函数对物理坐标的导数为
                             (16)
另外,对于二维平面单元还要完成面积的映射,为
                     (17)
可以看出Jacob矩阵在等参变化中扮演着至关重要的角色,Jacob矩阵具体的表达式如下所示,
            (18)
公式18对应的八节点单元雅各比矩阵的求解代码为:
function J=Jacobi(ie,s,t,Elements,Nodes)            ENodes = Elements(ie,:);                 %获取单元结点 xe = Nodes(ENodes(:),:);                 %获取节点坐标 x1=xe(1,1);y1=xe(1,2); x2=xe(2,1);y2=xe(2,2); x3=xe(3,1);y3=xe(3,2); x4=xe(4,1);y4=xe(4,2); J=1/4*[-(1 t) -(1-t) 1-t 1 t;1-s -(1-s) -(1 s) 1 s]*[x1 y1;x2 y2;x3 y3;x4 y4];end
公式18对应的四节点单元雅各比矩阵的求解代码为:
function J=Jacobi(ie,kesi,yita,Elements,Nodes)            ENodes = Elements(ie,:);                 %获取单元结点 xe = Nodes(ENodes(:),:);                 %获取结点坐标 x1=xe(1,1);y1=xe(1,2); x2=xe(2,1);y2=xe(2,2); x3=xe(3,1);y3=xe(3,2); x4=xe(4,1);y4=xe(4,2); J=1/4*[-(1-yita),(1-yita),(1 yita),-(1 yita);-(1-kesi),-(1 kesi),(1 kesi),(1-kesi)]*[x1 y1;x2 y2;x3 y3;x4 y4];end
3、刚度矩阵的推导

为了求出上述平面四节点和八节点单元的单元刚度矩阵,需要借助能量原理(虚功原理、最小势能原理)进行推导,能量原理的推导过程大家可以参考任意一本有限元理论书籍,都会有详细的推导过程,这里就不做进一步推导讲解,直接给出物理坐标和几何坐标系下的刚度矩阵的公式

   (19)

   (20)

其中B矩阵为应变矩阵,如下式;D矩阵为材料刚度矩阵,如公式(1)所示,是物理方程中表征应力应变关系的矩阵。从上述刚度矩阵的表达式可以看出,自然坐标和物理坐标间要完成坐标映射、偏导映射、面积隐射三个部分,具体映射公式已在上一节的等参单元讲解中详细给出。

                         (21)

4、高斯积分

公式(20)中的单元刚度矩阵通过数值积分求得,本案例中的四节点和八节点四边形等参单元均采用2*2个积分点的高斯积分即可求得精确结果。高斯积分点的坐标具体如图所示。

4-1 Gauss积分点示意图

公式(20)写成数值积分的形式为

                (22)

对于8节点单元实现上述数值积分的代码如下所示:

r = [-sqrt(1/3) sqrt(1/3)];             % 2*2 高斯积分点 s = [r(1) r(1) r(2) r(2)]; t = [r(2) r(1) r(1) r(2)];              % 高斯积分点坐标for i=1:4         J = Jacobi(E_ID,s(i),t(i),Elements,Nodes);             % 雅可比矩阵         Nst = DiffShapeFun(s(i),t(i));        % 形函数关于自然坐标s,t求导         Nxy = zeros(8,2);         for j=1:8           Nxy(j,:) = (J\Nst(j,:)')';             % 形函数关于 x,y 求导=inv(J)*Nst         end         Bm = [Nxy(1,1) 0 Nxy(2,1) 0 Nxy(3,1) 0 Nxy(4,1) 0 Nxy(5,1) 0 Nxy(6,1) 0 Nxy(7,1) 0 Nxy(8,1) 0;             0 Nxy(1,2) 0 Nxy(2,2) 0 Nxy(3,2) 0 Nxy(4,2) 0 Nxy(5,2) 0 Nxy(6,2) 0 Nxy(7,2) 0 Nxy(8,2);             Nxy(1,2) Nxy(1,1) Nxy(2,2) Nxy(2,1) Nxy(3,2) Nxy(3,1) Nxy(4,2) Nxy(4,1) Nxy(5,2) Nxy(5,1) Nxy(6,2) Nxy(6,1) Nxy(7,2) Nxy(7,1) Nxy(8,2) Nxy(8,1)];         ke = ke det(J)*Bm'*D*Bm*Width;  %数值积分  end

5、均布荷载的施加

在有限元中分布力要转为等效节点荷载,而确定等效节点荷载的方法也是通过能量原理推导得到

                  (22)

上式中,第一项代表体积力的等效荷载,第二项代表面积力的等效荷载,这个案例我们只考虑面力荷载。实现公式22的代码为

function Pe=UniLoad(ie,N_ID_p1,q0,Nodes,Elements)     k=-0.625e-3;                            % 均布荷载值 N/mms = [-sqrt(1/3) sqrt(1/3)];                 % 2*2 高斯积分点ENodes = N_ID_p1(ie,:);                    %获取单元结点号Pe=zeros(16,1);                          %生成临时单元节点力零列向量x1=Nodes(ENodes(1),1);x6=Nodes(ENodes(4),1);L16=abs(x6-x1);                          %单元长度for i=1:2                                 %用于高斯积分的求和循环    N_q=ShapeFun(s(i),1);                   % 4级子程序:ShapeFun(s(i),1)    q_x=q0;    Pe=Pe N_q'*q_x*[0;L16/2];            endend

三、Matlab有限元编程精品课

网格划分及变形结果如图3-1所示。本案例的详细视频教程和对应的matlab源码,请关注我的仿真秀官网和APP精品课程Matlab有限元编程从入门到精通10讲》。

图3-1 梁变形结果

此外,为帮助大家更好的入门学习Matlab有限元编程分析能力,欢迎大家直接在附件下载。如果遇到问题请在文章下方留言或者联系平台小助手。

我的Matlab有限元编程精品课

点击图片试看

本课程为matlab有限元编程专题课,课程主要以案例的形式进行讲解,中间会穿插案例中所涉及到的有限元基本理论,案例不局限于力学问题的有限元求解,还会涉及传热学、电学等问题的有限元求解。

因为固体力学领域我最熟悉,所以我们从固体力学开始,所涉及的单元有杆单元,梁单元,平面三角形单元,薄板单元,厚板单元,四面体实体单元等等,力学问题有静力学问题,也有动力学问题,后期还会涉及材料非线性、几何非线性、接触非线性等非线性问题,内容丰富,不断更新完善。

此外,笔者为所有订阅用户提供知识圈答疑服务VIP用户交流群。并附赠课程相关资料等(平台支持自行开具电子发票)。

1、你将学到  
  • 快速获得各典型有限元案例的Matlab代码;
  • 学习并掌握有限元基础理论;
  • 掌握Matlab编程实现有限元算法的流程;
  • 掌握多种有限元单元的基本理论Matlab编程实现过程;
  • 掌握静力学、动力学、材料非线性、几何非线性、接触非线性问题的Matlab编程实现;
  • 为订阅用户提供知识圈答疑服务,并建立VIP用户交流群,后续可根据订阅用户需求进行加餐直播。此外还提供课程对应的学习资料模型一份。

2、适合哪些人学习  
  • 理工科院校学生和教师;

  • 学习型仿真设计工程师;

  • Matlab有限元编程兴趣爱好者和应用者。

作者:SimPC博士   仿真秀专栏作者
声明:本文首发仿真秀App,部分图片和内容转自网如有不当请联系我们,欢迎分享,禁止私自转载,转载请联系我们。
来源:仿真秀App

附件

免费课程资料及模型.txt
Abaqus静力学非线性二次开发建筑电子MATLAB理论材料曲面
著作权归作者所有,欢迎分享,未经许可,不得转载
首次发布时间:2022-09-08
最近编辑:4月前
仿真圈
技术圈粉 知识付费 学习强国
获赞 10024粉丝 21478文章 3512课程 218
点赞
收藏
作者推荐
未登录
2条评论
嘿嘿
签名征集中
6月前
Matlab进群
回复
仿真秀0820111249
签名征集中
2年前
下载异常是什么情况
回复
课程
培训
服务
行家
VIP会员 学习 福利任务 兑换礼品
下载APP
联系我们
帮助与反馈