# Servos
Servos are a bit like motors, except their position is fixed. This is useful for building an arm mechanism that grabs cubes, or anything else that has fixed states that it needs to be in.
Similarly to motors, the position of a servo is expressed as a percentage. This can be negative.
Servos are plugged into the PWM ports on the BrainBox. PWM 1 represents servo 1, PWM 2 is servo 2, etc.
# Python
You can control servos using the servos
property of the Robot
object. To set the first servo to the 50% position use:
R.servos[1] = 50
To control the fourth servo instead, replace servos[1]
with servos[4]
.
Here's a more complete example:
import robot
R = robot.Robot()
# set servo 1 to the 50% position
R.servos[1] = 50
# set servo 3 to the -100% position
R.servos[3] = -100
# set servos 1 & 3 to the default positions
R.servos[1] = 0
R.servos[3] = 0
# Blockly
Blocks for controlling servos can be found in the Movement section.
# Default positions
Servos default to a starting position 1/2 way through their travel, for some uses teams may need to start with a different resting position to ensure their robot fits within the set sizes, you can set the position that the servo holds while waiting for the start button to be pressed by initilizing the robot object with servo_defaults=((servo_number,position)...,(servo_number,position))
E.g. to set PWM1 to 100%
and PWM3 to 50%
use
import robot
servo_values = {
1: 100,
2: 50,
3: -100
}
R = robot.Robot(servo_defaults=servo_values)