08_PYNQ快速上手实验介绍

Pynq hands-on demos介绍

PYNQ-Z1快速上手demo集锦,清单如下所示

  • ComputerVision

  • DeepLearning

  • InternetOfThings

安装

下载整个项目的压缩包(链接),并将它复制(可以通过网络、离线等多种方式)到你的PYNQ-Z1上。

每个文件夹中都有单独的使用指南(离线)。

cv2PYNQ

这是一个在PYNQ平台上加速OpenCV图像处理算法的Python扩展包。这个库目前实现了某几个特定的图像处理算法的硬件加速,可以在16ms内处理完1080p的灰度图的滤波算法。

目前已经实现的算法列表:

  • Sobel: 3x3; 5x5

  • Scharr

  • Laplacian: ksize = 1; 3; 5

  • blur: ksize = 3

  • GaussinBlur: ksize = 3

  • erode: ksize = 3

  • dilate: ksize = 3

  • Canny

安装

取决于Pynq软件版本的不同,安装方式各有不同。

首先需要打开PYNQ-Z1板卡上的Linux命令行界面,然后根据不同版本输入如下安装命令:

= PYNQ v2.3

sudo pip3 install -e .

<= PYNQ v2.2

sudo pip3.6 install -e .

运行完安装脚本之后就可以在Jupyter界面看到cv2PYNQ的文件夹

运行Sobel滤波算法的案例

cv2PYNQ文件夹中有一个Sobel滤波算法的notebook,跟着其中的步骤做就可以了。

BNN-PYNQ

这个项目实现了在PYNQ上部署量化神经网络的任务,目前实现了多种不同精度的量化网络结构:

  • 1 bit weights and 1 bit activation (W1A1) for CNV and LFC

  • 1 bit weights and 2 bit activation (W1A2) for CNV and LFC

  • 2 bit weights and 2 bit activation (W2A2) for CNV

安装

取决于Pynq软件版本的不同,安装方式各有不同。

首先需要打开PYNQ-Z1板卡上的Linux命令行界面,然后根据不同版本输入如下安装命令:

= PYNQ v2.3

sudo pip3 install -e .

<= PYNQ v2.2

sudo pip3.6 install -e .

运行完安装脚本之后就可以在Jupyter界面看到bnn的文件夹

运行Road-Signs路标识别

bnn文件夹中有一个路标识别的notebook,跟着其中的步骤做就可以了。

IoT

这个demo会教你如何在IoT场景中控制传感器和制动器

安装

打开Jupyter首页,将如下两个notebook文件上传到Jupyter中即可。

  • arduino_grove_ledbar.ipynb

  • pmod_grove_usranger.ipynb

  • ledbar_and_ultrasonic_ranger.ipynb

运行Demo

准备物件:

打开刚刚上传的notebook,根据其中的指令一步步照做即可。

超声波测距仪传感器这个Demo为例。

超声波测距仪传感器

通过Jupyter打开InternetOfThings目录下的pmod_grove_usranger.ipynb

这个例子展示了如何使用 超声波测距仪传感器。它的测量最大范围为400cm,测量最小范围是3cm,分辨率为1cm。

如果没有障碍物,则会默认返回500cm。

在这个notebook里,我们只展示如何控制grove ultrasonic ranger连接到Pmod接口上,因此需要一个pmod grove和转换器。当然读者也可以自己把控制移植到Arduino接口的版本上去。

from pynq.overlays.base import BaseOverlay

base = BaseOverlay("base.bit")
  • 使用 Microblaze 去控制超声波传感器

下面的程序假设超声波传感器是连接在Pmod-Grove转接器的G1接口上的,以及该转接器连接在PMODA接口上。

时钟控制器的寄存器分布如下:

%%microblaze base.PMODA

#include "xparameters.h"
#include "xtmrctr.h"
#include "gpio.h"
#include "timer.h"
#include <pmod_grove.h>

#define TCSR0 0x00
#define TLR0 0x04
#define TCR0 0x08
#define TCSR1 0x10
#define TLR1 0x14
#define TCR1 0x18
#define MAX_COUNT 0xFFFFFFFF

void create_10us_pulse(gpio usranger){
    gpio_set_direction(usranger, GPIO_OUT);
    gpio_write(usranger, 0);
    delay_us(2);
    gpio_write(usranger, 1);
    delay_us(10);
    gpio_write(usranger, 0);
}

void configure_as_input(gpio usranger){
    gpio_set_direction(usranger, GPIO_IN);
}

unsigned int capture_duration(gpio usranger){
    unsigned int count1, count2;
    count1=0;
    count2=0;
    XTmrCtr_WriteReg(XPAR_TMRCTR_0_BASEADDR, 0, TLR0, 0x0);
    XTmrCtr_WriteReg(XPAR_TMRCTR_0_BASEADDR, 0, TCSR0, 0x190);
    while(!gpio_read(usranger));
    count1=XTmrCtr_ReadReg(XPAR_TMRCTR_0_BASEADDR, 0, TCR0);
    while(gpio_read(usranger));
    count2=XTmrCtr_ReadReg(XPAR_TMRCTR_0_BASEADDR, 0, TCR0);
    if(count2 > count1) {
        return (count2 - count1);
    } else {
        return((MAX_COUNT - count1) + count2);  
    }
}

unsigned int read_raw(){
    gpio usranger;
    usranger = gpio_open(PMOD_G1_A);
    create_10us_pulse(usranger);
    configure_as_input(usranger);
    return capture_duration(usranger);
}
  • 测量距离

记住放一些障碍物在传感器面前,否则它将返回默认的500cm。

from pynq import Clocks

def read_distance_cm():
    raw_value = read_raw()
    clk_period_ns = int(1000 / Clocks.fclk0_mhz)
    num_microseconds = raw_value * clk_period_ns * 0.001
    if num_microseconds * 0.001 > 30:
        return 500
    else:
        return num_microseconds/58
read_distance_cm()
11.873448275862069

最后更新于