- learn what a drive base is and how it can be to command your robot
- set up a drive base on your robot
- make the robot drive forever
- make the robot drive for a fixed distance
- make the robot turn a set nubmer of degrees
- make the robot drive in a set arc
- learn to calibrate the robot so the distance measurements are accurate
:class: important
To explore all Pybricks' features check the **[Pybricks documentaion](https://docs.pybricks.com/en/stable/index.html)**. This can also be seen in the right-hand panel of the Pybricks IDE.
Pybricks uses Drivebase
to combine two motors so you can issue command to them as a single unit. You will then be able to issue commands to your robot, rather than individual motors, getting it to move a specific distance, or turn a specific angle.
- Positive distances, radii, or drive speeds mean driving forward. Negative means backward.
- Positive angles and turn rates mean turning right. Negative means left. So when viewed from the top, positive means clockwise and negative means counter-clockwise.
:class: important
It is important to note the difference between Motor angels and Drivebase angels.
- Motor angles indicate the amount of rotation of the axel of a motor, eg. 180° will turn a wheel half a rotation.
- Drivebase angles indicate how far from straight the robot will turn, eg. 180° will make the robot face backwards.
To start using the drive base you first need to create a left_motor
and a right_motor
in the same way you did in the Motors tutorial.
You then need to create a drive base by calling
DriveBase(left_motor, right_motor, wheel_diameter, axle_track)
.
- `left_motor → the name you gave the left motor
- right_motor → the name you gave the right motor
- wheel_diameter → the diameter of the robot's wheel in millimetres (for your robot use
56
) - axle_track → the distance between the wheels in millimetres (for your robot use
80
)
Go ahead and create your first drive base:
- Create a new file called
drive_base.py
- Type the code below into the file
- Predict what you think will happen.
- Run your code
:linenos:
Did you predict that your robot would do nothing? Actually it didn't do nothing, what it did do was initialise both motors and combined them to make a drive base called my_robot
. The reason your robot did nothing was that you didn't give it any commands. Let's fix that by learning some commands you can use.
:class: note
After creating a DriveBase object, you can still use its two motors individually. If you start one motor, the other motor will automatically stop. Likewise, if a motor is already running and you make the drive base move, the original maneuver is cancelled and the drive base will take over.
Pybricks has two function used to implement continuous driving of the drive base:
drive(speed, turn_rate)
→ Starts driving at the specified speed and turn rate.stop()
→ Stops the robot by letting the motors spin freely.
Use the code below to see these functions in use:
- Create a new file called
drive_base_forever.py
- Type the code below into the file
- Predict what you think will happen.
- Run your code
:linenos:
- **lines 3 - 7** → imports all the Pybricks command for use with your robot
- **line 10** → initialised the hub
- **lines 13 - 15** → initialises the drive base
- **line 18** → creates a infinite loop
- **line 19** → sets status light to white
- **line 20** → sets drive base to drive straight
- **line 21** → waits half a second
- **line 23** → sets status light to red
- **line 24** → sets drive base to drive a left curve
- **line 25** → waits half a second
- **line 27** → stops the drive base
- **line 28** → waits a second
- **line 30** → sets status light to white
- **line 31** → sets drive base to drive straight
- **line 32** → waits half a second
- **line 34** → sets status light to green
- **line 35** → sets drive base to drive a right curve
- **line 36** → waits half a second
- **line 38** → stops the drive base
- **line 39** → waits a second
:class: caution
- what is lowest turning value to provide the sharpest turn?
- can you make the robot drive backwards?
- what happens if you comment out all the `wait()` commands?
There are three different ways that you can program you drive base to drive a fixed amount:
straight(distance, then=Stop.HOLD, wait=True)
→ Drives straight for a given distance (mm) and then stops.turn(angle, then=Stop.HOLD, wait=True)
→ Turns in place by a given angle and then stops.curve(radius, angle, then=Stop.HOLD, wait=True)
→ Drives an arc along a circle of a given radius (mm), by a given angle.
There is also a function to change the setting used by the three functions above:
settings(straight_speed, straight_acceleration, turn_rate, turn_acceleration)
→ Configures the speed and acceleration used bystraight()
,turn()
, andcurve()
settings()
→ If you give no arguments, this returns the current values as a tuple.
Use the code below to see these functions in use:
- Create a new file called
drive_base_fixed.py
- Type the code below into the file
- Predict what you think will happen.
- Run your code
:linenos:
- **lines 3 - 7** → imports all the Pybricks command for use with your robot
- **line 10** → initialised the hub
- **lines 13 - 15** → initialises the drive base
- **line 18** → creates a infinite loop
- **line 19** → sets status light to yellow
- **line 20** → configures the drive base for:
- straight speed `200` mm/s
- straight_acceleration `200` mm/s<sup>2</sup>
- turn rate `200` deg/s
- turn acceleration `200` deg/s<sup>2</sup>
- **line 21** → prints current drive base configuration
- **line 22** → drives the robot strait for 200mm
- **line 23** → turns the robot in place for 90°
- **line 24** → drives the robot in a 180° arc with a radius of 100mm
- **line 19** → sets status light to magenta
- **line 20** → configures the drive base for:
- straight speed `500` mm/s
- straight_acceleration `500` mm/s<sup>2</sup>
- turn rate `500` deg/s
- turn acceleration `500` deg/s<sup>2</sup>
- **line 21** → prints current drive base configuration
- **line 22** → drives the robot strait for 200mm
- **line 23** → turns the robot in place for 90°
- **line 24** → drives the robot in a 180° arc with a radius of 100mm
:class: caution
- what is the fastest effective values for straight speed, straight_acceleration, turn rate and turn acceleration?
- what is the slowest effective values for straight speed, straight_acceleration, turn rate and turn acceleration?
- what happens when you use negative values for straight speed, straight_acceleration, turn rate and turn acceleration?
The values you entered for wheel_diameter and the axle_track were estimates measured with a ruler.
In practice, most wheels compress slightly under the weight of the robot. To verify, make your robot drive 1000 mm using my_robot.straight(1000)
and measure how far it really travelled.
Change the DriveBase
values as follows:
- robot doesn't drive far enough → decrease the
wheel_diameter
value slightly - robot drives too far → increase the
wheel_diameter
value slightly.
Motor shafts and axles bend slightly under the load of the robot, causing the ground contact point of the wheels to be closer to the midpoint of your robot. To verify, make your robot turn 720 degrees using my_robot.turn(720) and check that it is back in the same place.
Change the DriveBase
values as follows:
- robot doesn't turns far enough → increase the
axle_track
value slightly. - robot turns too far → decrease the
axle_track
value slightly.
When making these adjustments, always adjust the wheel_diameter first, as done above. Be sure to test both turning and driving straight after you are done.
Use the code below to calibrate your robot:
- press the left button to measure the wheel diameter
- press the right button to measure the axel track
:linenos:
:class: important
Keep a record of your calibrated value for the wheel diameter and the axel track.
These are the values you should use for all future robots.