数字IC前端学习笔记:脉动阵列的设计方法学(四)

相关阅读

数字IC前端icon-default.png?t=O83Ahttps://blog.csdn.net/weixin_45791458/category_12173698.html?spm=1001.2014.3001.5482


引言

        脉动结构(也称为脉动阵列)表示一种有节奏地计算并通过系统传输数据的处理单元(PEs)网络。这些处理单元有规律地泵入泵出数据以保持规则的数据流。因此,脉动阵列的特征是模块化和规则化,这对于VLSI设计来说是一个重要的性质。脉动阵列可以作为与主机配合的协处理器,从主机接收数据进行计算并将最终结果返回主机。这个操作类似心脏的血液流动,因此被称为“脉动”。

        典型情况下,脉动阵列的所有处理单元是相同的,且全流水的(即PE包含寄存器等延时单元),通常只包含局部互联。然而,为了增加脉动阵列的实用性,一些设计也存在放宽。这些放宽包括:不仅使用局部互连,还使用邻近(接近,但不是最近的)互连,使用数据广播操作,以及在系统中使用不同的处理单元,特别是在边界处。通过这些放宽措施,可以为数字信号处理(DSP)应用设计一系列模块化、规则和高效的数据驱动阵列架构。

        本文以串行FIR滤波器为例介绍了脉动阵列设计方法学,其中可以使用线性映射或投影技术为任何给定的规则迭代算法设计多种流线架构。

脉动阵列设计方法学

        流线架构是通过在规则依赖图上使用线性映射技术来设计的。依赖图中的边表示前置约束。一个依赖图(DG)如果在任何节点中某个方向上的边的存在,意味着在依赖图中的所有节点在同一方向上都有相应的边,那么该依赖图被称为规则依赖图。

        作为一个例子,考虑如下所示的3抽头FIR滤波器的依赖图,如图1所示。

y(n) = \omega _{0}x(n) + \omega _{1}x(n - 1) + \omega _{2}x(n - 2)

 图1 FIR滤波器的依赖图(空间表示)

        这个依赖图有3个基本的边(用\boldsymbol{e}表示):输入用向上的边用向量表示为(0, 1),系数用向右的边用向量表示为(1, 0),输出用下右下角移动的边用向量表示为(1, -1)。由于依赖图中的所有节点都包含这3种边,因此该依赖图是规则的。

        该依赖图对应于一个空间表示,因为其中没有为任何计算分配时间不。映射技术将空间表示转换为空间-时间表示,在空间-时间表示中,每个节点被映射到某个处理单元,并且被调度到某个时间步。

        脉动阵列设计方法学将一个N维的依赖图映射到一个低维的脉动阵列。在本文中,只考虑一级映射,即将一个N维的依赖图映射到一个(N-1)维的脉动阵列(对于FIR滤波器而言是将2维依赖图映射到1维脉动阵列)。

        下面定义脉动阵列设计中的基本向量:

  • 投影向量(也称迭代向量):\boldsymbol{d} = (d_{1}, d_{2}),如果两个节点间的距离为投影向量的整数倍,则他们由同一个处理单元计算。
  • 处理器空间向量:\boldsymbol{p} = (p_{1}, p_{2}),任何坐标为\boldsymbol{I} = (i, j)的节点由处理单元\boldsymbol{p} \cdot \boldsymbol{I}计算。
  • 调度向量:\boldsymbol{s} = (s_{1}, s_{2}),任何坐标为\boldsymbol{I} = (i, j)的节点在时间步\boldsymbol{s} \cdot \boldsymbol{I}计算。
  • 硬件利用率:\boldsymbol{HUE} = 1 / ( \boldsymbol{s} \cdot \boldsymbol{d}),这是因为同一个处理单元的两次计算相隔\boldsymbol{s} \cdot \boldsymbol{d}

        对于给定的问题,可以通过选择不同的投影向量、处理器空间向量和调度向量来设计多种脉动阵列,但这些向量必须满足以下推导出的两个可行性约束。

        1、处理器空间向量和投影向量必须彼此正交(内积为0)。如果节点A和B间的距离等于投影向量的整数倍,即\boldsymbol{I_{A}} - \boldsymbol{I_{B}} = n\boldsymbol{d},则这两个节点由同一个处理单元计算,所以\boldsymbol{p} \cdot \boldsymbol{I_{A}} = \boldsymbol{p} \cdot \boldsymbol{I_{B}},即\boldsymbol{p} \cdot (\boldsymbol{I_{A}} - \boldsymbol{I_{B}}) = 0 \rightarrow n\boldsymbol{p} \cdot \boldsymbol{d} = 0

        2、如果节点A和B被映射到同一个处理器,那么其不能同时计算,所以\boldsymbol{s} \cdot \boldsymbol{I_{A}} \neq \boldsymbol{s} \cdot \boldsymbol{I_{B}},即\boldsymbol{s} \cdot (\boldsymbol{I_{A}} - \boldsymbol{I_{B}}) \neq 0 \rightarrow n\boldsymbol{s} \cdot \boldsymbol{d} \neq 0

        另外,将空间表示转换为空间-时间表示时,引入处理器轴\boldsymbol{j^{'} }= \boldsymbol{p} \cdot \boldsymbol{I},时间步轴\boldsymbol{t^{'}} = \boldsymbol{s} \cdot \boldsymbol{I}。 将依赖图映射到脉动阵列时,每个依赖图中的边\boldsymbol{e}对应脉动阵列中的一个延时边,方向\boldsymbol{p} \cdot \boldsymbol{e},延时值为\boldsymbol{s} \cdot \boldsymbol{e}

