声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 1149|回复: 2

[编程技巧] 请教一个eig小问题

[复制链接]
发表于 2006-8-31 11:08 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?我要加入

x
是结构动力分析方面的:
     计算固有频率时,我算出了[K]和[M],也就是只剩解[K]*U=λ*[M]*U了,我一开始的做法是
将上式转化成(inv[M])*[K]*U=λ*U,然后用eig((inv[M])*[K])求出频率和振型,但结果和ansys算出来的有很大出入,尤其是前几阶(我只需要用前4阶就可以了)。后来我感觉是不是我上面的转化一步错了,因为解出来的λ和U都是矩阵阿,那样[M]就不能那样做了。由于我的数学不好,matlab又刚学,所以算到这一步我就卡住了。各位大虾帮帮忙阿,能不能指点一下,公式[K]*U=λ*[M]*U在matlab里到底该怎么解阿?不胜感激,谢谢

我说得不够明白吗?请大家不惜笔墨,小弟心里挺着急的

[ 本帖最后由 ChaChing 于 2009-12-13 01:00 编辑 ]
回复
分享到:

使用道具 举报

发表于 2006-8-31 16:02 | 显示全部楼层
不惜笔墨,呵呵。

机子上没有matlab,记得是这样的格式才对:
[V,D] = eig(K,M);

V是特征向量矩阵,当然是没有归一化的。
D是一个对角化的特征值矩阵。取对角值,并对其开方根就是固有频率。

评分

1

查看全部评分

 楼主| 发表于 2006-8-31 18:55 | 显示全部楼层
谢谢啦!我试试。十分感谢


我试了试,以下两种算法的结果一样:
    1. KM=inv(M)*K;
        [V,D]=eig(KM);
    2.[V,D]=eig(K,M);
很感谢toes的指点,至少我知道了我的程序里不是着出错了,而可能是K、M的求解错了。
多谢,我再看其他部分

[ 本帖最后由 ChaChing 于 2009-12-13 01:01 编辑 ]
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2024-11-12 18:02 , Processed in 0.076585 second(s), 21 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表