IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> Cambricon: An Instruction Set Architecture for Neural Networks -> 正文阅读

[人工智能]Cambricon: An Instruction Set Architecture for Neural Networks

神经网络处理器(e.g. Cambricon-based accelerator) vs 神经网络加速器(e.g. DianNao, DaDianNao)

神经网络加速器(e.g. DianNao, DaDianNao)

  1. 指令是面向Layer的,硬件“理解”Layer,对各个Layer的优化直接体现在硬件设计中,“These accelerators often adopt high-level and informative instructions that directly specify the high-level functional blocks(e.g. layer type: convolution/ pooling/ classifier) or even an NN as a whole
  2. 只能支持具有相似计算模式和数据重用模式的一类神经网络,注重效率,通用性较差,DianNao系列针对通用性设计的主要思想是*“Duo to the limited number of target algorithms”*。
  3. 一般没有编译器,没有指令集的概念,调用Layer并针对Layer直接产生指令,“DianNao: there is a need for code generation, but a compiler would be overkill in our case as only three main types of code must be generated. So we have implemented three dedicated code generators for the three layers”
  4. 指令译码复杂,开销大。

神经网络处理器(e.g. Cambricon-based accelerator)

  1. 神经网络处理器 = 指令集ISA + 硬件加速器,指令是面向“操作”的,这些“操作”是通过观察一类算法或应用抽取出来的,硬件设计只需要加速这些“操作”,对各种Layer的优化体现在对“操作”的抽取上,例如Cambricon的抽取思想:“In GoogLeNet, 99.992% arithmetic operations can be aggregated as vector operations, and 99.791% of the vector operations can be aggregated as matrix operations”
  2. 广泛支持各种Neural Network Structure,注重通用性,ISA作为中间件可能对效率有影响,因此反复提到*“Negligible latency/ power/ area overheads”*。
  3. 一般有编译器,有指令集,编译生成各Layer的Code/Instructions,当然也可以像汇编一样直接写机器级代码,与code generator不同。
  4. 指令译码较简单,开销小。

举例(个人理解、想法)

  1. 比如我们在Python中直接写Convolution(), Pooling(), FC(),DianNao的code generator直接生成CP代码,这样的粒度是很高的,Cambricon的编译器也可以采用这样高粒度方式生成ISA中的指令,但Cambricon的编译器能支持更多的网络结构,如LSTM()等。
  2. 但Cambricon可以更细粒度,比如等到Python解释器先将Python代码转换为底层代码后,再将底层代码中的循环等编译为ISA中的Vector或Matrix操作,只要ISA 可支持/转化 该Layer的底层操作就可编译(CPU支持最底层的操作,因此CPU是万能的)。

Cambricon ISA

Overview

  1. 重点关注数据级并行,“Data-level parallelism enabled by vector/matrix instructions can be more efficient than instruction-level parallelism of traditional scalar instructions”
  2. “Small yet representative set of vector/matrix instructions for existing NN techniques”
  3. “Replace vector register files with on-chip scratchpad memory,向量操作数的长度不再受固定宽度向量寄存器的限制,向量或矩阵的长度是可变的。
  4. “Load-store architecture”,*64 32-bit General-Purpose Registers(GPRs)*可用于片上SPM寄存器间接寻址或保存标量。
  5. “Four types of instructions: computational, logical, control, and data transfer instructions, and the instruction length is fixed to be 64-bit”

Control Instructions

Jump instruction: the offset will be accumulated to the PC

在这里插入图片描述

Conditional branch: the branch target(either PC+{ offset } or PC + 1) is determined by a comparison between the predictor and zero

在这里插入图片描述

Data Transfer Instructions

支持可变长度的向量或矩阵;可以在主存与SPM之间 或 SPM与GPRs之间移动数据。

在这里插入图片描述

Matrix Instructions

Forward Pass,以MLP为例, y = f ( W x + b ) {y = f(Wx + b)} y=f(Wx+b),提供Matrix Mult Vector instruction(MMV)。

在这里插入图片描述

Backward Pass,以MLP为例,如果使用MMV,需要转置,因此提供Vector Mult Matrix Instruction。

Update,以MLP为例, W = W + η Δ W {W = W + \eta\Delta W} W=W+ηΔW,为产生 Δ W {\Delta W} ΔW提供the outer product of two vectors,还提供Matrix Mult Scalar instruction和Matrix Add Matrix instruction。

Vector Instructions

W x + b {Wx + b} Wx+b,提供Vector Add Vector instruction。
f ( W x + b ) {f(Wx + b)} f(Wx+b),以Sigmoid activation function为例,提供 Vector Exponential instruction,Vector Add Scalar instruction,Vector Div Vector instruction。

Logical Instructions

主要用于池化层,
例如,Vector Greater Than Merge instruction, V o u t [ i ] = ( V i n 0 [ i ] > V i n 1 [ i ] ) ? V i n 0 [ i ] : V i n 1 [ i ] {Vout[i] = (Vin0[i]>Vin1[i])?Vin0[i]:Vin1[i]} Vout[i]=(Vin0[i]>Vin1[i])?Vin0[i]:Vin1[i]

在这里插入图片描述

Scalar Instructions

Cambricon Based Accelerator

在这里插入图片描述

  1. Seven major instruction pipeline stages: fetching, decoding, issuing, register reading, execution, writting back, and committing
  2. 用成熟的DMA和SPM技术,A promising ISA must be easy to implement and should not be tightly coupled with emerging techniques.
  3. Issue Queue保证指令发射的同步关系,Memory Queue保证访存请求的同步关系,Reorder Buffer保证指令提交的同步关系,都是buffer。
  4. 经过取指,译码,从标量寄存器(GPRs)取到操作数(scalar data, or address/size of vector/matrix data)后,指令被分流。
  5. Control instructions and scalar computational/logical instructions被送入scalar functional unit执行,写回GPRs后,送入Reorder Buffer等待被提交。
  6. 涉及向量、矩阵、访存(Cache/ Scratchpad Memory)的指令,首先送入AGU产生地址,经过Memory Queue消除数据依赖,然后再次分流,标量的load/store指令送入L1 Cache,向量和矩阵相关操作的指令分别送入Vector Func. UnitMatrix Func. Unit,执行完成后送入Reorder Buffer等待被提交。
  7. The vector unit contains 32 16-bit adders, 32 16-bit multipliers, and is equipped with a 64 KB scratchpad memory. The matrix unit contains 1024 multipliers and 1024 adders, which has been divided into 32 separate computational blocks to avoid excessive wire congestion and power consumption on long-distance data movements. Each computational block is equipped with a separate 24 KB scratchpad.

最后有关port和bank的概念一直没搞清楚,只能理解Matrix Scratchpad Memory Structure可以帮助进行并行的读写访问,但具体原理不太明白,以及为什么是4个并发读写请求?

在这里插入图片描述

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-12-11 15:43:23  更:2021-12-11 15:45:54 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 23:48:25-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码