http://hsanyi.blog.163.com/blog/static/5502232520114141175990/
一维脉动阵列是这样的“二维"空间:一个维度是PE空间,也就是说PE是线形的,另一个维度是时间;
二维脉动阵列是一个三维空间,其中两个维度形成PE空间,显然PE就是平面网络,可能是矩形,也可能是三角形或者六边形,另一个维度是时间。
设计脉动这列,其实就是对DG(依赖图)中的各个节点进行调度,也就是说xxx节点安排在xxx周期调度到xxx处理器上运行;其实本质就是节点调度的问题,只是这种调度不是任意的,要符合一定的规则,这样才能保证所得脉动这列功能是正确的。
约定一个PE在一个周期内只能执行一个节点的计算任务,也就是说,不能在同一个周期将多于一个的节点映射到同一个PE。
从数学意义上说,对一维脉动阵列,时间轴不能和处理轴平行;对于二维脉动阵列,时间轴不能和处理器平面平行;