Previous
fake
The gpio
model supports DC motors (both brushed and brushless).
You can configure encoders to work with gpio
motors.
Find more information in the encoded motor documentation.
To configure a DC motor as a component of your machine, first make sure the motor is wired to a suitable motor driver, which is in turn wired to the microcontroller. Connect the system to power if you want to test it while configuring. Configure the board to which the motor driver is wired. Then configure the motor: Then add your motor:
Navigate to the CONFIGURE tab of your machine’s page in the Viam app.
Click the + icon next to your machine part in the left-hand menu and select Component.
Select the motor
type, then select the gpio
model.
Enter a name or use the suggested name for your motor and click Create.
Edit and fill in the attributes as applicable.
{
"components": [
{
"name": "<your-board-name>",
"model": "<your-board-model>",
"type": "board",
"namespace": "rdk",
"attributes": {},
"depends_on": [],
},
{
"name": "<your-motor-name>",
"model": "gpio",
"type": "motor",
"namespace": "rdk",
"attributes": {
"pins": {
"dir": "<int>",
"pwm": "<int>"
},
"board": "<your-board-name>",
"min_power_pct": <float>,
"max_power_pct": <float>,
"pwm_freq": <float>,
"dir_flip": <float>
},
"depends_on": []
}
]
}
An example configuration for a gpio
motor:
{
"components": [
{
"name": "local",
"model": "pi",
"type": "board",
"namespace": "rdk",
"attributes": {},
"depends_on": []
},
{
"name": "example-gpio",
"model": "gpio",
"type": "motor",
"namespace": "rdk",
"attributes": {
"pins": {
"dir": "36",
"pwm": "32"
},
"board": "local"
},
"depends_on": []
}
]
}
The following attributes are available for gpio
motors:
Name | Type | Required? | Description |
---|---|---|---|
board | string | Required | name of the board to which the motor driver is wired. |
pins | object | Required | A structure that holds pin configuration information; see below. |
min_power_pct | float | Optional | Sets a limit on minimum power percentage sent to the motor. Default: 0.0 |
max_power_pct | float | Optional | Range is 0.06 to 1.0; sets a limit on maximum power percentage sent to the motor. Default: 1.0 |
pwm_freq | int | Optional | Sets the PWM pulse frequency in Hz. Many motors operate optimally in the kHz range. Default: 800 |
dir_flip | bool | Optional | Flips the direction of “forward” versus “backward” rotation. Default: false |
encoder | string | Optional | The name of an encoder attached to this motor. See encoded motor. |
Refer to your motor and motor driver data sheets for specifics.
pins
There are three common ways for your computer to communicate with a brushed DC motor driver chip. Your motor driver data sheet will specify which one to use.
pwm
and dir
.a
and b
.a
, b
, and pwm
.Inside the pins
struct you need to configure two or three of the following depending on your motor driver:
Name | Type | Required? | Description |
---|---|---|---|
a | string | Required for some drivers | Board pin number this motor driver’s “IN1” or “A” pin is wired to. |
b | string | Required for some drivers | Board pin number this motor driver’s “IN2” or “B” pin is wired to. |
dir | string | Required for some drivers | Board pin number this motor driver’s direction (“DIR”) pin is wired to. |
pwm | string | Required | Board pin number this motor driver’s “PWM” pin is wired to. |
esp32
boardsEach gpio
motor uses a PWM pin at 10000 Hz PWM frequency.
This leaves you with three remaining PWM frequencies for use on an esp32
.
If the frequency of another PWM signal is unimportant, it can also be set to 10000 Hz.
See PWM signals on esp32
pins for more information.
Once your motor is configured and connected, open the motor’s TEST panel on the CONFIGURE or CONTROL tabs. Use the buttons to try turning your motor forwards or backwards at different power levels and check whether it moves as expected.
If the motor does not appear on the TEST panel, or if you notice unexpected behavior, check your machine’s LOGS tab for errors, and review the configuration.
If your motor is not working as expected, follow these steps:
If none of these steps work, reach out to us on the Community Discord and we will be happy to help.
For more configuration and usage info, see:
Was this page helpful?
Glad to hear it! If you have any other feedback please let us know:
We're sorry about that. To help us improve, please tell us what we can do better:
Thank you!