Fortran Coder

查看: 8200|回复: 7
打印 上一主题 下一主题

[线性代数] 两个矩阵的直积

[复制链接]

1

帖子

1

主题

0

精华

入门

F 币
31 元
贡献
6 点
跳转到指定楼层
楼主
发表于 2014-9-3 11:03:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

[Fortran] 纯文本查看 复制代码
subroutine product_AB(H,A,B,m,n,r,s,index1,index2)
  implicit none
  integer(8)::m,n,r,s,ii,jj,kk,ll,row,column,index1,index2       
  complex(8)::A(m,n),B(r,s),H(index1,index2)
  row=0
  do ii=1,m
    do kk=1,r             
      row=row+1         
      column=0
      do jj=1,n
        do ll=1,s
          column=column+1
          h(row,column)=a(ii,jj)*b(kk,ll)
        enddo
      end do
    enddo
  enddo
end subroutine product_AB

评分

参与人数 1权杖 +15 F 币 +15 收起 理由
fcode + 15 + 15 很给力!

查看全部评分

分享到:  微信微信
收藏收藏 点赞点赞 点踩点踩

2033

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1641 元
贡献
709 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

沙发
发表于 2014-9-3 13:57:08 | 只看该作者
如果用数组片段的话,这个命题就更简单了。

[Fortran] 纯文本查看 复制代码
Module KroneckerProduct_Mod
  Implicit None
  Integer , parameter , private :: DP = Selected_Real_Kind( 9 )
contains

  Subroutine KroneckerProduct( A , B , H )
    Real( Kind = DP ) , Intent( IN )  :: A(:,:) , B(:,:)
    Real( Kind = DP ) , Intent( OUT ) :: H(:,:)
    Integer :: i , j , m , n , p , q
    m = size( A , dim = 1 )
    n = size( A , dim = 2 )
    p = size( B , dim = 1 )
    q = size( B , dim = 2 )
    Do i = 1 , m
      Do j = 1 , n
        H( p*(i-1)+1 : p*i , q*(j-1)+1 : q*j ) = B * A(i,j)
      End Do
    End Do
  End Subroutine KroneckerProduct

End Module KroneckerProduct_Mod

Program www_fcode_cn
  use KroneckerProduct_Mod
  Implicit None
  Integer , parameter :: DP = Selected_Real_Kind( 9 )
  Integer , parameter :: m=2 , n=3 , p=4, q=5 , index1 = m*p , index2 = n*q
  Real(kind=8) :: A(m,n) , B(p,q) , H(index1,index2)
  integer :: i
  A = reshape( (/1,2,3,4,5,6/) , (/2,3/) )
  B = reshape( (/1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20/) , (/4,5/) )
  call KroneckerProduct( A , B , H )
  Do i = 1 , index2
    Write(*,'(8(f5.1,1x))') H( :, i)
  End do
End Program www_fcode_cn

136

帖子

3

主题

0

精华

版主

F 币
1964 元
贡献
1677 点

帅哥勋章管理勋章爱心勋章新人勋章热心勋章元老勋章

板凳
发表于 2014-9-3 19:48:45 | 只看该作者
fcode 发表于 2014-9-3 13:57
如果用数组片段的话,这个命题就更简单了。

[mw_shl_code=fortran,true]Module KroneckerProduct_Mod

你这回复得太及时了,根本不给我们机会啊~

2033

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1641 元
贡献
709 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

地板
发表于 2014-9-3 19:53:28 | 只看该作者
aliouying 发表于 2014-9-3 19:48
你这回复得太及时了,根本不给我们机会啊~

简单的我来,难的你上

136

帖子

3

主题

0

精华

版主

F 币
1964 元
贡献
1677 点

帅哥勋章管理勋章爱心勋章新人勋章热心勋章元老勋章

5#
发表于 2014-9-4 09:41:06 | 只看该作者
fcode 发表于 2014-9-3 19:53
简单的我来,难的你上

简单的还能凑凑份子,难的我就不会了,还得你来啊~

39

帖子

8

主题

0

精华

熟手

F 币
249 元
贡献
142 点
6#
发表于 2014-9-11 23:15:37 | 只看该作者
每天学习一点

35

帖子

2

主题

1

精华

专家

超子

F 币
565 元
贡献
196 点

规矩勋章

QQ
7#
发表于 2014-10-22 04:10:06 | 只看该作者
mark~~不错的例子

2

帖子

0

主题

0

精华

新人

F 币
20 元
贡献
12 点
8#
发表于 2014-12-31 12:40:31 | 只看该作者
很好的讨论啊!
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

捐赠本站|Archiver|关于我们 About Us|小黑屋|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2024-12-24 03:02

Powered by Tencent X3.4

© 2013-2024 Tencent

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