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

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日

悬赏问题

  • ¥15 如何让子窗口鼠标滚动独立,不要传递消息给主窗口
  • ¥15 如何能达到用ping0.cc检测成这样?如图
  • ¥15 关于#DMA固件#的问题,请各位专家解答!
  • ¥15 matlab生成的x1图不趋于稳定,之后的图像是稳定的水平线
  • ¥15 请问华为OD岗位的内部职业发展通道都有哪些,以及各个级别晋升的要求
  • ¥20 微信小程序 canvas 问题
  • ¥15 系统 24h2 专业工作站版,浏览文件夹的图库,视频,图片之类的怎样删除?
  • ¥15 怎么把512还原为520格式
  • ¥15 MATLAB的动态模态分解出现错误,以CFX非定常模拟结果为快照
  • ¥15 求高通平台Softsim调试经验