在使用NAS Parallel Benchmarks 的代码进行课题编译的时候,make出现报错。
输入命令:make ft NPROCS=4 CLASS=A
报错显示:
NPB编译的时候make出现mismatch报错
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
29条回答 默认 最新
关注 获得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 库。解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥15 如何让子窗口鼠标滚动独立,不要传递消息给主窗口
- ¥15 如何能达到用ping0.cc检测成这样?如图
- ¥15 关于#DMA固件#的问题,请各位专家解答!
- ¥15 matlab生成的x1图不趋于稳定,之后的图像是稳定的水平线
- ¥15 请问华为OD岗位的内部职业发展通道都有哪些,以及各个级别晋升的要求
- ¥20 微信小程序 canvas 问题
- ¥15 系统 24h2 专业工作站版,浏览文件夹的图库,视频,图片之类的怎样删除?
- ¥15 怎么把512还原为520格式
- ¥15 MATLAB的动态模态分解出现错误,以CFX非定常模拟结果为快照
- ¥15 求高通平台Softsim调试经验