1 / 49
文档名称:

并行程序设计基础.ppt

格式:ppt   页数:49
下载后只包含 1 个 PPT 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

并行程序设计基础.ppt

上传人:一文千金 2012/2/23 文件大小:0 KB

下载得到文件列表

并行程序设计基础.ppt

文档介绍

文档介绍:十二、并行程序设计基础
国家高性能计算中心(合肥)
2
2017/11/11
并行程序设计基础
并行程序设计概述
进程
线程
同步
通信
并行程序设计模型
国家高性能计算中心(合肥)
3
2017/11/11
并行程序设计概述
并行程序设计难的原因
并行语言的构造方法
并行性问题
交互/通信问题
五种并行编程风范
计算圆周率的样本程序
国家高性能计算中心(合肥)
4
2017/11/11
1 并行程序设计难的原因
技术先行,缺乏理论指导
程序的语法/语义复杂, 需要用户自已处理
任务/数据的划分/分配
数据交换
同步和互斥
性能平衡
并行语言缺乏代可扩展和异构可扩展, 程序移植困难, 重写代码难度太大
环境和工具缺乏较长的生长期, 缺乏代可扩展和异构可扩展
国家高性能计算中心(合肥)
5
2017/11/11
2 并行语言的构造方法
串行代码段
for ( i= 0; i<N; i++ ) A[i]=b[i]*b[i+1];
for (i= 0; i<N; i++) c[i]=A[i]+A[i+1];
(a) 使用库例程构造并行程序
id=my_process_id();
p=number_of_processes();
for ( i= id; i<N; i=i+p) A[i]=b[i]*b[i+1];
barrier();
for (i= id; i<N; i=i+p) c[i]=A[i]+A[i+1];
例子: MPI,PVM, Pthreads
(b) 扩展串行语言
my_process_id,number_of_processes(), and barrier()
A(0:N-1)=b(0:N-1)*b(1:N)
c=A(0:N-1)+A(1:N)
例子: Fortran 90
(c) 加编译注释构造并行程序的方法
#pragma parallel
#pragma shared(A,b,c)
#pragma local(i)
{
# pragma pfor iterate(i=0;N;1)
for (i=0;i<N;i++) A[i]=b[i]*b[i+1];
# pragma synchronize
# pragma pfor iterate (i=0; N; 1)
for (i=0;i<N;i++)c[i]=A[i]+A[i+1];
}
例子:SGI power C
国家高性能计算中心(合肥)
6
2017/11/11
三种并行语言构造方法比较
2 并行语言的构造方法
国家高性能计算中心(合肥)
7
2017/11/11
3 并行性问题
进程的同构性
SIMD: 所有进程在同一时间执行相同的指令
MIMD:各个进程在同一时间可以执行不同的指令
SPMD: 各个进程是同构的,多个进程对不同的数据执行相同的代码(一般是数据并行的同义语)
常对应并行循环,数据并行结构,单代码
MPMD:各个进程是异构的, 多个进程执行不同的代码(一般是任务并行,或功能并行,或控制并行的同义语)
常对应并行块,多代码
要为有1000个处理器的计算机编写一个完全异构的并行程序是很困难的
国家高性能计算中心(合肥)
8
2017/11/11
并行块
parbegin S1 S2 S3 …….Sn parend
S1 S2 S3 …….Sn可以是不同的代码
并行循环: 当并行块中所有进程共享相同代码时
parbegin S1 S2 S3 …….Sn parend
S1 S2 S3 …….Sn是相同代码
简化为
parfor (i=1; i<=n, i++) S(i)
进程的同构性
3 并行性问题
国家高性能计算中心(合肥)
9
2017/11/11
用单代码方法说明SPMD
要说明以下SPMD程序:
parfor (i=0; i<=N, i++) foo(i)
用户需写一个以下程序:
pid=my_process_id();
numproc=number_of _processes();
parfor (i=pid; i<=N, i=i+numproc) foo(i)
此程序经编译后生成可执行程序A, 用shell脚本将它加载到N个处理结点上:
run A –numnodes N
SPMD程序的构造方法
用数据并行程序的构造方法
要说明以下SPMD程序:
parfor (i=0; i<=N, i++) {
C[i]=A[i]+B[i];
}
用户可用一条数据赋值语句:
C=A+B

forall (i=1,N) C[i]=A[i]+B[i]
进程的同构性
3 并

最近更新

2024年略阳县招教考试备考题库含答案解析(必.. 31页

2024年石家庄职工大学马克思主义基本原理概论.. 12页

2024年福建师范大学马克思主义基本原理概论期.. 12页

2024年绍兴文理学院马克思主义基本原理概论期.. 13页

2024年色达县招教考试备考题库附答案解析(必.. 30页

2024年莱芜职业技术学院马克思主义基本原理概.. 13页

2024年西安铁路职业技术学院马克思主义基本原.. 13页

2024年贵州省(80所)马克思主义基本原理概论.. 13页

2024年辽宁商贸职业学院马克思主义基本原理概.. 12页

2024年通河县幼儿园教师招教考试备考题库含答.. 31页

2024年郑州汽车工程职业学院马克思主义基本原.. 13页

2024年重庆师范大学马克思主义基本原理概论期.. 13页

2024年铜鼓县幼儿园教师招教考试备考题库带答.. 30页

2024年长江艺术工程职业学院马克思主义基本原.. 13页

2024年隆安县幼儿园教师招教考试备考题库附答.. 30页

2024年靖州苗族侗族县招教考试备考题库含答案.. 31页

2024年鱼台县招教考试备考题库带答案解析(必.. 30页

2024年黑龙江林业职业技术学院马克思主义基本.. 12页

2025年上海外国语大学贤达经济人文学院单招职.. 45页

2025年上海科技管理干部学院马克思主义基本原.. 13页

2025年中国地质大学(北京)马克思主义基本原.. 12页

2025年临汾职业技术学院单招职业适应性测试题.. 43页

2025年乐业县招教考试备考题库附答案解析(必.. 31页

绿色物流标准制定-第1篇 35页

2025年兖州矿区职工大学马克思主义基本原理概.. 13页

老年心理危机干预机制 35页

2025年剑川县招教考试备考题库附答案解析(必.. 31页

2025年南京农业大学马克思主义基本原理概论期.. 12页

考试心理状态与学习效率的关系研究 35页

2025年厦门海洋职业技术学院马克思主义基本原.. 13页