本文转载自:<span id="profileBt"><a href="https://mp.weixin.qq.com/s/Rz16WJoMVLIyJA9vizkjmw">PYNQ开源社区微信公众号</a></s…;
在PYNQ RFSoCWorkshop之后,Xilinx再次推出DSP-PYNQ,与之前只发布了基于RFSoC2x2开发套件的overlay和notebooks不同,本次发布的工程增加了对ZCU111和Ultra96的支持。
<strong>Overlay</strong>
开发者可以通过简单的命令快速安装overlay,并正式开启基于PYNQ的数字信号处理之旅。
<pre>
# PYNQ v2.4.1 v2.5
pip3 install https://github.com/Xilinx/DSP-PYNQ/releases/download/v1.0_$BOARD/dsp_py…
# PYNQ v2.6
pip3 install https://github.com/Xilinx/DSP-PYNQ/releases/download/v2.0_$BOARD/dsp_py…
python3 -c 'import dsp_pynq; dsp_pynq.install_notebooks()'
</pre>
<strong>Notebooks</strong>
本次DSP-PYNQ一共发布了两个有关数字信号处理的notebooks,这些notebooks可以帮助开发者快速熟悉和理解如何使用Python和PYNQ开发数字信号处理(DSP)应用。其中第一个notebook是围绕数字信号处理功能的DSP和Python包入门应用,第二个notebook在第一个的基础上,将FFT和FIR处理搬移到PL端进行加速处理。
<strong>Notebook 1:苏格兰鸟类录音分析</strong>
在该示例应用中,我们将从可视化一些有趣的信号开始——苏格兰鸟类的录音!这段录音包含两种不同频率的苏格兰鸟的声音,我们将使用一些不同的分析技术来了解这些信号,最后对音频进行处理以分离出单一类型的鸟类。
引入SciPy ecosystem,包括用于DSP运算的scipy.signal和用于数组的numpy。
<li>获取采样频率,样本数组类型,样本数据格式,数据长度等信息。</li>
<li>使用Scipy对原始样本数据进行FFT操作。</li>
<center><img src="http://xilinx.eetrend.com/files/2021-05/wen_zhang_/100113158-207469-tu1…; alt=""></center>
<p align="center"><strong>时域信号</strong></p>
<center><img src="http://xilinx.eetrend.com/files/2021-05/wen_zhang_/100113158-207470-tu2…; alt=""></center>
<p align="center"><strong>频域信号</strong></p>
使用Scipy设计FIR滤波器,并验证其频率响应。
<center><img src="http://xilinx.eetrend.com/files/2021-05/wen_zhang_/100113158-207471-tu3…; alt=""></center>
<p align="center"><strong>FIR频率响应</strong></p>
使用FIR滤波器对原始信号进行滤波。
<center><img src="http://xilinx.eetrend.com/files/2021-05/wen_zhang_/100113158-207472-tu4…; alt=""></center>
<p align="center"><strong>FIR滤波前频谱</strong></p>
<center><img src="http://xilinx.eetrend.com/files/2021-05/wen_zhang_/100113158-207473-tu5…; alt=""></center>
<p align="center"><strong>FIR滤波后频谱</strong></p>
使用plotly_express和pandas dataframe实现可视化操作,能够自由对绘图进行zoomin/pan around/zoom back 保存等操作,上述图片均使用ploty_express绘得。
<strong>Notebook2:使用FPGA实现硬件加速</strong>
在该示例应用中,我们将会使用相同的SciPy技术来分析记录有两种鸟类声音的音频,并使用滤波器来分离其中一种声音。但是,这一次我们将会把软件的FFT和FIR函数搬移到FPGA端实现硬件加速,同时使用PYNQ控制。
使用LogiCoreFIR Compiler和LogiCireFFT构建硬件加速逻辑。
<center><img src="http://xilinx.eetrend.com/files/2021-05/wen_zhang_/100113158-207474-tu6…; alt=""></center>
<p align="center"><strong>硬件设计</strong></p>
使用AXI DMA实现PL端与PS端的Memory共享。
使用Python为FPGA硬件构建控制函数,通过DMA传输数据和配置信息,实现对FFT和FIR IP核的on-the-fly重配置以及功能实现。
更多详细信息请点击:https://github.com/Xilinx/DSP-PYNQ