Configure a GPIO-Controlled Motor
The gpio
model supports DC motors (both brushed and brushless).
Note
Encoders can be configured 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 a board. 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 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>",
"en_low": "<int>"
},
"board": "<your-board-name>",
"max_rpm": <int>,
"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",
"max_rpm": 500
},
"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. |
max_rpm | int | Required | This is an estimate of the maximum RPM the motor will run at with full power under no load. The GoFor method calculates how much power to send to the motor as a percentage of max_rpm . If unknown, you can set it to 100, which will mean that giving 40 as the rpm argument to GoFor or GoTo will set it to 40% speed. Not required or available for encoded gpio motors. |
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/DIR: Use this if one of your motor driver’s pins (labeled “PWM”) takes a pulse width modulation (PWM) signal to the driver to control speed while another pin labeled “DIR” takes a high or low signal to control the direction.
- Configure
pwm
anddir
.
- Configure
- In1/In2: Use this if your motor driver has pins labeled “IN1” and “IN2” or “A” and “B,” or similar.
One digital signal set to a high voltage and another set to a low voltage turns the motor in one direction and vice versa.
Speed is controlled with PWM through one or both pins.
- Configure
a
andb
.
- Configure
- In1/In2 and PWM: Use this if your motor driver uses three pins: In1 (A) and In2 (B) to control direction and a separate PWM pin to control speed.
- Configure
a
,b
, andpwm
.
- Configure
Inside the pins
struct you need to configure two or three of the following, in addition to "en_high"
or "en_low"
, 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 for some drivers | Board pin number this motor driver’s “PWM” pin is wired to. |
en_high / en_low | string | Optional | Some drivers have optional enable pins that enable or disable the driver chip. If your chip requires a high signal to be enabled, add en_high with the pin number to this struct. If you need a low signal use en_low . |
Important
Only two or three of these pins
attributes are required, depending on your motor driver.
If your motor drivers uses only In1 and In2, and not a third PWM pin, do not configure a pwm
pin.
Wiring examples
Tip
The following are just examples and do not apply to all motor setups. Refer to your motor and motor driver data sheets for information on power requirements and how to properly wire your motor.
Brushed DC motor
Taking a 12V brushed DC motor controlled by a DRV8256E Single Brushed DC Motor Driver Carrier wired to a Raspberry Pi as an example, the wiring diagram would look like this:
The signal wires in the diagram run from two GPIO pins on the Pi to the DIR and PWM pins on the motor driver. Refer to a Raspberry Pi pinout schematic to locate generic GPIO pins and determine their pin numbers for configuration.
Brushless DC motor
Brushless DC motor drivers work in much the same way as brushed DC motor drivers. They typically require a PWM/DIR input or an A/B (In1/In2) and PWM input to set the motor power and direction. The key difference between a brushed and brushless motor driver is on the motor output side. Brushless motors typically have three power connections (commonly referred to as A, B and C; or sometimes Phase 1, 2 and 3) and 3 sensor connections (commonly referred to as Hall A, Hall B, and Hall C) running between the motor and driver.
The configuration file of a BLDC motor with Viam is the same as that of a brushed motor. Only the output side of the driver board is different in that more wires connect the driver to the motor.
Test the motor
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.
Troubleshooting
If your motor is not working as expected, follow these steps:
- Check your machine logs on the LOGS tab to check for errors.
- Review this motor model’s documentation to ensure you have configured all required attributes.
- Check that all wires are securely attached to the correct pins.
- Click on the TEST panel on the CONFIGURE or CONTROL tab and test if you can use the motor there.
If none of these steps work, reach out to us on the Community Discord and we will be happy to help.
Next steps
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!