How to Build Your Own 3D Printed Raspberry Pi Robot (Updated)

Update 7th August 2022: We’ve updated this article to include how to program the Explora in Python on page 2.

Original Tutorial Published June 4, 2022:

Building your own robot is one of the most satisfying things you can do. It combines mechanical, electrical, and programming skills together in a way few projects do.

I’ve been building robots for a couple of years now and love to expand my knowledge and skills by using different controller boards, motors, wheels, and sensors to detect the world around the robot.

Raspberry Pi robots are particularly impressive. The Raspberry Pi provides the robot with the full power of Linux and a plethora of Python libraries.  With all of this power, it means we can add advanced machine learning, computer vision, and Internet connectivity into the mix. All this at an affordable price point and tiny form factor too.

Building Raspberry Pi robots from kits, such as  Pimoroni’s Trilobot, or from a custom design such as Explora, is fun and helps develop skills such as programming in Python, mechanical design, and electronics. People love playing with robots and teaching them to perform tasks and move around the environment unaided.

Explora uses the Pimoroni Explorer pHAT (we included the Explorer HAT Pro in our best Raspberry Pi HATs guide) to control the motors and has a handy Python library to make this simple. Explora is programmed in Python and uses sensors to avoid obstacles and follow your handExplora can also be remotely controlled over Wi-Fi.

Explora can detect objects in front of it using an HC-SR04 ultrasonic range finder module. These modules come in either a 5v version or a 3.3v version (HCSR04+ or HC-SR04P). The Explorer pHAT is 5v tolerant, but it’s best to get the HC-SR04+ or HC-SR04-P version to be on the safe side. Using the 5v version on a Raspberry Pi can damage the board.

Explora was designed using AutoDesk Fusion 360 (opens in new tab). Each piece is a discrete component to enable easier  3D printing. Fusion 360 makes it really easy to export the models into STL files, ready for slicing and then 3D printing. To slice the robot parts (creating the instructions for a 3D printer to print the part) from Fusion 360 I use Cura, and then upload it to OctoPrint to manage the print jobs. The 3D printed parts are designed to be quick and easy to print, and the whole thing is easy to assemble using a couple of screws and wire up.

My personal choice of 3D printer is the Creality Ender 3 Pro and Ender 3 V2.

The electronics for the project are relatively straightforward and involve some soldering. You will need to solder wires to each motor and then to some Male DuPont cables (jumper jerky), one set per motor. You’ll also need something to hold the motors while you solder the wires to the tiny motor connectors which can be a bit tricky if you’ve not done this before. Some “helpful hands” or modeling clay is useful to keep the wires in place.

What You Will Need

  • Soldering iron
  • Solder and some flux
  • Screwdriver
  • Wire cutters
  • Wire strippers
  • Helping hands – for use with soldering
  • A computer with an SD card reader slot

3D Printed Files

Building Explora

(Image credit: Tom’s Hardware)

The print times for each of Explora’s parts depends on your specific printer and quality settings. I found the files took the following amount of time to print:

# Part Approx Time to Print
1. Chassis 5 hours 16 minutes
2. Top Section 2 hours 22 minutes
3. Motor Holders – all 4 at once 3 hours 44 minutes
4. Camera holder & Camera holder back at once 2 hours 30 minutes

I prefer to use PLA+ for my prints and usually have some white or yellow filament already in each printer, ready to go.

To Prepare Explora’s 3D Printed Parts

(Image credit: Tom’s Hardware)

1. Download the 3D printable STL files.

2. Slice the parts using Cura – We like to use Cura, but you are free to use an alternative. and don’t forget to enable supports for the motor holders

3. Transfer the G-Code file from Cura to your 3D Printer. Save the G-Code file to an SD card (if that’s how your 3D printer accepts files) alternatively you can use software such as OctoPrint that runs on a Raspberry Pi and presents a Web-based interface for managing 3D Print jobs. If you’re using OctoPrint you can drag the G-Code file over the left-hand side of the page and it will begin to upload the file, ready for printing.

(Image credit: Tom’s Hardware)

4. Load the G-code and print – We used Octoprint to manage our print jobs

Wiring up Explora

(Image credit: Tom’s Hardware)