设计4(输入移动、权重反向移动、输出保持)

\boldsymbol{d} = (1, -1)\, \, \, \, \, \boldsymbol{p} = (1, 1)\, \, \, \, \, \boldsymbol{s} = (1, -1)

        可以很容易地验证,这些向量满足提到的两个可行性约束,并且可得到:

  • 任何坐标为\boldsymbol{I} = (i, j)的节点由处理单元\boldsymbol{p} \cdot \boldsymbol{I} = i+j计算。
  • 任何坐标为\boldsymbol{I} = (i, j)的节点在时间步\boldsymbol{s} \cdot \boldsymbol{I} = i-j计算。
  • 硬件利用率为\boldsymbol{HUE} = 1 / ( \boldsymbol{s} \cdot \boldsymbol{d}) = 1/2

        在空间-时间表示中,处理器轴\boldsymbol{j^{'} }= \boldsymbol{p} \cdot \boldsymbol{I}对应空间表示中的\boldsymbol{i} + \boldsymbol{j}轴,时间步轴\boldsymbol{t^{'}} = \boldsymbol{s} \cdot \boldsymbol{I}对应空间表示中的\boldsymbol{i} - \boldsymbol{j}轴。

        将依赖图映射到脉动阵列时,边映射的情况如表1所示。

 表1 设计1的边映射情况

\boldsymbol{e}\boldsymbol{p}\boldsymbol{s}\boldsymbol{p} \cdot \boldsymbol{e}(方向)\boldsymbol{s} \cdot \boldsymbol{e}(延迟)
输入: (0, -1)(1, 1)(1, -1)-11
权重: (1, 0)11
输出: (1, -1)02

        表1中需要注意的是,输入边选择用(0, -1)向量表示而不是(0, 1)向量表示,这是为了避免出现负的延迟,这种向量反转在输入边上不存在优先级约束时是可行的。

        如数字IC前端学习笔记:脉动阵列的设计方法学(二)-CSDN博客一文所说,不能将处理器轴上的每一个值都对应一个单独的处理单元,在输出后,应该还能计算其他输出。根据不同的处理单元复用策略,有以下三种情况。

情况1

        图2给出了设计4的一种空间-时间表示。其中红线表示处于同一时间步的计算,而蓝线表示处于同一处理单元的计算。

