gxyjdr 2024-04-02 14:23 采纳率: 0%
浏览 27
已结题

NPB编译的时候make出现mismatch报错

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

img

  • 写回答

29条回答 默认 最新

  • 专家-赤兔[在线] 优质创作者: 编程框架技术领域 2024-04-02 14:23
    关注
    获得1.00元问题酬金

    引自免费微信小程序:皆我百晓生

    根据您提供的错误信息,您在编译 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 库。

    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 4月10日
  • 创建了问题 4月2日