24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1978  |  回复: 8

田山东

捐助贵宾 (著名写手)

[求助] fortran到底怎么弄稀疏矩阵啊?



大家好,我对稀疏矩阵很模糊,在网上和论坛上搜了下一直没找到该怎么去构建稀疏矩阵。我这里有个图形,是六角格子,沿着x方向具有平移对称性,也就是说x方向是一样的,y方向我取8个点为一个原包,也就是y方向8个点为一个最小单元,我现在把这8个点的哈密顿矩阵写出来:

0  t  0  0  0  0  0  t

t  0  t  0  0  0  0  0

0  t  0  t  0  0  0  0

0  0  t  0  t  0  0  0

0  0  0  t  0  t  0  0

0  0  0  0  t  0  t  0

0  0  0  0  0  t  0  t

t  0  0  0  0  0  t  0

  



t的近邻两点之间相互作用,从哈密顿形式上看,是稀疏矩阵,我有一个问题:怎么用fortran把它写成稀疏矩阵?比如我把上面的哈密顿写出来之后,怎么把它转成稀疏矩阵?

这个小程序就是上面这个哈密顿矩阵的写法。

      program  xishu

     implicit none

     real(8)       :: t=1.0   

     integer       :: i1,ny

     real(8),allocatable  :: h(:,: )

     ny=8  

     allocate(h(ny,ny))

     h=0.0

     do i1=1,ny-1

     h(i1,i1+1)=t

     h(i1+1,i1)=t

     enddo

     h(1,ny)=t

     h(ny,1)=t

     end

我想把它转成稀疏矩阵,该怎么办呢?sparse命令到底是怎么用的呢?纠结啊!!
回复此楼

» 猜你喜欢

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

everythinghasitsseason.enjoyyourlife.
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

virtualzx

木虫 (著名写手)

【答案】应助回帖


感谢参与,应助指数 +1
jjdg: 金币+1, 感谢参与 2012-11-10 01:05:08
2楼2012-11-09 03:03:32
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

田山东

捐助贵宾 (著名写手)

继续摸索
everythinghasitsseason.enjoyyourlife.
3楼2012-11-09 19:21:31
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

weiwei43

至尊木虫 (正式写手)


jjdg: 金币+1, 感谢参与 2012-11-11 01:12:34
稀疏矩阵我在有限元程序中用过,主要是考虑存储空间紧张,有限元刚度阵是对角稀疏矩阵,如果存储下三角,需要很多存储空间,所以根据稀疏矩阵特点,只存储非零元素。
存储时要增加一个一维数组,记录每行长度。具体的方法在老版本的有限元书中会有程序段,可以参考。
不过我感觉你的用法和有限元中用法好像不太一致。
4楼2012-11-10 08:22:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

田山东

捐助贵宾 (著名写手)

引用回帖:
4楼: Originally posted by weiwei43 at 2012-11-10 08:22:12
稀疏矩阵我在有限元程序中用过,主要是考虑存储空间紧张,有限元刚度阵是对角稀疏矩阵,如果存储下三角,需要很多存储空间,所以根据稀疏矩阵特点,只存储非零元素。
存储时要增加一个一维数组,记录每行长度。具体 ...

实际上我存储的是对角线旁边的元素,可以跟我说下那本书吗?我在看别人的代码。有点看不懂啊。想找本书参考着看下。另外,稀疏矩阵可以求特征值和特征向量吗?跟普通矩阵一样吗》
everythinghasitsseason.enjoyyourlife.
5楼2012-11-10 08:31:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

weiwei43

至尊木虫 (正式写手)


jjdg: 金币+1, 感谢参与 2012-11-11 01:12:48
引用回帖:
5楼: Originally posted by 田山东 at 2012-11-10 08:31:44
实际上我存储的是对角线旁边的元素,可以跟我说下那本书吗?我在看别人的代码。有点看不懂啊。想找本书参考着看下。另外,稀疏矩阵可以求特征值和特征向量吗?跟普通矩阵一样吗》...

我这里主要是利用稀疏矩阵特点存储,至于求解方法什么的适当的根据存储特点修改了一下,主要是减少计算量。稀疏矩阵可以求特征值和特征向量我感觉是和一般的方阵求解是一样的。
关于书,我现在手头没有,没法给你提出具体数目。你可以看一下70-80年代的有限元书或结构分析书,很多书后面都附有程序的。
6楼2012-11-10 08:49:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

