Table of Contents

Let's talk about Duckietown

(Harley Lara, Jun 2024)

In April 2024 we received a batch of 12 Duckiebots with NVIDIA Jetson Nano 4GB (variant DB21J) as part of the Classroom Kit (12). The main motivation behind choosing duckietown as our educational robot was mainly based on two aspects: 1. Open Hardware and documentation: The fact that it is Open Hardware gives us the flexibility (in the future) to extend the capabilities of the robot with different sensors or actuators. 2. Educational content: Duckietown offers a MOOC on autonomous driving, plus a series of exercises and notebooks called duckietown-lx as practical implementations of some concepts, this was the selling point to choose duckietown as it offloaded the amount of work required to prepare the material and exercises of a course from scratch, so it left us more freedom to focus on supporting students in their learning process instead of worrying about the material.

About the Hardware

The materials: One thing you need to know is that duckiebot is a low cost robot (compared to other educational robots), however the low cost comes at the cost of the materials the robot is made of. At first impression you receive a box containing all the materials and even tools needed for assembly, this is much appreciated. It was no surprise that the main structural material of the robot is acrylic, which despite being a bit fragile once assembled correctly feels like a solid construction (remember it is the variant DB21J). Of course it is not perfect and presents some medium and long term limitations in the life of the robot, many of those cons are listed in the paper Duckietown Project Pros and Cons, just consider that the paper review the varian DB21M, but some problems still remain (more details on this later in this post).

The assembly instructions: As mentioned above, we have the DB21J variant, so the assembly instructions are as follows Assembly - Duckiebot DB21J. It should be noted that the instructions are relatively easy to follow, but in some cases the images are not explicit enough or there is no explanatory text and it assumes that the student knows what to do with those parts, here are a series of problems that our students had during the assembly process:

Interestingly the assembly instructions of the legacy version DB21M is better documented, has better explained illustrations accompanied by text, warnings, notes and covers many of the points mentioned above, an example is step 13.

About Software

Every robot requires software and mastering software is difficult. This creates a huge barrier to entry for students interested in the field of robotics, as they are faced with the need to master these technologies in order to develop software:

  1. GNU/Linux knowledge, filesystem, peripherals management, networking. The vast majority of robots out there use linux as the main operating system, therefore every student interested in robotics should master the basic concepts of GNU/Linux.
  2. Bash, terminal tools and bash scripting. The most common way to interact with a robot as a software developer is through a terminal, so bash skills and terminal usage is a very useful skill.
  3. Programming skills, e.g. Python or C++. Programming skills are crucial to be able to translate ideas into an executable set of instructions for the robot.
  4. Robot Operating System (ROS). The de facto standard middleware; it provides a set of tools and packages that allow the reuse of components in robotics.
  5. (extra) Docker: Runtime to run containerized software.

Requiring students to learn that stack of software tools in one semester in a autonomous robotics course only causes them to lose focus, because instead of concentrating on concepts, implementation and algorithms for autonomous systems students have to invest time in acquiring the necessary knowledge (if they don't have it) in order to gain the skills that will then allow them to perform the implementations and assignments, for example the student may have never used GNU/Linux and now they have to become familiar with it.

The problem of this monumental barrier to entry, is the one that many companies with an educational focus are trying to address, among them of course, duckietown (more about this later); where they provide a “ready-to-use” environment so that the learner can concentrate on the concepts/algorithms and not on the whole stack of software and setups that make it possible to run. As an example (I have to admit that the example is a bit of an exaggeration, but it's just to make the point): No “conventional” computer user studies the Linux Kernel to be able to use the operating system, because the right level of abstraction is also highly appreciated, and sometimes we just need things to “just work”.

With that preamble the following is a set of good things, and some things we consider not so good about the Duckietown software stack.

Software on students' laptops:

Software on the robot:

The setup in the robot is like a blackbox, you get a pre-build image (see duckietown-shell-commands source code) and you burn it into the microSD. There is no information (as far as I know) how this image is configured, what tools it contains, modifications, patches etc.