⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 gtrans.f

📁 网络带宽测试工具
💻 F
字号:
      Subroutine gtrans( a, at, n1, n2, size1, size2, ctime )! ----------------------------------------------------------------------! --- 'gtrans' does a global transpose of array 'a' and puts it in !     array 'at'.! ----------------------------------------------------------------------      Use         numerics      Use         dist_module ! Contains # of proc.s & proc. no.s      Implicit    None      Include     'mpif.h'      Integer  :: n1, n2, size1, size2      Real(l_) :: a(n1,size2), at(n2,size1), ctime      Real(l_) :: wrk(size2,n1)      Real(l_) :: time      Integer  :: actsiz(0:nodes-1,2), base(0:nodes-1,2)      Integer  :: scnts(0:nodes-1), sdpls(0:nodes-1),     &            rcnts(0:nodes-1), rdpls(0:nodes-1)      Integer  :: ierr! ----------------------------------------------------------------------! --- Get distribution & offsets for a.      Call sizoff( n1, n2, actsiz, base )! ----------------------------------------------------------------------! --- Do local transposition.      Call ltrans( n1, actsiz(me,2), a, at )! ----------------------------------------------------------------------! --- Determine sizes and displacements of data to be sent.      Call cntdpls( actsiz, scnts, sdpls, rcnts, rdpls )! ----------------------------------------------------------------------! --- Distribute appropriate blocks over the processors.      time = MPI_Wtime()      Call MPI_Barrier( MPI_Comm_world, ierr )      Call MPI_AlltoAllv( at, scnts, sdpls, MPI_Real8,     &                   wrk, rcnts, rdpls, MPI_Real8,     &                   MPI_Comm_World, ierr )      time  = MPI_Wtime() - time      ctime = ctime + time! ----------------------------------------------------------------------! --- Do block transposition of the communicated data.      Call btrans( wrk, actsiz(me,1), n2, actsiz, at )! ----------------------------------------------------------------------      End Subroutine gtrans           

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -