在使用NAS Parallel Benchmarks 的代码进行课题编译的时候,make出现报错。
输入命令:make ft NPROCS=4 CLASS=A
报错显示:

在使用NAS Parallel Benchmarks 的代码进行课题编译的时候,make出现报错。
输入命令:make ft NPROCS=4 CLASS=A
报错显示:

关注引自免费微信小程序:皆我百晓生
根据您提供的错误信息,您在编译 NAS Parallel Benchmarks (NPB) 中的 FT 测试时遇到了类型不匹配(Type mismatch)错误。在 Fortran 代码中调用 MPI 函数时,需要确保传递给 MPI 函数的数据类型与函数所期望的 MPI 数据类型一致。
错误1:
call MPI_Reduce(t1,tsum,tmax+2,MPI_DOUBLE_PRECISION, ...
此处 t1 变量可能被定义为复数类型(COMPLEX(8)),而您尝试将其作为双精度实数(MPI_DOUBLE_PRECISION)传递给 MPI_Reduce 函数。要解决这个问题,您需要将 MPI_DOUBLE_PRECISION 替换为相应的复数 MPI 数据类型,即 MPI_COMPLEX16。
修改后的代码应为:
call MPI_Reduce(t1, tsum, tmax+2, MPI_COMPLEX16, ...
错误2:
call MPI_BCAST(timers_enabled,1,MPI_LOGICAL,0,comm_solve, ierr)
这里 timers_enabled 是逻辑类型(LOGICAL),但在调用 MPI_BCAST 时使用的数据类型是 MPI_INTEGER。应将其替换为 MPI_LOGICAL。
修正后的代码应为:
call MPI_BCAST(timers_enabled, 1, MPI_LOGICAL, 0, comm_solve, ierr)
在修改了上述错误后,请重新运行 make ft NPROCS=4 CLASS=A 命令进行编译,这应该能解决您当前遇到的类型不匹配问题。同时,请确保您的编译器支持这些 MPI 数据类型,并且已经正确链接了 MPI 库。