Soldering is an essential maker skill. Learning to solder opens up the entire world of electronics and this project could be your first steps on an exciting journey. If your motors come without any wires attached you’ll need to prepare your own wires and solder these onto the tiny motors. Soldering small parts can be tricky; you will need a steady hand and something to hold the motors while you hold the solder in one hand and the soldering iron in the other.

  • Prepare the wires for soldering. Cut four strips of red wire 100mm long each and another four strips of black wire. We should have a pair of black and red wires for each motor.
  • Strip wires. Strip about 4mm of wire from each end, exposing the copper wire. A good pair of wire strippers is an essential part of a maker’s toolbox.
  • Add Flux. Apply some flux to one end of the wire that will be soldered. Flux helps the solder run around the part correctly. Even if your solder comes with a flux core, a little extra flux will make soldering much easier.
  • Tin the wires by adding a small amount of solder to the wires with your soldering iron. Tinning will help the wires solder to the small motor terminals
  • Solder the red wire onto the motor terminal – you’ll notice a small + sign above the terminal that is the positive terminal. Take your time, as this can be tricky if you’ve not done it before.
  • Push the wire through the hole in the terminal first to make a good mechanical connection and will help hold the wire in place as you solder, then solder the wire to the terminal.
  • Repeat the last step for the black wire but this time solder the black wire to the Negative terminal on the motor.
  • Twist red and black wires for strength. This will help strengthen the connection if you accidentally tug on the wires.

(Image credit: Tom’s Hardware)

9. Solder the 40 pin header and 20 pin header to the Explorer pHat

(Image credit: Tom’s Hardware)

Assembly

The assembly part of the build won’t take long as it only involves screwing the four motor holders into the chassis using the M2.5 screw and nuts. Then we screw the standoffs into the chassis and Raspberry Pi Zero 2 W, and finally, we attach the Camera holders and top section.

1. Push each motor into a 3D printed motor holder. The motor holders ensure that the motor remains in place on Explora’s chassis. They also offer mechanical rigidity so that the motors do not move position in use.

2. Put a nut into each hexagonal pocket on the motor holder, then screw it from the top side of the chassis through to the motor holder into the nut. Don’t over-tighten as you’ll end up splitting the chassis. This will create a substantial connection between the motor holder and the chassis.

(Image credit: Tom’s Hardware)

3. Add stand-offs to the chassis by screwing four M2.5 screws into the bottom of the chassis, and screw on a stand-off barrel onto the exposed screw thread until it becomes tight against the chassis.

4. Add four stand-offs to the Raspberry Pi Zero, then attach the Explorer pHat.

(Image credit: Tom’s Hardware)

5. Screw the Raspberry Pi Zero into the Chassis stand-offs.

6. Push the Camera Holder into the Chassis. You may need to file off some material if it’s a tight fit.

7. Push the ultrasonic rangefinder into the Camera Holder.

8. Push the female end of the DuPont wires onto the Rangefinder.

9. Push the male end of the DuPont wires onto Explorer pHATs 5v, GND, Output 1 to Trigger, Input 1 to Echo connections. 

10. Push the Camera back into the Chassis.

(Image credit: Tom’s Hardware)

11. Add the last four stand-offs onto the Raspberry Pi Zero

12. Push the Top section over the two camera holders and screw the last 4 M2.5 screws from the top section into the standoffs

13. Using a velcro strap, secure the battery in place. 

(Image credit: Tom’s Hardware)

14. Push the 4 wheels onto the ends of the motors. The motor axles are D-shaped, be sure to match the alignment of the axle to the wheel before firmly pushing on.

Preparing the Raspberry Pi

The Raspberry Pi needs a suitable OS to run the Python code to control the motors and optionally capture images. When the Raspberry Pi camera first launched a software library called PiCamera was provided to make it simple to capture stills and video. With the most recent release of Raspberry Pi OS ‘Bullseye’, this old library has been replaced with a library called LibCamera, which is not backward compatible with PiCamera. On the 32-bit release of Bullseye you can choose a legacy camera option from raspi-config, however, this option is not available on the 64bit release.

1. Using the official Raspberry Pi Imager tool, flash the latest 32-bit OS to a micro SD card. We use the 32-bit version of Raspberry Pi OS because the PiCamera library is currently not compatible with the 64-bit version of Raspberry Pi OS. 

(Image credit: Tom’s Hardware)

2. Put the micro SD card into the SD card reader slot on your computer.

(Image credit: Tom’s Hardware)

3. Select the micro SD card from the Raspberry Pi imager Storage menu.

(Image credit: Tom’s Hardware)

4. Click the Advanced (cog) button, and add your Wi-Fi SSID and password details to enable the Raspberry Pi to connect to the wifi automatically.

(Image credit: Tom’s Hardware)

5. Click on Enable SSH and create a username and password. SSH enables a remote to the Raspberry Pi using a terminal without the need for a monitor, keyboard, or mouse.

6. Click Write to begin flashing the image to the micro SD card.

(Image credit: Tom’s Hardware)

