如何实现用Python开发FPGA?

近日,想必各位科技爱好者的朋友圈都被一篇发表在第25届ieee国际讨论会上,用python开发fpga的论文刷屏了吧,那么这是如何实现的呢?今天,就请各位看官和小编一起来了解一下,这个构想的实现基础——pynq。
pynq介绍
pynq全称为python productivity for zynq,即在原有zynq架构的基础上,添加了对python的支持。zynq是赛灵思公司推出的行业第一个可扩展处理平台系列,在芯片中集成了arm处理器和fpga可编程逻辑器件,旨在为视频监视、汽车驾驶员辅助以及工厂自动化等高端嵌入式应用提供所需的处理与计算性能水平。pynq希望能够借助python语言本身易用易学、扩展库多而全、社区活跃贡献度高等特性,有效降低zynq嵌入式系统的开发门槛。pynq将arm处理器与fpga器件的底层交互逻辑完全封装起来,顶层封装使用python,只需要import对应的模块名称即可导入对应的硬件模块即可进行底层到上层数据的交互或者为系统提供硬件加速。对于pynq的开发者来说,arm上运行着一个linux系统,fpga被抽象为若干加速ip,开发者可以通过一行简单的python脚本即可完成动态加载bitstream,通过dma将数据流传输到加速ip融合输出。pynq板卡也提供了非常丰富的接口资源,如hdmi、audio、grove模块、常用接口如spi/i2c等等以及很多通用io。
图为python调用底层硬件框架
下面给一个在pynq中插入hdmi输入和输出的例子from pynq importoverlayfrompynq.lib.video import *
base =overlay('base.bit')hdmi_in =base.video.hdmi_inhdmi_out = base.video.hdmi_out
简单高效开发pynq-jupyter
对于嵌入式系统开发来说,往往由于性能的局限性,我们只能ssh进嵌入式linux,在命令行终端进行开发,开发效率是个很大的问题。在pynq上,我们使用了python扩展库jupyter notebook,其本质上是一个web服务器,提供了远程可视化、分步运行python脚本的能力。jupyter同时可以实时显示程序运行结果,我们甚至可以在浏览器中直接看到我们使用硬件加速处理图像的结果。我们只需要将pynq板子接入网关,即可通过浏览器访问在板上运行的作为嵌入式web服务器的jupyter notebook。
图为jupyternotebook实时显示运算图片
pynq能做什么
pynq的整个技术栈包含了python+linux+arm+fpga,提供了无限种扩展的可能性,我们可以使用它来做很多有意思的应用。在pynq.io的社区页面我们可以看到许多pynq社区开发的项目。包括bnn(二值神经网络)的案例。
图为pynq社区应用案例
同时,官方提供了非常多的外部接口案例。同时还包括了opencv的案例。
logictools功能则实现了使用python编写fpga状态机的功能,使用logictools可以用python编写fpga i/o端口输出任意波形了。
图为pynq logictools
查阅pynq文档
关于pynq的所有资料都可以在网站pynq.io中找到,点击getting started就进入了pynq的文档页面。文档中包含了如何设置pynq等入门资料、如何创建pynq的fpga硬件工程、pynq libraries的详细介绍以及最关键的python-pynq的函数文档,也可以使用搜索功能直接查找关键词。
图为pynq.io getting started
至此,pynq就为大家介绍到这里了。希望python可以为大家拓展出新的思路。

深度理解神经网络黑盒子:可验证性和可解释性
在这个信息化的时代 工业控制常用的DSP竞争将越来越激烈
特斯拉明年将发布一款电动越野摩托车 预计2021年年底开始量产
粮食镉大米重金属检测仪概述及技术参数
LMC058嵌入式IO高速计数器有什么功能?详细实例讲解
如何实现用Python开发FPGA?
安芯教育和重庆邮电大学联合举办的4天智能互联实训班顺利结业
泰凌微电子Zephyr编译环境搭建
腾讯微视回应120GB一夜爆满:日志组件出现Bug导致,已经第一时间修复
创维追风,明年也要重点发展LED产业
云安全的新战场上,如何打破“云威胁”的阴霾?
ios10.3.2正式版怎么样?ios10.3.2也许是老设备的最后一个版本?你升级了吗
还不赶快投资捞一笔 2017不买比特币返贫,比特币暴涨23500人民币创历史新高
微机保护装置的特点说明
汽车传感器有哪些 智能传感器十大应用
ZC706千兆网测试(ZYNQ,FreeRTOS,Echo,lwIP,TCP,RGMII)
中国和意大利将在伊朗合作建设太阳能发电厂
fpga最小系统设计和原理图解析
NB-IoT网络商用还看智能抄表 智能抄表领头羊企业分析
手腕传感器的潜在应用包括哪些?