Using the Pulse Width Modulation (PWM) with microPython.
Last updated
Last updated
In this tutorial, we will be using the PWM module from the microPython firmware to control an external LED. This will allow us to control the brightness of the LED.
nodeMCU dev kit board
220 ohm resistor
Breadboard
5mm LED
Jumper wires
The first thing you will need to do is setup the circuit as is shown in the diagram below.
Firstly, on the breadboard insert the LED as shown above.
Using a jumper wire connect one end to the long leg of the LED, then connect the other end to the pin D2 on the nodeMCU board.
Connect the one end of the 220 ohm resistor to the short leg of the LED as shown above. The other end of the resistor is connected to the GND pin on the nodeMCU board.
This is the code that you will write on the editor of Thonny IDE and then upload it to the nodeMCU dev kit board.
In this line of code, we get the Pin and PWM class from the built-in module called machine. This is to create the PWM pin.
In this section of the code, we are creating a PWM object that uses the pin that is connected to, the signal frequency, and the duty cycle as its parameters.
The duty cycle can be a value between 0 and 1023. 1023 is the same as 100% duty cycle, which is translated to full brightness (of led). 0 is the same as 0% duty cycle which is unlit led.
The frequency can be a value between 0 and 78125. A frequency of 5000 Hz can be used to control the brightness.
Here we use a while loop to set the duty cycle so that we don't need to pass the duty cycle parameter. if we don't set the duty cycle when instantiating the PWM object, it will be 0 by default.
To set the duty cycle use the duty() method on the PWM object.
Inside the while loop, we use a for loop that increases the duty cycle by 1 in each loop with an interval of 5 ms between each change.
The range() function used above has the following syntax:
start: a number which specifies at which position to start.
stop: a number which specifies at which position we want to stop, excluding that value.