24小时热门版块排行榜    

查看: 1073  |  回复: 6
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

nll1989

新虫 (著名写手)

[交流] 想用Fortran语言实现矩阵连乘,并且矩阵里面有一个变量 已有3人参与

想用Fortran实现对矩阵M的连乘,而且矩阵里面含有一个变量EM,当EM<=15,EM=6.7. 当EM>15,EM=8.7,但是用以下程序不能实现。希望大家帮忙解决,不胜感激!

PROGRAM MAIN
      USE IMSL
      COMPLEX:: M(2,2),P(2,2)
     
        REAL*8 E,TE,TM,EM,TD,H,N
        COMPLEX*8 M11,M12,M21,M22,A1,A2,A3
        TD=0.8D0
        TM=1.0D0
        EM=7.75D0
        N=10
C======================================================


      OPEN(UNIT=30,FILE="DNA-DAN01.DAT"

        DO E=6.89,9.750,0.001D0


C================================================

cc================================================
        P=M
        DO I=1,N
        IF (I .LT. 15) THEN
           EM=6.7
        ELSE IF (I .GE. 15) THEN
           EM=8.7  
        END IF
C====================================================
      H=acos((E-EM)/(2*TM))

      M11=CMPLX((E-EM)/TD,0)
        M12=CMPLX(-1,0)
        M21=CMPLX(1,0)
        M22=CMPLX(0,0)
      M=RESHAPE ((/M11,M21,M12,M22/),(/2,2/))

        P=MATMUL(M,P)

      END DO

C=====================================================
        A1=4*SIN(H)*SIN(H)

        A2=(P(1,2)-P(2,1)+(P(1,1)-P(2,2))*COS(H))**2

        A3=(P(1,1)+P(2,2))**2*SIN(H)**2

        TE=A1/(A2+A3)
       

      Write(30,*) E,TE

        END DO
        END
回复此楼

» 猜你喜欢

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

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

pippi6

铁杆木虫 (著名写手)

工程和科学数值计算咨询


小木虫: 金币+0.5, 给个红包,谢谢回帖
do loop 的循环指数可是real吗?
3楼2014-11-13 20:22:16
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 nll1989 的主题更新
普通表情 高级回复 (可上传附件)
信息提示
请填处理意见