Preparing a custom version of MicroPython with TensorFlow

Introduction

For work with ML algorithms I use the esp32-cam module because it is small, cheap and has a camera installed on it. To get it ready for ML models we must first create a custom version of MicroPython. Michael O'Cleirigh's github repository (https://github.com/mocleiri/tensorflow-micropython-examples) contains all the tools to do just this.

Here are the steps to build this custom microPython version:

  • Download the repository:
    git clone https://github.com/mocleiri/tensorflow-micropython-examples tflite-micro-micropython
  • The steps to build the firmware can be found in tflite-micro-micropython/.github/workflows/build_esp32.yml
    In my case the Espressif development environment espidf has already been downloaded and set up earlier. I use espidf version 4.3.1, the latest stable version at time of writing.

    Activate the virtual Python environment needed for espidf
    Make sure that the modules Pillow and Wave have been installed on this virtual environment. If not, install them with pip:
    • pip3 install Pillow
    • pip3 install Wave
  • Setup the sub-modules needed for tflm:
    • cd tflite-micro-micropython
    • git submodule init
    • git submodule update --recursive
  • Setup the sub-modules for the ESP32 port of MicroPython
    • cd micropython
    • git submodule update --init lib/axtls
    • git update --init lib/berkeley-db-1.xx
  • Get the esp32-camera driver from Espressif
    • cd ..
    • cd tflm-esp-kernels
    • git submodule update --init examples/person_detection/esp32-camera
  • Build the MicroPython cross compiler
    • cd ../micropython/mpy_cross
    • make
  • cd .. (the micropython folder of tflite-micro-micropython)
    • git apply ../boards/esp32/MICROLITE_SPIRAM_CAM/micropython.patch
      !MicroPython allocates the full SPIRAM installed on the esp32-cam module for its heap. However, the esp32-camera driver needs some of the SPIRAM for its image buffer. The patch modifies main.c in micropython/ports/esp32 such that part of the SPIRAM is kept free for the camera driver.
    • idf.py clean build (this builds the MicroPython firmware)
  • flash the custom MicroPython interpreter
    • idf.py flash
Once you have flashed the custom interpreter you can check if all the Python modules are available:

tflite_micropython.png

Since all the necessary drivers and libraries are now available in MicroPython we can go ahead and try the TensorFlow Lite Micro examples.

-- Uli Raich - 2022-01-31

Comments

Topic attachments
I Attachment History Action Size Date Who Comment
PNGpng tflite_micropython.png r1 manage 22.3 K 2022-01-31 - 13:25 UliRaich  
Edit | Attach | Watch | Print version | History: r9 | r4 < r3 < r2 < r1 | Backlinks | Raw View | Raw edit | More topic actions...
Topic revision: r2 - 2022-01-31 - UliRaich
 
  • Edit
  • Attach
This site is powered by the TWiki collaboration platform Powered by PerlCopyright © 2008-2025 by the contributing authors. All material on this collaboration platform is the property of the contributing authors.
Ideas, requests, problems regarding TWiki? Send feedback