/Micropython-I2C-GNSS

MicroPython I2C library and example for Gravity: GNSS module

Primary LanguagePython

MicroPython I2C library and example for Gravity: GNSS Receiver Module

This repository contains the MicroPython I2C library for the Gravity: GNSS Receiver Module from DFRobot, as well as a very simple example of how to use it. The original repository from DFRobot is located here (for Arduino and Raspberry Pi).

Why this repository?

The original version of DFRobot uses Python serial (UART) and Python SMBus (I2C), which are not compatible with MicroPython. Also, I was not so happy with the Python code style/quality. That's why I created this version.

Prerequisite

  • Gravity: GNSS Receiver Module
  • ESP32 (MicroPython compatible device)
  • MicroPython firmware installed (min. 1.20.0.*)
  • USB cable (for connection between ESP32 and sensor)
  • latest VCP driver installed

GNSS.jpg

Installation

Clone this repository to your local computer.

# clone repository
$ git clone https://github.com/Lupin3000/Micropython-I2C-GNSS.git

# change into local repository folder
$ cd Micropython-I2C-GNSS/

You can optionally install other helpful Python packages.

  • esptool (to flash the MicroPython firmware to the ESP32)
  • rshell (to establish a serial connection between the local computer and the ESP32 and to transfer data)
  • micropython-esp32-stubs (to facilitate local development, for example: code completion)
# install python packages (optional)
$ pip install -r requirements.txt

Connect the sensor to the ESP32. Make sure that you have set the communication mode on the sensor to I2C and use the correct connections (ESP GPIO's/Sensor interface)! Only then connect the ESP32 to your local computer via USB.

In the example main.py, the GPIOs pins 21 (SDA) and 22 (SCL) are used. However, you can adapt these to your needs at any time.

Then start the serial connection and load the example and the library onto the ESP32 device.

# start rshell connection
$ rshell -p /dev/cu.usbserial-0001

# upload files and folder
/YOUR/LOCAL/PATH> cp main.py /pyboard/
/YOUR/LOCAL/PATH> cp -r lib/ /pyboard/

The example device/path /dev/cu.usbserial-0001 could be different for you! Please adapt before your execute the commands!

Usage

# start the Python REPL
/YOUR/LOCAL/PATH> repl

Now press the keys CTRL + d on your local device, to trigger the soft-reset of the ESP32. If there are no errors, you should see the GNSS values in the terminal after a very short time.

Entering REPL. Use Control-X to exit.
>
MicroPython v1.20.0 on 2023-04-26; ESP32 module with ESP32
Type "help()" for more information.
>>> 
>>> 
MPY: soft reboot

If you found few satellites, the output looks similar to this example:

---
GNSS mode: 1
Satellite number: 7
Date: 2024-02-11 Time: 09:43:23
latitude degree: 47.48249° latitude direction: E
longitude degree: 8.767172° longitude direction: N
altitude: 93.09 meters
speed over ground: 0.0 N
course over ground: 207.37 T

Additional information: