《OpenCL异构并行编程实战》补充笔记散点,第一至四章
▶ 总体印象:适合 OpenCL 入门的书,有丰富的代码和说明,例子较为简单。先把 OpenCL 代码的基本结构(平台 → 设备 → 上下文 → 命令队列 → 创建缓冲区 → 读写缓冲区 → 编译代码 → 创建程序 → 创建内核 → 设定内核参数 → 执行内核 → 缓冲区读写 → 回收检查结果)定死了,在围绕这个结构展开算法和应用。
▶ 第一章,并行编程入门
● 开放计算语言(Open Computuing Language,OpenCL)
● 设备语言可以高效映射到众多的内存系统构架上;主机端语言的目标是以较低的开销来高效管理复杂点的并行程序。两者共同为开发人员提供了一种从算法设计高效过渡到实现的途径。
● 并发性(Concurrency)考虑的是同时发生两个或两个以上的活动。并行性(Parallelism)指的是以提高总体性能为明确目标,并行进行两个或两个以上任务。并行程序必须有并发性,但是并发程序不一定要保证并行性。
●支持完全一致的共享内存模型,会在硬件上有较大开销,因为共享总线式设计瓶颈。
● 粒度,定义为计算与通信之比。并行粒度首先与应用程序算法的内在特性。
■ 细粒度的并行,计算强度低;没有租后的任务来隐藏长时间的异步通信耗时;容易通过提供大量可管理的工作单元来实现负载均衡;如果粒度过细,则可能人物之间的通信和同步开开销过大
■ 粗粒度的并行,计算强度高;完整的应用可以作为并行的粒度;难以有效实现负载均衡
● 程序实现指令集的细粒度并行,如超长指令字(VLIW)和超标量体系结构
▶ 第二章,并行编程入门
● OpenCL 规范有四个部分组成:平台模型,设备模型,内存模型,变成模型
● OpenCL 中编程人员的默表示尽可能细粒度地表示程序中的并行性,在计算单元上运行的 kernel 程序的每个实例都称为一个工作项(work-item)
● 工作项与工作组
● 上下文(Context)是一个抽象容器,存在于主机端,用于协调主机设备之间的交互,管理设备上可用的内存对象,跟踪每个设备新建的 kernel 程序。
● 命令队列(Command Queue)是主机端用于向设备端发送请求的行为机制,每个命令队列只能关联一个设备。
● 时间(Event),任何进入命令队列的操作都可以标记为一个事件,用以表示任务依赖关系(规定任务之间的拓扑顺序和阻塞)和提供程序剖析机制。
● 函数 clFinish() 阻塞直到命令队列中所有任务完成,函数 clFlush() 阻塞直到命令队列中所有任务都被移出任务队列,但不保证任务都执行完成。
● OpenCL 软件仅被链接到一个公共的运行层(ICD),所有平台特定的 SDK 通过一个动态库接口委托给某个厂商的运行时。
● 内存模型,注意关键字 __global,__constant,__local
● OpenCL 内存模型与 AMDGPU 内存的关系
▶ 第三章,OpenCL 设备架构
● SIMD 和超长指令字(Very Long Instruction Word,VLIW)构架尝试荣国提高算术操作逻辑电路的比例,进一步提高有效任务的数量;多线程方法通过增加可用的有效任务数量来占用计算逻辑部件,以隐藏其他使用非计算部件的时间,比如访问流水线。
● CMOS 动态功耗公式:P = ACV2F + Ileak 。A 为活动因子,电路中正在切换的晶体管数量;C 为电路电容量;V 为电路电压;F 为切换频率; Ileak 为估计的晶体管漏电电流。
● VLIW 通病是运行效率会因为编译器不能填满包而损失,这可以归结为编译器能力有限或指令缺乏内在的并行性
● SIMD 和向量并行是直接允许硬件指令参与数据并行执行,通产采用数据流水的形式进行计算而不是同时对所有数据单元进行操作。
● 同时多线程(Simultaneous Multithreading,SMT)通过扩展超标量调度逻辑电路来记录指令间的依赖关系和源线程,从而使得多线程指令在资源上交叉执行。
● 介绍了多种 CPU 和 GPU 的体系结构,没有细读。
● 几种并行的方式:
■ 汇编指令流的乱序执行
■ 汇编指令流的乱序执行,在结合第二个线程之后同时执行
■ 两个线程通过轮转时间片来调度执行
■ VLIW 乱序执行
■ SIMD 顺序调度,多个 ALU 上执行
▶ 第四章,OpenCL 基本实例,见代码堆,没有散点笔记
《OpenCL异构并行编程实战》补充笔记散点,第一至四章的更多相关文章
- 《OpenCL异构并行编程实战》补充笔记散点,第五至十二章
▶ 第五章,OpenCL 的并发与执行模型 ● 内存对象与上下文相关而不是与设备相关.设备在不同设备之间的移动如下,如果 kernel 在第二个设备上运行,那么在第一个设备上产生的任何数据结果在第二个 ...
- 《OpenCL异构并行编程实战》第十二至十四章
▶ 第十二章,在其他语言中使用 OpenCL ● JOCL(Java Building for OpenCL),PyOpenCL ● 一个 PyOpenCL 的例子代码,需要 pyopencl 包 i ...
- 【ARM-Linux开发】OpenACC并行编程实战笔记
今年运气比较好,学了cuda之后,了解到了gpu的另两种使用语言opencl和openacc, opencl(Open Computing Language ,开放计算语言)是面向异构系统的并行编程 ...
- ROS机器人程序设计(原书第2版)补充资料 (肆) 第四章 在ROS下使用传感器和执行器
ROS机器人程序设计(原书第2版)补充资料 (肆) 第四章 在ROS使用传感器和执行器 书中,大部分出现hydro的地方,直接替换为indigo或jade或kinetic,即可在对应版本中使用. 第四 ...
- 《Visual C++并行编程实战》译者序
说来凑巧,当开始着手这本书的翻译时,我刚刚入手了自己第一台四核计算机,而翻译工作临近完成之时,我又为自己添置了一台iPad 2(这是一台双核计算机).由此可见,多核计算机已经完全进入了我的日常生活.鉴 ...
- Java多线程编程实战读书笔记(一)
多线程的基础概念本人在学习多线程的时候发现一本书——java多线程编程实战指南.整理了一下书中的概念制作成了思维导图的形式.按照书中的章节整理,并添加一些个人的理解.
- 《java并发编程实战》笔记
<java并发编程实战>这本书配合并发编程网中的并发系列文章一起看,效果会好很多. 并发系列的文章链接为: Java并发性和多线程介绍目录 建议: <java并发编程实战>第 ...
- Java并发编程实战 读书笔记(一)
最近在看多线程经典书籍Java并发变成实战,很多概念有疑惑,虽然工作中很少用到多线程,但觉得还是自己太弱了.加油.记一些随笔.下面简单介绍一下线程. 一 线程与进程 进程与线程的解释 个人觉 ...
- Java并发编程实战 读书笔记(二)
关于发布和逸出 并发编程实践中,this引用逃逸("this"escape)是指对象还没有构造完成,它的this引用就被发布出去了.这是危及到线程安全的,因为其他线程有可能通过这个 ...
随机推荐
- hdu 5696 区间的价值
套路题 求出来以每个数为最大值/最小值时的一个区间范围, 然后枚举每个数为最大值的情况更新即可, 但是对于重复数的话需要特判一下, 假如用map记录来特判复杂度就是$O(nlogn)$, 不过题目说了 ...
- UVA-11903 Just Finish it up
题目大意:一个环形跑道上有n个加油站,每个加油站可加a[i]加仑油,走到下一站需要w[i]加仑油,初始油箱为空,问能否绕跑道一圈,起点任选,若有多个起点,找出编号最小的. 题目分析:如果从1号加油站开 ...
- HTML字符转码
以下是HTML特殊字符的编码表: 标记 编码 实际名称 ™ ™ € € Space ! ! " " " # # $ $ % % & & & ' ...
- [转载]浏览器中输入url 并且按下回车之后发生了什么?
解析URL 浏览器通过 URL 能够知道下面的信息: Protocol "http" 使用HTTP协议 Resource "/" 请求的资源是主页(index) ...
- html中元素盒子垂直居中的实现方法
<!doctype html> <html> <head> <meta charset="utf-8"> <title> ...
- React Diff 算法
React介绍 React是Facebook开发的一款JS库,用于构建用户界面的类库. 它采用声明式范例,可以传递声明代码,最大限度地减少与DOM的交互. 特点: 声明式设计:React采用声明范式, ...
- c# sqlbulkcopy批量插入数据
dt信息中包含数据和表名 public static void SqlBulkInsert(DataTable dt, string connStr) { try { using (var conn ...
- 第十课 C++异常简介
异常不是错误,异常是程序中可预料到的另一条执行分支,是可预见的.错误是不可预料的. C++内置了异常处理的语法元素try...catch...,如下: C++通过throw语句抛出异常信息: 上图中t ...
- yaf路由配置规则
使用框架的默认路由来访问的时候,会遇到一些困扰,这部分无法查看源代码,只能通过猜测来分析. 如果项目有多个模块,显然使用yaf的默认的静态路由是无法满足需求的. yaf默认的配置是着这样的: appl ...
- Linux中文档去掉windows文本的多余的回车符(^M)
1) 使用sed 去掉windows下的回车符 (注意^M 在linux 下写法 按^M 是回车换行符,输入方法是按住CTRL+v,松开v,按m) sed -i 's/^M//g' filenam ...