并行程序设计基础优秀PPT.ppt
《并行程序设计基础优秀PPT.ppt》由会员分享,可在线阅读,更多相关《并行程序设计基础优秀PPT.ppt(45页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、并行程序设计基础你现在浏览的是第一页,共45页并行程序设计基础 12.1 12.1 并行程序设计概述并行程序设计概述 12.2 12.2 进程进程 12.3 12.3 线程线程 12.4 12.4 同步同步 12.5 12.5 通信通信 12.6 12.6 并行程序设计模型并行程序设计模型2022/12/32你现在浏览的是第二页,共45页并行程序设计概述1并行程序设计难的原因并行程序设计难的原因并行程序设计难的原因并行程序设计难的原因2并行语言的构造方法并行语言的构造方法3 3并行性问题并行性问题4 4交互交互交互交互/通信问题通信问题通信问题通信问题5五种并行编程风范五种并行编程风范五种并行
2、编程风范五种并行编程风范6 6计算圆周率的样本程序计算圆周率的样本程序计算圆周率的样本程序计算圆周率的样本程序2022/12/33你现在浏览的是第三页,共45页1 并行程序设计难的原因并行程序设计难的原因 技术先行技术先行,缺乏理论指导缺乏理论指导 程序的语法程序的语法/语义复杂语义复杂,需要用户自已处理需要用户自已处理 任务任务/数据的划分数据的划分/分配分配 数据交换数据交换 同步和互斥同步和互斥 性能平衡性能平衡 并行语言缺乏代可扩展和异构可扩展并行语言缺乏代可扩展和异构可扩展,程序移植困难程序移植困难,重写重写代码难度太大代码难度太大 环境和工具缺乏较长的生长期环境和工具缺乏较长的生长
3、期,缺乏代可扩展和异构可扩缺乏代可扩展和异构可扩展展2022/12/34你现在浏览的是第四页,共45页2 并行语言的构造方法并行语言的构造方法串行代码段串行代码段for(i=0;iN;i+)Ai=bi*bi+1;for(i=0;iN;i+)ci=Ai+Ai+1;(a)使用库例程构造并行程序使用库例程构造并行程序id=my_process_id();p=number_of_processes();for(i=id;iN;i=i+p)Ai=bi*bi+1;barrier();for(i=id;iN;i=i+p)ci=Ai+Ai+1;例子例子:MPI,PVM,Pthreads(b)扩展串行语言扩展串
4、行语言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;iN;i+)Ai=bi*bi+1;#pragma synchronize#pragma pfor iterate(i=0;N;1)for(i=
5、0;iN;i+)ci=Ai+Ai+1;例子:例子:SGI power C 2022/12/35你现在浏览的是第五页,共45页三种并行语言构造方法比较三种并行语言构造方法比较2 并行语言的构造方法并行语言的构造方法2022/12/36你现在浏览的是第六页,共45页3 并行性问题并行性问题3.1 进程的同构性vSIMD:所有进程在同一时间执行相同的指令vMIMD:各个进程在同一时间可以执行不同的指令SPMD:各个进程是同构的,多个进程对不同的数据执行相同的代码(一般是数据并行的同义语)常对应并行循环,数据并行结构,单代码MPMD:各个进程是异构的,多个进程执行不同的代码(一般是任务并行,或功能并行
6、,或控制并行的同义语)常对应并行块,多代码 要为有1000个处理器的计算机编写一个完全异构的并行程序是很困难的2022/12/37你现在浏览的是第七页,共45页并行块parbegin S1 S2 S3.Sn parendS1 S2 S3.Sn可以是不同的代码并行循环:当并行块中所有进程共享相同代码时parbegin S1 S2 S3.Sn parend S1 S2 S3.Sn是相同代码简化为parfor (i=1;i=n,i+)S(i)进程的同构性3 并行性问题并行性问题2022/12/38你现在浏览的是第八页,共45页用单代码方法说明用单代码方法说明SPMD要说明以下SPMD程序:parfo
7、r (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 NSPMD程序的构造方法程序的构造方法用数据并行程序的构造方法用数据并行程序的构造方法要说明以下SPMD程序:parfor (i=0;i=N,i+)Ci=Ai+Bi;用户可用一条数据赋值语句:C=A+B或forall(i=1,N)Ci=Ai+Bi进程的同构性3
8、 并行性问题并行性问题2022/12/39你现在浏览的是第九页,共45页用用SPMD伪造伪造MPMD要说明以下MPMD程序:parbegin S1 S2 S3 parend 可以用以下SPMD程序:parfor (i=0;i0)beginfork(foo(C);C:=boo(C);end3 并行性问题并行性问题静态并行性:程序的结构以及进程的个数在运行之前(如编译时,连接时或加载时)就可确定,就认为该程序具有静态并行性.动态并行性:否则就认为该程序具有动态并行性.即意味着进程要在运行时创建和终止2022/12/311你现在浏览的是第十一页,共45页Process A:begin Z:=1for
9、k(B);T:=foo(3);endProcess B:begin fork(C);X:=foo(Z);join(C);output(X+Y);endProcess C:begin Y:=foo(Z);end开发动态并行性的一般方法:Fork/Join静态和动态并行性3 并行性问题并行性问题Fork:派生一个子进程Join:强制父进程等待子进程2022/12/312你现在浏览的是第十二页,共45页3.3 进程编组目的:支持进程间的交互,常把需要交互的进程调度在同一组中一个进程组成员由:组标识符+成员序号 唯一确定.3.4 划分与分配原则:使系统大部分时间忙于计算,而不是闲置或忙于交互;同时不牺
10、牲并行性(度).划分:切割数据和工作负载分配:将划分好的数据和工作负载映射到计算结点(处理器)上分配方式显式分配:由用户指定数据和负载如何加载隐式分配:由编译器和运行时支持系统决定就近分配原则:进程所需的数据靠近使用它的进程代码3 并行性问题并行性问题2022/12/313你现在浏览的是第十三页,共45页并行度(Degree of Parallelism,DOP):同时执行的分进程数.并行粒度(Granularity):两次并行或交互操作之间所执行的计算负载.指令级并行块级并行进程级并行任务级并行并行度与并行粒度大小常互为倒数:增大粒度会减小并行度.增加并行度会增加系统(同步)开销 3 并行性
11、问题并行性问题2022/12/314你现在浏览的是第十四页,共45页4 交互通信交互通信问题问题交互:进程间的相互影响4.1 交互的类型v通信:两个或多个进程间传送数的操作 通信方式:共享变量父进程传给子进程(参数传递方式)消息传递 2022/12/315你现在浏览的是第十五页,共45页v同步:导致进程间相互等待或继续执行的操作 同步方式:原子同步 控制同步(路障,临界区)数据同步(锁,条件临界区,监控程序,事件)例子:原子同步parfor(i:=1;in;i+)atomicx:=x+1;y:=y-1路障同步parfor(i:=1;in;i+)Pi barrierQi 临界区parfor(i:
12、=1;in;i+)criticalx:=x+1;y:=y+1数据同步(信号量同步)parfor(i:=1;in;i+)lock(S);x:=x+1;y:=y-1;unlock(S)4 交互通信交互通信问题问题2022/12/316你现在浏览的是第十六页,共45页v聚集(aggregation):用一串超步将各分进程计算所得的部分结果合并为一个完整的结果,每个超步包含一个短的计算和一个简单的通信或/和同步.聚集方式:归约扫描交互的类型4 交互通信交互通信问题问题例子例子:计算两个向量的内积计算两个向量的内积parfor(i:=1;in;i+)Xi:=Ai*Biinner_product:=agg
13、regate_sum(Xi);2022/12/317你现在浏览的是第十七页,共45页4.2 交互的方式4 交互通信交互通信问题问题 交互代码交互代码 C P1P2Pn相对于交互代码C,可对进程P定义如下状态:到达(arrived):P刚到达C,但还未进入在内(in):P在代码中完成(finished):P刚完成执行代码C,但还未离开在外(out):P不在代码中(未到达或已离开)同步的交互:所有参与者同时到达并执行交互代码C异步的交互:进程到达C后,不必等待其它进程到达即可执行C2022/12/318你现在浏览的是第十八页,共45页交互方式与入口/出口条件的组合4 交互通信交互通信问题问题锁定的
14、发送:消息已发完,但不一定已收到锁定的接收:消息已收到非锁定的发/收:只是发出发/收的请求2022/12/319你现在浏览的是第十九页,共45页4.3 交互的模式按交互模式是否能在编译时确定分为:静态的动态的按有多少发送者和接收者参与通信分为一对一:点到点(point to point)一对多:广播(broadcast),播撒(scatter)多对一:收集(gather),归约(reduce)多对多:全交换(Tatal Exchange),扫描(scan),置换/移位(permutation/shift)4 交互通信交互通信问题问题2022/12/320你现在浏览的是第二十页,共45页1 3
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 并行 程序设计 基础 优秀 PPT
限制150内