24小时热门版块排行榜    

查看: 3737  |  回复: 11

yueshuai977

新虫 (初入文坛)

[求助] 如何快速求解大型矩阵全部特征值与特征向量? 已有3人参与

矩阵是带状,还是旋转对称的方阵,规模大于10k*10k。

发自小木虫Android客户端
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
回帖支持 ( 显示支持度最高的前 50 名 )

cooooldog

铁杆木虫 (著名写手)

ส็็็

【答案】应助回帖

感谢参与,应助指数 +1
这类问题对硬件要求高,对算法要求也高。

首先保证硬件足够好,通常要多核心、64位、高配置的内存的电脑

其次,软件不建议使用matlab,除非你的应该足够强,比如可以用超算计算机,否则还是用C++/Fortran之类的库;

如果用C++, 有很多现成的库可以尝试。

10K的规模,还是可以尝试用Eigen C++ template library的(不过不一定行)

专门用来解决稀疏特征值问题的开源的库,及其例子:
The current version of SLEPc is 3.6, released in June, 2015

SLEPc, the Scalable Library for Eigenvalue Problem Computations
http://slepc.upv.es/

Eigenvalue Problem Solver - EPS: Examples
http://slepc.upv.es/documentatio ... ages/EPS/index.html

Eigenvalue Problem Solver - EPS: Examples
http://slepc.upv.es/documentatio ... utorials/index.html
ส็็็็็็็็็็็็็็็็็็็็
2楼2016-04-14 18:01:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

virtualzx

木虫 (著名写手)

10k带状矩阵不大,正常电脑的话用lapack带的DSBTRD子程序转化为三对角矩阵,然后用DSTERF解特征值就是最快的选项了。这么小的矩阵不需要使用大矩阵的方法。大矩阵方法都不适合解全部特征向量

发自小木虫IOS客户端
4楼2016-04-15 09:15:19
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

virtualzx

木虫 (著名写手)

fortran或c比较容易。不方便的话matlab的紧密对称矩阵求解函数eig用的应该是dsyevd,三十万以下的矩阵应该求解没有问题

发自小木虫IOS客户端
7楼2016-04-15 11:18:34
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Carpathia

银虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
只是求一个矩阵的特征值这个操作,用matlab是比较好的
matlab 也是用 MKL来求解,并且经过深度优化,单次操作速度不比C++ fortran 慢
追求理想的道路上东张西望
8楼2016-04-15 11:46:03
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yueshuai977

新虫 (初入文坛)

引用回帖:
7楼: Originally posted by virtualzx at 2016-04-15 11:18:34
fortran或c比较容易。不方便的话matlab的紧密对称矩阵求解函数eig用的应该是dsyevd,三十万以下的矩阵应该求解没有问题

这个dsyevd是?初学者不是很懂,望不吝赐教

发自小木虫Android客户端
9楼2016-04-15 20:18:14
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

virtualzx

木虫 (著名写手)

【答案】应助回帖

感谢参与,应助指数 +1
引用回帖:
9楼: Originally posted by yueshuai977 at 2016-04-15 20:18:14
这个dsyevd是?初学者不是很懂,望不吝赐教
...

dsyevd是求解密集对称矩阵特征值的函数。matlab的eig函数只是一个空壳,它会根据你的矩阵类型选择一个lapack函数调用。但是matlab只给出了密集和三对角矩阵的接口。你用的是带状矩阵,lapack里有专门的函数,但是你无法从matlab里调用。这样就没法利用带状矩阵的特性,速度稍慢,但也应该完全有能力处理。

发自小木虫IOS客户端

» 本帖已获得的红花(最新10朵)

10楼2016-04-15 22:14:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通回帖

乖女人不乖

木虫 (正式写手)

引用回帖:
2楼: Originally posted by cooooldog at 2016-04-14 18:01:30
这类问题对硬件要求高,对算法要求也高。

首先保证硬件足够好,通常要多核心、64位、高配置的内存的电脑

其次,软件不建议使用matlab,除非你的应该足够强,比如可以用超算计算机,否则还是用C++/Fortran之类的 ...

