ENG-CANSAT-PICO-HowTo

De MCHobby - Wiki
Sauter à la navigation Sauter à la recherche

MicroPython How To

This section of the tutoriel contains small portion of code explaining how to use digital pins, analog pins, buses and all the fundamentals to control the board with Python code.

Everything you learned about python language like variables, loops, conditionals, object programming, ... does applies to MicroPython.

A large part of standard Python libraries have been ported to MicroPython (partially or completely). Keep in mind that MicroControler doesn't have as much power and as much memory than a regular computer. So choice has been made: no gregorian calandar, no numpy (it exists some port anyway), no TKinter.

Print and Waits

This first example how to output text with print() and wait a moment with sleep() .

Everything you will print() will be sent to REPL (so over the USB-Serial line) and being visible in Thonny.

from time import sleep, sleep_ms

for x in range( 10 ): # 0..9
    print( "Value %i" % x )
    sleep( 0.5 ) # half second

You can also sleep for milliseconds with sleep_ms(x)

Control an output

The onboard LED is tied to the GPIO 25. Here how to control it.

from machine import Pin
led = Pin(25, Pin.OUT)
led.value(1) # Switch on the LED
led.value(0) # Switch off the LED

This will work the same with any GPIO pins.

In this next example, a RED is LED wired to GP20 could be controled by modifying only one line of code.

ENG-CANSAT-FEATHER-PICO-HowTo-22.png

from machine import Pin
led = Pin(20, Pin.OUT)
led.value(1) # Switch on the LED
led.value(0) # Switch off the LED

Tips & tricks:

  • LEDs are polarized component, they work only if wired the right way.
  • The longer LED pin is the "+" sign.
  • Don't use blue LED, their forward voltage is too close from 3V to make them lightning.
  • This assembly "source" the required current to the LED.

Input Reading

The following code will read the state of the GP15 configured as input pin.

ENG-CANSAT-FEATHER-PICO-HowTo-23.png

>>> from machine import Pin
>>> p = Pin( 15, Pin.IN )
>>> p.value()
0                <--- Pin tied to GND
>>> p.value()
1                <--- Pin tied to 3.3V

The logical state of a floating pin is unpredictable, it may be High, it may be Low... we don't know.

To avoids that issue, the best is to use a pull-up resistor. Many microcontroler have internal pull-up resistor (it just needs to be activated).

Input Reading with Pull-Up

The pico can activates a Pull-up resistor on any of its input pins.

When the Pin is tied to ground then the input is Low (0) otherwise, the pull-up resistor will drive back the pin voltage to 3.3V.

ENG-CANSAT-FEATHER-PICO-HowTo-24.png

The following code will read the state of the GP15 configured as input pin + pull-up.

>>> from machine import Pin
>>> p = Pin( 15, Pin.IN, PIN.PULL_UP )
>>> p.value()
0                <--- Pin tied to GND
>>> p.value()
1                <--- Pin tied to 3.3V or floating.

Analog Reading

Analog pins are able to read voltage between 0 and 3.3V.

Lets read some voltage from the ADC1 (attached to GPIO 27).

The value is read on the ADC via the common read_u16() method.

That method returns a 16 bits value, so a number between 0 and 65535.

ENG-CANSAT-FEATHER-PICO-HowTo-25.png

from machine import Pin, ADC
p = Pin( 27 )
analog = ADC( p )
#
# Read the ADC value
value = analog.read_u16()
print( 'value: %i' % value )
# 
# Transform into volts
volts = 3.3*value/65535
print( 'Volts: %f' % volts )

This may produce the following output in the REPL.

value: 8706
Volts: 0.438389

PWM Output

PWM stand for Pulse Width Modulation.

PWM is a method for reducing the average power delivered by an electrical signal. The average voltage that feds the load is controlled by fastly switching on & off the power between supply and load.

ENG-CANSAT-FEATHER-PICO-pwm-01.png

The average voltage (average power) of PWM signal depend on the duty cycle: Vavg = 3.3V * Th / T

ENG-CANSAT-FEATHER-PICO-pwm-02.png

Obviously, a 0% duty cyle is equivalent to a LOW signal whereas a 100% duty cycle is a HIGH signal.

In the following example, we will use PWM to dim the light on the onbloard LED.

The onboard LED is tied to the GPIO 25 (and PWM will work there as with other GPIOs).

Thank to PWM we can effectively control the LED luminosity (very low duty cycle will dim the light while highest duty cycle will make it brightest).

from machine import Pin, PWM
pwm25 = PWM( Pin(25) )
pwm.duty_u16( 65534 ) # 100%
pwm.duty_u16( 32767 ) # 50%
pwm.duty_u16( 0 ) # 0% = LOW

Notes:

  • PWM class must have a Pin instance as argument.
  • duty_u16() must have an 16 bits integer value (0 to 65534) for the duty cycle.
  • The effective Max duty_u16() value is 65534. A regression bug would make the 65535 (real max of 16 bits) equivalent to 0 !?!?!... this Phenix bug is coming back again and again.

Hardware buses

I2C Bus

An I2C bus is a very popular serial bus in electronic to connect sensors and electronics to a microcontroler.

Maybe not the fastest bus, this bus is easy to wire and to manage and requires only 2 wires:

  • SDA: Serial Data
  • SCL: Serial Clock

The I2C protocol use an address (0..127) to contact the target board with request and waiting for response. For sure each sensor boards must have an unique address on the I2C. On I2C implementation, the microcontroler do always keeps the control over the I2C communication.

640px

The Pico do have several I2C bus as [[ |mentionned on the PinOut diagram]]

from machine import Pin
x
x
x
x

UART Bus

The onboard LED is tied to the GPIO 25. Here how to control it.

from machine import Pin
x
x
x
x


SPI Bus

The onboard LED is tied to the GPIO 25. Here how to control it.

from machine import Pin
x
x
x
x

Additional tutorials

Anyway, the followings are also goods and complete references.

Getting Started

Tlogo-pico-get-started.png

Get Started with MicroPython on Raspberry Pi Pico.

Pico Python SDK

Tlogo-pico-python-sdk2.png

Advanced documentation for MicroPython environment on RP2040.

Pico debugging

Tlogo-pico-python-sdk.jpg

Debugging using another Pico (PicoProbe)

Resetting Flash

Tlogo-pico-python-sdk.jpg

How to reflash MicroPython on the Pico

 



Written by Meurisse D. for MCHobby


MCHobby investit du temps et de l'argent dans la réalisation de traduction et/ou documentation. C'est un travail long et fastidieux réalisé dans l'esprit Open-Source... donc gratuit et librement accessible.
SI vous aimez nos traductions et documentations ALORS aidez nous à en produire plus en achetant vos produits chez MCHobby.