mb10132_python_instruction_manual
mb10132_python_instruction_manual
Documentation
https://www.yuque.com/makeblock-help-center-en/mcode/mblock-python
Firmware Update
2|Page
A. The mBot2 Vehicle
Documentation
MBot2 Introduction
https://education.makeblock.com/help/cyberpi-series/cyberpi-series-cyberpi-
series-packages-and-extensions/mbot2-introduction/
Operational Guide
https://education.makeblock.com/help/cyberpi-series/cyberpi-series-cyberpi-
series-packages-and-extensions/mbot2-operational-guide/
Python Reference
https://www.yuque.com/makeblock-help-center-en/mcode/cyberpi-api-
shields#9eo89
mBuild Modules (Ultrasonic Sensor 2, Quad RGB Sensor)
https://www.yuque.com/makeblock-help-center-en/mcode/cyberpi-api-mbuild
or
https://education.makeblock.com/help/mblock-python/mblock-python-editor-
python-api-documentation-for-devices/mblock-python-editor-python-api-
documentation-for-cyberpi/mblock-python-editor-apis-for-mbuild-modules/
3|Page
B. Introduction and Setup
Download and install the mBlock Windows or Mac software from https://mblock.makeblock.com/en-us/download/
(The PC software seems to be more stable than the web version located at https://python.mblock.cc/ )
The Python Editor program will open. The block editor will stay open, but you can close it at any time.
4|Page
2. TURN ON THE MBOT2 USING THE SWITCH ON THE SIDE
The lights on both the ultrasonic sensor and the line follower sensor should turn on. If they are don’t, the
wiring is incorrect or unplugged, and needs to be fixed.
3. Select Upload mode. If a message appears, tick “Don’t remind me” and then click Sure to switch.
4. Plug the mBot2 into a USB port and click the Connect button .
Select your USB port from the list and click Connect.
6. Start coding
5|Page
C. Our First Program – Hello
Our first program will write ‘hello’ on the console, say it on the audio speaker and turn all LED’s to green for 2
seconds.
cpi.console.print("hello")
cpi.audio.play('hello')
cpi.led.on(0,255,0) #red, green, blue values from 0 to 255
time.sleep(2) #time delay in seconds
cpi.led.off()
cpi.console.clear()
Unsuccessful Upload
Save the project to your computer by clicking on the File menu and choosing Export project.
6|Page
Coding Errors and Feedback from the CyberPi
When you write code, errors show up with an explanation mark symbol.
If you were to upload this code it would not run and the upload window will show you the first error. Scroll to the
bottom of the text to see the error message.
Program Feedback
You can also give yourself feedback in the code you write by using the print() function. This is different to the
cpi.console.print() function. Try this:
cpi.console.print("hello")
print('talk to me')
cpi.audio.play('hello')
print('turn leds to green for 2 seconds')
cpi.led.on(0,255,0)
time.sleep(2)
cpi.led.off()
cpi.console.clear()
Put a # in front of any line to create comments or to turn code statements into comments so they are not executed.
7|Page
D. Buttons
The mBot2 is controlled by a module called cyberpi. This has a joystick, a home button and two push buttons (A and
B). We can use the joystick and buttons in our code. It also has a light sensor and microphone that we can use.
Instead of the code running automatically when it is uploaded, let’s turn on the display when we press button A. To
do this we use a while loop, that does nothing but turn on the red lights and wait for the button to be pressed.
cpi.console.print("hello")
cpi.audio.play('hello')
cpi.led.on(0,255,0)
time.sleep(2)
cpi.led.off()
cpi.console.clear()
8|Page
E. Run the Motors
There are a number of ways we may want to move the mBot2. Forward motor speeds are between 0 and 100.
Backward motor speeds are between 0 and -100. Movement still occurs at speeds close to zero.
Movement Commands
Forward or backward cpi.mbot2.forward(speed = 50)
forever.
forever cpi.mbot2.backward(speed = 50)
(Should only be used when the
ultrasonic sensor or colour
cpi.mbot2.forward(speed = -50)
sensors are used to control
when the motors should stop) cpi.mbot2.EM_stop(port = "all")
9|Page
Code Templates
There are two basic code templates we use when running motors. In both cases, we use button A to turn on the
mBot2 to start the actions.
Separating code into sections makes it much easier to understand the code and make changes to it. Later, we will
add more sections as we require them.
1. Single Actions. Use this when the mBot2 actions should only occur once.
#IMPORTS---------------------------------------
import cyberpi as cpi
import time
#WAIT TO START---------------------------------
cpi.console.println('Press A')
while not cpi.controller.is_press('a'):
cpi.led.on(255,0,0)
cpi.led.on(0,255,0)
#ROBOT ACTIONS---------------------------------
cpi.mbot2.forward(speed = 50, run_time = 2) #Example commands.
cpi.mbot2.backward(speed = 50, run_time = 2) #Replace with your own!
cpi.led.off()
If we have actions that are repeated, we can use a for loop. For example, to move in a square:
#IMPORTS---------------------------------------
import cyberpi as cpi
import time
#WAIT TO START---------------------------------
cpi.console.println('Press A')
while not cpi.controller.is_press('a'):
cpi.led.on(255,0,0)
cpi.led.on(0,255,0)
#ROBOT ACTIONS---------------------------------
for i in range(4):
cpi.mbot2.straight(40, speed = 50) #cm
cpi.mbot2.turn(90, speed = 50) #degrees
cpi.led.off()
CHALLENGES
1. Place one or more large objects on the floor. Navigate the mBot2 through and/or around them.
2. One of the RoboRAVE competitions is AMAZE-ing. It consists of a series of boards that make up a maze. You do
not know the shape of the maze until the competition. The person who keeps the robot on the boards and has
the fastest time wins.
10 | P a g e
2. Forever Actions. This code has a while True loop that repeats the actions forever – or until you press the home
button next to the USB connection.
#IMPORTS---------------------------------------
import cyberpi as cpi
import time
#WAIT TO START---------------------------------
cpi.console.println('Press A')
while not cpi.controller.is_press('a'):
cpi.led.on(255,0,0)
cpi.led.on(0,255,0)
#MAIN LOOP-------------------------------------
while True:
cpi.mbot2.forward(speed = 50, run_time = 2) #Example commands.
cpi.mbot2.backward(speed = 50, run_time = 2) #Replace with your own!
This code is mainly used in conjunction with the joystick and buttons, or the ultrasonic and line follower sensors,
where the mBot2 will respond to changes in sensor values.
CHALLENGES
3. Place two small objects on the floor at least 1m apart. Drive around these multiple times in a figure of 8. When
you turn use the led’s to indicate your turns.
4. Place a large object on the floor and turn around the object 3 times in a large, smooth circle. (Use the
cpi.mbot2.drive_power() function)
11 | P a g e
F. Avoid or Seek
The Ultrasonic Sensor is used to measure the distance between the mBot2 and anything in front of it (up to about
200cm). It can be used to avoid obstacles or seek out an object and move toward it.
The minimum distance detected in 4cm. Smaller distances give a reading of 300.
Test your Ultrasonic Sensor with this code. Putting all the sensor reading code into a function unclutters the main
loop.
#IMPORTS---------------------------------------
import cyberpi as cpi
import time
#GLOBAL VARIABLES------------------------------
distance = 300
#FUNCTIONS-------------------------------------
def get_all_values(output=True):
global distance
distance = cpi.ultrasonic2.get(index=1)
if output:
cpi.console.println( str(distance) )
time.sleep(0.1)
#WAIT TO START---------------------------------
cpi.console.println('Press A')
while not cpi.controller.is_press('a'):
cpi.led.on(255,0,0)
cpi.led.on(0,255,0)
#MAIN LOOP-------------------------------------
while True:
get_all_values(output=True)
Obstacle Avoidance
#MAIN LOOP--------------------------------------
while True:
get_all_values(output=False)
12 | P a g e
Slow Down when Close to a Collision
#MAIN LOOP--------------------------------------
while True:
get_all_values(output=False)
else:
cpi.mbot2.forward(speed = 50) #forward
Rotate to detect an object closer than 80cm, then move toward the object.
#MAIN LOOP--------------------------------------
while True:
get_all_values(output=False)
CHALLENGES
5. Place 4 objects at the corners of a square. Find one of them and stop before you hit it. Turn and find the next
object, until you have found all four.
6. Find your way autonomously through a simple maze (sides are 10cm high)
13 | P a g e
G. Detect and Follow a Line
The Quad RGB Sensor (color sensor) enables us to detect and follow lines, and detect colours and respond to the
colours in different ways.
Test the Sensor using this code, by passing the mBot2 over a black line on a white background.
#GLOBAL VARIABLES------------------------------
distance = 300
L1 = 0
L2 = 0
R1 = 0
R2 = 0
any_line = 0
#FUNCTIONS-------------------------------------
def get_all_values(output=True, black_line=True):
global distance, L1, L2, R1, R2, any_line
distance = cpi.ultrasonic2.get(index=1)
L2 = cpi.quad_rgb_sensor.get_gray('l2', index = 1)
L1 = cpi.quad_rgb_sensor.get_gray('l1', index = 1)
R1 = cpi.quad_rgb_sensor.get_gray('r1', index = 1)
R2 = cpi.quad_rgb_sensor.get_gray('r2', index = 1)
if black_line:
any_line = (L2 < 50) or (L1 < 50) or (R1 < 50) or (R2 < 50)
else:
any_line = (L2 > 50) or (L1 > 50) or (R1 > 50) or (R2 > 50)
if output:
#cpi.console.println(str(distance) )
cpi.console.println(str(L2)+' '+str(L1)+' '+str(R1)+' '+str(R2) )
#WAIT TO START---------------------------------
cpi.console.println('Press A')
while not cpi.controller.is_press('a'):
cpi.led.on(255,0,0)
cpi.led.on(0,255,0)
#MAIN LOOP--------------------------------------
while True:
get_all_values(output=True, black_line=True)
time.sleep(0.1)
14 | P a g e
We can use the color sensor values to test whether the color sensor is on or off a black line.
• On a line will give a low reflectance value or off a line will give a high value.
• Assume for a start that if the reflected light value is less than 50% if we are on or near a black line.
• Place the mBot2 on the middle of the black line
• If both sensors L1 and R1 are on black – go straight ahead
• If only sensor L1 is on black – turn to the left
• If only sensor R1 is on black – turn to the right
First, test the code below without the motors driving. Then take off the comment # and try with the motors running.
#MAIN LOOP--------------------------------------
cpi.mbot2.drive_power(50, -50) #forward
while True:
get_all_values(output=False, black_line=True)
CHALLENGES
5. Oval Race. Follow an oval line from start to finish. Time the run. The robot that does the quickest time wins.
6. RoboRAVE Line Follower Race. Be the fastest robot to get from home to the box.
15 | P a g e
H. SumoBot
SumoBots use the ultrasonic sensor to seek and destroy another robot vehicle in the Sumo ring, while using the color
sensor to sense the white border and avoid falling off the edge.
#MAIN LOOP--------------------------------------
found = False
cpi.mbot2.straight(20, speed = 40)
while True:
get_all_values(output=False, black_line=False)
H2. Enhancements
• Don’t waste time moving forward at the start before starting to find the other vehicle
• Only scan left and right up to 90 degrees the first time
• Stop every 10 degrees when scanning to make sure scan detects vehicle (moving too fast doesn’t work)
• Use movement sensor to detect a collision or the bot lifted off the ground (pitch or roll) and respond to that
(see Appendix 1)
• If motion is stopped for x seconds, use a series of rapid wheel movements (e.g. back and forth) to try and get
free
• Use a different strategy:
▪ Follow white line around the outside (use L2 or R2)
▪ Drive to a random place
▪ Drive forward until white line and turn and randomly go somewhere else until white line
• Use more than one ultrasonic sensor at different angles
16 | P a g e
I. Connect Servos, Sensors and Motors
Servos
Up to 4 servos can be plugged in the servo ports on the right-hand side (S3 and S4), or the general IO ports on the
left (S1 and S2).
while True:
cpi.mbot2.servo_set(90, 'S1')
time.sleep(1)
cpi.mbot2.servo_set(140, 'S1')
time.sleep(2)
cpi.mbot2.servo_set(40, 'S1')
time.sleep(2)
Read analog sensors (such as potentiometers or soil moisture sensors) using ports S1 and S2
cpi.mbot2.read_analog(port) #returns 0 – 5V
Run DC motors
17 | P a g e
More Loops
while True:
if cpi.controller.is_press('a'):
for i in range(1,6,2): cpi.led.on(0,255,0, id = i) #or id = 1, value 1-5
cpi.console.print('green\n')
elif cpi.controller.is_press('b'):
cpi.led.off()
for i in range(2,5,2): cpi.led.on(0,0,255, id = i)
cpi.console.print('blue\n')
time.sleep(0.1)
18 | P a g e
Appendix 1 CyberPi Extras
Ultrasonic, slider (potentiometer) and multi-touch
while True:
distance = cpi.ultrasonic2.get(index=1)
pot = cpi.slider.get()
touch = cpi.multi_touch.is_touch(ch = 1) #1-8 or ch = "any"
print(distance, pot, touch)
time.sleep(0.1)
Light sensor
light = cpi.get_bri()
Sound sensor
Audio Commands
cpi.audio.play_tone(freq, t)
cpi.audio.add_vol(val) #-100 – 100
Accelerometer/Gyro Commands
forward = cpi.is_tiltforward()
backward = cpi.is_tiltback()
left = cpi.is_tiltleft()
right = cpi.is_tiltright()
cpi.is_shake()
cpi.get_shakeval() #0-100
19 | P a g e