第六章-向量处理机课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《第六章-向量处理机课件.ppt》由用户(晟晟文业)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 第六 向量 处理机 课件
- 资源描述:
-
1、n向量处理机是解决数值计算问题的一种高性能计算机结构n向量处理机一般都采用流水线结构,有多条流水线并行工作n向量处理机通常属大型或巨型机,也可以用微机加一台向量协处理器组成n一般向量计算机中包括有一台高性能标量处理机n必须把要解决的问题转化为向量运算,向量处理机才能充分发挥作用6.1 向量处理的基本概念向量处理的基本概念n什么是向量处理什么是向量处理n 例如:一个简单的C语言程序如下:for(i=1;i N)GOTO 2010 read bI read cI add bI+cI store aIbI+cI read aI+1 multiply 2*aI+1 store bI 2*aI+1 in
2、crement I I+1 goto 1020Stop常量常量2 2,a,b,ca,b,c中每中每一个元素都称为一一个元素都称为一个标量。该指令序个标量。该指令序列称为标量指令序列称为标量指令序列,执行过程为标列,执行过程为标量处理过程,每一量处理过程,每一条指令只处理一个条指令只处理一个或一对数据。或一对数据。n上述程序用向量化指令序列实现为:a1:n=b1:n+c1:n temp1:n=a2:n+1 b1:n=2*temp1:n 将n个独立的数构成的整体称为向量向量,对这一组数的运算称为向量处理向量处理。一条向量处理指令可以处理n个或n对操作数。向量处理方式n要根据向量运算的特点和向量处理
3、机的类型选择向量的处理方式。n有三种处理方式:1横向处理方式,又称为水平处理方式,横向加工方式等。向量计算是按行的方式从左至右横向地进行。2纵向处理方式,又称为垂直处理方式,纵向加工方式等。向量计算是按列的方式自上而下纵向地进行。3纵横处理方式,又称为分组处理方式,纵横向加工方式等。横向处理和纵向处理相结合的方式。n 以一个简单的C语言编写的程序为例,说明向量的三种处理方式的工作原理。for(i=1;i=n;i+)yi=ai(bi+ci);n横向处理方式 也称为水平处理方式,横向加工方式等逐个分量进行处理:假设中间结果为TI计算第1个分量:T1 B1C1 Y1 A1T1计算第2个分量:T2 B
4、2C2 Y2 A2T2最后一个分量:TN BNCN YNANTNn存在两个问题:在计算向量的每个分量时,都发生写读数据相关。流水线效率低如果采用多功能流水线,必须频繁进行流水线切换n横向处理方式对向量处理机不适合即使在标量处理机中,也经常通过编译器进行指令流调度。n纵向处理n也称为垂直处理方式,纵向加工方式等T1=B1+C1T2=B2+C2Tn=Bn+CnY1=A1T1Y2=A2T2YN=AN TNn采用向量指令只需要2条:VADDB,C,TVMULA,T,Yn这种处理方式适用于向量处理机,数据相关不影响流水线连续工作。不同的运算操作只需要切换1次。n纵横处理方式 将长度为n的向量分成若干组,
5、每组长度为m,组内按纵向方式处理,依次处理各组。n用于寄存器-寄存器结构的向量处理机中向量寄存器的长度是有限的,例如,每个向量寄存器有64个寄存器。当向量长度N大于向量寄存器长度n时,需要分组处理。n分组方法:nm,其中:为余数,共分组。组内采用纵向处理方式,组间采用横向处理方式。因此,也称为分组处理方式,纵横向加工方式等。6.2 向量处理机结构向量处理机结构n向量处理机的基本思想是把两个向量的对应分量进行运算,产生一个结果向量。最关键问题是存储器系统能够满足运算部件带宽的要求。n主要采用两种方法:1.存储器存储器结构多个独立的存储器模块并行工作处理机结构简单,对存储系统的访问速度要求很高2.
6、寄存器寄存器结构运算通过向量寄存器进行需要大量高速寄存器,对存储系统访问速度的要求降低存储器存储器结构存储器存储器结构n下图说明一个具有8个存储体的向量处理机:MMMMMMMM流水结构加法器ABC=A+B三条互相独立的数据通路,可并行工作,同一个存储模块同时只能为一个通路服务n向量处理示例1:求C=A+B,设A、B、C的存储形式如图:C4B6A0C5B7A1C6B0A2C7B1A3C0B2A4C2B3A5C3B4A6C4B5A7模块0模块1模块2模块3模块4模块5模块6模块7A、B、C在主存储器中的存放情况流水段1流水段2流水段3流水段4W4W4RB6RB6RA0RA0W5W5RB7RB7RA
7、1RA1W6RA2RA2RB0RB0RA3RA3RB1RB1W0W0RA4RA4RB2RB2W1W1RA5RA5RB3RB3W2W2RA6RA6RB4RB4W3W3RA7RA7RB5RB576543210765432107654321076543210M0M1M2M3M4M5M6M70 1 2 3 4 5 6 7 8 9 10 11 12两个向量在流水线方式下分量相加的时序图时间(时钟周期)n在流水线的输入端和输出端增加缓冲器可以消除争用存储器现象。可变延迟器可变延迟器可变延迟器可变延迟器主存主存储器储器流水结流水结构加法构加法器器ABC延迟4个时钟周期延迟2个时钟周期W0RB8RB8RA8R
8、A8RB0RB0RA0RA0RB8RB8RA8RA8RB1RB1RA1RA1RB8RA8RA8RB2RB2RA2RA2 RA8RA8RB3RB3RA3RA3 RA8RB4RB4RA4RA4RB5RB5RA5RA5 RB6RB6RA6RA6RB7RB7RA7RA776543210765432106543210543210M0M1M2M3M4M5M6M70 1 2 3 4 5 6 7 8 9 10 11 12流水段1流水段2流水段3流水段4存储器发生冲突时两个向量相加的时序图寄存器寄存器-寄存器结构寄存器结构n把存储器-存储器结构中的缓冲栈改为向量寄存器,运算部件需要的操作数从向量寄存器中读取,运
9、算的中间结果也写到向量寄存器中。n向量寄存器与标量寄存器的主要差别是:一个向量寄存器能够保存一个向量,例如:64个64位寄存器。连续访问一个向量的各个分量。n需要有标量寄存器和地址寄存器等。n采用寄存器-寄存器结构的主要优点:降低主存储器的流量。例如:采用寄存器-寄存器结构的CRAY-1与采用存储器-存储器结构的STAR-100比较,运算速度高3倍多,而主存流量低2.5倍。nSTAR-100的主存储器流量:328W/1.28us=200MW/SCRAY-1的主存储器流量:4W/50ns=80MW/S8个向量寄存器86464主存储器8MB64个个体12个流水线结构的运算部件缓冲寄存器6464标量
10、寄存器864缓冲寄存器6424地址寄存器824指令缓冲寄存器25616CRAY-1向量处理机结构q向量处理机系统结构的设计目标向量处理机系统结构的设计目标 提高向量处理机性能的常用技术提高向量处理机性能的常用技术6.3 6.3 提高向量处理机性能的办法提高向量处理机性能的办法向量处理机系统结构的设计目标向量处理机系统结构的设计目标n较好地维持向量较好地维持向量/标量性能平衡标量性能平衡 向量平衡点(vector balance point)定义为:为了使向量硬件设备和标量硬件设备的利用率相等,一个程序中向量代码所占的百分比。例如:系统在向量模式下能够达到9Mflops,在标量模式下能够达到1M
11、flops的运算速度,假设代码的90%是向量运算,10%是标量运算,这样花在两种模式上的计算时间相等,那么向量平衡点为0.9。几种超级计算机的向量性能和标量性能(了解)机器型号Fujitsu VP400Cray ISCray 2SCray X-MPCray Y-MPHitachi S820NEC SX2向量性能Mflops标量性能Mflops向量平衡点85.09.80.90151.511.20.93143.313.10.92201.617.00.92737.317.80.98424.29.50.98207.16.60.97n可扩展性随处理机数目的增加而提高可扩展性随处理机数目的增加而提高 可扩
12、展性的三个目标:规模可扩展性、换代可扩展性、问题可扩展性。n提供高性能的提供高性能的I/OI/O和易访问的网络和易访问的网络 提高向量处理机性能的常用技术提高向量处理机性能的常用技术n链接技术链接技术 向量指令的类型:n4321VjVkVin4321SjVkVi第一类向量指令第二类向量指令存储器7654321Vi存储器7654321Vi第三类向量指令第四类向量指令n向量运算中的相关和冲突n向量运算中的数据相关和功能部件冲突:采用顺序发射顺序完成方式(1)写读数据相关。(2)读读数据相关,或向量寄存器冲突。(3)运算部件冲突。V0 V1V2 V3 V1V2V3 V4*V5 V6 V4+V5(a)
13、不相关的指令 (b)功能部件的预定V3 V1V2 V0 V1V2V6 V1*V5 V3 V1+V5(c)操作数寄存器预定 (d)功能部件和操作数寄存器的预定n3、向量链接技术(chaining)n 结果寄存器可能成为后继指令的操作数寄存器两条有数据相关的向量指令并行执行,这种技术称为两条流水线的链接技术。例如:有如下3条向量指令:V3 AV2 V0V1V4 V2V3第一、二条指令没有数据相关和功能部件冲突,可以同时开始执行。第三条指令与第一、二条指令均存在写读数据相关,可以链接执行。浮点加71 2 3 4 5 6MemV0V1V2V3V41 2 3 4 5 61 2 3 4 5 6浮点乘n三种
展开阅读全文