gdb调试mpi

        今天跟贵鑫学习了gdb调试mpi程序,赶紧记下来!

        1. 在程序的MPI_Init()后添加while循环,例如int flag = 1; while(flag);这是为了让程序停在这里,好让gdb调试;

        2. 修改configure.ac,去掉编译优化选项-O3,这是gdb调试时需要修改上述的循环条件set flag = 0,而-O3有可能将变量优化为常量从而无法修改;

        3. 在configure时增加-g选项,以便gdb调试;

        4. 程序正常执行,并且会在while循环处停下;

        5. ssh登录到计算节点,用top命令查看进程ID,如果有两个进程会看到两个进程ID;

        6. 执行命令$ gdb [可执行文件的全路径],$attach [进程ID];

        7. 修改变量$ set flag = 0;

        8. 然后开另一个终端,同样attach到另一个进程,就可以用基本命令调试了!n:单句执行;b:文件名+行号,设置断点;c:执行到断点停下;bt:查看堆栈;print:变量名,打印变量。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MPI是一种并行计算标准,通过使用MPI库函数,可以实现多个计算节点之间的通信和协调,从而实现并行计算。在MPI并行程序编写与调试实验中,我们通常使用MPI矩阵-向量乘法作为实验原理。 MPI矩阵-向量乘法是一种常见的并行计算问题。它的目标是将一个n*n的矩阵A乘以一个n*1的向量x,得到一个n*1的向量y。在串行计算中,每个元素在矩阵中都需要乘以向量中的每个元素,然后将它们相加得到结果。在并行计算中,我们可以将矩阵和向量划分为多个部分,每个计算节点负责计算其中一部分,最后将它们相加得到最终结果。 MPI矩阵-向量乘法的实现需要以下步骤: 1. 初始化MPI,获取进程数和进程编号。 2. 在主进程中读入矩阵和向量,并将它们划分为多个部分。 3. 将划分后的矩阵和向量分发给各个计算节点。 4. 在各个计算节点中,对分配到的矩阵和向量进行计算,并将结果发送回主进程。 5. 在主进程中将各个节点的计算结果相加,得到最终结果。 MPI矩阵-向量乘法的调试通常需要使用MPI的调试工具,例如MPI的调试器和性能分析工具。在调试过程中,需要注意以下问题: 1. 确保矩阵和向量的划分是正确的,每个进程计算的部分不会重叠。 2. 确保进程之间的通信和同步是正确的,避免死锁和竞态条件。 3. 使用MPI的调试器和性能分析工具来查找和解决问题,例如MPI的调试器gdb和性能分析工具OpenMPI
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值