7. Insert the micro SD card into the Raspberry Pi and then power up the Raspberry Pi via the power bank.

Connecting to the Pi

1.  Find out the IP address of your Raspberry Pi – you can usually do this from your router (or wherever your router gets its IP addresses from, or by typing:

ssh pi@raspberrypi.local

– where `pi` is the username you created earlier in step 5 above.

2. Launch Terminal – if you’re on Windows, you’ll need to use some terminal software such as Putty (https://www.putty.org). Mac and Linux computers have terminal build-in. 

(Image credit: Tom’s Hardware)

3. SSH to the Raspberry Pi – Type `ssh pi@raspberrypi.local>` into the terminal to connect to the Pi. Linux / Mac users can use the following to SSH into the Pi. If you know the IP address you cal also type `ssh@`, where is the IP address of the Raspberry Pi.

ssh pi@raspberrypi.local

(Image credit: Tom’s Hardware)

From the Raspberry Pi terminal, clone the Explora software repository. The software is on Github, and we can use the git clone command to download the latest version to our Raspberry Pi:

git clone https://www.github.com/kevinmcaleer/explora

(Image credit: Tom’s Hardware)

4. Install the Explorer Library via Pimoroni’s online install script.

curl https://get.pimoroni.com/explorerhat | bash

4. From the Raspberry Pi terminal, clone the Explora software repository. The software is on Github, and we can use the git clone command to download the latest version to our Raspberry Pi:

curl https://get.pimoroni.com/explorerhat | bash

You should now have a fully assembled Explora robot on your desk, ready to receive your first Explora Python program. You can expand the capabilities of Explora by adding a LIDAR laser scanner and Raspberry Pi Camera such as the ones in the picture below.

Next, we create some programs for Explora in Python to move the robot around and detect objects.

(Image credit: Tom’s Hardware)

Writing the project code

The board at the heart of our robot is the Pimoroni Explorer HAT. The Explorer HAT has been around since 2015 and it has been proven to be a reliable and easy to use platform for robotics. This is in part due to the Python 3 library and its corresponding documentation. The Explorer HAT Python 3 module provides several helper functions that we will use in our project. 

Explorer pHAT has a series of connections broken out along one side of the board. There are two physical motor connectors,each with a positive and negative connection. There are also four input pins and four output pins,and four analog inputs. Two 5 Volt outputs (labeled 5V) and two Ground connections (labeled GND) are there to provide power to components. 

These pins are all referred to in the Explorer HAT Python 3 module as:

Motors
explorerhat.motor.one
explorerhat.motor.two

Inputs
explorerhat.input.one
explorerhat.input.two
explorerhat.input.three
explorerhat.input.four

Outputs
explorerhat.output.one
explorerhat.output.two
explorerhat.output.three
explorerhat.output.four

Motor functions

The Explorer HAT Python 3 module has several motor functions that we can call from within our code. The Documentation describes these as:

  • invert() – Reverses the direction of forwards & backwards for this motor
  • forwards(speed) – Turns the motor forwards at speed (default speed is 100%)
  • backwards(speed) – Turns the motor backwards speed (default speed is 100%)
  • speed(-100 to 100) – Turns the motor at the speed you specify, with -100 being full backwards to 100 being full forwards
  • stop() – Stops the motor by setting the speed to 0

Detecting objects

(Image credit: Tom’s Hardware)

Our robot uses a passive infrared (PIR) obstacle sensor module to detect objects. The sensor module has 3 pins:

  • VCC
  • Ground (GND)
  • Signal 

The PIR module attaches to the front, underside section of the robot, and only costs around $3. It works by firing invisible infrared light and using it to detect obstacles. When an obstacle is detected, the signal pin changes state from low to high, and this change is used as a trigger in our code.. The range of the sensor can be tweaked using the potentiometer and can be set from 2 to 30 Centimeters. 

(Image credit: Tom’s Hardware)

The PIR sensor attaches to the Explorer pHAT as follows

Explorer pHAT PIR Sensor Wire Color
5V VCC Red
Input 1 Signal Yellow
GND GND Black

(Image credit: Tom’s Hardware)

Controlling the Robot

Our robot has the sensor to “see” the world around it, but now we need to give it the intelligence to use that data as a means to navigate the world. Luckily this is made quite simple thanks to Explorer HAT’s abstracted Python 3 library.

1. Go to the main Raspberry Pi OS menu and select Programming >> Thonny. Thonny is the default Python editor for Raspberry Pi OS.

(Image credit: Tom’s Hardware)

2. Create a new file and import the Explorer HAT Python 3 module as eh. By doing this we shorten the reference to the module and reduce the risk of a typo.

import explorerhat as eh

3. Import the sleep function from the time module. We will use this to control the duration of our motors.

from time import sleep

4. Create a new function to move the robot forward which takes one argument, the speed at which the motors should spin.. Functions are reusable blocks of code we can call from within our program. Functions take parameters, such as ‘speed’, that allow us to change values within our function’s code. In this example, the speed parameter will change the speed the motors spin when moving our robot forward. A speed of 0 will stop our robot.

def forwards(speed):

(Image credit: Tom’s Hardware)

5. Print a message to the Python shell for debug purposes. This will print “Forward” to the shell, enabling us to debug any motor issues.

   print(“Forward”)

6. Set the motor connected to motor one to move forwards, motor two to backwards. Motor two is on the other side of the robot, and so to make the motor move in the same direction as motor one, we need to spin it backward.

  eh.motor.one.forwards(speed)
  eh.motor.two.backwards(speed)

7. Create a new function to move the robot backward. This is essentially the same as forwards, but we reverse the motor directions.

def backwards(speed):
   print("Backward")
   explorer_hat.motor.one.backwards(speed)
   explorer_hat.motor.two.forwards(speed)

8. Create a new function to spin the robot to the left. By moving both motors in the same direction it will spin the robot.

def turn_left(speed):
   print("Left")
   eh.motor.one.forwards(speed)
   eh.motor.two.forwards(speed)

9. Create a new function to spin the robot to the right. We spin the motors in the opposite direction to the left, causing the robot to spin on the spot.

def turn_right(speed):
   print("Right")
   eh.motor.one.backwards(speed)
   eh.motor.two.backwards(speed)
def stop():
   print("Stop")
   eh.motor.one.stop()
   eh.motor.two.stop()

10. Create a loop that will continually run the robot code. We need this loop so that the code within the loop is continually checked.

while True:

11. Create a conditional statement that will check the obstacle sensor output by reading the state of input 1. When the sensor detects an obstacle, its state changes from 0 (low) to 1 (high). Our if condition trigger will activate when the sensor sends 1.

   if eh.input.one.read() == 1:

12. Stop the robot, then turn left at 100% speed. This will force the robot to stop moving, then spin to the left, searching for a path around an obstacle.

       stop()
       turn_left(100)

13. Pause for half a second then stop spinning and add an additional half second sleep. The extra sleep will slow the code looping back to the start of the conditional test. If there were no sleep, the code would loop far too quickly, and our robot would become unpredictable.

       sleep(0.5)
       stop()
       sleep(0.5)

14. Add an else condition, which will move the robot forwards at full speed for five seconds. If there is no obstacle, en.input.one.read() will return 0 (low) and our robot will move forwards for five seconds before the loop repeats.

   else:
       forwards(100)
       sleep(5)

15. Save the code and click Run (green arrow on toolbar) to start the code. The robot will attempt to navigate the world. It is worth elevating your robot so that its wheels are lifted off of the ground. That way you are not chasing your robot around the room while debugging any issues.

Complete Code Listing

import explorerhat as eh
from time import sleep
def forwards(speed):
  print("Forward")
  eh.motor.one.forwards(speed)
  eh.motor.two.backwards(speed)
def backwards(speed):
   print("Backward")
   eh.motor.one.backwards(speed)
   eh.motor.two.forwards(speed)
def turn_left(speed):
   print("Left")
   eh.motor.one.forwards(speed)
   eh.motor.two.forwards(speed)
def turn_right(speed):
   print("Right")
   eh.motor.one.backwards(speed)
   eh.motor.two.backwards(speed)
def stop():
   print("Stop")
   eh.motor.one.stop()
   eh.motor.two.stop()
while True:
   if eh.input.one.read() == 1:
       stop()
       turn_left(100)
       sleep(0.5)
       stop()
   else:
       forwards(100)
sleep(5)

Checklist: What Have We Achieved?

(Image credit: Tom’s Hardware)

Congratulations you’ve created a robot that can detect and avoid objects.

  • How to download, slice and print the Explora 3D printable files.
  • How to build and assemble all the parts.
  • How to solder wires onto the motors.
  • How to prepare the Raspberry Pi OS and install the Explorer Hat Python module.
  • You’ve learned how to use the Pimoroni Explorer HAT Python module.
  • You have created a control system that senses the real world and feeds this back to our program, steering the robot away from obstacles in its path.

Automating the code

To set the Python 3 robot code to run when the Raspberry Pi boots, all we need to do is follow our guide on running Python code at boot, and your robot will be truly autonomous.

This post was originally published on this site