0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何实现用Python开发FPGA?

YCqV_FPGA_EETre 来源:未知 作者:胡薇 2018-08-10 14:57 次阅读

近日,想必各位科技爱好者的朋友圈都被一篇发表在第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可以为大家拓展出新的思路。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • FPGA
    +关注

    关注

    1602

    文章

    21296

    浏览量

    593091
  • python
    +关注

    关注

    51

    文章

    4669

    浏览量

    83457

原文标题:用Python玩FPGA背后的故事

文章出处:【微信号:FPGA-EETrend,微信公众号:FPGA开发圈】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    AD7747怎么实现用LabVIEW实现数据采集与处理?求助啊

    AD7747怎么实现用LabVIEW实现数据采集与处理?求助啊,我买了一款AD747的开发板,但是开发板自带软件界面不太好看,想用LabVIEW取代自带软件,
    发表于 01-04 08:58

    MicroPython:STM32上的Python开发

    初学者。Python本身自带的各种模块加上丰富的第三方模块,免去了很多“重复造轮子”的工作,节省了不少开发时间。Python的配置环境也不复杂,mac和linux都内置了python
    发表于 12-30 16:00

    夏老师推荐:惊人!Python+FPGA 实现FPGA开发大提速?!!

    夏老师推荐:惊人!Python+FPGA 实现FPGA开发大提速?!! 夏宇闻老师昨天在微信上推荐了一个帖子,说的是有人用Digilent的PYNQ-Z1板卡
    发表于 06-14 09:43

    夏老师推荐:惊人!Python+FPGA 实现FPGA开发大提速?!!

    夏老师推荐:惊人!Python+FPGA 实现FPGA开发大提速?!!
    发表于 06-14 19:27

    夏老师推荐:惊人!Python FPGA 实现FPGA开发大提速?!!

    夏老师推荐:惊人!Python FPGA 实现FPGA开发大提速?!!
    发表于 01-24 11:03

    python开发ide哪个好?

    有,IDEL用Python实现Python的IDE工具,但说实话,功能真心不咋地。我个人常用的IDE如下:PyCharmPyCharm是JetBrains开发
    发表于 06-07 14:55

    评估通过Python快速开发异构处理器FPGA应用性能(PYNQ评测)

    本帖最后由 lee_st 于 2018-6-21 02:18 编辑 评估通过Python快速开发异构处理器FPGA应用性能(PYNQ评测)
    发表于 06-19 08:36

    请问如何实现用串口实现蓝牙接收

    请教各位大神如何实现用串口实现蓝牙接收啊,不会编程啊
    发表于 02-18 00:09

    如何实现用C语言播放音乐

    实现用C语言播放音乐的方法
    发表于 12-28 06:18

    实现linux里的python界面开发

    。因此,本文主要来实现linux里的python界面开发,在这里使用开源的界面库wxpython。由于嵌入式linux都是在linux下开发,那么在linux写一些界面测试例子,就非常
    发表于 10-27 07:56

    新手要学习编程语言,我必推荐Python

    Python软件实现FPGA性能潜力的结合是一个非常有意义的工作,将会开创出一个类似于树莓派和Arduino的广大的开发者社区。Python+FP
    的头像 发表于 08-08 18:30 4574次阅读
    新手要学习编程语言,我必推荐<b class='flag-5'>Python</b>

    python开发环境搭建步骤

    在正式学习Python编程之前,要先安装Python,这包括“标准Python”、“第三方Python包”、“Python程序
    的头像 发表于 05-05 22:23 2903次阅读
    <b class='flag-5'>python</b><b class='flag-5'>开发</b>环境搭建步骤

    PYNQ就是通过Python语言直接对FPGA进行编程吗

    PYNQ框架的设计初衷是通过高层次的封装,将底层硬件FPGA实现细节与上层应用层的使用脱耦,对软件开发者来说,PYNQ框架已经提供了完整的访问FPGA资源的library,让上层应用
    的头像 发表于 02-08 10:59 4113次阅读

    Python项目开发实战

    Python项目开发实战
    发表于 06-13 14:51 2次下载

    在洗碗机中设计和实现用户界面的新方法

    在洗碗机中设计和实现用户界面的新方法
    发表于 10-31 08:23 2次下载
    在洗碗机中设计和<b class='flag-5'>实现用</b>户界面的新方法