0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何用matlab实现针对四面体单元划分的三维结构进行有限元编程

8XCt_sim_ol 来源:仿真秀App 作者:SimPC 2022-10-12 18:11 次阅读

导读:自9月以来,我的《教你Matlab有限元编程对悬臂梁进行受力分析》原创文章发布以来,我的精品课《Matlab有限元编程从入门到精通10讲》受到了越来越多的工程师朋友的关注,已超过50多人已经订阅学习,欢迎大家加入订阅用户交流群一起讨论Matlab有限元编程那些事(哈哈哈,为大家答疑和分享资料)。

今天,我接着分享Matlab有限元编程专业技能。之前的课程我们学习了一维梁单元,二维平面单元,三维板壳单元的matlab有限元编程,本次案例主要讲解如何用matlab实现针对四面体单元划分的三维结构进行有限元编程,具体案例是一个悬臂梁受集中荷载的问题。图1为本案例Matlab编程计算得到的结果。主要内容涉及四面体单元的有限元基本理论的推导,主要是单元刚度矩阵的推导,此外还包括等参单元和Hammer数值积分以及三维问题的后处理计算。

1d62cc6e-4a16-11ed-a3b6-dac502259ad0.png

图1 悬臂梁受集中荷载的应力云图

一个完整的有限元程序基本组成部分包括前处理模块、分析主程序模块和后处理模块。在前处理模块中,实现节点坐标输入、单元节点编号、网络划分以及边界条件输入等工作;在分析主程序模块中,求解整体刚度方程;在后处理模块中,实现结果显示、数据输出等工作。

对应的有限元法的基本步骤:

