Professional Documents
Culture Documents
Version v3.0.0a3
Index 245
i
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
This documentation has everything you need to install Pybricks and run your first scripts.
Step 1: Install Pybricks
Pybricks scripts are the same across all hubs. The only difference is in how you install Pybricks and how you run
scripts. To get started, click one of the platforms below.
1
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 1
Note: This guide and documentation is for Pybricks 3.0. It is under constant development. This version includes
support for LEGO MINDSTORMS EV3 and LEGO Powered Up.
Click here to view the documentation for version 2.0. This is is the stable version officially supported by LEGO
Education. It includes support for LEGO MINDSTORMS EV3 only.
1.1 Installation
This page guides you through the steps to collect and install everything you need to start programming.
2
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
• A mini-USB cable, like the one included with your EV3 set
The typical configuration of this equipment is summarized in Figure 1.1.
You’ll write your MicroPython programs using Visual Studio Code. Follow the steps below to download, install, and
configure this application:
1. Download Visual Studio Code.
2. Follow the on-screen instructions to install the application.
3. Launch Visual Studio Code.
4. Open the extensions tab.
5. Install the EV3 MicroPython extension as shown in Figure 1.2.
To make it possible to run MicroPython programs on your EV3 Brick, you’ll now learn how to install the required
tools on your microSD card.
If the microSD card contains files you want to keep, make sure to create a backup of its contents first. See managing
files on the EV3 to learn how to backup your previous MicroPython programs if necessary.
This process erases everything on your microSD card, including any previous MicroPython programs on it.
To install the MicroPython tools on your microSD card:
3
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Figure 1.2: Installing the extension from the Visual Studio Code marketplace
1. Download the EV3 MicroPython microSD card image and save it in a convenient location. This file is approximately
360 MB. You do not need to unzip the file.
2. Download and install a microSD card flashing tool such as Etcher.
3. Insert the microSD card into your computer or card reader.
4. Launch the flashing tool and follow the steps on your screen to install the file you have just downloaded. If you
use Etcher, you can follow the instructions below, as shown in Figure 1.3.
(a) Select the EV3 MicroPython microSD card image file you have just downloaded.
(b) Select your microSD card. Make sure that the device and size correspond to your microSD card.
(c) Start the flashing process. This may take several minutes. Do not remove the card until the flashing process
is complete.
Figure 1.3: Using Etcher to flash the EV3 MicroPython microSD card image
4
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
To update the microSD card, download a new image file using the link above and flash it to the microSD card as
described above. Be sure to back up any MicroPython programs you want to save.
You do not need to erase the contents of the microSD card first. This is done automatically when you flash the new
image file.
Make sure the EV3 Brick is turned off. Insert the microSD card you prepared into the microSD card slot on the EV3
Brick, as shown in Figure 1.4.
Figure 1.4: Inserting the flashed microSD card into the EV3 Brick
Turn on the EV3 Brick by pressing the dark gray center button.
The boot process may take several minutes. While booting, the EV3 Brick status light turns orange and blinks inter-
mittently, and you’ll see a lot of text on the EV3 screen. The EV3 Brick is ready for use when the status light turns
green.
To turn the EV3 Brick off, open the shutdown menu with the back button, and then select Power Off using the center
button, as shown in Figure 1.5.
5
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
When you’re not running a program, you can view motor and sensor values using the device browser, as shown in
Figure 1.6.
You can run previously downloaded programs directly from the EV3 Brick.
To do so, find the program using the file browser on the EV3 screen and press the center button key to start the program
as shown in Figure 1.7.
You can go back to the LEGO® firmware and your LEGO programs at any time. To do so:
1. Turn the EV3 Brick off as shown above.
6
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Figure 1.7: Starting a program using the buttons on the EV3 Brick
2. Wait for the screen and brick status light to turn off.
3. Remove the microSD card.
4. Turn the EV3 on.
Now that you’ve set up your computer and EV3 Brick, you’re ready to start writing programs.
To make it easier to create and manage your programs, let’s first have a quick look at how MicroPython projects and
programs for your EV3 robots are organized.
Programs are organized into project folders, as shown in Figure 1.8. A project folder is a directory on your computer
that contains the main program (main.py) and other optional scripts or files. This project folder and all of its contents
will be copied to the EV3 Brick, where the main program will be run.
This page shows you how to create such a project and how to transfer it to the EV3 Brick.
Figure 1.8: A project contains a program called main.py and optional resources like sounds or MicroPython modules.
7
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
To create a new project, open the EV3 MicroPython tab and click create a new project, as shown in Figure 1.9. Enter
a project name in the text field that appears and press Enter. When prompted, choose a location for this program and
confirm by clicking choose folder.
Figure 1.9: Creating a new project. This example is called getting_started, but you can choose any name.
When you create a new project, it already includes a file called main.py. To see its contents and to modify it, open it
from the file browser as shown in Figure 1.10. This is where you’ll write your programs.
If you are new to MicroPython programming, we recommend that you keep the existing code in place and add your
code to it.
8
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
To open a project you created previously, click File and click Open Folder, as shown in Figure 1.11. Next, navigate
to your previously created project folder and click OK. You can also open your recently used projects using the Open
Recent menu option.
To be able to transfer your code to the EV3 Brick, you’ll first need to connect the EV3 Brick to your computer with
the mini-USB cable and configure the connection with Visual Studio Code. To do so:
• Turn the EV3 Brick on
• Connect the EV3 Brick to your computer with the mini-USB cable
• Configure the USB connection as shown in Figure 1.12.
You can press the F5 key to run the program. Alternatively, you can start it manually by going to the debug tab and
clicking the green start arrow, as shown in Figure 1.13.
When the program starts, a pop-up toolbar allows you to stop the program if necessary. You can also stop the program
at any time using the back button on the EV3 Brick.
If your program produces any output with the print command, this is shown in the output window.
9
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Figure 1.12: Configuring the USB connection between the computer and the EV3 Brick
10
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Now that you’ve run the basic code template, you can expand the program to make a motor move. First, attach a Large
Motor to Port B on the EV3 Brick, as shown in Figure 1.14.
Figure 1.14: The EV3 Brick with a Large Motor attached to port B.
#!/usr/bin/env pybricks-micropython
from pybricks.hubs import EV3Brick
from pybricks.ev3devices import Motor
from pybricks.parameters import Port
11
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
# Run the motor up to 500 degrees per second. To a target angle of 90 degrees.
test_motor.run_target(500, 90)
This program makes your robot beep, rotate the motor, and beep again with a higher pitched tone. Run the program to
make sure that it works as expected.
After you’ve downloaded a project to the EV3 Brick, you can run, delete, or back up programs stored on it using the
device browser as shown in Figure 1.15.
Figure 1.15: Using the EV3 device browser to manage files on your EV3 Brick
12
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
MicroPython runs on top of ev3dev, which is a specific version of Linux. Linux is an operating system. (Other
popular operating systems are Microsoft Windows and Apple macOS.) This means that your EV3 is almost like a real
computer, just much smaller.
Note: If you just want to write MicroPython programs, you can skip the remaining sections.
The remaining sections are aimed at curious users who want go beyond MicroPython and access some of the other
built-in features of Linux and ev3dev.
Although your EV3 Brick is quite like a real computer, you do not interact with it using a big screen and a mouse.
Instead, you can access files and programs on it using the command line. It is also called the terminal.
Follow the steps in Figure 1.16 to access the command line. Now you can enter commands by typing them in and
pressing enter.
Figure 1.16: Opening the Linux command line and running the ls command.
ls
then you will see the contents of the current folder. Figure 1.16 shows the result: it listed the project folder of the
getting_started project that we just ran.
If you type the following command and press enter:
exit
then the command line will be closed. Alternatively, click the garbage icon shown in Figure 1.16.
13
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
You can copy text from the command line by selecting it and then pressing ctrl shift c. You can paste text into
the command line using ctrl shift v.
Running commands as an administrator
Some commands require a password to run. This is similar to administrative tasks on your computer or tablet, such as
installing a new app. These commands work like any other command, but you add sudo in front of them.
As an exercise, you can run the following command to turn the EV3 Brick off:
sudo poweroff
You will be prompted for a password. Type maker and then press Enter.
Warning: Only run commands with sudo if you know what you are doing.
When you search for your EV3 using Visual Studio Code, you see all EV3 Bricks listed by their name. By default, all
EV3 Bricks are named ev3dev. Follow these steps to change that name:
1. Open Visual Studio Code and connect to your EV3 as usual.
2. Read the steps above about running commands as an administrator.
3. Think of a good name. In this example, we’ll call it autonomous-vehicle2
4. Enter the following command and press enter:
14
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
To upgrade, download the latest microSD card file and install it using the standard instructions.
Note that this will erase all your existing files on the SD Card. Before you upgrade, make sure that you still have all
your projects on your computer. If not, you can upload files back to your computer using these instructions.
As with any software update, be careful about when you update. For example, if you developed your code using
version v1.0 and you are halfway into your robotics competition season, you may want to stick with v1.0 for now.
Most changes in v2.0 are new features, like support for additional sensors. Naturally, this will not affect your existing
code. However, some changes were made to existing features to improve performance.
All originally documented features in v1.0 will still work after you upgrade. This means that most programs originally
made for v1.0 will work with the v2.0 microSD card image without any changes.
To try this, simply download and run your original code as you did before.
However, it is recommended that you upgrade both the microSD card and your programs at the same time to ensure
everything works as expected.
Version 2.0 introduces the EV3Brick() class. You can use it instead of the old ev3brick module. The old
ev3brick module can still be used, but it is no longer recommended or documented.
The EV3Brick() class improves the speed and reliability of the EV3 screen and the EV3 speaker. It also adds
functionality like speech and drawing shapes. The default font size is also bigger to make it easier to read text on the
screen.
You can use the following table as a starting point to upgrade your scripts. See the EV3Brick() class documentation
for complete details of all methods and arguments.
15
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
brick.light(Color.RED) ev3.light.on(Color.RED)
Light on
brick.light(None) ev3.light.off()
Light off
brick.sound.beep() ev3.speaker.beep()
Play a
beep
brick.sound. ev3.speaker.play_
Play a
˓→file(SoundFile.HELLO) ˓→file(SoundFile.HELLO)
sound file
ev3.speaker.say("I can
Text to
˓→say anything!")
speech
ev3.speaker.play_notes([
Play
˓→'C4/4', 'G4/4'])
notes
brick.display.text("Hello! ev3.screen.draw_text(50,
Write text
˓→", (50, 60)) ˓→60, "Hello!")
at a given
position
brick.display.text("Hello ev3.screen.print("Hello")
Write text
˓→") ev3.screen.print("world!")
and scroll brick.display.text("world!
automatically ˓→")
from pybricks.media.
Change font
˓→ev3dev import Font
size
big_font = Font(size=24)
ev3.screen.set_font(big_ 16
˓→font)
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
• Most methods of the Motor() class now have Stop.HOLD as the default instead of Stop.COAST. This
improves accuracy in most applications. You can still select Stop.COAST if you like.
• The internal PID controllers for the motors are more accurate than before. If you give a motor command when
it is already running, it smoothly adjusts the speed to the newly given command. This works even if you keep
adjusting the speed in a fast loop.
• Methods to configure motor settings have changed. You can change settings using the control attribute now. The
old settings setters continue to exist in the implementation, but they are no longer documented.
• So-called Python keyword arguments are now supported. Previously, you could only enter the argument values.
For example:
This is still possible. But you can now choose to omit optional arguments and specify others with keywords.
This can make your code easier to read. For example:
• It is no longer necessary to import pybricks.tools.print. The print function is now built-in. It works
just like Python or MicroPython.
• Most parameters in the parameters now have a specific type and representation. For example, suppose you
measure a color and print the result. If you do print(Color.RED), you will see the parameter instead of a
technical number.
• Sound and image files have moved to a dedicated media module. Importing them from the old location will
continue to work in this release, to make sure existing scripts will still work.
Installing an older version of the Visual Studio Code extension
The Visual Studio Code extension and this documentation are updated automatically. You can still use your existing
scripts with the updated extension. If you absolutely wish to keep the old version, look for the EV3 extension on the
extension tab, click the gear icon, and click install another version.
17
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 2
This page shows how you can install Pybricks on your hub and run your first program. When you’re ready, browse
through the Pybricks Modules in the left hand menu to modify the example program.
Note:
• This is still in beta! Not everything may work as expected yet.
• We welcome your questions, feedback and bug reports on our support page.
• For now, sensors/motors are detected automatically only once. So if you change the cables, you have to turn the
hub off and on again. You can turn it off by holding down the button for about 5 seconds.
Writing Pybricks programs requires a web browser with web Bluetooth functionality. Currently, only Google Chrome
supports this. Download Google Chrome from here.
18
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Pybricks uses an improved firmware that can run autonomous programs. Installing it is easy:
1. Make sure you use fresh batteries.
2. Unplug all motors and sensors.
3. Follow the steps in the video below.
Click to show/hide written step-by-step instructions.
• Make sure you use fresh batteries.
• Unplug all motors and sensors.
• Make sure the hub is off.
• Press and hold the green button.
• Wait for the light to blink, but keep holding the button.
• On the Pybricks Code page, click the firmware update button.
• Select the LEGO Bootloader and click Pair.
• The light should change to a red/green/blue sequence.
• You can now release the button.
• Wait for the update to finish, indicated by a blinking blue light.
• If you use the recommended browser, this will take about 90 seconds.
Once the firmware is installed, you can start coding! Use the Bluetooth button to search for and connect to your
Pybricks Hub. Then press run to start your program.
To get started, just copy and paste this snippet:
# Say hello :)
print("Hello, Pybricks!")
(continues on next page)
19
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
20
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
while True:
# Set the speed based on dial angle
speed = dial.angle()*3
if abs(speed) < 100:
speed = 0
Note:
• This functionality is in beta. It is currently only recommended for advanced users. In the long run, we’ll make
this easy to do with the online editor.
• All LEGO motors and sensors need a few seconds to boot. You don’t normally notice because you spend that
time connecting. But this is way faster. So if you experience problems, give your hub a few seconds before you
start your program.
When you run a program the normal way, it is deleted as soon as it’s done. That’s because Powered Up hubs don’t
have a file system to store programs. Fortunately, you can still save a script on the hub by including it in the firmware.
Of course, this is a bit slow to do every time. We recommend the using the standard procedure most of the time. When
you’re happy with your final program, you can save it permanently as described below. To change the program, just
repeat these steps:
1. Sign in to GitHub.
2. Go to our GitHub commits.
3. Click on the green checkmark next to the latest commit. On the dialog that pops up, click details.
4. Then click Artifacts on the right hand side of the page.
5. Download the firmware for your hub. The firmware is a ZIP archive containing the basic firmware and one
main.py script.
6. Modify the main.py file as you like.
7. Drag your modified ZIP file onto the firmware update button of the online editor.
8. The update now proceeds as usual.
Once installed, you can start that program with the green button. No connection required!
21
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Pybricks uses the same update method as the LEGO apps; just with a different firmware file. This means you can go
back to the original firmware any time. As shown in the video below, just put the hub in update mode and connect
using a LEGO app.
This video shows the Powered Up app in create mode. It has firmware for all hubs. As usual, you may need to restart
the app to detect the hub. If it fails, try again with fresh batteries.
22
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 3
Coming soon!
23
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 4
class MoveHub
LEGO® Powered Up Move Hub.
Show/hide examples
Example 1: Turning the light on and off
from pybricks.hubs import MoveHub
from pybricks.parameters import Color
from pybricks.tools import wait
24
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
hub.light.on(Color.RED)
wait(1000)
hub.light.off()
wait(500)
wait(2000)
wait(10000)
wait(10000)
25
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
wait(10000)
wait(10000)
light.on(color)
Turns on the light at the specified color.
Parameters color (Color) – Color of the light.
light.off()
Turns off the light.
light.blink(color, durations)
Blinks the light at a given color by turning it on and off for given durations.
The light keeps blinking indefinitely while the rest of your program keeps running.
This method provides a simple way to make basic but useful patterns. For more generic and multi-color
patterns, use animate() instead.
Parameters
• color (Color) – Color of the light.
• durations (list) – List of (time: ms) values of the form [on_1, off_1, on_2,
off_2, ...].
light.animate(colors, interval)
Animates the light with a list of colors. The next color in the list is shown after the given interval.
The animation runs in the background while the rest of your program keeps running. When the animation
completes, it repeats.
Parameters
• colors (list) – List of Color values.
• interval (time: ms) – Time between color updates.
battery.voltage()
Gets the voltage of the battery.
Returns Battery voltage.
Return type voltage: mV
battery.current()
Gets the current supplied by the battery.
Returns Battery current.
Return type current: mA
26
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
class CityHub
LEGO® Powered Up City Hub.
Show/hide examples
Example 1: Turning the light on and off
from pybricks.hubs import CityHub
from pybricks.parameters import Color
from pybricks.tools import wait
hub.light.on(Color.RED)
wait(1000)
hub.light.off()
wait(500)
wait(2000)
27
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
wait(2000)
wait(10000)
wait(10000)
wait(10000)
# Make the color RED grow faint and bright using a sine pattern.
hub.light.animate(
[Color.RED * (0.5 * sin(i / 15 * pi) + 0.5) for i in range(30)], 40)
wait(10000)
wait(10000)
light.on(color)
Turns on the light at the specified color.
28
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
battery.voltage()
Gets the voltage of the battery.
Returns Battery voltage.
Return type voltage: mV
battery.current()
Gets the current supplied by the battery.
Returns Battery current.
Return type current: mA
class TechnicHub
LEGO® Technic Hub.
Show/hide examples
Example 1: Turning the light on and off
29
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
hub.light.on(Color.RED)
wait(1000)
hub.light.off()
wait(500)
wait(2000)
wait(2000)
30
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
wait(10000)
wait(10000)
wait(10000)
# Make the color RED grow faint and bright using a sine pattern.
hub.light.animate(
[Color.RED * (0.5 * sin(i / 15 * pi) + 0.5) for i in range(30)], 40)
wait(10000)
wait(10000)
light.on(color)
Turns on the light at the specified color.
Parameters color (Color) – Color of the light.
light.off()
Turns off the light.
light.blink(color, durations)
Blinks the light at a given color by turning it on and off for given durations.
The light keeps blinking indefinitely while the rest of your program keeps running.
This method provides a simple way to make basic but useful patterns. For more generic and multi-color
patterns, use animate() instead.
Parameters
31
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
battery.voltage()
Gets the voltage of the battery.
Returns Battery voltage.
Return type voltage: mV
battery.current()
Gets the current supplied by the battery.
Returns Battery current.
Return type current: mA
class PrimeHub
LEGO® SPIKE Prime Hub.
This class is identical to the InventorHub class, except for the name.
32
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Show/hide examples
Example 1: Turning the light on and off
hub.light.on(Color.RED)
wait(1000)
hub.light.off()
wait(500)
wait(2000)
wait(2000)
33
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
wait(10000)
wait(10000)
wait(10000)
# Make the color RED grow faint and bright using a sine pattern.
hub.light.animate(
[Color.RED * (0.5 * sin(i / 15 * pi) + 0.5) for i in range(30)], 40)
wait(10000)
wait(10000)
light.on(color)
Turns on the light at the specified color.
Parameters color (Color) – Color of the light.
light.off()
Turns off the light.
light.blink(color, durations)
Blinks the light at a given color by turning it on and off for given durations.
The light keeps blinking indefinitely while the rest of your program keeps running.
This method provides a simple way to make basic but useful patterns. For more generic and multi-color
patterns, use animate() instead.
Parameters
• color (Color) – Color of the light.
34
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
• durations (list) – List of (time: ms) values of the form [on_1, off_1, on_2,
off_2, ...].
light.animate(colors, interval)
Animates the light with a list of colors. The next color in the list is shown after the given interval.
The animation runs in the background while the rest of your program keeps running. When the animation
completes, it repeats.
Parameters
• colors (list) – List of Color values.
• interval (time: ms) – Time between color updates.
Show/hide examples
Example 1: Displaying images
35
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
36
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
# Make a square that is bright on the outside and faint in the middle.
SQUARE = Matrix([
[100, 100, 100, 100, 100],
[100, 50, 50, 50, 100],
[100, 50, 0, 50, 100],
[100, 50, 50, 50, 100],
[100, 100, 100, 100, 100],
])
while True:
37
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
for i in range(3):
# Display eyes open plus the random brows.
hub.display.image(Icon.EYE_LEFT + Icon.EYE_RIGHT + brows)
wait(2000)
wait(200)
display.orientation(up)
Sets the orientation of the light matrix display.
Only new displayed images and pixels are affected. The existing display contents remain unchanged.
Parameters top (Side) – Which side of the light matrix display is “up” in your design. Choose
Side.TOP, Side.LEFT, Side.RIGHT, or Side.BOTTOM.
display.off()
Turns off all the pixels.
display.pixel(row, column, brightness=100)
Turns on one pixel at the specified brightness.
Parameters
38
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Show/hide examples
Example: Detecting button presses
39
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
# Display a circle.
hub.display.image(Icon.CIRCLE)
wait(3000)
buttons.pressed()
Checks which buttons are currently pressed.
Returns List of pressed buttons.
Return type List of Button
battery.voltage()
Gets the voltage of the battery.
40
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
class InventorHub
LEGO® MINDSTORMS Inventor Hub.
This class is identical to the PrimeHub class, except for the name.
Show/hide examples
Example 1: Turning the light on and off
hub.light.on(Color.RED)
(continues on next page)
41
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
hub.light.off()
wait(500)
wait(2000)
wait(2000)
wait(10000)
wait(10000)
42
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
wait(10000)
# Make the color RED grow faint and bright using a sine pattern.
hub.light.animate(
[Color.RED * (0.5 * sin(i / 15 * pi) + 0.5) for i in range(30)], 40)
wait(10000)
wait(10000)
light.on(color)
Turns on the light at the specified color.
Parameters color (Color) – Color of the light.
light.off()
Turns off the light.
light.blink(color, durations)
Blinks the light at a given color by turning it on and off for given durations.
The light keeps blinking indefinitely while the rest of your program keeps running.
This method provides a simple way to make basic but useful patterns. For more generic and multi-color
patterns, use animate() instead.
Parameters
• color (Color) – Color of the light.
• durations (list) – List of (time: ms) values of the form [on_1, off_1, on_2,
off_2, ...].
light.animate(colors, interval)
Animates the light with a list of colors. The next color in the list is shown after the given interval.
The animation runs in the background while the rest of your program keeps running. When the animation
completes, it repeats.
Parameters
• colors (list) – List of Color values.
• interval (time: ms) – Time between color updates.
Show/hide examples
Example 1: Displaying images
43
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
44
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
45
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
# Make a square that is bright on the outside and faint in the middle.
SQUARE = Matrix([
[100, 100, 100, 100, 100],
[100, 50, 50, 50, 100],
[100, 50, 0, 50, 100],
[100, 50, 50, 50, 100],
[100, 100, 100, 100, 100],
])
while True:
for i in range(3):
# Display eyes open plus the random brows.
hub.display.image(Icon.EYE_LEFT + Icon.EYE_RIGHT + brows)
wait(2000)
46
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
display.orientation(up)
Sets the orientation of the light matrix display.
Only new displayed images and pixels are affected. The existing display contents remain unchanged.
Parameters top (Side) – Which side of the light matrix display is “up” in your design. Choose
Side.TOP, Side.LEFT, Side.RIGHT, or Side.BOTTOM.
display.off()
Turns off all the pixels.
display.pixel(row, column, brightness=100)
Turns on one pixel at the specified brightness.
Parameters
• row (int) – Vertical grid index, starting at 0 from the top.
• column (int) – Horizontal grid index, starting at 0 from the left.
• brightness (brightness: %) – Brightness of the pixel.
display.image(matrix)
Displays an image, represented by a matrix of brightness: % values.
Parameters matrix (Matrix) – Matrix of intensities (brightness: %). A 2D list is also ac-
cepted.
display.animate(matrices, interval)
Displays an animation made using a list of images.
Each image has the same format as above. Each image is shown for the given interval. The animation
repeats forever while the rest of your program keeps running.
Parameters
• matrix (list) – List of Matrix of intensities.
47
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Show/hide examples
Example: Detecting button presses
48
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
# Display a circle.
hub.display.image(Icon.CIRCLE)
wait(3000)
buttons.pressed()
Checks which buttons are currently pressed.
Returns List of pressed buttons.
Return type List of Button
battery.voltage()
Gets the voltage of the battery.
Returns Battery voltage.
Return type voltage: mV
battery.current()
Gets the current supplied by the battery.
Returns Battery current.
Return type current: mA
class EV3Brick
LEGO® MINDSTORMS® EV3 Brick.
49
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
buttons.pressed()
Checks which buttons are currently pressed.
Returns List of pressed buttons.
Return type List of Button
light.on(color)
Turns on the light at the specified color.
Parameters color (Color) – Color of the light.
Show/hide example
Example: Turn the light on and change the color.
#!/usr/bin/env pybricks-micropython
# Wait
wait(1000)
light.off()
Turns off the light.
50
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
speaker.beep(frequency=500, duration=100)
Play a beep/tone.
Parameters
• frequency (frequency: Hz) – Frequency of the beep. Frequencies below 100 are treated
as 100.
• duration (time: ms) – Duration of the beep. If the duration is less than 0, then the
method returns immediately and the frequency play continues to play indefinitely.
speaker.play_notes(notes, tempo=120)
Plays a sequence of musical notes.
For example, you can play: ['C4/4', 'C4/4', 'G4/4', 'G4/4'].
Parameters
• notes (iter) – A sequence of notes to be played (see format below).
• tempo (int) – Beats per minute where a quarter note is one beat.
Show/hide musical note format
Each note is a string with the following format:
• The first character is the name of the note, A to G or R for a rest.
• Note names can also include an accidental # (sharp) or b (flat). B#/Cb and E#/Fb are not allowed.
• The note name is followed by the octave number 2 to 8. For example C4 is middle C. The octave
changes to the next number at the note C, for example, B3 is the note below middle C (C4).
• The octave is followed by / and a number that indicates the size of the note. For example /4 is a
quarter note, /8 is an eighth note and so on.
• This can optionally followed by a . to make a dotted note. Dotted notes are 1-1/2 times as long as
notes without a dot.
• The note can optionally end with a _ which is a tie or a slur. This causes there to be no pause between
this note and the next note.
speaker.play_file(file)
Plays a sound file.
Parameters file (str) – Path to the sound file, including the file extension.
speaker.say(text)
Says a given text string.
You can configure the language and voice of the text using set_speech_options().
Parameters text (str) – What to say.
speaker.set_speech_options(language=None, voice=None, speed=None, pitch=None)
Configures speech settings used by the say() method.
Any option that is set to None will not be changed. If an option is set to an invalid value say() will use
the default value instead.
Parameters
• language (str) – Language of the text. For example, you can choose 'en' (English)
or 'de' (German). A list of all available languages is given below.
51
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
• voice (str) – The voice to use. For example, you can choose 'f1' (female voice
variant 1) or 'm3' (male voice variant 3). A list of all available voices is given below.
• speed (int) – Number of words per minute.
• pitch (int) – Pitch (0 to 99). Higher numbers make the voice higher pitched and lower
numbers make the voice lower pitched.
Show/hide available languages and voices
You can choose the following languages:
• 'af': Afrikaans
• 'an': Aragonese
• 'bg': Bulgarian
• 'bs': Bosnian
• 'ca': Catalan
• 'cs': Czech
• 'cy': Welsh
• 'da': Danish
• 'de': German
• 'el': Greek
• 'en': English (default)
• 'en-gb': English (United Kingdom)
• 'en-sc': English (Scotland)
• 'en-uk-north': English (United Kingdom, Northern)
• 'en-uk-rp': English (United Kingdom, Received Pronunciation)
• 'en-uk-wmids': English (United Kingdom, West Midlands)
• 'en-us': English (United States)
• 'en-wi': English (West Indies)
• 'eo': Esperanto
• 'es': Spanish
• 'es-la': Spanish (Latin America)
• 'et': Estonian
• 'fa': Persian
• 'fa-pin': Persian
• 'fi': Finnish
• 'fr-be': French (Belgium)
• 'fr-fr': French (France)
• 'ga': Irish
• 'grc': Greek
• 'hi': Hindi
52
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
• 'hr': Croatian
• 'hu': Hungarian
• 'hy': Armenian
• 'hy-west': Armenian (Western)
• 'id': Indonesian
• 'is': Icelandic
• 'it': Italian
• 'jbo': Lojban
• 'ka': Georgian
• 'kn': Kannada
• 'ku': Kurdish
• 'la': Latin
• 'lfn': Lingua Franca Nova
• 'lt': Lithuanian
• 'lv': Latvian
• 'mk': Macedonian
• 'ml': Malayalam
• 'ms': Malay
• 'ne': Nepali
• 'nl': Dutch
• 'no': Norwegian
• 'pa': Punjabi
• 'pl': Polish
• 'pt-br': Portuguese (Brazil)
• 'pt-pt': Portuguese (Portugal)
• 'ro': Romanian
• 'ru': Russian
• 'sk': Slovak
• 'sq': Albanian
• 'sr': Serbian
• 'sv': Swedish
• 'sw': Swahili
• 'ta': Tamil
• 'tr': Turkish
• 'vi': Vietnamese
• 'vi-hue': Vietnamese (Hue)
53
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
screen.clear()
Clears the screen. All pixels on the screen will be set to Color.WHITE.
screen.draw_text(x, y, text, text_color=Color(0, 0, 0, ’BLACK’), background_color=None)
Draws text on the screen.
The most recent font set using set_font() will be used or Font.DEFAULT if no font has been set yet.
Parameters
• x (int) – The x-axis value where the left side of the text will start.
• y (int) – The y-axis value where the top of the text will start.
• text (str) – The text to draw.
54
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
#!/usr/bin/env pybricks-micropython
# It takes some time for fonts to load from file, so it is best to only
# load them once at the beginning of the program like this:
tiny_font = Font(size=6)
big_font = Font(size=24, bold=True)
chinese_font = Font(size=24, lang='zh-cn')
# Say hello
ev3.screen.print('Hello!')
55
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
screen.set_font(font)
Sets the font used for writing on the screen.
The font is used for both draw_text() and print().
Parameters font (Font) – The font to use.
Example: See example in print().
screen.load_image(source)
Clears this image, then draws the source image centered in the screen.
Parameters source (Image or str) – The source Image. If the argument is a string, then
the source image is loaded from file.
Show/hide example
Example: Show an image on the screen.
#!/usr/bin/env pybricks-micropython
# It takes some time to load images from the SD card, so it is best to load
# them once at the beginning of a program like this:
ev3_img = Image(ImageFile.EV3_ICON)
# Show an image
ev3.screen.load_image(ev3_img)
56
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
#!/usr/bin/env pybricks-micropython
# Draw a rectangle
ev3.screen.draw_box(10, 10, 40, 40)
# Draw a circle
ev3.screen.draw_circle(25, 75, 20)
57
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Parameters
• x1 (int) – The x coordinate of the left side of the box.
• y1 (int) – The y coordinate of the top of the box.
• x2 (int) – The x coordinate of the right side of the box.
• y2 (int) – The y coordinate of the bottom of the box.
• r (int) – The radius of the corners of the box.
• fill (bool) – If True, the box will be filled with color, otherwise only the outline of
the box will be drawn.
• color (Color) – The color of the box.
Example: See example in draw_line().
screen.draw_circle(x, y, r, fill=False, color=Color(0, 0, 0, ’BLACK’))
Draws a circle on the screen.
Parameters
• x (int) – The x coordinate of the center of the circle.
• y (int) – The y coordinate of the center of the circle.
• r (int) – The radius of the circle.
• fill (bool) – If True, the circle will be filled with color, otherwise only the circum-
ference will be drawn.
• color (Color) – The color of the circle.
Example: See example in draw_line().
screen.width
Gets the width of the screen in pixels.
screen.height
Gets the height of the screen in pixels.
screen.save(filename)
Saves the screen as a .png file.
Parameters filename (str) – The path to the file to be saved.
Raises
• TypeError – filename is not a string.
• OSError – There was a problem saving the file.
battery.voltage()
Gets the voltage of the battery.
Returns Battery voltage.
Return type voltage: mV
battery.current()
Gets the current supplied by the battery.
58
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
class MoveHub
LEGO® Powered Up Move Hub.
class CityHub
LEGO® Powered Up City Hub.
class TechnicHub
LEGO® Technic Hub.
class PrimeHub
LEGO® SPIKE Prime Hub.
class InventorHub
LEGO® MINDSTORMS Inventor Hub.
class EV3Brick
LEGO® MINDSTORMS® EV3 Brick.
59
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
60
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 5
Figure 5.1: Powered Up motors without rotation sensors. The arrows indicate the default positive direction.
Show/hide examples
Example 1: Making the motor move back and forth
# Make the motor go clockwise (forward) at 70% duty cycle ("70% power").
example_motor.dc(70)
(continues on next page)
61
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
# When we choose a positive duty cycle, the motor now goes counterclockwise.
example_motor.dc(70)
# This is useful when your (train) motor is mounted in reverse or upside down.
# By changing the positive direction, your script will be easier to read,
# because a positive value now makes your train/robot go forward.
example_motor.dc(70)
wait(1000)
example_motor.stop()
wait(1000)
62
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
dc(duty)
Rotates the motor at a given duty cycle (also known as “power”).
Parameters duty (percentage: %) – The duty cycle (-100.0 to 100).
stop()
Stops the motor and lets it spin freely.
The motor gradually stops due to friction.
brake()
Passively brakes the motor.
The motor stops due to friction, plus the voltage that is generated while the motor is still moving.
63
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
# When we choose a positive speed value, the motor now goes counterclockwise.
example_motor.run(500)
# Make the output axle run at 100 degrees per second. The motor speed
# is automatically increased to compensate for the gears.
geared_motor.run(100)
Measuring
Show/hide examples
Example 1: Measuring the angle and speed
64
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
speed()
Gets the speed of the motor.
Returns Motor speed.
Return type rotational speed: deg/s
angle()
Gets the rotation angle of the motor.
Returns Motor angle.
Return type angle: deg
reset_angle(angle=None)
Sets the accumulated rotation angle of the motor to a desired value.
65
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
If you don’t specify an angle, the absolute angle will be used if your motor supports it.
Parameters angle (angle: deg) – Value to which the angle should be reset.
Stopping
Show/hide example
Example: Stopping the motor in different ways
stop()
Stops the motor and lets it spin freely.
The motor gradually stops due to friction.
brake()
Passively brakes the motor.
The motor stops due to friction, plus the voltage that is generated while the motor is still moving.
hold()
Stops the motor and actively holds it at its current angle.
Action
Show/hide examples
66
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
67
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
68
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
run(speed)
Runs the motor at a constant speed.
69
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
The motor accelerates to the given speed and keeps running at this speed until you give a new command.
Parameters speed (rotational speed: deg/s) – Speed of the motor.
run_time(speed, time, then=Stop.HOLD, wait=True)
Runs the motor at a constant speed for a given amount of time.
The motor accelerates to the given speed, keeps running at this speed, and then decelerates. The total
maneuver lasts for exactly the given amount of time.
Parameters
• speed (rotational speed: deg/s) – Speed of the motor.
• time (time: ms) – Duration of the maneuver.
• then (Stop) – What to do after coming to a standstill.
• wait (bool) – Wait for the maneuver to complete before continuing with the rest of the
program.
run_angle(speed, rotation_angle, then=Stop.HOLD, wait=True)
Runs the motor at a constant speed by a given angle.
Parameters
• speed (rotational speed: deg/s) – Speed of the motor.
• rotation_angle (angle: deg) – Angle by which the motor should rotate.
• then (Stop) – What to do after coming to a standstill.
• wait (bool) – Wait for the maneuver to complete before continuing with the rest of the
program.
run_target(speed, target_angle, then=Stop.HOLD, wait=True)
Runs the motor at a constant speed towards a given target angle.
The direction of rotation is automatically selected based on the target angle. It does matter if speed is
positive or negative.
Parameters
• speed (rotational speed: deg/s) – Speed of the motor.
• target_angle (angle: deg) – Angle that the motor should rotate to.
• then (Stop) – What to do after coming to a standstill.
• wait (bool) – Wait for the motor to reach the target before continuing with the rest of
the program.
run_until_stalled(speed, then=Stop.COAST, duty_limit=None)
Runs the motor at a constant speed until it stalls.
Parameters
• speed (rotational speed: deg/s) – Speed of the motor.
• then (Stop) – What to do after coming to a standstill.
• duty_limit (percentage: %) – Torque limit during this command. This is useful to
avoid applying the full motor torque to a geared or lever mechanism.
Returns Angle at which the motor becomes stalled.
Return type angle: deg
70
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
dc(duty)
Rotates the motor at a given duty cycle (also known as “power”).
This method lets you use a motor just like a simple DC motor.
Parameters duty (percentage: %) – The duty cycle (-100.0 to 100).
track_target(target_angle)
Tracks a target angle. This is similar to run_target(), but the usual smooth acceleration is skipped: it
will move to the target angle as fast as possible. This method is useful if you want to continuously change
the target angle.
Parameters target_angle (angle: deg) – Target angle that the motor should rotate to.
control
The motors use PID control to accurately track the speed and angle targets that you specify. You can
change its behavior through the control attribute of the motor. See The Control Class for an overview
of available methods.
5.3 Color
and
Dis-
tance
Sen-
sor
Show/hide
ex-
am-
ples
Example
1:
Mea-
sur-
ing
color
71
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
from
˓→pybricks.
˓→pupdevices
˓→import
˓→ColorDista
from
˓→pybricks.
˓→parameters
˓→import
˓→Port
from
˓→pybricks.
˓→tools
˓→import
˓→wait
˓→#
˓→Initialize
˓→the
˓→sensor.
˓→
sensor
˓→=
˓→ColorDista
˓→A)
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→Read
˓→the
˓→color.
˓→
˓→
˓→
˓→
˓→color
˓→=
˓→sensor.
˓→color()
˓→
˓→
˓→
˓→
˓→#
˓→Print
˓→the
˓→measured
˓→color.
(continues on next page)
˓→
72
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→print(colo
˓→
˓→
˓→
˓→
˓→#
˓→Move
˓→the
˓→sensor
˓→around
˓→and
˓→see
˓→how
˓→
˓→
˓→
˓→
˓→#
˓→well
˓→you
˓→can
˓→detect
˓→colors.
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Wait
˓→so
˓→we
˓→can
˓→read
˓→the
˓→value.
˓→
˓→
˓→
˓→
˓→wait(100)
Example
2:
Wait-
ing
for
73
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
a
color
from
˓→pybricks.
˓→pupdevices
˓→import
˓→ColorDista
from
˓→pybricks.
˓→parameters
˓→import
˓→Port,
˓→
˓→Color
from
˓→pybricks.
˓→tools
˓→import
˓→wait
˓→#
˓→Initialize
˓→the
˓→sensor.
˓→
sensor
˓→=
˓→ColorDista
˓→A)
˓→#
˓→This
˓→is
˓→a
˓→function
˓→that
˓→waits
˓→for
˓→a
˓→desired
˓→color.
˓→
def
˓→wait_
˓→for_
˓→color(desi
˓→color):
˓→
˓→
˓→
˓→
˓→#
˓→While
(continues on next page) ˓→the
˓→color
˓→is
74 ˓→not
˓→the
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors ˓→desired
˓→color,
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→while
˓→sensor.
˓→color()
˓→!
˓→=
˓→desired_
˓→color:
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→wait(20)
˓→#
˓→Now
˓→we
˓→use
˓→the
˓→function
˓→we
˓→just
˓→created
˓→above.
˓→
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→Here
˓→you
˓→can
˓→make
˓→your
˓→train/
˓→vehicle
˓→go
˓→forward.
˓→
˓→
˓→
(continues on next page) ˓→
˓→print(
˓→"Waiting
75 ˓→for
˓→red
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
˓→.
˓→.
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→wait_
˓→for_
˓→color(Colo
˓→RED)
˓→
˓→
˓→
˓→
˓→#
˓→Here
˓→you
˓→can
˓→make
˓→your
˓→train/
˓→vehicle
˓→go
˓→backward.
˓→
˓→
˓→
˓→
˓→print(
˓→"Waiting
˓→for
˓→blue
˓→.
˓→.
˓→.
˓→
˓→")
˓→
˓→
˓→
˓→wait_
˓→for_
˓→color(Colo
˓→BLUE)
Example
3:
Mea-
sur-
ing
dis-
tance
76
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
from
˓→pybricks.
˓→pupdevices
˓→import
˓→ColorDista
from
˓→pybricks.
˓→parameters
˓→import
˓→Port,
˓→
˓→Color
from
˓→pybricks.
˓→tools
˓→import
˓→wait
˓→#
˓→Initialize
˓→the
˓→sensor.
˓→
sensor
˓→=
˓→ColorDista
˓→A)
˓→#
˓→Repeat
˓→forever.
˓→
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→If
˓→the
˓→sensor
˓→sees
˓→an
˓→object
˓→nearby.
˓→
˓→
˓→
˓→
˓→if
˓→sensor.
˓→distance()
(continues on next page)
˓→
˓→<=
˓→40:
77
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Then
˓→blink
˓→the
˓→light
˓→red/
˓→blue
˓→5
˓→times.
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→for
˓→i
˓→in
˓→range(5):
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→sensor.
˓→light.
˓→on(Color.
˓→RED)
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
(continues on next page) ˓→
˓→
˓→
78 wait(30)
˓→
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→sensor.
˓→light.
˓→on(Color.
˓→BLUE)
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
wait(30)
˓→
˓→
˓→
˓→
else:
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→#
˓→If
˓→the
˓→sensor
˓→sees
˓→nothing
˓→
˓→
˓→
˓→
˓→
˓→
˓→
(continues on next page) ˓→
#
˓→
nearby,
˓→
79 ˓→
˓→just
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
˓→wait
˓→briefly.
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→wait(10)
class ColorDist
LEGO®
Pow-
ered
Up
Color
and
Dis-
tance
Sen-
sor.
Parameters
port
(Port)
–
Port
to
which
the
sen-
sor
is
con-
nected.
color()
Scans
the
color
of
a
sur-
face.
You
choose
which
col-
ors
are
de-
tected
us-
ing
80
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
the
detectable_
method.
By
de-
fault,
it
de-
tects Color.RED, Color.YELLOW, Color.GREEN, Color.BLUE, Color.WHITE, or None.
Returns
Detected
color.
Return type
Color
reflection()
Measures
the
re-
flec-
tion
of
a
sur-
face.
Returns
Reflection,
rang-
ing
from
0.0
(no
re-
flec-
tion)
to
100.0
(high
re-
flec-
tion).
Return type
percentage:
%
ambient()
Measures
the
am-
bi-
ent
light
in-
81
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
ten-
sity.
Returns
Ambient
light
in-
ten-
sity,
rang-
ing
from
0
(dark)
to
100
(bright).
Return type
percentage:
%
distance()
Measures
the
rel-
a-
tive
dis-
tance
be-
tween
the
sen-
sor
and
an
ob-
ject
us-
ing infrared light.
Returns
Relative
dis-
tance
rang-
ing
from
0
(clos-
est)
to
100
(far-
thest).
82
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Return type
relative
dis-
tance:
%
Advanced
color
sens-
ing
Show/hide
ex-
am-
ples
Example
1:
Read-
ing
hue,
sat-
u-
ra-
tion,
and
value
from
˓→pybri
˓→pupde
˓→impor
˓→Color
from
˓→pybri
˓→param
˓→impor
˓→Port
from
˓→pybri
˓→tools
˓→impor
˓→wait
˓→#
˓→Initi
˓→the
˓→senso
˓→
sensor
˓→=
˓→Color
˓→A)
83
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→The
˓→stand
˓→color
˓→metho
˓→alway
˓→
˓→"roun
˓→"
˓→the
˓→
˓→
˓→
˓→
˓→#
˓→measu
˓→to
˓→the
˓→neare
˓→
˓→"whol
˓→"
˓→color
˓→
˓→
˓→
˓→
˓→
˓→#
˓→That
˓→'s
˓→usefu
˓→for
˓→most
˓→appli
˓→
˓→
˓→
˓→
˓→
˓→#
˓→But
˓→you
˓→can
˓→get
˓→the
(continues on next page) ˓→origi
˓→hue,
˓→
84 ˓→satur
˓→
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→and
˓→value
˓→witho
˓→
"roun
˓→
",
˓→
˓→
as
˓→
follo
˓→
˓→
˓→
˓→
˓→color
˓→=
˓→senso
˓→hsv()
˓→
˓→
˓→
˓→
˓→#
˓→Print
˓→the
˓→resul
˓→
˓→
˓→
˓→
print
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Wait
˓→so
˓→we
˓→can
˓→read
˓→the
˓→value
˓→
˓→
˓→
(continues on next page) ˓→
wait(
˓→
85
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Example
2:
Chang-
ing
the
de-
tectable
col-
ors
By
de-
fault,
the
sen-
sor
is
con-
fig-
ured
to
de-
tect
red,
yel-
low,
green,
blue,
white, or None, which suits many applications.
For
bet-
ter
re-
sults
in
your
ap-
pli-
ca-
tion,
you
can
mea-
sure
your
de-
sired
colors in advance, and tell the sensor to look only for those colors. Be sure to measure them at the same distance and
light conditions as in your final application. Then you’ll get very accurate results even for colors that are otherwise
hard to detect.
86
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
from
˓→pybri
˓→pupde
˓→impor
˓→Color
from
˓→pybri
˓→param
˓→impor
˓→Port,
˓→
˓→Color
from
˓→pybri
˓→tools
˓→impor
˓→wait
˓→#
˓→Initi
˓→the
˓→senso
˓→
sensor
˓→=
˓→Color
˓→A)
˓→#
˓→First
˓→
˓→decid
˓→which
˓→objec
˓→you
˓→want
˓→to
˓→detec
˓→
˓→#
˓→Then
˓→measu
˓→their
˓→color
˓→with
˓→the
˓→hsv()
˓→metho
˓→
˓→#
˓→as
˓→shown
˓→in
˓→the
(continues on next page)
˓→previ
˓→examp
˓→
87
˓→Write
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
˓→them
˓→down
Pybricks Modules and Examples Version v3.0.0a3
˓→#
˓→as
˓→shown
˓→below
˓→
˓→The
˓→name
˓→is
˓→optio
˓→
˓→but
˓→it
˓→is
˓→#
˓→usefu
˓→when
˓→you
˓→the
˓→color
˓→value
˓→
green
˓→=
˓→Color
˓→
˓→s=94,
˓→
˓→v=26,
˓→
˓→ name=
˓→ 'GREE
˓→BRICK
˓→')
magenta
˓→=
˓→Color
˓→
˓→s=96,
˓→
˓→v=40,
˓→
˓→ name=
˓→ 'MAGE
˓→BRICK
˓→')
brown
˓→=
˓→Color
˓→
˓→s=78,
˓→
˓→v=15,
˓→
˓→name=
(continues on next page) ˓→'BROW
˓→BRICK
˓→')
88
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→Color
˓→
˓→s=97,
˓→
˓→v=39,
˓→
˓→name=
˓→'RED_
˓→BRICK
˓→')
˓→#
˓→Put
˓→your
˓→color
˓→in
˓→a
˓→list
˓→or
˓→tuple
˓→
˓→#
˓→Inclu
˓→None
˓→is
˓→optio
˓→
˓→Just
˓→omit
˓→it
˓→if
˓→#
˓→you
˓→alway
˓→want
˓→to
˓→get
˓→one
˓→of
˓→your
˓→color
˓→
my_
˓→color
˓→=
˓→(gree
˓→
˓→magen
˓→
˓→brown
˓→
˓→red,
(continues on next page) ˓→
˓→None)
89
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→#
˓→Save
˓→your
˓→color
˓→
sensor.
˓→detec
˓→color
˓→color
˓→#
˓→color
˓→works
˓→as
˓→usual
˓→
˓→but
˓→it
˓→only
˓→#
˓→retur
˓→one
˓→of
˓→your
˓→speci
˓→color
˓→
while
˓→True:
˓→
˓→
˓→
˓→color
˓→=
˓→senso
˓→color
˓→
˓→
˓→
˓→
˓→#
˓→Print
˓→the
˓→color
˓→
˓→
˓→
˓→
˓→print
(continues on next page)
90
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→Check
˓→which
˓→one
˓→it
˓→is.
˓→
˓→
˓→
˓→
˓→if
˓→color
˓→==
˓→magen
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→print
˓→"It
˓→works
˓→
")
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Wait
˓→so
˓→we
˓→can
˓→read
˓→it.
˓→
˓→
˓→
˓→
wait(
˓→
hsv()
Scans
the
91
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
color
of
a
sur-
face.
This
method
is
sim-
i-
lar
to
color(),
but
it
gives
the
full
range
of
hue,
sat-
u-
ration and brightness values, instead of rounding it to the nearest detectable color.
Returns
Measured
color.
The
color
is
de-
scribed
by
a
hue
(0–359),
a
sat-
u-
ra-
tion
(0–100),
and a brightness value (0–100).
Return type
Color
detectable_colo
Configures
which
col-
ors
the
color()
92
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
method
should
de-
tect.
Specify
only
col-
ors
that
you
wish
to
de-
tect
in
your
ap-
pli-
ca-
tion.
This
way,
the full-color measurements are rounded to the nearest desired color, and other colors are ignored. This improves
reliability.
If
you
give
no
ar-
gu-
ments,
the
cur-
rently
cho-
sen
col-
ors
will
be
re-
turned
as a tuple.
Parameters
colors
(list)
–
List
of
Color
ob-
jects:
93
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
the
col-
ors
that
you
want
to
de-
tect.
You can pick standard colors such as Color.MAGENTA, or provide your own colors like Color(h=348, s=96,
v=40, name='MY_MAGENTA_BRICK') for even better results. You measure your own colors with the hsv()
method.
Built-
in
light
This
sen-
sor
has
a
built-
in
light.
You
can
make
it
red,
green,
blue,
or
turn
it
off. If you use the sensor to measure something afterwards, the light automatically turns back on at the default color
for that sensing method.
Show/hide
ex-
am-
ples
Example:
Blink-
ing
the
built-
in
light
from
˓→pybri
˓→pupde
˓→Color
94
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→param
˓→impor
˓→Port,
˓→
˓→Color
from
˓→pybri
˓→tools
˓→impor
˓→wait
˓→#
˓→Initi
˓→the
˓→senso
˓→
sensor
˓→=
˓→Color
˓→A)
˓→#
˓→Repea
˓→forev
˓→
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→If
˓→the
˓→senso
˓→sees
˓→an
˓→objec
˓→nearb
˓→
˓→
˓→
˓→
˓→if
˓→senso
˓→dista
˓→
˓→<=
˓→40:
95
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Then
˓→blink
˓→the
˓→light
˓→red/
˓→blue
˓→5
˓→times
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→for
˓→i
˓→in
˓→range
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→senso
˓→light
˓→on(Co
˓→RED)
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
(continues on next page) ˓→
˓→
wait(
˓→
96
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→senso
˓→light
˓→on(Co
˓→BLUE)
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
wait(
˓→
˓→
˓→
˓→
else:
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→#
˓→If
˓→the
˓→senso
˓→sees
˓→nothi
˓→
˓→
˓→
˓→
˓→
˓→
˓→
(continues on next page) ˓→
#
˓→
nearb
˓→
97 ˓→
˓→just
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
˓→wait
˓→brief
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→
˓→
˓→
wait(
˓→
light.on(color)
Turns
on
the
light
at
the
spec-
i-
fied
color.
Parameters
color
(Color)
–
Color
of
the
light.
light.off()
Turns
off
the
light.
5.4 Powe
Func-
tions
The
ColorDistan
can
send
in-
frared
sig-
nals
to
con-
trol
98
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Power
Func-
tions
in-
frared
re-
ceivers.
You can use this technique to control medium, large, extra large, and train motors. The infrared range is limited to
about 30 cm, depending on the angle and ambient conditions.
Figure 5.3: Powered Up ColorDistanceSensor (left), Power Functions infrared receiver (middle), and a Power
Functions motor (right). Here, the receiver uses channel 1 with a motor on the red port.
Show/hide
ex-
am-
ples
Example
1:
Con-
trol
a
Power
Func-
tions
mo-
tor
from
˓→pybricks.
˓→pupdevices
˓→import
˓→ColorDista
˓→
˓→PFMotor
from
˓→pybricks.
˓→parameters
˓→import
˓→Port,
˓→
˓→Color
from
˓→pybricks.
(continues on next page)
˓→tools
˓→import
99 ˓→wait
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→#
˓→Initialize
˓→the
˓→sensor.
˓→
sensor
˓→=
˓→ColorDista
˓→B)
˓→#
˓→Initialize
˓→a
˓→motor
˓→on
˓→channel
˓→1,
˓→
˓→on
˓→the
˓→red
˓→output.
˓→
motor
˓→=
˓→PFMotor(se
˓→
˓→1,
˓→
˓→Color.
˓→RED)
˓→#
˓→Rotate
˓→and
˓→then
˓→stop.
˓→
motor.
˓→dc(100)
wait(1000)
motor.
˓→stop()
wait(1000)
˓→#
˓→Rotate
˓→the
˓→other
˓→way
˓→at
˓→half
(continues on next page) ˓→speed,
˓→
˓→and
100 ˓→then
˓→stop.
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
˓→
Pybricks Modules and Examples Version v3.0.0a3
˓→50)
wait(1000)
motor.
˓→stop()
Example
2:
Con-
trol-
ling
mul-
ti-
ple
Power
Func-
tions
mo-
tors
from
˓→pybricks.
˓→pupdevices
˓→import
˓→ColorDista
˓→
˓→PFMotor
from
˓→pybricks.
˓→parameters
˓→import
˓→Port,
˓→
˓→Color,
˓→
˓→Direction
from
˓→pybricks.
˓→tools
˓→import
˓→wait
˓→#
˓→Initialize
˓→the
˓→sensor.
˓→
sensor
˓→=
˓→ColorDista
˓→B)
˓→#
(continues on next page) ˓→You
˓→can
˓→use
101 ˓→multiple
˓→motors
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
˓→on
˓→different
Pybricks Modules and Examples Version v3.0.0a3
˓→PFMotor(se
˓→
˓→1,
˓→
˓→ Color.
˓→ BLUE)
wheel
˓→=
˓→PFMotor(se
˓→
˓→4,
˓→
˓→Color.
˓→RED,
˓→
˓→Direction.
˓→COUNTERCLO
˓→#
˓→Accelerate
˓→both
˓→motors.
˓→
˓→Only
˓→these
˓→values
˓→are
˓→available.
˓→
˓→#
˓→Other
˓→values
˓→will
˓→be
˓→rounded
˓→down
˓→to
˓→the
˓→nearest
˓→match.
˓→
for
˓→duty
˓→in
˓→[15,
˓→
˓→30,
˓→
˓→45,
˓→
˓→60,
˓→
˓→75,
(continues on next page) ˓→
˓→90,
˓→
102 ˓→100]:
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
arm.
˓→
dc(duty)
˓→
˓→
˓→
˓→
wheel.
˓→
dc(duty)
˓→
˓→
˓→
˓→
wait(1000)
˓→
˓→#
˓→To
˓→make
˓→the
˓→signal
˓→more
˓→reliable,
˓→
˓→there
˓→is
˓→a
˓→short
˓→#
˓→pause
˓→between
˓→commands.
˓→
So,
˓→
˓→
˓→they
˓→change
˓→speed
˓→and
˓→#
˓→stop
˓→at
˓→a
˓→slightly
˓→different
˓→time.
˓→
˓→#
˓→Brake
˓→both
(continues on next page) ˓→motors.
˓→
103
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
wheel.
˓→brake()
class PFMotor(s
Control
Power
Func-
tions
mo-
tors
with
the
in-
frared
func-
tion-
al-
ity
of
the
ColorDistan
Parameters
•
sensor
(ColorDista
–
Sen-
sor
ob-
ject.
•
channel
(int)
–
Chan-
nel
num-
ber
of
the
re-
ceiver:
1,
2,
3,
or
4.
•
104
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
color
(Color)
–
Color
marker
on
the
re-
ceiver:
Color.
BLUE
or
Color.
RED
•
positive_di
(Direction)
–
Which
di-
rec-
tion
the
mo-
tor
should
turn
when
you
give
a
pos-
itive duty cycle value.
dc(duty)
Rotates
the
mo-
tor
at
a
given
duty
cy-
cle
(also
known
as
“power”).
Parameters
duty
(per-
cent-
105
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
age:
%)
–
The
duty
cy-
cle
(-
100.0
to
100).
stop()
Stops
the
mo-
tor
and
lets
it
spin
freely.
The
mo-
tor
grad-
u-
ally
stops
due
to
fric-
tion.
brake()
Passively
brakes
the
mo-
tor.
The
mo-
tor
stops
due
to
fric-
tion,
plus
the
volt-
age
that
is
106
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
gen-
er-
ated
while
the motor is still moving.
5.5 Color
Sen-
sor
Show/hide
ex-
am-
ples
Example
1:
Mea-
sur-
ing
color
and
re-
flec-
tion
from
˓→pybricks.
˓→pupdevices
˓→import
˓→ColorSenso
from
˓→pybricks.
˓→parameters
˓→import
˓→Port
from
˓→pybricks.
˓→tools
˓→import
˓→wait
107
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→#
˓→Initialize
˓→the
˓→sensor.
˓→
sensor
˓→=
˓→ColorSenso
˓→A)
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→Read
˓→the
˓→color
˓→and
˓→reflection
˓→
˓→
˓→
˓→color
˓→=
˓→sensor.
˓→color()
˓→
˓→
˓→
˓→reflection
˓→=
˓→sensor.
˓→reflection
˓→
˓→
˓→
˓→
˓→#
˓→Print
˓→the
˓→measured
˓→color
˓→and
˓→reflection
˓→
˓→
˓→
(continues on next page) ˓→
˓→print(colo
˓→
108 ˓→reflection
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→Move
˓→the
˓→sensor
˓→around
˓→and
˓→see
˓→how
˓→
˓→
˓→
˓→
˓→#
˓→well
˓→you
˓→can
˓→detect
˓→colors.
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Wait
˓→so
˓→we
˓→can
˓→read
˓→the
˓→value.
˓→
˓→
˓→
˓→
˓→wait(100)
Example
2:
Wait-
ing
for
a
color
from
˓→pybricks.
(continues on next page)
˓→pupdevices
˓→import
109 ˓→ColorSenso
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→parameters
˓→import
˓→Port,
˓→
˓→Color
from
˓→pybricks.
˓→tools
˓→import
˓→wait
˓→#
˓→Initialize
˓→the
˓→sensor.
˓→
sensor
˓→=
˓→ColorSenso
˓→A)
˓→#
˓→This
˓→is
˓→a
˓→function
˓→that
˓→waits
˓→for
˓→a
˓→desired
˓→color.
˓→
def
˓→wait_
˓→for_
˓→color(desi
˓→color):
˓→
˓→
˓→
˓→
˓→#
˓→While
˓→the
˓→color
˓→is
˓→not
˓→the
˓→desired
˓→color,
(continues on next page) ˓→
˓→we
˓→keep
110 ˓→waiting.
˓→
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→while
˓→sensor.
˓→color()
˓→!
˓→=
˓→desired_
˓→color:
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→wait(20)
˓→#
˓→Now
˓→we
˓→use
˓→the
˓→function
˓→we
˓→just
˓→created
˓→above.
˓→
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→Here
˓→you
˓→can
˓→make
˓→your
˓→train/
˓→vehicle
˓→go
˓→forward.
˓→
˓→
˓→
(continues on next page) ˓→
˓→print(
˓→"Waiting
111 ˓→for
˓→red
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
˓→.
˓→.
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→wait_
˓→for_
˓→color(Colo
˓→RED)
˓→
˓→
˓→
˓→
˓→#
˓→Here
˓→you
˓→can
˓→make
˓→your
˓→train/
˓→vehicle
˓→go
˓→backward.
˓→
˓→
˓→
˓→
˓→print(
˓→"Waiting
˓→for
˓→blue
˓→.
˓→.
˓→.
˓→
")
˓→
˓→
˓→
˓→
˓→wait_
˓→for_
˓→color(Colo
˓→BLUE)
class ColorSens
LEGO®
SPIKE
Color
Sen-
sor.
Parameters
port
112
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
(Port)
–
Port
to
which
the
sen-
sor
is
con-
nected.
color(surface=Tru
Scans
the
color
of
a
sur-
face
or
an
ex-
ter-
nal
light
source.
You
choose
which
col-
ors
are
de-
tected
us-
ing
the
detectable_
method.
By
de-
fault,
it
de-
tects Color.RED, Color.YELLOW, Color.GREEN, Color.BLUE, Color.WHITE, or None.
Parameters
surface
(bool)
–
Choose
true
to
113
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
scan
the
color
of
ob-
jects
and
sur-
faces.
Choose
false
to scan the color of screens and other external light sources.
Returns
Detected
color.
Return type
Color
reflection()
Measures
the
re-
flec-
tion
of
a
sur-
face.
Returns
Reflection,
rang-
ing
from
0.0
(no
re-
flec-
tion)
to
100.0
(high
re-
flec-
tion).
Return type
percentage:
%
ambient()
Measures
the
am-
bi-
114
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
ent
light
in-
ten-
sity.
Returns
Ambient
light
in-
ten-
sity,
rang-
ing
from
0
(dark)
to
100
(bright).
Return type
percentage:
%
Advanced
color
sens-
ing
Show/hide
ex-
am-
ples
Example
1:
Read-
ing
hue,
sat-
u-
ra-
tion,
and
value
from
˓→pybri
˓→pupde
˓→impor
˓→Color
from
˓→pybri
˓→param
(continues on next page) ˓→impor
˓→Port
115
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→tools
˓→impor
˓→wait
˓→#
˓→Initi
˓→the
˓→senso
˓→
sensor
˓→=
˓→Color
˓→A)
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→The
˓→stand
˓→color
˓→metho
˓→alway
˓→
˓→"roun
˓→"
˓→the
˓→
˓→
˓→
˓→
˓→#
˓→measu
˓→to
˓→the
˓→neare
˓→
˓→"whol
˓→"
˓→color
˓→
˓→
˓→
˓→
˓→
˓→#
˓→That
˓→'s
(continues on next page) ˓→usefu
˓→for
˓→most
116 ˓→appli
˓→
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→But
˓→you
˓→can
˓→get
˓→the
˓→origi
˓→hue,
˓→
satur
˓→
˓→
˓→
˓→
˓→
˓→
˓→#
˓→and
˓→value
˓→witho
˓→
"roun
˓→
",
˓→
˓→
as
˓→
follo
˓→
˓→
˓→
˓→
˓→color
˓→=
˓→senso
˓→hsv()
˓→
˓→
˓→
˓→
˓→#
˓→Print
˓→the
˓→resul
˓→
˓→
˓→
˓→
print
˓→
117
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→Wait
˓→so
˓→we
˓→can
˓→read
˓→the
˓→value
˓→
˓→
˓→
˓→
wait(
˓→
Example
2:
Chang-
ing
the
de-
tectable
col-
ors
By
de-
fault,
the
sen-
sor
is
con-
fig-
ured
to
de-
tect
red,
yel-
low,
green,
blue,
white, or None, which suits many applications.
For
bet-
ter
re-
sults
118
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
in
your
ap-
pli-
ca-
tion,
you
can
mea-
sure
your
de-
sired
colors in advance, and tell the sensor to look only for those colors. Be sure to measure them at the same distance and
light conditions as in your final application. Then you’ll get very accurate results even for colors that are otherwise
hard to detect.
from
˓→pybri
˓→pupde
˓→impor
˓→Color
from
˓→pybri
˓→param
˓→impor
˓→Port,
˓→
˓→Color
from
˓→pybri
˓→tools
˓→impor
˓→wait
˓→#
˓→Initi
˓→the
˓→senso
˓→
sensor
˓→=
˓→Color
˓→A)
˓→#
˓→First
˓→
˓→decid
˓→which
˓→objec
˓→you
˓→want
˓→to
˓→detec
119
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→#
˓→Then
˓→measu
˓→their
˓→color
˓→with
˓→the
˓→hsv()
˓→metho
˓→
˓→#
˓→as
˓→shown
˓→in
˓→the
˓→previ
˓→examp
˓→
˓→Write
˓→them
˓→down
˓→#
˓→as
˓→shown
˓→below
˓→
˓→The
˓→name
˓→is
˓→optio
˓→
˓→but
˓→it
˓→is
˓→#
˓→usefu
˓→when
˓→you
˓→the
˓→color
˓→value
˓→
green
˓→=
˓→Color
˓→
˓→s=94,
˓→
˓→v=26,
˓→
˓→name=
˓→'GREE
(continues on next page) ˓→BRICK
˓→')
120
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→Color
˓→
˓→s=96,
˓→
˓→v=40,
˓→
˓→ name=
˓→ 'MAGE
˓→BRICK
˓→')
brown
˓→=
˓→Color
˓→
˓→s=78,
˓→
˓→v=15,
˓→
˓→ name=
˓→ 'BROW
˓→BRICK
˓→')
red
˓→=
˓→Color
˓→
˓→s=97,
˓→
˓→v=39,
˓→
˓→name=
˓→'RED_
˓→BRICK
˓→')
˓→#
˓→Put
˓→your
˓→color
˓→in
˓→a
˓→list
˓→or
˓→tuple
˓→
˓→#
˓→Inclu
˓→None
˓→is
˓→optio
˓→
˓→Just
˓→omit
(continues on next page) ˓→it
˓→if
121
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→#
˓→you
˓→alway
˓→want
˓→to
˓→get
˓→one
˓→of
˓→your
˓→color
˓→
my_
˓→color
˓→=
˓→(gree
˓→
˓→magen
˓→
˓→brown
˓→
˓→red,
˓→
˓→None)
˓→#
˓→Save
˓→your
˓→color
˓→
sensor.
˓→detec
˓→color
˓→color
˓→#
˓→color
˓→works
˓→as
˓→usual
˓→
˓→but
˓→it
˓→only
˓→#
˓→retur
˓→one
˓→of
˓→your
˓→speci
˓→color
˓→
while
˓→True:
(continues on next page)
122
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→color
˓→=
˓→senso
˓→color
˓→
˓→
˓→
˓→
˓→#
˓→Print
˓→the
˓→color
˓→
˓→
˓→
˓→
print
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Check
˓→which
˓→one
˓→it
˓→is.
˓→
˓→
˓→
˓→
˓→if
˓→color
˓→==
˓→magen
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→print
˓→"It
˓→works
˓→
(continues on next page) ")
˓→
123
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→Wait
˓→so
˓→we
˓→can
˓→read
˓→it.
˓→
˓→
˓→
˓→
wait(
˓→
Example
3:
Read-
ing
am-
bi-
ent
hue,
sat-
u-
ra-
tion,
value,
and
color
from
˓→pybri
˓→pupde
˓→impor
˓→Color
from
˓→pybri
˓→param
˓→impor
˓→Port
from
˓→pybri
˓→tools
˓→impor
˓→wait
˓→#
˓→Initi
˓→the
(continues on next page)
˓→senso
˓→
124
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→Color
˓→A)
˓→#
˓→Repea
˓→forev
˓→
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→Get
˓→the
˓→ambie
˓→color
˓→value
˓→
˓→Inste
˓→of
˓→scann
˓→the
˓→color
˓→of
˓→ a surface,
˓→
˓→
˓→
˓→
˓→#
˓→this
˓→lets
˓→you
˓→scan
˓→the
˓→color
˓→of
˓→light
˓→sourc
˓→like
˓→lamps
˓→or
˓→ screens.
˓→
˓→
˓→
˓→hsv
˓→=
(continues on next page) ˓→senso
˓→hsv(s
125
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→color
˓→=
˓→senso
˓→color
˓→
˓→
˓→
˓→
˓→#
˓→Get
˓→the
˓→ambie
˓→light
˓→inten
˓→
˓→
˓→
˓→
˓→ambie
˓→=
˓→senso
˓→ambie
˓→
˓→
˓→
˓→
˓→#
˓→Print
˓→the
˓→measu
˓→
˓→
˓→
˓→
print
˓→
˓→
color
˓→
˓→
ambie
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Point
(continues on next page) ˓→the
˓→senso
˓→at
126 ˓→a
˓→compu
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
˓→scree
˓→or
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
#
˓→
Also,
˓→
˓→
˓→cover
˓→the
˓→senso
˓→with
˓→your
˓→hands
˓→and
˓→watch
˓→the
˓→ambie
˓→ value.
˓→
˓→
˓→
˓→
˓→#
˓→Wait
˓→so
˓→we
˓→can
˓→read
˓→the
˓→line
˓→
˓→
˓→
wait(
˓→
hsv(surface=True)
Scans
the
color
of
a
sur-
face
or
an
ex-
ter-
nal
light
source.
127
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
This
method
is
sim-
i-
lar
to
color(),
but
it
gives
the
full
range
of
hue,
sat-
u-
ration and brightness values, instead of rounding it to the nearest detectable color.
Parameters
surface
(bool)
–
Choose
true
to
scan
the
color
of
ob-
jects
and
sur-
faces.
Choose
false
to scan the color of screens and other external light sources.
Returns
Measured
color.
The
color
is
de-
scribed
by
a
hue
(0–359),
a
sat-
u-
128
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
ra-
tion
(0–100),
and a brightness value (0–100).
Return type
Color
detectable_colo
Configures
which
col-
ors
the
color()
method
should
de-
tect.
Specify
only
col-
ors
that
you
wish
to
de-
tect
in
your
ap-
pli-
ca-
tion.
This
way,
the full-color measurements are rounded to the nearest desired color, and other colors are ignored. This improves
reliability.
If
you
give
no
ar-
gu-
ments,
the
cur-
rently
cho-
sen
col-
ors
will
129
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
be
re-
turned
as a tuple.
Parameters
colors
(list)
–
List
of
Color
ob-
jects:
the
col-
ors
that
you
want
to
de-
tect.
You can pick standard colors such as Color.MAGENTA, or provide your own colors like Color(h=348, s=96,
v=40, name='MY_MAGENTA_BRICK') for even better results. You measure your own colors with the hsv()
method.
Built-
in
lights
This
sen-
sor
has
3
built-
in
lights.
You
can
ad-
just
the
bright-
ness
of
each
light.
If you use the sensor to measure something, the lights will be turned on or off as needed for the measurement.
Show/hide
ex-
am-
130
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
ples
Example:
Blink-
ing
the
built-
in
lights
from
˓→pybri
˓→pupde
˓→impor
˓→Color
from
˓→pybri
˓→param
˓→impor
˓→Port
from
˓→pybri
˓→tools
˓→impor
˓→wait
˓→#
˓→Initi
˓→the
˓→senso
˓→
sensor
˓→=
˓→Color
˓→A)
˓→#
˓→Repea
˓→forev
˓→
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→Turn
˓→on
˓→one
˓→light
˓→at
˓→a
˓→time,
˓→at
˓→half
131 ˓→the
˓→brigh
LEGO, the LEGO
˓→ logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→Do
˓→this
˓→for
˓→all
˓→3
˓→light
˓→and
˓→repea
˓→that
˓→5
˓→times
˓→
˓→
˓→
˓→
˓→for
˓→i
˓→in
˓→range
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→senso
˓→light
˓→on(50
˓→
0,
˓→
˓→
0)
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
wait(
˓→
˓→
˓→
˓→
˓→
˓→
˓→
(continues on next page) ˓→
˓→senso
˓→light
132 ˓→on(0,
˓→
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
50,
˓→
˓→
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→
˓→
˓→
wait(
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→senso
˓→light
˓→on(0,
˓→
0,
˓→
˓→
50)
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
wait(
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Turn
˓→all
˓→light
˓→on
˓→at
˓→maxim
˓→brigh
˓→
˓→
˓→
˓→
˓→senso
˓→light
˓→on(10
˓→
(continues on next page) ˓→
˓→
wait(
˓→
133
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→Turn
˓→all
˓→light
˓→off.
˓→
˓→
˓→
˓→
˓→senso
˓→light
˓→off()
˓→
˓→
˓→
wait(
˓→
lights.on(bright
Turns
on
the
lights
at
the
spec-
i-
fied
bright-
ness.
Parameters
brightness
(tu-
ple
of
bright-
ness:
%)
–
Bright-
ness
of
each
light,
in
the
or-
134
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
der
shown above. If you give one brightness value instead of a tuple, all lights get the same brightness.
lights.off()
Turns
off
all
the
lights.
5.6 Ultras
Sen-
sor
Show/hide
ex-
am-
ples
Example
1:
Mea-
sur-
ing
dis-
tance
and
switch-
ing
on
the
lights
from
˓→pybricks.
˓→pupdevices
˓→import
˓→Ultrasonic
from
˓→pybricks.
˓→parameters
˓→import
˓→Port
(continues on next page)
135
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→tools
˓→import
˓→wait
˓→#
˓→Initialize
˓→the
˓→sensor.
˓→
eyes
˓→=
˓→Ultrasonic
˓→A)
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→Print
˓→the
˓→measured
˓→distance.
˓→
˓→
˓→
˓→
˓→print(eyes
˓→distance()
˓→
˓→
˓→
˓→
˓→#
˓→If
˓→an
˓→object
˓→is
˓→detected
˓→closer
˓→than
˓→500mm:
˓→
˓→
˓→
˓→if
˓→eyes.
(continues on next page) ˓→distance()
˓→
˓→<
136 ˓→500:
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Turn
˓→the
˓→lights
˓→on.
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→eyes.
˓→lights.
˓→on(100)
˓→
˓→
˓→
else:
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Turn
˓→the
˓→lights
˓→off.
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→eyes.
˓→lights.
˓→off()
(continues on next page)
137
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→Wait
˓→some
˓→time
˓→so
˓→we
˓→can
˓→read
˓→what
˓→is
˓→printed.
˓→
˓→
˓→
˓→
˓→wait(100)
Example
2:
Us-
ing
math
to
grad-
u-
ally
change
the
bright-
ness
of
the
lights
from
˓→pybricks.
˓→pupdevices
˓→import
˓→Ultrasonic
from
˓→pybricks.
˓→parameters
˓→import
˓→Port
from
˓→pybricks.
˓→tools
˓→import
˓→wait,
(continues on next page)
˓→
˓→StopWatch
138
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→#
˓→The
˓→math
˓→module
˓→is
˓→part
˓→of
˓→standard
˓→MicroPytho
˓→ #
˓→ https:/
˓→/
˓→docs.
˓→micropytho
˓→org/
˓→en/
˓→latest/
˓→library/
˓→math.
˓→html
from
˓→math
˓→import
˓→pi,
˓→
˓→sin
˓→#
˓→Initialize
˓→the
˓→sensor.
˓→
eyes
˓→=
˓→Ultrasonic
˓→A)
˓→#
˓→Initialize
˓→a
˓→timer.
˓→
watch
˓→=
˓→StopWatch(
˓→#
˓→We
˓→want
˓→one
˓→full
(continues on next page) ˓→light
˓→cycle
˓→to
139 ˓→last
˓→three
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
˓→seconds.
˓→
Pybricks Modules and Examples Version v3.0.0a3
˓→3000
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→The
˓→phase
˓→is
˓→where
˓→we
˓→are
˓→in
˓→the
˓→unit
˓→circle
˓→now.
˓→
˓→
˓→
˓→
˓→phase
˓→=
˓→watch.
˓→time()/
˓→PERIOD*2*p
˓→
˓→
˓→
˓→
˓→#
˓→Each
˓→light
˓→follows
˓→a
˓→sine
˓→wave
˓→with
˓→a
˓→mean
˓→of
˓→50,
˓→
˓→
˓→
˓→
(continues on next page) ˓→
˓→#
˓→We
140 ˓→offset
˓→this
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
˓→sine
˓→wave
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→lights
˓→do
˓→something
˓→different.
˓→
˓→
˓→
˓→
˓→brightness
˓→=
˓→[sin(phase
˓→+
˓→offset*pi/
˓→2)
˓→*
˓→50
˓→+
˓→50
˓→for
˓→offset
˓→in
˓→range(4)]
˓→
˓→
˓→
˓→
˓→#
˓→Set
˓→the
˓→brightness
˓→values
˓→for
˓→all
˓→lights.
˓→
˓→The
˓→*
˓→symbol
˓→unpacks
˓→ the list
˓→
˓→
˓→
˓→
˓→#
˓→of
˓→brightness
(continues on next page) ˓→values
˓→into
˓→separate
141 ˓→arguments.
˓→
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→eyes.
˓→lights.
˓→on(*bright
˓→
˓→
˓→
˓→
˓→#
˓→Wait
˓→some
˓→time.
˓→
˓→
˓→
˓→
wait(50)
˓→
class Ultrasoni
LEGO®
SPIKE
Color
Sen-
sor.
Parameters
port
(Port)
–
Port
to
which
the
sen-
sor
is
con-
nected.
distance()
Measures
the
dis-
tance
be-
tween
the
sen-
sor
and
142
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
an
ob-
ject
us-
ing
ul-
tra-
sonic sound waves.
Returns
Measured
dis-
tance.
If
no
valid
dis-
tance
was
mea-
sured,
it
re-
turns
2000
mm.
Return type
distance:
mm
presence()
Checks
for
the
pres-
ence
of
other
ul-
tra-
sonic
sen-
sors
by
de-
tect-
ing
ul-
trasonic sounds.
Returns
True
if
ul-
tra-
143
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
sonic
sounds
are
de-
tected,
False
if
not.
Return type
bool
Built-
in
lights
This
sen-
sor
has
4
built-
in
lights.
You
can
ad-
just
the
bright-
ness
of
each
light.
lights.on(bright
Turns
on
the
lights
at
the
spec-
i-
fied
bright-
ness.
Parameters
brightness
(tu-
ple
of
144
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
bright-
ness:
%)
–
Bright-
ness
of
each
light,
in
the
or-
der
shown above. If you give one brightness value instead of a tuple, all lights get the same brightness.
lights.off()
Turns
off
all
the
lights.
5.7 Force
Sen-
sor
Show/hide
ex-
am-
ples
Example
1:
Mea-
sur-
ing
force
and
move-
ment
145
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
from
˓→pybricks.
˓→pupdevices
˓→import
˓→ForceSenso
from
˓→pybricks.
˓→parameters
˓→import
˓→Port
from
˓→pybricks.
˓→tools
˓→import
˓→wait
˓→#
˓→Initialize
˓→the
˓→sensor.
˓→
button
˓→=
˓→ForceSenso
˓→A)
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→Read
˓→all
˓→the
˓→informatio
˓→we
˓→can
˓→get
˓→from
˓→this
˓→sensor.
˓→
˓→
˓→
˓→
˓→force
˓→=
˓→button.
˓→force()
˓→
˓→
˓→
(continues on next page)
˓→dist
˓→=
˓→button.
146
˓→distance()
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→press
˓→=
˓→button.
˓→pressed()
˓→
˓→
˓→
˓→touch
˓→=
˓→button.
˓→touched()
˓→
˓→
˓→
˓→
˓→#
˓→Print
˓→the
˓→values
˓→
˓→
˓→
˓→print(
˓→"Force
˓→",
˓→
force,
˓→
˓→
˓→
"Dist:
˓→
",
˓→
˓→
dist,
˓→
˓→
˓→
"Pressed:
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Push
˓→the
˓→sensor
˓→button
˓→see
(continues on next page) ˓→what
˓→happens
˓→to
147 ˓→the
˓→values.
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
˓→
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→Wait
˓→some
˓→time
˓→so
˓→we
˓→can
˓→read
˓→what
˓→is
˓→printed.
˓→
˓→
˓→
˓→
˓→wait(200)
Example
2:
Mea-
sur-
ing
peak
force
from
˓→pybricks.
˓→pupdevices
˓→import
˓→ForceSenso
from
˓→pybricks.
˓→parameters
˓→import
˓→Port
from
˓→pybricks.
˓→tools
˓→import
˓→wait
˓→#
˓→Initialize
˓→the
˓→sensor.
˓→
button
˓→=
˓→ForceSenso
(continues on next page)
˓→A)
148
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→#
˓→This
˓→function
˓→waits
˓→until
˓→the
˓→button
˓→is
˓→pushed.
˓→
˓→It
˓→keeps
˓→track
˓→of
˓→the
˓→maximum
˓→#
˓→detected
˓→force
˓→until
˓→the
˓→button
˓→is
˓→released.
˓→
˓→Then
˓→it
˓→returns
˓→the
˓→maximum.
˓→
def
˓→wait_
˓→for_
˓→force():
˓→
˓→
˓→
˓→
˓→#
˓→Wait
˓→for
˓→a
˓→force,
˓→
˓→by
˓→doing
˓→nothing
˓→for
˓→as
˓→long
(continues on next page) ˓→the
149
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→print(
˓→"Waiting
˓→for
˓→force.
˓→
")
˓→
˓→
˓→
˓→
˓→while
˓→button.
˓→force()
˓→
˓→<=
˓→0.
˓→1:
˓→
˓→
˓→
˓→
˓→
˓→
˓→
wait(10)
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Now
˓→we
˓→wait
˓→for
˓→the
˓→release,
˓→
˓→by
˓→waiting
˓→for
˓→the
˓→force
˓→ to be zero again.
˓→
˓→
˓→
˓→print(
˓→"Waiting
˓→for
(continues on next page) ˓→release.
˓→
")
˓→
150
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→While
˓→we
˓→wait
˓→for
˓→that
˓→to
˓→happen,
˓→
˓→we
˓→keep
˓→reading
˓→the
˓→
˓→
˓→
˓→
˓→#
˓→the
˓→maximum
˓→force.
˓→
˓→We
˓→do
˓→this
˓→by
˓→initializi
˓→the
˓→maximum
˓→at
˓→ 0, and
˓→
˓→
˓→
˓→
˓→#
˓→updating
˓→it
˓→each
˓→time
˓→we
˓→detect
˓→a
˓→bigger
˓→force.
˓→
˓→
(continues on next page) ˓→
˓→
˓→maximum
151 ˓→=
˓→0
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→force
˓→=
˓→10
˓→
˓→
˓→
˓→while
˓→force
˓→>
˓→
0.
˓→
1:
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Read
˓→the
˓→force.
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→force
˓→=
˓→button.
˓→force()
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Update
˓→the
˓→maximum
(continues on next page) ˓→if
˓→the
˓→measured
152 ˓→force
˓→is
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
˓→ larger.
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→if
˓→force
˓→>
˓→
maximum:
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→maximum
˓→=
˓→force
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Wait
˓→and
˓→then
˓→measure
˓→again.
˓→
˓→
˓→
˓→
˓→
˓→
˓→
˓→
wait(10)
˓→
˓→
(continues on next page) ˓→
˓→
˓→
153 ˓→#
˓→Return
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
˓→the
˓→maximum
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→return
˓→maximum
˓→#
˓→Keep
˓→waiting
˓→for
˓→the
˓→sensor
˓→button
˓→to
˓→be
˓→pushed.
˓→
˓→When
˓→it
˓→is,
˓→
˓→display
˓→#
˓→the
˓→peak
˓→force
˓→and
˓→repeat.
˓→
while
˓→True:
˓→
˓→
˓→
˓→peak
˓→=
˓→wait_
˓→for_
˓→force()
˓→
˓→
˓→
˓→print(
˓→"Released.
˓→
˓→Peak
˓→force:
˓→
˓→{0}
˓→
˓→N\n
(continues on next page) ˓→".
˓→format(pea
154
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
class ForceSens
LEGO®
SPIKE
Force
Sen-
sor.
Parameters
port
(Port)
–
Port
to
which
the
sen-
sor
is
con-
nected.
force()
Measures
the
force
ex-
erted
on
the
sen-
sor.
Returns
Measured
force
(up
to
ap-
prox-
i-
mately
10.00
N).
Return type
force:
N
distance()
Measures
by
how
much
the
155
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
sen-
sor
but-
ton
has
moved.
Returns
How
much
the
sen-
sor
but-
ton
has
moved
(up
to
ap-
prox-
i-
mately
8.00
mm).
Return type
distance:
mm
pressed(force=3)
Checks
if
the
sen-
sor
but-
ton
is
pressed.
Parameters
force
(force:
N)
–
Min-
i-
mum
force
to
be
con-
sid-
ered
pressed.
156
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Returns
True
if
the
sen-
sor
is
pressed,
False
if
it
is
not.
Return type
bool
touched()
Checks
if
the
sen-
sor
is
touched.
This
is
sim-
i-
lar
to
pressed(),
but
it
de-
tects
slight
move-
ments
of
the
but-
ton
even when the measured force is still considered zero.
Returns
True
if
the
sen-
sor
is
touched
or
pressed,
157
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
False
if
it
is
not.
Return type
bool
5.8 Infrar
Sen-
sor
Show/hide
ex-
am-
ple
Example:
Mea-
sur-
ing
dis-
tance,
ob-
ject
count,
and
re-
flec-
tion
from
˓→pybricks.
˓→pupdevices
˓→import
˓→InfraredSe
from
˓→pybricks.
˓→parameters
˓→import
˓→Port
158
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→tools
˓→import
˓→wait
˓→#
˓→Initialize
˓→the
˓→sensor.
˓→
ir
˓→=
˓→InfraredSe
˓→A)
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→Read
˓→all
˓→the
˓→informatio
˓→we
˓→can
˓→get
˓→from
˓→this
˓→sensor.
˓→
˓→
˓→
˓→
˓→dist
˓→=
˓→ir.
˓→distance()
˓→
˓→
˓→
˓→count
˓→=
˓→ir.
˓→count()
˓→
˓→
˓→
˓→ref
(continues on next page) ˓→=
˓→ir.
˓→reflection
159
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→Print
˓→the
˓→values
˓→
˓→
˓→
˓→print(
˓→"Distance:
˓→",
˓→
dist,
˓→
˓→
˓→
"Count:
˓→
",
˓→
˓→
count,
˓→
˓→
˓→
"Reflectio
˓→
˓→ ", ref)
˓→
˓→
˓→
˓→
˓→#
˓→Move
˓→the
˓→sensor
˓→around
˓→and
˓→move
˓→your
˓→hands
˓→in
˓→front
˓→
˓→
˓→
˓→
˓→#
˓→of
˓→it
˓→to
˓→see
˓→what
(continues on next page) ˓→happens
˓→to
˓→the
160 ˓→values.
˓→
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→Wait
˓→some
˓→time
˓→so
˓→we
˓→can
˓→read
˓→what
˓→is
˓→printed.
˓→
˓→
˓→
˓→
wait(200)
˓→
class InfraredS
LEGO®
Pow-
ered
Up
In-
frared
Sen-
sor.
Parameters
port
(Port)
–
Port
to
which
the
sen-
sor
is
con-
nected.
distance()
Measures
the
rel-
a-
tive
dis-
tance
161
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
be-
tween
the
sen-
sor
and
an
ob-
ject
us-
ing infrared light.
Returns
Relative
dis-
tance
rang-
ing
from
0
(clos-
est)
to
100
(far-
thest).
Return type
relative
dis-
tance:
%
reflection()
Measures
the
re-
flec-
tion
of
a
sur-
face
us-
ing
an
in-
frared
light.
Returns
Reflection,
rang-
ing
from
0.0
162
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
(no
re-
flec-
tion)
to
100.0
(high
re-
flec-
tion).
Return type
percentage:
%
count()
Counts
the
num-
ber
of
ob-
jects
that
have
passed
by
the
sen-
sor.
Returns
Number
of
ob-
jects
counted.
Return type
int
5.9 Tilt
Sen-
sor
Show/hide
ex-
am-
ple
Example:
Mea-
sur-
ing
163
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
pitch
and
roll
from
˓→pybricks.
˓→pupdevices
˓→import
˓→TiltSensor
from
˓→pybricks.
˓→parameters
˓→import
˓→Port
from
˓→pybricks.
˓→tools
˓→import
˓→wait
˓→#
˓→Initialize
˓→the
˓→sensor.
˓→
accel
˓→=
˓→TiltSensor
˓→A)
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→Read
˓→the
˓→tilt
˓→angles
˓→relative
˓→to
˓→the
˓→horizontal
(continues on next page)
˓→plane.
˓→
164
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
pitch,
˓→
˓→
˓→roll
˓→=
˓→accel.
˓→tilt()
˓→
˓→
˓→
˓→
˓→#
˓→Print
˓→the
˓→values
˓→
˓→
˓→
˓→print(
˓→"Pitch:
˓→",
˓→
pitch,
˓→
˓→
˓→
"Roll:
˓→
",
˓→
˓→
roll)
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Wait
˓→some
˓→time
˓→so
˓→we
˓→can
˓→read
˓→what
˓→is
˓→printed.
˓→
˓→
˓→
˓→
(continues on next page) wait(100)
˓→
165
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
class TiltSenso
LEGO®
Pow-
ered
Up
Tilt
Sen-
sor.
Parameters
port
(Port)
–
Port
to
which
the
sen-
sor
is
con-
nected.
tilt()
Measures
the
tilt
rel-
a-
tive
to
the
hor-
i-
zon-
tal
plane.
Returns
Tuple
of
pitch
and
roll
an-
gles.
Return type
(angle:
deg,
an-
gle:
deg)
166
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
5.10 Ligh
Show/hide
ex-
am-
ples
Example
1:
Mak-
ing
the
light
blink
from
˓→pybricks.
˓→pupdevices
˓→import
˓→Light
from
˓→pybricks.
˓→parameters
˓→import
˓→Port
from
˓→pybricks.
˓→tools
˓→import
˓→wait
˓→#
˓→Initialize
˓→the
˓→light.
˓→
light
˓→=
˓→Light(Port
˓→A)
˓→#
˓→Blink
(continues on next page)
˓→the
˓→light
˓→forever.
167
˓→
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→Turn
˓→the
˓→light
˓→on
˓→at
˓→100
˓→%
˓→brightness
˓→
˓→
˓→
˓→
˓→light.
˓→on(100)
˓→
˓→
˓→
˓→wait(500)
˓→
˓→
˓→
˓→
˓→#
˓→Turn
˓→the
˓→light
˓→off.
˓→
˓→
˓→
˓→
˓→light.
˓→off()
˓→
˓→
˓→
˓→wait(500)
Example
2:
Us-
ing
math
168
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
to
grad-
u-
ally
change
the
bright-
ness
of
the
light
from
˓→pybricks.
˓→pupdevices
˓→import
˓→Light
from
˓→pybricks.
˓→parameters
˓→import
˓→Port
from
˓→pybricks.
˓→tools
˓→import
˓→wait,
˓→
˓→StopWatch
˓→#
˓→The
˓→math
˓→module
˓→is
˓→part
˓→of
˓→standard
˓→MicroPytho
˓→ #
˓→ https:/
˓→/
˓→docs.
˓→micropytho
˓→org/
˓→en/
˓→latest/
˓→library/
˓→math.
˓→html
from
˓→math
˓→import
˓→pi,
˓→
169
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
˓→#
˓→Initialize
˓→the
˓→light
˓→and
˓→a
˓→StopWatch.
˓→
light
˓→=
˓→Light(Port
˓→A)
watch
˓→=
˓→StopWatch(
˓→#
˓→Cosine
˓→pattern
˓→properties
˓→
PERIOD
˓→=
˓→2000
MAX
˓→=
˓→100
˓→#
˓→Make
˓→the
˓→brightness
˓→fade
˓→in
˓→and
˓→out.
˓→
while
˓→True:
˓→
˓→
˓→
˓→
˓→#
˓→Get
˓→phase
˓→of
˓→the
˓→cosine.
˓→
˓→
(continues on next page) ˓→
˓→
˓→phase
170 ˓→=
˓→watch.
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
˓→time()/
˓→PERIOD*2*p
Pybricks Modules and Examples Version v3.0.0a3
˓→
˓→
˓→
˓→
˓→#
˓→Evaluate
˓→the
˓→brightness
˓→
˓→
˓→
˓→
˓→brightness
˓→=
˓→(0.
˓→5
˓→-
˓→
0.
˓→
5*cos(phas
˓→
˓→
˓→
˓→
˓→
˓→#
˓→Set
˓→light
˓→brightness
˓→and
˓→wait
˓→a
˓→bit.
˓→
˓→
˓→
˓→
light.
˓→
on(brightn
˓→
˓→
˓→
˓→
wait(10)
˓→
class Light(port
LEGO®
Pow-
ered
Up
Light.
171
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Parameters
port
(Port)
–
Port
to
which
the
de-
vice
is
con-
nected.
on(brightness=100)
Turns
on
the
light
at
the
spec-
i-
fied
bright-
ness.
Parameters
brightness
(bright-
ness:
%)
–
Bright-
ness
of
the
light.
off()
Turns
off
the
light.
172
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 6
6.1 Motors
Figure 6.1: EV3-compatible motors. The arrows indicate the default positive direction.
173
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Measuring
speed()
Gets the speed of the motor.
Returns Motor speed.
Return type rotational speed: deg/s
angle()
Gets the rotation angle of the motor.
Returns Motor angle.
Return type angle: deg
reset_angle(angle)
Sets the accumulated rotation angle of the motor to a desired value.
Parameters angle (angle: deg) – Value to which the angle should be reset.
Stopping
stop()
Stops the motor and lets it spin freely.
The motor gradually stops due to friction.
brake()
Passively brakes the motor.
The motor stops due to friction, plus the voltage that is generated while the motor is still moving.
hold()
Stops the motor and actively holds it at its current angle.
Action
run(speed)
Runs the motor at a constant speed.
The motor accelerates to the given speed and keeps running at this speed until you give a new command.
Parameters speed (rotational speed: deg/s) – Speed of the motor.
run_time(speed, time, then=Stop.HOLD, wait=True)
Runs the motor at a constant speed for a given amount of time.
The motor accelerates to the given speed, keeps running at this speed, and then decelerates. The total
maneuver lasts for exactly the given amount of time.
Parameters
• speed (rotational speed: deg/s) – Speed of the motor.
• time (time: ms) – Duration of the maneuver.
• then (Stop) – What to do after coming to a standstill.
• wait (bool) – Wait for the maneuver to complete before continuing with the rest of the
program.
174
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
track_target(target_angle)
Tracks a target angle. This is similar to run_target(), but the usual smooth acceleration is skipped: it
will move to the target angle as fast as possible. This method is useful if you want to continuously change
the target angle.
Parameters target_angle (angle: deg) – Target angle that the motor should rotate to.
175
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
control
The motors use PID control to accurately track the speed and angle targets that you specify. You can
change its behavior through the control attribute of the motor. See The Control Class for an overview
of available methods.
class TouchSensor(port)
LEGO® MINDSTORMS® EV3 Touch Sensor.
Parameters port (Port) – Port to which the sensor is connected.
pressed()
Checks if the sensor is pressed.
Returns True if the sensor is pressed, False if it is not pressed.
Return type bool
class ColorSensor(port)
LEGO® MINDSTORMS® EV3 Color Sensor.
Parameters port (Port) – Port to which the sensor is connected.
color()
Measures the color of a surface.
Returns Color.BLACK, Color.BLUE, Color.GREEN, Color.YELLOW, Color.RED,
Color.WHITE, Color.BROWN or None.
Return type Color, or None if no color is detected.
ambient()
Measures the ambient light intensity.
Returns Ambient light intensity, ranging from 0 (dark) to 100 (bright).
176
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Each method of this class puts the sensor in a different mode. Switching modes takes about one second on this sensor.
To make sure that your program runs quickly, use only of these methods in your program.
class InfraredSensor(port)
LEGO® MINDSTORMS® EV3 Infrared Sensor and Beacon.
Parameters port (Port) – Port to which the sensor is connected.
distance()
Measures the relative distance between the sensor and an object using infrared light.
Returns Relative distance ranging from 0 (closest) to 100 (farthest).
Return type relative distance: %
beacon(channel)
Measures the relative distance and angle between the remote and the infrared sensor.
Parameters channel (int) – Channel number of the remote.
Returns Tuple of relative distance (0 to 100) and approximate angle (-75 to 75 degrees) between
remote and infrared sensor.
Return type (relative distance: %, angle: deg) or (None, None) if no remote is detected.
buttons(channel)
Checks which buttons on the infrared remote are pressed.
This method can detect up to two buttons at once. If you press more buttons, you may not get useful data.
Parameters channel (int) – Channel number of the remote.
Returns List of pressed buttons on the remote on selected channel.
177
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
class UltrasonicSensor(port)
LEGO® MINDSTORMS® EV3 Ultrasonic Sensor.
Parameters port (Port) – Port to which the sensor is connected.
distance(silent=False)
Measures the distance between the sensor and an object using ultrasonic sound waves.
Parameters silent (bool) – Choose True to turn the sensor off after measuring the distance.
This reduces interference with other ultrasonic sensors. If you do this too frequently, the
sensor can freeze. If this happens, unplug it and plug it back in.
Returns Distance.
Return type distance: mm
presence()
Checks for the presence of other ultrasonic sensors by detecting ultrasonic sounds.
If the other ultrasonic sensor is operating in silent mode, you can only detect the presence of that sensor
while it is taking a measurement.
Returns True if ultrasonic sounds are detected, False if not.
Return type bool
178
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
179
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 7
Use LEGO® MINDSTORMS® NXT motors and sensors with the EV3 brick.
This motor works just like a LEGO MINDSTORMS EV3 Large Motor. You can use it in your programs using the
Motor class.
class TouchSensor(port)
LEGO® MINDSTORMS® NXT Touch Sensor.
Parameters port (Port) – Port to which the sensor is connected.
pressed()
Checks if the sensor is pressed.
Returns True if the sensor is pressed, False if it is not pressed.
Return type bool
180
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
class LightSensor(port)
LEGO® MINDSTORMS® NXT Color Sensor.
Parameters port (Port) – Port to which the sensor is connected.
ambient()
Measures the ambient light intensity.
Returns Ambient light intensity, ranging from 0 (dark) to 100 (bright).
Return type percentage: %
reflection()
Measures the reflection of a surface using a red light.
Returns Reflection, ranging from 0 (no reflection) to 100 (high reflection).
Return type percentage: %
class ColorSensor(port)
LEGO® MINDSTORMS® NXT Color Sensor.
Parameters port (Port) – Port to which the sensor is connected.
color()
Measures the color of a surface.
Returns Color.BLACK, Color.BLUE, Color.GREEN, Color.YELLOW, Color.RED,
Color.WHITE or None.
Return type Color, or None if no color is detected.
ambient()
Measures the ambient light intensity.
Returns Ambient light intensity, ranging from 0 (dark) to 100 (bright).
181
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Built-in light
This sensor has a built-in light. You can make it red, green, blue, or turn it off.
light.on(color)
Turns on the light at the specified color.
Parameters color (Color) – Color of the light.
light.off()
Turns off the light.
class UltrasonicSensor(port)
LEGO® MINDSTORMS® NXT Ultrasonic Sensor.
Parameters port (Port) – Port to which the sensor is connected.
distance()
Measures the distance between the sensor and an object using ultrasonic sound waves.
Returns Distance.
Return type distance: mm
182
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
class TemperatureSensor(port)
LEGO® MINDSTORMS® NXT Temperature Sensor.
Parameters port (Port) – Port to which the sensor is connected.
temperature()
Measures the temperature.
Returns Measured temperature.
Return type temperature: °C
183
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
184
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
If you did not provide a conversion function earlier, no conversion will be applied.
Parameters voltage (voltage: mV) – Analog sensor voltage
Returns Converted sensor value.
Return type float
value()
Measures the sensor voltage() and then applies your conversion() to give you the sensor value.
Returns Converted sensor value.
Return type float
Show/hide example
Example: Using the Surface Temperature Sensor.
#!/usr/bin/env pybricks-micropython
from pybricks.parameters import Port
from pybricks.nxtdevices import VernierAdapter
185
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 8
Note: This module provides classes to interact with unofficial motors, sensors, and other custom electronics. You
should only connect custom electronics or unofficial devices if you know what you are doing. Proceed with caution.
class LUMPDevice(port)
Devices using the LEGO UART Messaging Protocol.
Parameters port (Port) – Port to which the device is connected.
read(mode)
Reads values from a given mode.
Parameters mode (int) – Device mode.
186
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
class AnalogSensor(port)
Generic or custom analog sensor.
Parameters port (Port) – Port to which the sensor is connected.
voltage()
Measures analog voltage.
Returns Analog voltage.
Return type voltage: mV
resistance()
Measures resistance.
This value is only meaningful if the analog device is a passive load such as a resistor or thermistor.
Returns Resistance of the analog device.
Return type resistance: Ω
active()
Sets sensor to active mode. This sets pin 5 of the sensor port to high.
This is used in some analog sensors to control a switch. For example, if you use the NXT Light Sensor
as a custom analog sensor, this method will turn the light on. From then on, voltage() returns the raw
reflected light value.
passive()
Sets sensor to passive mode. This sets pin 5 of the sensor port to low.
This is used in some analog sensors to control a switch. For example, if you use the NXT Light Sensor
as a custom analog sensor, this method will turn the light off. From then on, voltage() returns the raw
ambient light value.
187
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
#!/usr/bin/env pybricks-micropython
from pybricks.hubs import EV3Brick
from pybricks.iodevices import I2CDevice
from pybricks.parameters import Port
188
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
I2C addresses are 7-bit values. However, most vendors who make LEGO compatible sensors provide an 8-bit address
in their documentation. To use those addresses, you must shift them by 1 bit. For example, if the documented address
is 0xD2, you can do address = 0xD2 >> 1.
Some rudimentary I2C devices do not require a register argument or even any data. You can achieve this behavior as
shown in the examples below.
Show/hide example
Example: Advanced I2C read and write techniques.
#!/usr/bin/env pybricks-micropython
from pybricks.hubs import EV3Brick
from pybricks.iodevices import I2CDevice
from pybricks.parameters import Port
189
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
190
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
#!/usr/bin/env pybricks-micropython
from pybricks.hubs import EV3Brick
from pybricks.iodevices import UARTDevice
from pybricks.parameters import Port
from pybricks.media.ev3dev import SoundFile
8.5 DC Motor
191
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
EV3 MicroPython is built on top of ev3dev, which means that a sensor may be supported even if it is not listed in this
documentation. If so, you can use it with the Ev3devSensor class. This is easier and faster than using the custom
device classes given above.
To check whether you can use the Ev3devSensor class:
• Plug the sensor into your EV3 Brick.
• Go to the main menu of the EV3 Brick.
• Select Device Browser and then Sensors.
• If your sensor shows up, you can use it.
Now select your sensor from the menu and choose set mode. This shows all available modes for this sensor. You can
use these mode names as the mode setting below.
To learn more about compatible devices and what each mode does, visit the ev3dev sensors page.
class Ev3devSensor(port)
Read values of an ev3dev-compatible sensor.
Parameters port (Port) – Port to which the device is connected.
sensor_index
Index of the ev3dev sysfs lego-sensor class.
port_index
Index of the ev3dev sysfs lego-port class.
read(mode)
Reads values at a given mode.
Parameters mode (str) – Mode name.
Returns Values read from the sensor.
Return type tuple
192
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
#!/usr/bin/env pybricks-micropython
from pybricks.parameters import Port
from pybricks.tools import wait
from pybricks.iodevices import Ev3devSensor
# Initialize an Ev3devSensor.
# In this example we use the
# LEGO MINDSTORMS EV3 Color Sensor.
sensor = Ev3devSensor(Port.S3)
while True:
# Read the raw RGB values
r, g, b = sensor.read('RGB-RAW')
# Print results
print('R: {0}\t G: {1}\t B: {2}'.format(r, g, b))
# Wait
wait(200)
#!/usr/bin/env pybricks-micropython
from pybricks.parameters import Port
from pybricks.iodevices import Ev3devSensor
class MySensor(Ev3devSensor):
"""Example of extending the Ev3devSensor class."""
def get_modes(self):
"""Get a list of mode strings so we don't have to look them up."""
193
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
194
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 9
195
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
class Direction
Rotational direction for positive speed or angle values.
CLOCKWISE
A positive speed value should make the motor move clockwise.
COUNTERCLOCKWISE
A positive speed value should make the motor move counterclockwise.
In general, clockwise is defined by looking at the motor shaft, just like looking at a clock.
Some motors have two shafts. If in doubt, refer to the following diagrams:
• Clockwise direction for EV3/NXT motors
• Clockwise direction for Powered Up Motors
• Clockwise direction for Move Hub Motors
class Stop
Action after the motor stops: coast, brake, or hold.
COAST
Let the motor move freely.
BRAKE
Passively resist small external forces.
HOLD
Keep controlling the motor to hold it at the commanded angle. This is only available on motors with
encoders.
The following table show how each stop type adds an extra level of resistance to motion. In these examples, m
is a Motor and and d is a DriveBase. The examples also show how running at zero speed compares to these
stop types.
196
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Coast
•
m.stop()
m.
run_target(500,
90,
Stop.
COAST)
Brake
• •
m.brake()
m.
run_target(500,
90,
Stop.
BRAKE)
• • •
m.run(0)
d.drive(0,
0)
Hold
• • • •
m.hold()
m.
run_target(500,
90,
Stop.HOLD)
d.
straight(0)
d.
straight(100)
Saturated colors
197
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Unsaturated colors
class Button
Buttons on a brick or remote:
LEFT_DOWN
DOWN
RIGHT_DOWN
LEFT
CENTER
RIGHT
LEFT_UP
UP
BEACON
RIGHT_UP
class Side
Side of a hub or a sensor. These devices are mostly rectangular boxes with six sides:
TOP
BOTTOM
FRONT
198
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
BACK
LEFT
RIGHT
Screens or light matrices have only four sides. For those, TOP is treated the same as FRONT, and BOTTOM is
treated the same as BACK.
Click a tab below to see the sides for relevant devices.
Prime Hub
Inventor Hub
Move Hub
Technic Hub
Tilt Sensor
199
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
200
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 10
201
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
#!/usr/bin/env pybricks-micropython
from pybricks.ev3devices import Motor
from pybricks.parameters import Port
from pybricks.tools import DataLog, StopWatch, wait
# Create a data log file in the project folder on the EV3 Brick.
# * By default, the file name contains the current date and time, for example:
# log_2020_02_13_10_07_44_431260.csv
# * You can optionally specify the titles of your data columns. For example,
# if you want to record the motor angles at a given time, you could do:
data = DataLog('time', 'angle')
# Each time you use the log() method, a new line with data is added to
# the file. You can add as many values as you like.
# In this example, we save the current time and motor angle:
data.log(time, angle)
202
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
When you upload the file to your computer as shown above, you can open it in a spreadsheet editor. You can then
generate a graph of the data, as shown in Figure 10.1.
In this example, we see that the motor angle changes slowly at first. Then the angle begins to change faster, and the
graph becomes a straight line. This means that the motor has reached a constant speed. You can verify that the angle
increases by 500 degrees per second.
Figure 10.1: Original file contents (left) and a generated graph (right).
203
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
#!/usr/bin/env pybricks-micropython
from pybricks.parameters import Color
from pybricks.tools import DataLog
# The log method uses the print() method to add a line of text.
# So, you can do much more than saving numbers. For example:
data.log('Temperature', 25)
data.log('Sunday', 'Monday', 'Tuesday')
data.log({'Kiwi': Color.GREEN}, {'Banana': Color.YELLOW})
# You can upload the file to your computer, but you can also print the data:
print(data)
204
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 11
robotics – Robotics
Use the following commands to drive a given distance, or turn by a given angle.
This is measured using the internal rotation sensors. Because wheels may slip while moving, the traveled
distance and angle are only estimates.
straight(distance)
Drives straight for a given distance and then stops.
Parameters distance (distance: mm) – Distance to travel.
turn(angle)
Turns in place by a given angle and then stops.
205
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Drive forever
Measuring
distance()
Gets the estimated driven distance.
Returns Driven distance since last reset.
Return type distance: mm
angle()
Gets the estimated rotation angle of the drive base.
Returns Accumulated angle since last reset.
Return type angle: deg
state()
Gets the state of the robot.
This returns the current distance(), the drive speed, the angle(), and the turn rate.
206
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
As a first estimate, you can measure the wheel_diameter and the axle_track with a ruler. Because it is
hard to see where the wheels effectively touch the ground, you can estimate the axle_track as the distance
between the midpoint of the wheels.
In practice, most wheels compress slightly under the weight of your robot. To verify, make your robot drive 1000
mm using my_robot.straight(1000) and measure how far it really traveled. Compensate as follows:
• If your robot drives not far enough, decrease the wheel_diameter value slightly.
• If your 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 360 degrees using my_robot.
turn(360) and check that it is back in the same place:
• If your robot turns not far enough, increase the axle_track value slightly.
• If your 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.
Suppose you make a DriveBase object using two Motor objects called left_motor and right_motor.
You cannot use these motors individually while the DriveBase is active.
The DriveBase is active if it is driving, but also when it is actively holding the wheels in place after a
straight() or turn() command. To deactivate the DriveBase, call stop().
Advanced Settings
The settings() method is used to adjust commonly used settings like the default speed and acceleration for
straight maneuvers and turns. Use the following attributes to adjust more advanced control setttings.
You can only change the settings while the robot is stopped. This is either before you begin driving or after you
call stop().
distance_control
The traveled distance and drive speed are controlled by a PID controller. You can use this attribute to
change its settings. See The Control Class for an overview of available methods.
heading_control
The robot turn angle and turn rate are controlled by a PID controller. You can use this attribute to change
its settings. See The Control Class for an overview of available methods.
207
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 12
This module describes media such as sound and images that you can use in your projects. Media are divided into
submodules that indicate on which platform they are available.
EV3 MicroPython is built on top of ev3dev, which comes with a variety of image and sound files. You can access
them using the classes below.
You can also use your own sound and image files by placing them in your project folder.
class ImageFile
Paths to standard EV3 images.
Information
ACCEPT
BACKWARD
208
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
DECLINE
FORWARD
LEFT
NO_GO
QUESTION_MARK
RIGHT
STOP_1
STOP_2
THUMBS_DOWN
THUMBS_UP
209
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
WARNING
LEGO
EV3
EV3_ICON
Objects
TARGET
Eyes
ANGRY
AWAKE
BOTTOM_LEFT
BOTTOM_RIGHT
210
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
CRAZY_1
CRAZY_2
DIZZY
DOWN
EVIL
KNOCKED_OUT
MIDDLE_LEFT
MIDDLE_RIGHT
NEUTRAL
PINCHED_LEFT
211
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
PINCHED_MIDDLE
PINCHED_RIGHT
SLEEPING
TIRED_LEFT
TIRED_MIDDLE
TIRED_RIGHT
UP
WINKING
212
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
class SoundFile
Paths to standard EV3 sounds.
Expressions
BOING
Download
BOO
Download
CHEERING
Download
CRUNCHING
Download
CRYING
Download
FANFARE
Download
KUNG_FU
Download
LAUGHING_1
Download
LAUGHING_2
Download
MAGIC_WAND
Download
OUCH
Download
SHOUTING
Download
213
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
SMACK
Download
SNEEZING
Download
SNORING
Download
UH_OH
Download
Information
ACTIVATE
Download
ANALYZE
Download
BACKWARDS
Download
COLOR
Download
DETECTED
Download
DOWN
Download
ERROR
Download
ERROR_ALARM
Download
FLASHING
Download
214
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
FORWARD
Download
LEFT
Download
OBJECT
Download
RIGHT
Download
SEARCHING
Download
START
Download
STOP
Download
TOUCH
Download
TURN
Download
UP
Download
Communication
BRAVO
Download
EV3
Download
FANTASTIC
Download
215
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
GAME_OVER
Download
GO
Download
GOOD_JOB
Download
GOOD
Download
GOODBYE
Download
HELLO
Download
HI
Download
LEGO
Download
MINDSTORMS
Download
MORNING
Download
NO
Download
OKAY
Download
OKEY_DOKEY
Download
216
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
SORRY
Download
THANK_YOU
Download
YES
Download
Movement sounds
SPEED_DOWN
Download
SPEED_IDLE
Download
SPEED_UP
Download
Colors
BLACK
Download
BLUE
Download
BROWN
Download
GREEN
Download
RED
Download
WHITE
Download
YELLOW
217
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Download
Mechanical
AIR_RELEASE
Download
AIRBRAKE
Download
BACKING_ALERT
Download
HORN_1
Download
HORN_2
Download
LASER
Download
MOTOR_IDLE
Download
MOTOR_START
Download
MOTOR_STOP
Download
RATCHET
Download
SONAR
Download
TICK_TACK
Download
Animal sounds
218
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
CAT_PURR
Download
DOG_BARK_1
Download
DOG_BARK_2
Download
DOG_GROWL
Download
DOG_SNIFF
Download
DOG_WHINE
Download
ELEPHANT_CALL
Download
INSECT_BUZZ_1
Download
INSECT_BUZZ_2
Download
INSECT_CHIRP
Download
SNAKE_HISS
Download
SNAKE_RATTLE
Download
T_REX_ROAR
Download
Numbers
219
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
ZERO
Download
ONE
Download
TWO
Download
THREE
Download
FOUR
Download
FIVE
Download
SIX
Download
SEVEN
Download
EIGHT
Download
NINE
Download
TEN
Download
System sounds
CLICK
Download
CONFIRM
Download
220
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
GENERAL_ALERT
Download
OVERPOWER
Download
READY
Download
12.1.3 Fonts
Language codes
Note: Languages depend on installed fonts. Additional language codes are possible and some listed language codes may not have a satisfactory
font.
– 'aa': Afar
– 'af': Afrikaans
– 'an': Aragonese
– 'av': Avaric
– 'ay': Aymara
– 'az-az': Azerbaijani
– 'be': Belarusian
– 'bg': Bulgarian
– 'bi': Bislama
– 'bm': Bambara
– 'br': Breton
– 'bs': Bosnian
– 'bua': Buriat
– 'ca': Catalan
– 'ce': Chechen
221
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
222
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
style
Gets a string describing the font style.
Can be “Regular” or “Bold”.
width
Gets the width of the widest character of the font.
– 'ie': Interlingue
– 'ik': Inupiaq
– 'io': Ido
– 'is': Icelandic
– 'it': Italian
– 'ja': Japanese
– 'jv': Javanese
– 'ki': Kikuyu
– 'kj': Kuanyama
– 'kl': Kalaallisut
– 'ko': Korean
– 'ku-tr': Kurdish
– 'kum': Kumyk
– 'kw': Cornish
– 'kwm': Kwambi
– 'la': Latin
– 'lb': Luxembourgish
– 'lez': Lezghian
– 'lg': Ganda
– 'li': Limburgan
– 'ln': Lingala
– 'lt': Lithuanian
– 'lv': Latvian
– 'mg': Malagasy
– 'mh': Marshallese
– 'mi': Maori
– 'mk': Macedonian
– 'mn-mn': Mongolian
– 'mo': Moldavian
– 'ms': Malay
– 'mt': Maltese
– 'na': Nauru
– 'nb': Norwegian Bokmål
– 'nds': Low German
– 'ng': Ndonga
– 'nl': Dutch
– 'nn': Norwegian Nynorsk
223
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
height
Gets the height of the font.
text_width(text)
Gets the width of the text when the text is drawn using this font.
Parameters text (str) – The text.
– 'no': Norwegian
– 'nr': South Ndebele
– 'nso': Northern Sotho
– 'nv': Navajo
– 'ny': Chichewa
– 'oc': Occitan
– 'om': Oromo
– 'os': Ossetian
– 'pap-an': Papiamento, Netherlands Antilles
– 'pap-aw': Papiamento, Aruba
– 'pl': Polish
– 'pt': Portuguese
– 'qu': Quechua
– 'quz': Cusco Quechua
– 'rm': Romansh
– 'rn': Rundi
– 'ro': Romanian
– 'ru': Russian
– 'rw': Kinyarwanda
– 'sc': Sardinian
– 'sco': Scots
– 'se': Northern Sami
– 'sel': Selkup
– 'sg': Sango
– 'sk': Slovak
– 'sl': Slovenian
– 'sm': Samoan
– 'sma': Southern Sami
– 'smj': Lule Sami
– 'smn': Inari Sami
– 'sms': Skolt Sami
– 'sn': Shona
– 'so': Somali
– 'sq': Albanian
– 'sr': Serbian
– 'ss': Swati
– 'st': Southern Sotho
224
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
– 'su': Sundanese
– 'sv': Swedish
– 'sw': Swahili
– 'tk': Turkmen
– 'tl': Tagalog
– 'tn': Tswana
– 'to': Tonga
– 'tr': Turkish
– 'ts': Tsonga
– 'ty': Tahitian
– 'uk': Ukrainian
– 'uz': Uzbek
– 'vo': Volapük
– 'vot': Votic
– 'wa': Walloon
– 'wen': Sorbian
– 'wo': Wolof
– 'xh': Xhosa
– 'yap': Yapese
– 'yi': Yiddish
– 'za': Zhuang
– 'zh-cn': Chinese, China
– 'zh-sg': Chinese, Singapore
– 'zh-tw': Chinese, Taiwan
– 'zu': Zulu
225
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Pybricks only allows the use of bitmap fonts (scalable=false) and the screen on the EV3 has 119 pixels
per inch (dpi=119).
Instead of drawing directly on the EV3 screen, you can make and interact with image files using the Image class
given below.
class Image(source, sub=False)
Object representing a graphics image. This can either be an in-memory copy of an image or the image displayed
on a screen.
Parameters
• source (str or Image) – The source of the image.
If source is a string, then the image will be loaded from the file path given by the string.
Only .png files are supported. As a special case, if the string is _screen_, the image will
be configured to draw directly on the screen.
If an Image is given, the new object will contain a copy of the source image object.
• sub (bool) – If sub is True, then the image object will act as a sub-image of the source
image (this only works if the type of source is Image and not when it is a str).
Additional keyword arguments x1, y1, x2, y2 are needed when sub=True. These specify
the top-left and bottom-right coordinates in the source image that will be used as the
bounds for the sub-image.
static empty(width=<screen width>, height=<screen height>)
Creates a new empty Image object.
Parameters
• width (int) – The width of the image in pixels.
• height (int) – The height of the image in pixels.
Returns A new image with all pixels set to Color.WHITE.
Return type Image
Raises
• TypeError – width or height is not a number.
• ValueError – width or height is less than 1.
• RuntimeError – There was a problem allocating a new image.
Drawing text
There are two ways to draw text on images. draw_text() lets text be placed precisely on the image or
print() can be used to automatically print text on a new line.
226
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Drawing images
A copy of another image can be drawn on an image. Also consider using sub-images to copy part of an image.
draw_image(x, y, source, transparent=None)
Draws the source image on this image.
Parameters
• x (int) – The x-axis value where the left side of the image will start.
• y (int) – The y-axis value where the top of the image will start.
• source (Image or str) – The source Image. If the argument is a string, then the
source image is loaded from file.
• transparent (Color) – The color of image to treat as transparent or None for no
transparency.
227
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Drawing shapes
These are the methods to draw basic shapes, including points, lines, rectangles and circles.
draw_pixel(x, y, color=Color(0, 0, 0, ’BLACK’))
Draws a single pixel on this image.
Parameters
• x (int) – The x coordinate of the pixel.
• y (int) – The y coordinate of the pixel.
• color (Color) – The color of the pixel.
draw_line(x1, y1, x2, y2, width=1, color=Color(0, 0, 0, ’BLACK’))
Draws a line on this image.
Parameters
• x1 (int) – The x coordinate of the starting point of the line.
• y1 (int) – The y coordinate of the starting point of the line.
• x2 (int) – The x coordinate of the ending point of the line.
• y2 (int) – The y coordinate of the ending point of the line.
• width (int) – The width of the line in pixels.
• color (Color) – The color of the line.
draw_box(x1, y1, x2, y2, r=0, fill=False, color=Color(0, 0, 0, ’BLACK’))
Draws a box on this image.
Parameters
• x1 (int) – The x coordinate of the left side of the box.
• y1 (int) – The y coordinate of the top of the box.
• x2 (int) – The x coordinate of the right side of the box.
• y2 (int) – The y coordinate of the bottom of the box.
• r (int) – The radius of the corners of the box.
• fill (bool) – If True, the box will be filled with color, otherwise only the outline of
the box will be drawn.
• color (Color) – The color of the box.
draw_circle(x, y, r, fill=False, color=Color(0, 0, 0, ’BLACK’))
Draws a circle on this image.
Parameters
• x (int) – The x coordinate of the center of the circle.
• y (int) – The y coordinate of the center of the circle.
• r (int) – The radius of the circle.
• fill (bool) – If True, the circle will be filled with color, otherwise only the circum-
ference will be drawn.
• color (Color) – The color of the circle.
228
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
Image properties
width
Gets the width of this image in pixels.
height
Gets the height of this image in pixels.
clear()
Clears this image. All pixels on this image will be set to Color.WHITE.
load_image(source)
Clears this image, then draws the source image centered in this image.
Parameters source (Image or str) – The source Image. If the argument is a string, then
the source image is loaded from file.
save(filename)
Saves this image as a .png file.
Parameters filename (str) – The path to the file to be saved.
Raises
• TypeError – filename is not a string.
• OSError – There was a problem saving the file.
229
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 13
messaging – Messaging
An EV3 Brick can send information to another EV3 Brick using Bluetooth. This page shows you how to connect
multiple bricks and how to write scripts to send messages between them.
Before two EV3 bricks can exchange messages, they must be paired. You’ll need to do this only the first time. First,
activate bluetooth on all EV3 bricks as shown in Figure 13.1.
Now you can make one EV3 Brick search for the other and pair with it, as shown in Figure 13.2.
Once they are paired, do not click connect in the menu that appears. The connection will be made when you run your
programs, as described below.
When you scan for Bluetooth devices, you’ll see a list of device names. By default, all EV3 Bricks are named ev3dev.
Click here to learn how to change that name. This makes it easy to tell them apart.
Repeat the steps in Figure 13.2 if you want to pair more than two EV3 Bricks.
230
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
A wireless network consists of EV3 Bricks acting as servers or clients. A example with one server and one client is
shown in Figure 13.3. Messages can be sent in both ways: the server can send a message to the client, and the client
can send a message to the server.
Figure 13.3: An example network with one server and one clients.
231
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
#!/usr/bin/env pybricks-micropython
# Before running this program, make sure the client and server EV3 bricks are
# paired using Bluetooth, but do NOT connect them. The program will take care
# of establishing the connection.
server = BluetoothMailboxServer()
mbox = TextMailbox('greeting', server)
# In this program, the server waits for the client to send the first message
# and then sends a reply.
mbox.wait()
print(mbox.read())
mbox.send('hello to you!')
#!/usr/bin/env pybricks-micropython
# Before running this program, make sure the client and server EV3 bricks are
# paired using Bluetooth, but do NOT connect them. The program will take care
# of establishing the connection.
client = BluetoothMailboxClient()
mbox = TextMailbox('greeting', client)
print('establishing connection...')
client.connect(SERVER)
print('connected!')
# In this program, the client sends the first message and then waits for the
# server to reply.
mbox.send('hello!')
mbox.wait()
print(mbox.read())
The only difference between the client and the server is which one initiates the connection at the beginning of the
program:
232
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
• The server must always be started first. It uses the BluetoothMailboxServer class. Then it waits for
clients using the wait_for_connection method.
• The client uses the BluetoothMailboxClient class. It connects to the server using the connect method.
• After that, sending and receiving messages is done in the same way on both EV3 Bricks.
class BluetoothMailboxServer
Object that represents a Bluetooth connection from one or more remote EV3s.
The remote EV3s can either be running MicroPython or the standard EV3 firmware.
A “server” waits for a “client” to connect to it.
wait_for_connection(count=1)
Waits for a BluetoothMailboxClient on a remote device to connect.
Parameters count (int) – The number of remote connections to wait for.
Raises OSError – There was a problem establishing the connection.
close()
Closes all connections.
class BluetoothMailboxClient
Object that represents a Bluetooth connection to one or more remote EV3s.
The remote EV3s can either be running MicroPython or the standard EV3 firmware.
A “client” initiates a connection to a waiting “server”.
connect(brick)
Connects to an BluetoothMailboxServer on another device.
The remote device must be paired and waiting for a connection. See BluetoothMailboxServer.
wait_for_connection().
Parameters brick (str) – The name or Bluetooth address of the remote EV3 to connect to.
Raises OSError – There was a problem establishing the connection.
close()
Closes all connections.
13.3 Mailboxes
Mailboxes are used to send data to and from other EV3 Bricks.
A Mailbox has a name, similar to the “subject” of an email. If two EV3 Bricks have a Mailbox with the same name,
they can send messages between them. Each EV3 Brick can read its own Mailbox, and send messages to the Mailbox
on the other EV3 Brick.
Depending on the type of messages you would like to exchange (bytes, booleans, numbers, or text), you can choose
one of the Mailboxes below.
class Mailbox(name, connection, encode=None, decode=None)
Object that represents a mailbox containing data.
You can read data that is delivered by other EV3 bricks, or send data to other bricks that have the same mailbox.
By default, the mailbox reads and send only bytes. To send other data, you can provide an encode function
that encodes your Python object into bytes, and a decode function to convert bytes back to a Python object.
Parameters
233
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
234
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
The classes in this module are not limited to just two EV3 Bricks. for example, you can add more clients to your
network. An example with pseudo-code is shown in Figure 13.4.
Figure 13.4: An example network with one server and two clients.
235
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 14
class Matrix(rows)
Mathematical representation of a matrix. It supports common operations such as matrix addition (+), subtraction
(-), and multiplication (*). A Matrix object is immutable.
Parameters rows (list) – List of rows. Each row is itself a list of numbers.
T
Returns a new Matrix that is the transpose of the original.
shape
Returns a tuple (m, n), where m is the number of rows and n is the number of columns.
vector(x, y, z=None)
Convenience function to create a Matrix with the shape (3, 1) or (2, 1).
Parameters
• x (float) – x-coordinate of the vector.
• y (float) – y-coordinate of the vector.
• z (float) – z-coordinate of the vector (optional).
Returns A matrix with the shape of a column vector.
Return type Matrix
236
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 15
Many commands allow you to specify arguments in terms of well-known physical quantities. This page gives an
overview of each quantity and its unit.
15.1 Time
15.1.1 time: ms
All angles are measured in degrees (deg). One full rotation corresponds to 360 degrees.
For example, the angle values of a Motor or the GyroSensor are expressed in degrees.
Rotational speed, or angular velocity describes how fast something rotates, expressed as the number of degrees per
second (deg/s).
For example, the rotational speed values of a Motor or the GyroSensor are expressed in degrees per second.
While we recommend working with degrees per second in your programs, you can use the following table to convert
between commonly used units.
237
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
deg/s rpm
1 deg/s = 1 1/6=0.167
1 rpm = 6 1
Rotational acceleration, or angular acceleration describes how fast the rotational speed changes. This is expressed
as the change of the number of degrees per second, during one second (deg/s/s). This is also commonly written as
𝑑𝑒𝑔/𝑠2 .
For example, you can adjust the rotational acceleration setting of a Motor to change how smoothly or how quickly it
reaches the constant speed set point.
15.3.1 distance: mm
mm cm inch
1 mm = 1 0.1 0.0394
1 cm = 10 1 0.394
1 inch = 25.4 2.54 1
15.3.2 dimension: mm
Linear acceleration describes how fast the speed changes. This is expressed as the change of the millimeters per
second, during one second (deg/s/s). This is also commonly written as 𝑚𝑚/𝑠2 .
For example, you can adjust the acceleration setting of a DriveBase to change how smoothly or how quickly it
reaches the constant speed set point.
238
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
15.4.1 percentage: %
Some signals do not have specific units. They range from a minimum (0%) to a maximum (100%). Specifics type of
percentages are relative distances or brightness.
Another example is the sound volume, which ranges from 0% (silent) to 100% (loudest).
Some distance measurements do not provide an accurate value with a specific unit, but they range from very close
(0%) to very far (100%). These are referred to as relative distances.
For example, the distance value of the InfraredSensor is a relative distance.
15.4.3 brightness: %
The perceived brightness of a light is expressed as a percentage. It is 0% when the light is off and 100% when the light
is fully on. When you choose 50%, this means that the light is perceived as approximately half as bright to the human
eye.
15.5 Force
15.5.1 force: N
mN N lbf
1 mN = 1 0.001 2.248 · 10−4
1N= 1000 1 0.2248
1 lbf = 4448 4.448 1
15.6 Electricity
15.6.1 voltage: mV
15.6.2 current: mA
239
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
15.6.3 energy: J
15.6.4 power: mW
Power is the rate at which energy is stored or consumed. It is expressed in milliwatt (mW).
15.7.1 frequency: Hz
15.7.2 temperature: °C
Temperature is measured in degrees Celcius (°C). To convert to degrees Fahrenheit (°F) or Kelvin (K), you can use the
following conversion formulas:
9
𝐹 =𝐶 · 5 + 32.
𝐾 = 𝐶 + 273.15.
240
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
CHAPTER 16
The Motor class uses PID control to accurately track your commanded target angles. Similarly, the DriveBase
class uses two of such controllers: one to control the heading and one to control the traveled distance.
You can change the control settings through the following attributes, which are instances of the Control class given
below.:
• Motor.control
• DriveBase.heading_control
• DriveBase.distance_control
You can only change the settings while the controller is stopped. For example, you can set the settings at the beginning
of your program. Alternatively, first call stop() to make your Motor or DriveBase stop, and then change the
settings.
class Control
Class to interact with PID controller and settings.
scale
Scaling factor between the controlled integer variable and the physical output. For example, for a single
motor this is the number of encoder pulses per degree of rotation.
Status
done()
Checks if an ongoing command or maneuver is done.
Returns True if the command is done, False if not.
Return type bool
241
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
stalled()
Checks if the controller is currently stalled.
A controller is stalled when it cannot reach the target speed or position, even with the maximum actuation
signal.
Returns True if the controller is stalled, False if not.
Return type bool
Settings
242
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
stall_tolerances(speed, time)
Gets or sets stalling tolerances.
If no arguments are given, this will return the current values.
Parameters
• speed (rotational speed: deg/s or speed: mm/s) – If the controller cannot reach this speed
for some time even with maximum actuation, it is stalled.
• time (time: ms) – How long the controller has to be below this minimum speed before
we say it is stalled.
243
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Python Module Index
p
pybricks.ev3devices, 173
pybricks.geometry, 236
pybricks.hubs, 24
pybricks.iodevices, 186
pybricks.media, 208
pybricks.media.ev3dev, 208
pybricks.messaging, 230
pybricks.nxtdevices, 180
pybricks.parameters, 195
pybricks.pupdevices, 61
pybricks.robotics, 205
pybricks.tools, 201
244
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Index
245
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
246
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
247
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
248
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
249
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
250
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors
Pybricks Modules and Examples Version v3.0.0a3
U
UARTDevice (class in pybricks.iodevices), 190
UltrasonicSensor (class in pybricks.ev3devices), 178
UltrasonicSensor (class in pybricks.nxtdevices), 182
UltrasonicSensor (class in pybricks.pupdevices), 142
V
value() (VernierAdapter method), 185
vector() (in module pybricks.geometry), 236
VernierAdapter (class in pybricks.nxtdevices), 184
VIOLET (Color attribute), 198
voltage() (AnalogSensor method), 187
voltage() (pybricks.hubs.CityHub.battery class method),
29
voltage() (pybricks.hubs.EV3Brick.battery class method),
58
voltage() (pybricks.hubs.InventorHub.battery class
method), 49
voltage() (pybricks.hubs.MoveHub.battery class method),
26
voltage() (pybricks.hubs.PrimeHub.battery class method),
40
voltage() (pybricks.hubs.TechnicHub.battery class
method), 32
voltage() (VernierAdapter method), 184
W
wait() (in module pybricks.tools), 201
wait() (Mailbox method), 234
wait_for_connection() (BluetoothMailboxServer
method), 233
wait_new() (Mailbox method), 234
waiting() (UARTDevice method), 190
WHITE (Color attribute), 198
width (EV3Brick.screen attribute), 58
width (Font attribute), 223
width (Image attribute), 229
write() (I2CDevice method), 188
251
LEGO, the LEGO logo, MINDSTORMS and the MINDSTORMS EV3 logo are trademarks and/or copyrights of the LEGO Group of companies which does not sponsor, authorize or endorse this site. © 2018-2020 The Pybricks Authors