图2 情况1的FIR滤波器的空间-时间表示

        可以看出,总共需要使用5个PE在时间步0输出后,继续在时间步1计算x_{3}\omega _{2}(这本应该是PE_{5}的任务),时间步3计算x_{4}\omega_{1},并最终在时间步5输出y_{5},对于其他PE,情况也是如此。

        对于权重,PE_{4}的权重输出连接到PE_{0}的权重输入。

        对于输入,由于每个输入只会被3个PE使用,因此在某个PE在进行任务切换时不会使用其他PE传来的输入,而是由输入端口获取输入,例如对于PE_{1},其在输出y_{1}后的下一个时间步,不会使用PE_{2}传递来的输入,而是从输入端口获得输入x_{4}

        最后需要注意的是,PE的累加计算是每隔2个或1个时间步进行的(对于单个任务时是2个时间步,对于任务切换时是1个时间步),这种情况下,硬件利用率应略高于前面分析的1/2。整体的脉动阵列每个时间步都会有一个有效结果输出。

        图3给出了情况1的脉动阵列框图,其中D代表有延时单元(如寄存器)的边,2D表示两倍延迟。

图3 情况1的脉动阵列框图

        情况1的具体实现如图4所示,其中标出了一种权重的可能情况,可以发现有些权重之间存在0数据(比如\omega_{1}\omega_{2}),这是因为PE在单个任务中累加计算是每隔2个时间步进行,而有些权重之间则是连续的(比如\omega_{2}\omega_{0}),这是因为PE在任务切换时的计算是隔1个时间步进行,而任务切换发生在\omega_{0}的相关运算完成后。

图4 情况1的具体实现

        情况1中,PE需要设计为能在2个时间步累加和1个时间步累加之间切换,这可能会导致PE更加复杂,如果不想如此该怎么做?很简单,只要每个PE在任务切换时多等待一个时间步即可,如情况2所示。

情况2

        图5给出了设计4的一种空间-时间表示。其中红线表示处于同一时间步的计算,而蓝线表示处于同一处理单元的计算。

图5 情况2的FIR滤波器的空间-时间表示

        可以看出,与情况1相比不同之处在于总共需要6个PEPE_{0}在时间步0输出后,继续在时间步2计算x_{4}\omega _{2}(这本应该是PE_{6}的任务),时间步4计算x_{5}\omega_{1},并最终在时间步6输出y_{6},对于其他PE,情况也是如此。

        对于权重,PE_{5}的权重输出连接到PE_{0}的权重输入。

        对于输入,由于每个输入只会被3个PE使用,因此在某个PE在进行任务切换时不会使用其他PE传来的输入,而是由输入端口获取输入,例如对于PE_{1},其在输出y_{1}后的2个时间步时,不会使用PE_{2}传递来的输入,而是从输入端口获得输入x_{5}

        最后需要注意的是,PE的累加计算是每隔2个时间步进行的,这种情况下,硬件利用率为1/2。整体的脉动阵列每个时间步都会有一个有效结果输出。

        图6给出了情况2的脉动阵列框图,其中D代表有延时单元(如寄存器)的边,2D表示两倍延迟。

图6 情况2的脉动阵列框图

        情况2的具体实现如图7所示,其中标出了一种权重的可能情况,可以发现权重之间存在0数据,这是因为PE的累加计算是每隔2个时间步进行的。

图7 情况2的具体实现

        情况1和情况2不仅使用了5个PE和6个PE,还需要输入序列从不同的端口进入,有没有什么情况能使设计4与之前的设计1、2、3那样只使用3个PE且无需多个输入端口呢?情况3就展示了这种情况。

情况3

        图8展示了情况3的空间-时间表示,其中由PE_{0}完成PE_{3}的任务,PE_{1}完成PE_{4}的任务,以此类推。可以看出其中并没有用红线表示处于同一时间步的计算,这是因为由于此时只有3个PE,在时间步-1时PE_{0}不能开始y_{3}的任务,因为它需要在时间步0先完成y_{0}的任务;在时间步0时PE_{1}不能开始y_{4}的任务,因为它正在完成y_{1}的任务。不能用时间步轴代表所有在同一时间步的计算,需要更为巧妙的计算安排。

图8 情况3的FIR滤波器的空间-时间表示

        根据表1,输入由PE_{2}进入,进而传递给PE_{1},最后传递给PE_{0},而权重由PE_{0}进入,进而传递给PE_{1},最后传递给PE_{2}。由于输入在PE间的延迟为D,某个输入在3个PE中的3次计算必须在连续的3个时间步进行,且由于输出的累加计算是每隔2个时间步进行的,有效的输入和权重每隔2个时间步进入PE

        综上所述,给出了图9所示的FIR滤波器的空间-时间表示,其中用红色标注出了每个计算的时间步。

