想要实现FPGA的CNN加速需要考虑以下内容

网上对于     FPGA   CNN加速的研究已经很多了,     神经网络   的硬件加速似乎已经满大街都是了,这里我们暂且不讨论谁做的好谁做的不好,我们只是根据许许多多的经验来总结一下实现硬件加速,需要哪些知识,考虑哪些因素。

 想要实现FPGA的CNN加速需要考虑以下内容_设计制作_制造/封装

很多人都说在做FPGA的神经网络加速,可是有多少人真正拿出了实际结果,可能大部分人就是用HLS(高层次综合)写了个四五层的小网络,或者简单实现了一下卷积操作。真正要用FPGA做加速,得先明白算法的整体流程以及数据的输入输出形式,然后结合FPGA的特点设计相应的加速结构,在结构设计层次里面涉及到一些关键的点。例如,如何加速原始卷积(winograd、fft或者其他),如何对数据进行复用减少数据的搬移次数,如何设计合理的流水线结构。在算法层次,需要对计算进行量化,因为现有的算法大部分都是浮点运算,FPGA 擅长定点运算,所以必须量化,卷积层量化方法有dynamic fixed point 方法,有聚类方法,也有mini float point 方法等等,当然除了卷积,还有softmax等分类算法如何量化,NMS如何在硬件上实现。另外目前的神经网络越做越大,FPGA资源有限,因此对网络进行裁剪也是一个需要关注的问题。

总的来说用FPGA 加速神经网络,是一个整体性工程,需要软件和硬件协同配合,另外硬件这边除了核心算法,还需要考虑数据的输入以及调度形式,可能需要用PCIE 等高速接口实时传入图像,再利用DDR3/4对计算的部分结果进行缓存,当网络确定,而一个FPGA 资源又不够用的时候,可能需要考虑两个FPGA 互联,那就需要用到光口或者其他高速接口,这些外围高速接口,如果之前没有接触过,任何一个都可能花费相当长的时间。所以说,做FPGA 加速,一个人是绝对不行的,另外,目前能够进行神经网络加速的FPGA ,xilinx 的UltraScale K/V/Zynq系列是比较合适的,但是这些属于高端FPGA,当然,不是说中低端不行,而是以目前主流网络和现有的优化手段,在资源较少的FPGA 上进行加速难度较大,而高端FPGA 价格都比较高,所以必须得考虑成本问题。

15
176
0
83

相关资讯

  1. 1、欧盟就日本电产收购恩布拉科开展深入调查3902
  2. 2、全国最大机器人小镇深汕合作区动工843
  3. 3、美国国家标准技术研究院将采用非接触式光学仪器来检测MEMS的结构1079
  4. 4、电源内部系统的电磁兼容问题分析3164
  5. 5、工业机器人生产迈上新台阶,去年安徽省生产1.1万台,增长37.5%1641
  6. 6、机器人产业园进入爆发期721
  7. 7、两个不同的服务器之间如何进行安全数据迁移2657
  8. 8、移动机器人行业一季度融资一览778
  9. 9、特高压直流输电核心设备——换流阀3088
  10. 10、快克股份激光镭雕设备已在IC芯片封装领域开始接单2890
全部评论(0)
我也有话说
0
收藏
点赞
顶部