Configure a wheeled-odometry movement sensor
Configure a wheeled-odometry
movement sensor to implement wheeled odometry on your robot.
Wheeled odometry is the estimation of the rate of change of position, orientation, linear velocity, and angular velocity using the dimensions of a base, calculated by measuring the movement of the motors through encoders.
Because of this method of estimation, you don’t have to have a specific piece of movement sensor hardware to implement wheeled-odometry
on your robot.
This model uses encoders from position reporting motors to get an odometry estimate of a wheeled base as it moves.
With a configured wheeled-odometry
movement sensor, your robot calculates an estimation of the position, orientation, linear velocity, and angular velocity of the wheeled base each time time_interval_msec
elapses during a session.
You can access these readings through the movement sensor API.
For the best accuracy with odometry calculations, it is recommended you configure a time interval of less than 1000
milliseconds.
After configuring a wheeled-odometry
movement sensor, you can operate your base with Viam’s built-in services like the navigation service.
Set-up requirements
To prepare your robot, attach encoders to each of the position-reporting motors on your base to measure their rotation.
- Select motors that can report their own position, like an encoded
roboclaw
orgpio
motors with encoders, or theodrive
module. You can access this property of a configured motor through the motor API’sGetProperties()
. - Configure your rover as a wheeled base component.
Make sure to configure the base width and circumference, as these measurements as a property of the base are vital for accurate odometry estimations by your movement sensor.
This movement sensor accesses these values through the base’s
GetProperties()
API method. - Configure each of the position-reporting motors as motor components.
- Then, proceed to configure a
wheeled-odometry
movement sensor with the name of each of the motor components.
Configuration
Navigate to the Config tab of your robot’s page in the Viam app. Select Raw JSON mode. Copy and paste the following:
"name" : "<your-wheeledodometry-movement-sensor-name>",
"type" : "movement_sensor",
"model" : "wheeled-odometry",
"attributes" : {
"base" : "<your-base-name>",
"left_motors" : ["<your-base-left-motor-name-1>", "<your-base-left-motor-name-2>"],
"right_motors" : ["<your-base-right-motor-name-1", "your-base-right-motor-name-2>"],
"time-interval-msec": <number>
}
Fill in and edit the attributes as applicable.
Attributes
The following attributes are available for wheeled-odometry
movement sensors:
Name | Type | Inclusion | Description |
---|---|---|---|
base | string | Required | The name of the base to which the encoders making up this movement sensor are wired. |
left_motors | object | Required | A list containing the name of each of the bases’ left position-reporting motors. |
right_motors | object | Required | A list containing the name of each of the bases’ right position-reporting motors. |
time_interval_msec | number | Optional | The time in milliseconds between each wheeled odometry calculation. Default: 500.0 |
Test the movement sensor
After you configure your movement sensor, navigate to the Control tab and select the dedicated movement sensor dropdown panel. This panel presents the data collected by the movement sensor. The sections in the panel include the position, orientation, angular velocity, linear velocity, and linear acceleration.

Have questions, or want to meet other people working on robots? Join our Community Discord.
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!