RobotKitLib is our replacement for wpilib-robotpy for the Freenove Raspberry Pi Robot Kit, with compaitability (with minimal modifications) for frc robotpy code.
The Freenove 4WD Raspberry Pi - based robot kit looks like a promising platform for software training. This kits costs about $70, but requires a number of other components to be fully functional.
- $35 Raspberry Pi 3B+
- $10 32G SD-Card
- $12 4 x 3.7V Lithium Ion Cells
- $10 LI battery charger
Important files:
- robot.py - robot-specific implementation of the typical FRC robot functions (resident on Pi)
- run.py - the frc-like robot runtime that calls the entry points in robot.py (resident on Pi)
- robot_setup.py - infrastructure for receiving new code and reseting run instance. This is what runs on boot (resident on Pi)
- /pikitlib/* - our replacement files for (but look-alike) for wpilib functions that are robot specific. (resident on Pi and laptop)
- driverstation.py - resident on the laptop. Reads controls, maybe displays dashboard, enables/disables and sends control/commands to the robot.
- <>.py - other files needs to be integrated into the library. (should not really be visible at the top layer, but they are there now for expediency)
- deploy.py - sends new code to the robot
NOTE: Using this code requires Python 3.9
Note for Windows users - In order to deploy code, you will need to install a bash terminal such as Git Bash (https://git-scm.com/downloads, make sure to select download for Windows) and run the file from there.
Setup:
Clone the repo both on your local machine and the robot's raspberry pi.
Install requirements.txt with pip on both your local machine and on the robot
On the raspberry pi, enable SSH and GPIO
On the raspberry pi, run setup_autorunner.sh
to allow the robot to run on boot
Usage:
Driverstation:
The driverstation is run with python driverstation.py IP_ADDRESS
with the IP being the IP of the robot (found with hostname -I
)
Deploying code:
Simply run python deploy.py IP_ADDRESS
with the IP again being the IP of the robot
On the robot:
Running the code:
Run python robot_setup.py
(in future versions this will start on boot)
I think it can also serve as a platform for design/mechanical and electrical to do some nice custom projects.
One limitation that we discovered right away is the software architecture seems very limiting for what we want to do with robot programming. But, fortunately, everything is written in python, so fixing it up is certainly an option.
So we have kicked off a software project to make it programmable using the same robot.py kind of architecture that we are accustomed to. This requires:
- A driverstation application - at a minimum, this supports changing robot modes and driving or operating the robot using an XboxController.
- A driver dashboard that can display information about the robot state (this could be Shuffleboard)
- A replacement for the wpilib components that we all know and love.
- XboxController object - receives the joystick state via NetworkTables from the driverstation and makes "button-pressed" and axis controller values visible using the same wpilib interface.
- Motor controller objects, Speed Controller, and Drivetrains.
- New sensor components and on-robot treats that will need object interfaces.
The task of creating this environment should be excellent training for returning students, and should help them understand a little what has maybe been "magic" before.