有限元刚度矩阵的一维变带宽存储用C++实现(三)

本文继前文介绍了一维变带宽存储的有限元刚度矩阵实现后,详细阐述如何从存储数组pGK中取出总刚度矩阵[K]的任意元素。通过建立对应关系,利用矩阵对称性,实现了对总刚度矩阵上下三角部分的元素访问。并给出了程序流程图和C++代码示例。
摘要由CSDN通过智能技术生成

有限元刚度矩阵的一维变带宽存储用C++实现(二)中,我们已经把总体刚度矩阵[K]中下三角部分的带内元素顺利存入pGK数组中,现在我们来讨论如何从pGK数组中取出[K]内的任意元素。

从存储了总刚矩阵[K]中的带内元素的一维数组pGK中取出总刚矩阵[K]的元素,主要是建立总刚矩阵[K]中第i行第j列的元素与pGK[]数组中元素的对应关系。根据[K]为对称矩阵的前提,就可以根据pGK[]中的总刚矩阵下三角部分,推断总刚矩阵的上三角部分的元素。

(1)建立总刚矩阵[K]中第GKi行第GKj列与pGK数组中元素的对应关系。

1)对于[K]中的下三角部分,GKi> GKj。此时按行取出[K]中元素。

第GKi行主对角元到当前元素的距离为:iBuf=GKi-GKj;

对于[K]中的带内元素,已存入pGK数组中,

此时[K]中第GKi行第GKj列的元素在pGK数组中的下标为&

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值