如何使用Fortran使用MPI I / O将多个变量写入文件

时间:2017-12-20 05:48:27

标签: io fortran mpi mpi-io

下面的代码为我提供了4个变量,保存了4个不同的行,包含10个列,而我需要保存10行中的4列。我正在使用hexdump语法从文件中提取

program main
use mpi
integer :: wsize,wrank,ierr,i,fh,offset
integer , parameter :: count = 10
integer :: buf1(count),buf2(count),buf3(count),buf4(count)
integer , dimension(10,2) :: buf
call MPI_Init(ierr)
call MPI_Comm_rank(MPI_COMM_WORLD,wrank,ierr)
call MPI_Comm_size(MPI_COMM_WORLD,wsize,ierr)

offset = 0;

call MPI_File_open(MPI_COMM_WORLD, "test1.dat", MPI_MODE_RDWR + MPI_MODE_CREATE, MPI_INFO_NULL, fh, ierr)

do i = 1,count
    buf1(i) = 1*i
    buf2(i) = 2*i
    buf3(i) = 3*i
    buf4(i) = 4*i

end do

call MPI_FILE_WRITE_AT(fh, offset, /buf1,buf2,buf3,buf4/), 4*count, MPI_INTEGER, mpi_status_ignore, ierr)

call MPI_File_close(fh,ierr)
call MPI_FINALIZE(ierr)
end program main

使用Hexdump命令:

hexdump -v -e ' "%10d" ' -e ' "\n"' test1.dat > hextest1.dat`

如果您尝试在转换后打开hextest1.dat,它似乎就像我发布的那样。

1    2      3      4      5      6      7      8      9     10
2    4      6      8     10      12    14     16     18     20
3    6      9     12     15      18    21     24     27     30
4   8      12     16     20      24    28     32     36     40

0 个答案:

没有答案