貌似你C++用得应该挺溜的。。但是我觉得你答非所问。。

发自小木虫Android客户端
3楼2016-04-14 22:40:46
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yueshuai977

新虫 (初入文坛)

引用回帖:
2楼: Originally posted by cooooldog at 2016-04-14 18:01:30
这类问题对硬件要求高,对算法要求也高。

首先保证硬件足够好,通常要多核心、64位、高配置的内存的电脑

其次,软件不建议使用matlab,除非你的应该足够强,比如可以用超算计算机,否则还是用C++/Fortran之类的 ...

感谢您的回答!

发自小木虫Android客户端
5楼2016-04-15 10:07:48
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yueshuai977

新虫 (初入文坛)

引用回帖:
4楼: Originally posted by virtualzx at 2016-04-15 09:15:19
10k带状矩阵不大,正常电脑的话用lapack带的DSBTRD子程序转化为三对角矩阵,然后用DSTERF解特征值就是最快的选项了。这么小的矩阵不需要使用大矩阵的方法。大矩阵方法都不适合解全部特征向量
...

额,能问下这个具体用lapack么?新手,一直不懂这是什么,matlab如何应用这个?非常感谢你!

发自小木虫Android客户端
6楼2016-04-15 10:08:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 yueshuai977 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 272求调剂 +4 田智友 2026-02-28 4/200 2026-03-01 06:43 by 刘兵
[基金申请] 面上模板改不了页边距吧? +5 ieewxg 2026-02-25 6/300 2026-03-01 00:10 by addressing
[考研] 307求调剂 +4 73372112 2026-02-28 6/300 2026-03-01 00:04 by ll247
[考研] 304求调剂 +3 52hz~~ 2026-02-28 5/250 2026-03-01 00:00 by 52hz~~
[考研] 化工专硕348,一志愿985求调剂 +4 弗格个 2026-02-28 6/300 2026-02-28 22:00 by wang_dand
[考研] 292求调剂 +3 yhk_819 2026-02-28 3/150 2026-02-28 21:57 by gaoxiaoniuma
[考研] 290求调剂 +5 材料专硕调剂; 2026-02-28 6/300 2026-02-28 21:40 by gaoxiaoniuma
[考研] 295求调剂 +5 19171856320 2026-02-28 5/250 2026-02-28 21:39 by gaoxiaoniuma
[考博] 26申博 +4 想申博! 2026-02-26 4/200 2026-02-28 21:37 by limorning
[考研] 材料学调剂 +5 提神豆沙包 2026-02-28 5/250 2026-02-28 21:34 by gaoxiaoniuma
[考研] 311求调剂 +8 南迦720 2026-02-28 8/400 2026-02-28 21:30 by gaoxiaoniuma
[考研] 求调剂 +4 repeatt?t 2026-02-28 4/200 2026-02-28 21:16 by gaoxiaoniuma
[考研] 284求调剂 +4 天下熯 2026-02-28 4/200 2026-02-28 21:13 by gaoxiaoniuma
[考研] 高分子化学与物理调剂 +4 好好好1233 2026-02-28 7/350 2026-02-28 20:42 by 好好好1233
[考研] 085600材料工程一志愿中科大总分312求调剂 +8 吃宵夜1 2026-02-28 10/500 2026-02-28 20:27 by L135790
[考博] 博士自荐 +3 kkluvs 2026-02-28 3/150 2026-02-28 16:59 by StarAura
[高分子] 求环氧树脂研发1名 +3 孙xc 2026-02-25 11/550 2026-02-28 16:57 by ichall
[考研] 0856调剂 +3 刘梦微 2026-02-28 3/150 2026-02-28 13:22 by houyaoxu
[考研] 寻找调剂 +3 LYidhsjabdj 2026-02-28 3/150 2026-02-28 12:59 by miniwendy
[硕博家园] 【博士招生】太原理工大学2026化工博士 +4 N1ce_try 2026-02-24 8/400 2026-02-26 08:40 by N1ce_try
信息提示
请填处理意见