This project involves using the PYNQ Z2 board to play with audio and use peripherals such as the OLED display to show information about the audio files being played.
A full copy of all files is included within the GitHub page, a full breakdown of these is listed as follows:
Images - The folder containing all of the pictures in the Notebook
Overlays - The folder containing the custom overlays used on the board
Audio.ipynb - The main Jupyter Notebook file containing all of the code
Highwaytohell.wav - The song file that is used with all functions
README.md - This file
init.py - The TinyTag initiation Python file
main.py - The TinyTag launch Python file
fspan.wav - The spanning frequency sound used for testing
test.wav - The filter test - clean
test1.wav - The first filter test - noisy
tinytag.py - The External TinyTag Library
Pmod - Allows the use of external peripherals
Grove_OLED - Allows the OLED to be used with predefined commands
Ipywidgets - Allows widgets to display in the Jupyter Notebook
Wave - Allows to read and write WAV files in Python
Numpy - Allows a specific type of array to be used with in the program
Matplotlib - Allows MATLAB figures and graph to be created and used
Scipy - Used on conversion from an array back into a WAV file
Time - Allows the use of timers – used in execution time
Xlnk - Allows the use of Python buffers
IPython.display - Lets audio files be played in the notebook through interactions
TinyTag - Extracts metadata from provided WAV or MP3 files.
The OLED is set up to be able to display any alphanumeric character – as shown in intro.
Takes an input and an output connection through the board and can control the individual channels of left and rights gain values to increase or decrease the volume.
Reads a WAV file into an array to allow it to be filtered in a later stage and to be displayed in Amplitude waveforms and frequency spectrums
With the array assembled of the WAV file, it is then plotted using MATLAB commands to make waveforms for the channels in the sound as shown below.
With the array assembled of the WAV file, it is then plotted using MATLAB commands and Fourier transform commands to make waveforms for the frequency spectrum in each of the channels for the sound as shown below.
Lights up and is in progress to represent individual volume channels
Records up to a 60 second audio clip and plays it back to the user. Also allows a widget to be displayed to the user so the sound can be played out through the board.
Returns the parameters of the audio file that is placed in the path. Then shows these parameters on both OLED displays to allow more information to be shown to the user. An example is shown in the following two images.
There are three overlays that are used within the project. These are the base overlay that is included in the board. An overlay that gives the ability to stream audio directly through the board and an overlay that allows the PS and PL regions of the board to be connected and a sound filtered through.
The overlay was designed in System Generator and exported to Vivado. It is shown below. The following waveforms show the outputs of the filter in the Jupyter Notebook, the first one being in software and the second using the hardware.
There are minute differences between the two waveforms. The execution times are vastly different. This can be further seen by opening the Jupyter Notebook.
[1] TinyTag https://pypi.org/project/tinytag/
[2] FIR Filter https://www.fpgadeveloper.com/2018/03/how-to-accelerate-a-python-function-with-pynq.html
[3] Beautiful Soup https://www.crummy.com/software/BeautifulSoup/
[4] PyLyrics https://pypi.org/project/PyLyrics/
[5] LyricMaster https://pypi.org/project/lyricsmaster/
[6] LyricWikia https://pypi.org/project/lyricwikia/