Knowledge Base

The AB Electronics UK Knowledge Base provides support solutions, tutorials and troubleshooting guides.

Knowledge Base

ADC Pi MicroPython Library

ADC Pi MicroPython Library code and demos

Created 29/07/2024 | Last Updated: 30/07/2024

MicroPython Library to use the ADC Pi development board with the Raspberry Pi Pico development board.

The example python files can be found in /ABElectronics_MicroPython_Libraries/ADCPi/demos

Downloading and Installing the library

To download to your Raspberry Pi type in the terminal:

git clone https://github.com/abelectronicsuk/ABElectronics_MicroPython_Libraries.git

To install the MicroPython Library use the Thonny Python IDE from thonny.

Create a file for your chosen board and copy the contents of the python file into that board's directory. For example for the ADC Pi create a new file in Thonny called ADCPi.py and copy contents from ADCPi.py into the new file and save it onto the Raspberry Pi Pico board.

Create a second file where your main program will reside and import the board library at the top of the program.

from ADCPi import ADCPi

Run with "Run Current Command" or F5 in Thonny.


Pins used on the Raspberry Pi Pico:

The ADC Pi library uses the following pins on the Raspberry Pi Pico board.

Pico Pin Pico GPIO Function Pi Pin Pi GPIO
26 20 I2C SDA 3 GPIO 2
27 21 I2C SCL 5 GPIO 3

You will also need to connect 3.3V, 5V and GND on the ADC Pi GPIO header.


Wiring Diagram:

Connecting the ADC Pi to a Pico!


Classes:

ADCPi(address, address2, bus)

Parameters:
address: I2C address for channels 1 to 4, defaults to 0x68
address2: I2C address for channels 5 to 8, defaults to 0x69
rate: bit rate, values can be 12, 14, 16 or 18. Defaults to 18
sda (optional): I2C SDA pin number. If no value is set the class will use pin 20.
scl (optional): I2C SCL pin number. If no value is set the class will use pin 21.


Functions:

read_voltage(channel) 

Read the voltage from the selected channel
Parameters: channel - 1 to 8
Returns: number as a float between 0 and 5.0


read_raw(channel) 

Read the raw int value from the selected channel
Parameters: channel - 1 to 8
Returns: number as an int


set_pga(gain)

Set the gain of the PGA on the chip
Parameters: gain - 1, 2, 4, 8
Returns: null


setBitRate(rate)

Set the sample bit rate of the ADC
Parameters: rate - 12, 14, 16, 18
Returns: null
12 = 12 bit (240SPS max)
14 = 14 bit (60SPS max)
16 = 16 bit (15SPS max)
18 = 18 bit (3.75SPS max)


set_conversion_mode(mode)

Set the conversion mode for the ADC
Parameters: mode - 0 = One-shot conversion, 1 = Continuous conversion
Returns: null

Usage

To use the ADC Pi library in your code you must first import the library:

from ADCPi import ADCPi

Next, you must create and initialise an adc object from the ADCPi class:

adc = ADCPi(0x68, 0x69, 18)

The first two arguments are the I2C addresses of the ADC chips. The values shown are the default addresses of the ADC board.

The third argument is the sample bit rate you want to use on the ADC chips. The sample rate can be 12, 14, 16 or 18

You can now read the voltage from channel 1 with:

x = adc.read_voltage(1)

Home

Shop

Learn

Forum

FAQ

Contact

0 item

Your cart is empty

Please browse our shop to order from the wide range of Raspberry Pi boards and accessories.

Subtotal:£0.00
View Basket Continue to Checkout