图9 情况3的FIR滤波器的空间-时间表示(标注时间步)

        可以看出,与情况1和情况2相比不同之处在于只需要3个PEPE_{0}在时间步2输出后,继续在时间步4计算x_{1}\omega _{2}(这本应该是PE_{3}的任务),时间步6计算x_{2}\omega_{1},并最终在时间步8输出y_{3},对于其他PE,情况也是如此。

        对于权重,PE_{2}的权重输出连接到PE_{0}的权重输入,且反馈回路上需要有一个延时边3D,这么做的理由可以从图11中找到。

        最后需要注意的是,PE的累加计算是每隔2个时间步进行的,这种情况下,硬件利用率为1/2。整体的脉动阵列并不是每个时间步都会有一个有效结果输出。

        图10给出了情况3的脉动阵列框图,其中D代表有延时单元(如寄存器)的边,3D表示两倍延迟。

图10 情况3的脉动阵列框图

        情况3的具体实现如图11所示,其中标出了一种权重的可能情况,可以发现权重之间存在0数据,这是因为PE的累加计算是每隔2个时间步进行的。

图11 情况3的具体实现

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/942563.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

观察者模式和发布-订阅模式有什么异同?它们在哪些情况下会被使用?

大家好,我是锋哥。今天分享关于【观察者模式和发布-订阅模式有什么异同?它们在哪些情况下会被使用?】面试题。希望对大家有帮助; 观察者模式和发布-订阅模式有什么异同?它们在哪些情况下会被使用? 1000道 …

【LeetCode】726、原子的数量

