当前位置: 首页 > news >正文

安义南昌网站建设公司推广方式和推广渠道

安义南昌网站建设公司,推广方式和推广渠道,wordpress用的什么主题查询,做商城的网站用什么框架好目录 问题描述 代码1(串行) 代码2(并行) 代码2执行时所用指令 错误信息 解决方案 解决方案1 解决方案2 问题描述 今天正在学习使用mpi4py,在对比运行以下2个代码时疯狂报错: 代码1(串…

目录

问题描述

代码1(串行)

代码2(并行)

代码2执行时所用指令

错误信息

解决方案 

解决方案1 

解决方案2


问题描述

今天正在学习使用mpi4py,在对比运行以下2个代码时疯狂报错:

代码1(串行)

import numpy as np
import timenp.random.seed(2)
size = 1000000x1 = np.random.random(size)
x2 = np.random.random(size)
result = np.zeros(size, dtype=float)since = time.time()
for i in range(size):result[i] = x1[i] + x2[i]
end = time.time()print(end - since)

代码2(并行)

from mpi4py import MPI
import numpy as np
import timecomm = MPI.COMM_WORLD
rank = comm.Get_rank()
nprocs = comm.Get_size()size = 1000000
x1 = np.random.random(size)
x2 = np.random.random(size)if rank == 0:ave, res = divmod(size, nprocs)count = [ave + 1 if p < res else ave for p in range(nprocs)]count = np.array(count)displ = [sum(count[:p]) for p in range(nprocs)]displ = np.array(displ)
else:sendbuf = Nonecount = np.zeros(nprocs, dtype=np.int)displ = Nonet0 = time.time()
comm.Bcast(count, root=0)recvbuf1 = np.zeros(count[rank])
recvbuf2 = np.zeros(count[rank])comm.Scatterv([x1, count, displ, MPI.DOUBLE], recvbuf1, root=0)
comm.Scatterv([x2, count, displ, MPI.DOUBLE], recvbuf2, root=0)print('After Scatterv, process {} has data:'.format(rank), recvbuf1)
print('After Scatterv, process {} has data:'.format(rank), recvbuf2)for i in range(recvbuf1.shape[0]):recvbuf1[i] += recvbuf2[i]sendbuf2 = recvbuf1
recvbuf2 = np.zeros(sum(count))
comm.Gatherv(sendbuf2, [recvbuf2, count, displ, MPI.DOUBLE], root=0)if comm.Get_rank() == 0:print('pi computed in {:.3f} sec'.format(time.time() - t0))print('After Gatherv, process 0 has data:', recvbuf2)

代码2执行时所用指令

# mpi_test.py是该代码存放的代码文件,代码是以root的权限执行的
mpirun -np 4 --allow-run-as-root python mpi_test.py

错误信息

这个错误是我第三次尝试解决,这次终于找到了解决方案,太不容易了,QAQ

解决方案 

参考链接:

python - Possible buffer size limit in mpi4py Reduce() - Stack Overflow

链接中指出,出现这个错误的主要原因是由于

The issue comes from the Cross-Memory Attach (CMA) system calls process_vm_readv() and process_vm_writev() that the shared-memory BTLs (Byte Transfer Layers, a.k.a. the things that move bytes between ranks) of Open MPI use to accelerate shared-memory communication between ranks that run on the same node by avoiding copying the data twice to and from a shared-memory buffer. This mechanism involves some setup overhead and is therefore only used for larger messages, which is why the problem only starts occurring after the messages size crosses the eager threshold.

有以下两个解决方案:

解决方案1 

在执行docker run时,带上参数

--cap-add=SYS_PTRACE

但是由于我拿到的是分好的docker,并不具备执行docker run指令的权限,所以只能选择解决方案2中的解决方法。 

解决方案2

 禁用CMA。

如果是Open MPI 1.8之前的版本,在执行mpirun时带上参数:

mpirun --mca btl_sm_use_cma 0 ...

如果是Open MPI 1.8之后的版本,执行mpirun时带上参数:

mpirun --mca btl_vader_single_copy_mechanism none

附上一个原网站的回答截图以备后续查阅: 

http://www.jinmujx.cn/news/78163.html

相关文章:

  • 怎么下载1688上的视频微信搜一搜排名优化
  • 做网站需要关注哪些特色产品推广方案
  • 支付网站建设会计分录seo引擎搜索入口
  • 家居网站 模板软文广告图片
  • 创办一个网站需要多少资金电商平台怎么加入
  • 徐州网站开发如何合肥网站推广优化
  • 怎么做网站编辑网络推广入门教程
  • 网站可以做充值吗江门网站建设
  • 如何做 试题类 网站高级搜索入口
  • 下载asp做网站网络广告文案范文
  • 网站开发前端毕业论文公司网站建设流程
  • 网站建设合作合同模板免费的舆情网站app
  • 网站收录做关键词排名网站开发流程图
  • 唐山哪个公司做网站seo网站推广专员
  • 检查网站是否做网站地图五种新型营销方式
  • 烟台公司做网站企业网站推广的方法有哪些
  • 可拖拽网站网站关键词seo费用
  • 网站添加flv视频代码找资源的关键词有哪些
  • 三维网站是怎么做的磁力搜索引擎torrentkitty
  • 做网站怎么赚钱 注册关键词排名点击器
  • 网站建设过程中的网站设计怎么做搜索引擎营销策划方案
  • 写作网站推荐关键词推广软件
  • 网络公司名字大全20000个seo职位
  • 做网站先做前台还是后台seo顾问合同
  • 挪威网站后缀东莞网站设计
  • 便宜网站建设建站推广网站
  • 响应式网站介绍怎么在百度上推广
  • 网新网站建设合同市场推广策略 包括哪些
  • 移动网站的开发流程互联网推广软件
  • 做商演任务的网站google chrome官网入口