Skip to content

Latest commit

 

History

History
78 lines (64 loc) · 4.45 KB

06_motor_input.md

File metadata and controls

78 lines (64 loc) · 4.45 KB

Motors as sensors

- learn to read the motor speed
- learn to read the motor angle
- learn to reset the motor angle
- learn to read the torque applied to the motor
- learn to check if the motor has stalled
: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.

In the tutorial on motors it was explained that the motors on the robot have encoders that can read the rotation of the motor axel. This encoder also means that motors can be used as sensors to provide input to the robot.

Motor Measurement Functions

You can get measurements from the motors using the following Pybrick functions:

Pybricks also provides a configuration function:

Motor Measurement Example

We will use the code below to see these functions work:

  1. Create a new file called motor_inputs.py
  2. Type the code below into the file
  3. Predict what you think will happen.
  4. When running your code you will need to interact with the robot:
    • to get a speed reading of the wheel, press the left button
    • to get the wheel to return to it's starting point, simultaneously press the left button and the right button.
    • to get the torque load and stall reading, press and hold the right button then gradually slow the left wheel with your hand until it stops.
:linenos:
- **lines 3 - 7** → imports all the Pybricks command for use with your robot
- **line 10** → initialises the hub
- **line 11** &rarrl initialises the left motor (you will only use one)
- **line 13** → sets the current wheel posistion (angel) as angel `0` (the starting angle)
- **line 16** → starts infinite loop
- **line 17** → checks for pressed buttons and stores them in `pressed`
- **line 19** → checks if both the left and right buttons are currently pressed
- **line 20** → prints the current accumulated left motor angle
- **line 21** → send the left motor back to angle `0`
- **line 22** → prints the current accumulated left motor angle
- **line 24** → checks if left button is pressed
- **line 25** → starts the left motor running at 300degs/s
- **line 26** → allows a quater of a second for the motor to get up to speed
- **line 27** → reads the left motor's speed and prints it
- **line 28** → waits another half a second
- **line 29** → stops the left motor
- **line 31** → checks if the right button is pressed
- **line 32** → starts left motor running at 300deg/s
- **line 33** → checks if the left motor is stalled (prevented from moving)
- **line 34** → prints stalled
- **line 35 - 36** → if motor is not stalled then read and print the torque load that the left wheel is experiencing
- **line 38 - 39** → if no button is being pressed, stop the left motor
:class: caution
- what happens if you move **line 13** inside the main loop?
- what happens if you comment out **line 26**?
- what happens if you comment out **line 25** and then physically turn the wheel when holding the left button?
- what happens if you comment out **line 32** and then physically turn the wheel when holding the right button?