当前位置: 首页 > 图文教程 > 开发语言 > VC++ > 一个最基本的有限元计算程序

VC++
透明窗体的又一实现
橡皮区矩形 CRectTracker C# 实现
Visual Basic .NET 中多 Windows 窗体的同步
轻松实现类 MSDN 2002 界面(二)
轻松实现类 MSDN 2002 界面
数据库开发之窗体编程
一个打印报表的简单的类
SDK 程序使用SkinMagic工具包换皮肤
Windows SDK笔记(七):创建MDI窗口
Windows SDK笔记(六):使用对话框资源建立窗口
Windows SDK笔记(五):非模式对话框
Windows SDK笔记(四):模式对话框
也谈如何隐藏显示在任务栏中的对话框程序
一个托盘程序演示 -闹钟 Alert
think window procedure
再谈 CFileDialog 对话框的定制
获得 Win32 窗口句柄的更好的方法
个人考勤软件开发实例配套代码 2.1版(Update)
介绍一个操作DHTML表格的C++对象
Windows资源管理器Web视图界面

VC++ 中的 一个最基本的有限元计算程序


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 35 ::
收藏到网摘: n/a

一个最基本的有限元计算程序


作者:西安空军工程大学工程学院,西安 710038
胡金山,朱青云,余治国


下载源代码


我们在学习有限元课程时做的另一个作业,用 C/C++ 编程求解了一个简单的有限元问题,可以作为有限元学习的编程实例,以更好地理解有限元理论,并为进一步使用大型有限元软件打下基础。本文所涉及的有限元基本理论请参考章本照先生编著的《流体力学中的有限元方法》PP.156-165。

一、二维传热问题
如图一所示:


图一 二维传热问题

二、解题过程

  • 1、对结构进行离散化,将待分析的结构物从几何上用线或面划分为有限个单元,按结构物的不同和分析要求,选取不同形式的单元,在单元的边界上设置节点,并书写编号。计算节点坐标
  • 2、单元分析:设法导出单元的结点位移和结点力之间的关系,建立单元刚度矩阵。
    单元刚度矩阵的计算:
    对于方程


    采用 Galerkin弱解表达式

    (*)

    这里采用三节点的三角形单元,单元的基函数共有三个,选用插值多项式



    分别代入单元三个节点的坐标可解得



    其中





    e单元中的近似函数为

    (**)

    将式(*)中的积分区域取为e单元的区域 ,并将单元中的近似函数表达式(**)代入,并注意到的任意性,可得



    (***)

    (****)

    将单元基函数的具体表达式(*)代入(***)式中,可得



    通过等参变换(具体见文献1第201页),可得



    这里指p为常数的情况,A为三角形单元的面积。



    这里g 均为0,所以此项不用计算。

  • 3、整体分析(以求结点力为例)整体分析就是将各个单元组成结构整体进行分析。整体分析的目的在于导出整个结构结点位移与结点力之间的关系,建立整个结构的刚度方程。分析步骤:首先按着一定的集成规则,将各单元刚度矩阵集合成结构整体刚度矩阵,并将单元等效结点荷载集合成整体等效结点荷载列阵;然后引入结构的位移边界条件,求解整体平衡方程组,得出基本未知量――结点位移列阵。
  • 4、用选定的算法语言编写出程序(C/C++),调试程序调用高斯消元法解方程的出结果。

附件程序Fem1.cpp计算了积分值,Fem2.cpp则采用了面积坐标下的插值函数,积分值取为三角形面积的三分之一。两者结果相同,但是后者更为通用,可以把程序用于其他形状的二维区域的有限元计算,Fem3.cpp计算了题2。