田山东

捐助贵宾 (著名写手)

引用回帖:
6楼: Originally posted by weiwei43 at 2012-11-10 08:49:45
我这里主要是利用稀疏矩阵特点存储,至于求解方法什么的适当的根据存储特点修改了一下,主要是减少计算量。稀疏矩阵可以求特征值和特征向量我感觉是和一般的方阵求解是一样的。
关于书,我现在手头没有,没法给你 ...

非常感谢您。我找到书了,也找了个例子,开个新帖,麻烦指点下。谢谢啦
everythinghasitsseason.enjoyyourlife.
7楼2012-11-10 20:52:35
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

mariohollis

新虫 (初入文坛)

引用回帖:
7楼: Originally posted by 田山东 at 2012-11-10 20:52:35
非常感谢您。我找到书了,也找了个例子,开个新帖,麻烦指点下。谢谢啦...

虫友,能不能把你关于Fortran稀疏矩阵存储的相关资料给我讲一下。万分感谢。。。
8楼2015-06-15 10:19:10
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

田山东

捐助贵宾 (著名写手)

引用回帖:
8楼: Originally posted by mariohollis at 2015-06-15 10:19:10
虫友,能不能把你关于Fortran稀疏矩阵存储的相关资料给我讲一下。万分感谢。。。...

哥们,我用MATLAB了。你也用吧
everythinghasitsseason.enjoyyourlife.
9楼2015-06-15 10:41:36
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 田山东 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 085600材料与化工301分求调剂院校 +4 刺痛jk 2026-04-06 5/250 2026-04-06 04:30 by 来看流星雨10
[考研] 085602调剂 初试总分335 +8 19123253302 2026-04-05 8/400 2026-04-05 20:44 by 南航~万老师
[考研] 318求调剂 +11 ykyhsa 2026-04-05 13/650 2026-04-05 12:44 by aidndnjck
[考研] 270求调剂 +9 小杰pp 2026-03-31 11/550 2026-04-05 11:02 by 风雨无晴
[考研] 材料调剂 +9 革微桂 2026-04-04 9/450 2026-04-05 08:27 by 544594351
[考研] 413求调剂 +4 柯某某 2026-03-31 4/200 2026-04-04 22:18 by 学员6BFVa3
[考研] 一志愿211,化学学硕,310分,本科重点双非,求调剂 +11 努力奋斗112 2026-04-04 11/550 2026-04-04 20:51 by 蓝云思雨
[考研] 材料383求调剂 +5 郭阳阳阳成 2026-04-04 5/250 2026-04-04 19:06 by dongzh2009
[考研] 292求调剂 +11 2022080213 2026-04-04 13/650 2026-04-04 18:38 by macy2011
[考研] 297求调剂 +11 ljy20040718! 2026-04-03 13/650 2026-04-04 09:23 by 来看流星雨10
[考研] 考研调剂 +5 小sun要好运 2026-04-03 5/250 2026-04-03 21:43 by 啵啵啵0119
[考研] 303求调剂 +9 DLkz1314. 2026-03-30 9/450 2026-04-03 18:34 by ls刘帅
[考研] 315分 085602 求调剂 +15 26考研上岸版26 2026-04-02 15/750 2026-04-03 12:45 by xingguangj
[考研] 314求调剂 +11 1xiaojun23 2026-03-31 12/600 2026-04-02 12:31 by 1xiaojun23
[考研] 372求调剂 +3 jj涌77 2026-04-02 3/150 2026-04-02 09:57 by olim
[考研] 285求调剂 +11 AZMK 2026-04-01 11/550 2026-04-01 22:40 by peike
[考研] 298求调剂 +4 什么是胖头鱼 2026-03-30 6/300 2026-04-01 22:06 by 客尔美德
[考研] 江苏科技大学招材料研究生 +4 Su032713. 2026-04-01 5/250 2026-04-01 22:03 by cccchenso
[考研] 08工科,295,接受跨专业调剂 +6 lmnlzy 2026-03-31 6/300 2026-04-01 11:02 by 逆水乘风
[考研] 358求调剂 +3 王向阳花 2026-03-31 3/150 2026-04-01 09:56 by zzchen2000
信息提示
请填处理意见