【LeetCode】726、原子的数量 文章目录 一、递归: 嵌套类问题1.1 递归: 嵌套类问题 二、多语言解法 一、递归: 嵌套类问题 1.1 递归: 嵌套类问题 遇到 ( 括号, 则递归计算子问题 遇到大写字母, 或遇到 ( 括号, 则清算历史, 并开始新的记录 记录由两部分组成: 大写字母开头的 …

【Select 语法全解密】.NET开源ORM框架 SqlSugar 系列

系列文章目录 🎀🎀🎀 .NET开源 ORM 框架 SqlSugar 系列 🎀🎀🎀 文章目录 系列文章目录前言一、Select 执行位置二、返回一个字段和多个字段三、单表返回DTO四、多表返回DTO4.1 手动DTO4.2 实体自动映射14.…

WebRTC服务质量(11)- Pacer机制(03) IntervalBudget

WebRTC服务质量(01)- Qos概述 WebRTC服务质量(02)- RTP协议 WebRTC服务质量(03)- RTCP协议 WebRTC服务质量(04)- 重传机制(01) RTX NACK概述 WebRTC服务质量(…

分布式协同 - 分布式事务_2PC 3PC解决方案

文章目录 导图Pre2PC(Two-Phase Commit)协议准备阶段提交阶段情况 1:只要有一个事务参与者反馈未就绪(no ready),事务协调者就会回滚事务情况 2:当所有事务参与者均反馈就绪(ready&a…

计算机图形学知识点汇总

一、计算机图形学定义与内容 1.图形 图形分为“图”和“形”两部分。 其中,“形”指形体或形状,存在于客观世界和虚拟世界,它的本质是“表示”;而图则是包含几何信息与属性信息的点、线等基本图元构成的画面,用于表达…

Nginx区分PC端和移动端访问

在使用Nginx时,可以通过$http_user_agent变量来判断用户访问的客户端类型,从而提供不同的内容或服务。下面是一个基于$http_user_agent变量来判断是否为PC访问的Nginx配置示例。 1. 理解$http_user_agent变量的含义及其在Nginx中的用途 $http_user_agen…

方法。。。

1. 方法概述 1.1 方法的概念 ​** 方法(method)是程序中最小的执行单元** 注意: 方法必须先创建才可以使用,该过程成为方法定义方法创建后并不是直接可以运行的,需要手动使用后,才执行,该过程…

jasypt原理

jasypt原理 一、背景知识二、原理分析1、(uml中蓝色)加载Encryptor、Detector和Resolver2、(uml中红色)加载EnableEncryptablePropertiesBeanFactoryPostProcessor3、(uml中绿色)解密过程 以jasypt 1.14为例 一、背景知识 需要了解spring的加载顺序: step1:主要是…

【UE5 C++课程系列笔记】13——GameInstanceSubsystem的简单使用

目录 概念 基本使用案例 效果 步骤 概念 UGameInstanceSubsystem 类继承自 USubsystem,它与 GameInstance 紧密关联,旨在为游戏提供一种模块化、可方便扩展和管理的功能单元机制。在整个游戏运行期间,一个 GameInstance 可以包含多个 UGa…

SpringCloud 系列教程:微服务的未来(二)Mybatis-Plus的条件构造器、自定义SQL、Service接口基本用法

本篇博客将深入探讨 MyBatis-Plus 的三个核心功能:条件构造器、自定义 SQL 和 Service 接口的基本用法。通过对这些功能的学习和掌握,开发者能够更加高效地使用 MyBatis-Plus 进行业务开发。 目录 前言 条件构造器 自定义SQL Service接口基本用法 总结…

我的 2024 年终总结

2024 年,我离开了待了两年的互联网公司,来到了一家聚焦教育机器人和激光切割机的公司,没错,是一家硬件公司,从未接触过的领域,但这还不是我今年最重要的里程碑事件 5 月份的时候,正式提出了离职…

STM32-笔记11-手写带操作系统的延时函数

1、为什么带操作系统的延时函数,和笔记10上的延时函数不能使用同一种? 因为笔记10的延时函数在每次调用的时候,会一直开关定时器,而在FreeRTOS操作系统中,SysTick定时器当作时基使用。 时基是一个时间显示的基本单位。…

人工智能与物联网:从智慧家居到智能城市的未来蓝图

引言:未来已来,智能化的世界 想象一下,一个早晨,智能闹钟根据你的睡眠状态自动调整叫醒时间,咖啡机早已备好热腾腾的咖啡,窗帘缓缓拉开,迎接清晨的阳光。这不是科幻小说中的场景,而是…

流程控制

第一章 流程控制语句 在一个程序执行的过程中,各条语句的执行顺序对程序的结果是有直接影响的。所以,我们必须清楚每条语句的执行流程。而且,很多时候要通过控制语句的执行顺序来实现我们想要的功能。 1.1 流程控制语句分类 ​ 顺序结构 …

台球助教平台系统开发APP和小程序信息收藏功能需求解析(第十二章)

以下是开发台球助教系统客户端(APP,小程序,H5)几端的信息收藏功能的详细需求和功能说明,内容比较详细,可以说是一个教科书式的详细说明了,这套需求说明不仅仅用在我们的台球助教系统程序上&…

RISC-V 医疗芯片发展方向探究及展望

(一)研究背景与意义 近年来,RISC-V作为一种开源指令集架构在芯片领域迅速兴起。它起源于加州大学伯克利分校,于2011年首次公开发布,后凭借其独特优势吸引了全球众多企业、机构以及科研人员的关注与参与。RISC-V具有开…

三维动画的常用“视觉特效”有哪些?

在当今的视觉盛宴中,三维动画技术宛如一位神奇的魔法师,为视觉特效(VFX)领域施下了变革的咒语。从大荧幕上的震撼电影,到让人沉浸其中的视频游戏,再到夺人眼球的广告以及精细的模拟场景,三维动画…

【EtherCATBasics】- KRTS C++示例精讲(2)

EtherCATBasics示例讲解 目录 EtherCATBasics示例讲解结构说明代码讲解 项目打开请查看【BaseFunction精讲】。 结构说明 EtherCATBasics:应用层程序,主要用于人机交互、数据显示、内核层数据交互等; EtherCATBasics.h : 数据定义…

前端初学基础

一.Web开发 前端三件 HTML ,页面展现 CSS,样式 JS(JavaScript),动起来 二,HTML 1.HTML概念 网页,网站中的一个页面,网页是构成网站的基本元素,是承载各种网站应用的平台。通俗的说,网站就…