(1)几何域离散,获得标准化的单元; (2)通过能量原理(虚功原理或最小势能原理,获得单元刚度方程; (3)单元的集成(装配); (4)处理位移边界条件; (5)计算位移场;

(6)计算单元的其他物理量(应力应变)。

这几步中,最核心的内容是单元研究,具体包括:

(1)节点描述(不同坐标系节点坐标的变化); (2)场描述(位移场,应变场,应力场,形函数);

(3)单元刚度方程(基于能量原理推导)。

需要说明的是后文的四面体单元有限元方程的推导过程是基于等参单元的基本理论从局部坐标(自然坐标、体积坐标)出发来推导四面体单元的刚度矩阵,因为这样做比较规范自然,推导过程也适用于其他类型单元。但是因为四面体单元相对简单也可以直接从直角坐标(全局坐标)进行推导,具体推导过程可参考清华大学曾攀老师的课程,直接从直角坐标(全局坐标)进行推导的过程省去了等参单元雅各比矩阵呀等坐标系映射的各种概念,理解起来相对容易。

公式(1)-(3)为弹性力学中三维空间弹性问题的完整描述,分别是空间问题的平衡方程、几何方程、物理方程,这是我们推导有限元方程的基础。这些公式会在后面的有限元方程推导过程中用到。

1d8170e2-4a16-11ed-a3b6-dac502259ad0.png

四面体单元的坐标描述涉及了等参单元的概念,在有限元方法中,若要离散边界为曲线或曲面的求解域,需要建立将形状规则的单元变换为边界为曲线或曲面的单元的方法,在有限元法中对应此问题所采用的变换方法是等参变换,即单元几何形状的变换和单元内场函数采用相同数目的节点及相同的插值函数进行变换。四面体单元的参数坐标就是体积坐标,体积坐标的定义如图2所示。

1da61190-4a16-11ed-a3b6-dac502259ad0.png

图2 四面体单元体积坐标的定义

参数坐标系下的形函数等于对应的体积坐标,四个节点对应四个形函数,如下式,

1dfa4f9e-4a16-11ed-a3b6-dac502259ad0.png

这样就实现了自然坐标系和物理坐标系下的坐标映射,如下式,

1e14c054-4a16-11ed-a3b6-dac502259ad0.png

同样形函数也可以用于物理场的插值,公式(6)是位移场的插值表达式。

1e2b5eb8-4a16-11ed-a3b6-dac502259ad0.png

有了位移场插值的表达式就可以通过公式(2)-(3)的几何方程和物理方程推导应变场和应力场的有限元表达式,但是公式(2)的几何方程中存在对于xy也就是物理坐标系下的偏导数,代入公式(6)后也就是形函数对物理坐标的偏导数,因为我们的形函数是在自然坐标系下定义的,是关于ξ, η, ζ的函数,想要知道他对x,y的偏导,这里利用了链式求导法则,即可建立如下式(7)所示的形函数对自然坐标的物理坐标偏导数的映射关系。中间的这个矩阵就叫Jacob矩阵。

1e3db1d0-4a16-11ed-a3b6-dac502259ad0.png

如何求Jacob矩阵呢?将公式(5)代入公式(7)可以得到如下式(8)所示的自然坐标偏导矩阵乘以一个坐标矩阵,

1e5422d0-4a16-11ed-a3b6-dac502259ad0.png

得到jacob矩阵后求逆,再乘以自然坐标偏导矩阵就可以得到形函数对物理坐标的导数。如下式(9),

1e6af9ce-4a16-11ed-a3b6-dac502259ad0.png

上述形函数对物理坐标的导数的求解过程对应的matlab代码如下:

function [NDxyz,JacobiDET] = ShapeFunction(ElementNodeCoordinate)
%计算形函数及形函数对局部坐标ksi eta zeta的导数
NDL = [-1 1 0 0;-1 0 1 0;-1 0 0 1];%3*4  [N1Dksi N2Dksi N3Dksi N4Dksi;N1Deta N2Deta N3Deta N4Deta……]
Jacobi = NDL*ElementNodeCoordinate;%计算雅可比矩阵3*4 4*3
JacobiDET = det(Jacobi);%计算雅可比行列式3*3 [DxDksi DyDksi DzDksi;DxDeta……
JacobiINV=inv(Jacobi);%对雅可比行列式求逆3*3
NDxyz=JacobiINV*NDL;%利用雅可比行列式的逆计算形函数对结构坐标的导数[DN1Dx DN2Dx DN3Dx;DN1Dy DN2Dy DN3Dy;……]
end
这样求出形函数对物理坐标的导数后就可以代入公式(2)几何方程求出应变场矩阵B,经过能量原理的推导可以得到单元刚度矩阵的表达式,注意刚度矩阵的表达式是一个积分的运算,由于被积函数较为复杂,如果代数积分进行计算要消耗大量的计算资源,因此有限元理论中引入数值积分,即我们熟悉的高斯积分和hammer积分,对于直角坐标系我们采用高斯积分,对于面积或者体积坐标系我们采用hammer数值积分,具体这两类积分的原理大家可以参考相关数值积分教材即可,这里我们只利用hammer数值积分的结论。四面体单元具体的数值积分公式如下:

1e7bae7c-4a16-11ed-a3b6-dac502259ad0.png

其中,对应的B矩阵如下式所示:

1e99b25a-4a16-11ed-a3b6-dac502259ad0.png


单元刚度矩阵确定好之后,将其按照自由度索引组装到全局刚度矩阵中,组装的核心思想就是确定好每个单元中的每个节点中的每个自由度在整体刚度矩阵中的位置即可。

整体刚度矩阵确定之后,就是荷载向量p的定义,这个很简单,只要依次确定每个节点每个自由度的外力荷载即可。

刚度矩阵和荷载向量确定后接下来就是边界条件的施加,大家最熟悉的可能就是直接划行划列的方法,这个方法的弊端在于划去自由度为零的行列之后,整体单元刚度矩阵的编号以及自由度编号都会改变,对于大规模计算非常不方便,影响计算效率。为了解决这个问题出现了乘大数法和置一法,置一法只能解决零边界问题,乘大数法可以解决零边界和非零边界,应用非常广泛。边界条件的施加这里我们采用乘大数法。针对边界条件采用乘大数法施加边界的方式为:在自由度1ebb71a6-4a16-11ed-a3b6-dac502259ad0.png上乘以一个很大的数a,然后在相应的外力向量对应的自由度上乘以1edca3a8-4a16-11ed-a3b6-dac502259ad0.png,具体如下式(22)所示

1ef19f42-4a16-11ed-a3b6-dac502259ad0.png

为了验证乘大数法的可靠性,将对应行列写成代数表达式的形式,如下式所示

1f292f20-4a16-11ed-a3b6-dac502259ad0.png

考虑到远大于,所以公式(13)可以写成,

1f640384-4a16-11ed-a3b6-dac502259ad0.png

即可得到1f7bb196-4a16-11ed-a3b6-dac502259ad0.png。可见乘大数法与实际边界条件是等价的。

施加了边界条件的刚度矩阵K与荷载矩阵p之后,可直接利用matlab中的高斯消去法 计算符“”,完成位移的求解,即u=Kp。

求出节点位移之后通常我们做受力分析时还会需要知道应力应变的分布情况,具体通过下述公式求解:

1f8a5e30-4a16-11ed-a3b6-dac502259ad0.png

对应的提取应力和应变的后处理代码如下:

% 计算形函数导数
    [NDxyz, ~] = ShapeFunction(ElementNodeCoordinate);%[DN1Dx DN2Dx DN3Dx;DN1Dy DN2Dy DN3Dy;……]
    ElementNodeDisplacement=U(ElementNodeDOF);%12*1 节点位移列阵
    ElementNodeDisplacement=reshape(ElementNodeDisplacement,Dof,4);%3*4
    % 计算单元应变 Strain3_3 3*3的应变矩阵
    Strain3_3=ElementNodeDisplacement*NDxyz';%高斯积分点处应变 3*4  4*3
    %把单元应变矩阵改写成6*1
    Strain=[Strain3_3(1,1) Strain3_3(2,2) Strain3_3(3,3) ...
    Strain3_3(1,2)+Strain3_3(2,1)....
    Strain3_3(2,3)+Strain3_3(3,2) Strain3_3(1,3)+Strain3_3(3,1)]';
Stress(1:6,1) = D*Strain;%高斯积分点处应变
利用绘图命令Patch我们可以得到如图1所示的应力云图。另外计算得到的变形和位移云图如图3-4所示。

1f9612e8-4a16-11ed-a3b6-dac502259ad0.png

图3 变形前后的网格对比

1fea5c40-4a16-11ed-a3b6-dac502259ad0.png

图4 位移云图





审核编辑:刘清

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • matlab
    +关注

    关注

    175

    文章

    2922

    浏览量

    228441
  • 矩阵
    +关注

    关注

    0

    文章

    406

    浏览量

    34250
  • 信号处理模块

    关注

    1

    文章

    6

    浏览量

    6962

原文标题:案例实操:四面体单元悬臂梁的Matlab有限元编程过程讲解

文章出处:【微信号:sim_ol,微信公众号:模拟在线】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    #硬声创作季 #数控加工 UG NX7.0-14.4.06 三维四面体网格

    三维数控UG
    水管工
    发布于 :2022年10月29日 16:51:11

    【PDF】matlab有限元法计算分析程序编写

    【PDF】matlab有限元法计算分析程序编写附件:
    发表于 02-28 11:04

    MATLAB有限元分析与应用

    13.1基本方程 13.2用到的MATLAB函数 13.3习题第14章二次边形 14.1基本方程 14.2用到的MATLAB函数 14.3习题第15章线性
    发表于 02-28 11:07

    Ansoft HFSS使用教程(1)——引言

    四面体的集合叫做有限元。下图是混合接头的有限元剖分图。将一个结构分成成千上万的小区域(
    发表于 12-10 10:17

    OASYS.Suite.13.1.WINDOWS.LINUX.64通用非线性瞬态动力分析有限元软件

    Bentley.MX.V8i.SS4.08.11.09.872三维CAD基础软件OASYS.Suite.13.1.WINDOWS.LINUX.64通用非线性瞬态动力分析有限元软件
    发表于 07-02 16:22

    基于有限元的PCB板上关键元件热可靠性分析

    向上和自顶向下方法创建实体模型。在创建实体模型过程中,由于电子元件结构复杂,为了网格划分方便及结果的准确性,可以简化实体模型,选用适合不规则形状单元划分的SOLID87 10节点
    发表于 08-27 16:07

    基于stm32f4的三维旋转显示平台设计资料(原理图、代码)

    stm32f4的浮点运算能力,实现了低成本的三维显示数据的生产,并利用类似分布式处理的系统结构,满足了
    发表于 08-30 14:42

    HFSS 仿真算法及其应用场景详解:有限元算法、积分方程算法、PO算法

    , DGTD)的三维全波电磁场仿真求解器,采用基于四面体有限元技术,能得到和HFSS频域求解器一样的自适应网格剖分精度,该技术使得HFSS的求精精度成为电磁场行业标准。这项技术完善了HFSS的频域求解器技术
    发表于 09-20 17:15

    如何有效的学习CAE有限元分析

      有限元分析在工程应用中正发挥着越来越重要的作用,尤其在复杂钢结构的创新设计中,离开有限元分析就很难使结构的强度、刚度以及稳定性等得到有效地保证。因而,为了更好地增加产品
    发表于 07-07 16:59

    有限元仿真分析软件的种算法模型格式介绍

      当仿真工作者进入一个更高层的应用,或者在一个全新的领域做分析时,商业通用的有限元软件可能不能满足需求,此时做算法的编程会是更自由的解决方案,本文是有限元科技小编详细介绍了种模型格
    发表于 07-07 17:18

    有限元法的原理

    所求边值问题的数值解。由于有限元法的单元剖分灵活性大,适应性强,解的精度高,电磁场的物理特性能被很好保持。电机中的电磁场问题一般归结为偏微分方程的边值问题。首先从偏微分方程边值问题出发找出一个称为能量泛...
    发表于 09-06 08:08

    利用有限元方法对280M1-2型相异步电机的法兰结构强度进行分析校核

    有限元分析计算可为电机法兰设计改进提供依据。  2 结构强度分析  2. 1 实体建模  对研究对象的电机整体进行实体建模,以形成电机三维模型,如图1所示。主要材料及特性如表2所示。因
    发表于 03-02 11:52

    如何使用Matlab进行有限元分析和硬盘的选购与使用资料说明

    介绍了Matlab 语言特点,给出了Matlab 环境下实现有限元的步骤。并以一个具体实例说明如何使用Matlab 进行
    发表于 07-24 16:27 5次下载
    如何使用<b class='flag-5'>Matlab</b><b class='flag-5'>进行</b><b class='flag-5'>有限元</b>分析和硬盘的选购与使用资料说明

    基于Matlab有限元编程的变截面悬臂梁分析

    以受均布荷载和集中荷载的变截面悬臂梁为研究对象,通过matlab编制四节点和八节点四边形单元有限元程序来对悬臂梁进行受力分析。
    的头像 发表于 09-08 11:11 2784次阅读

    基于六面体单元热应力问题的Matlab有限元编程求解

    导读:上一篇《弹性地基梁matlab有限元编程,以双排桩支护结构计算为例》引起了Matlab有限元
    的头像 发表于 11-17 11:10 1940次阅读