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 价格都比较高,所以必须得考虑成本问题。

42
98
0
75

相关资讯

  1. 1、心理悬疑片《心咒》画面绝美打造最惊艳恐怖401
  2. 2、院线热映:《哥斯拉》上档,赵薇新片首曝光4889
  3. 3、《悬崖之上》:看于和伟多层次演绎隐秘而伟大2013
  4. 4、为拍出真实效果,他竟真的跳进粪坑!网友:活该你红!3297
  5. 5、时尚教主黄伟文趣评《清唱团》:像日式意面1314
  6. 6、《笔仙惊魂3》武隆取景造宅与《变4》狭路相逢4235
  7. 7、《卧底警花》燃情开机力求再现卧底女警英勇风貌4560
  8. 8、她出演过潘金莲,男友不是侏儒就是巨人,口味变得实在太快1406
  9. 9、大起大落!施予斐扬言赶超巩俐,如今只能演丫鬟蹭镜头4454
  10. 10、《双雄》12月6日上映《角斗士》导演完美把关3228
全部评论(0)
我也有话说
0
收藏
点赞
顶部