No version for distro humble. Known supported distros are highlighted in the buttons above.
No version for distro jazzy. Known supported distros are highlighted in the buttons above.
No version for distro rolling. Known supported distros are highlighted in the buttons above.
![]() |
mep3 repositorymep3_behavior mep3_bringup mep3_controllers mep3_hardware mep3_localization mep3_msgs mep3_navigation mep3_simulation |
|
Repository Summary
Checkout URI | https://github.com/memristor/mep3.git |
VCS Type | git |
VCS Version | main |
Last Updated | 2025-01-28 |
Dev Status | UNMAINTAINED |
CI status | No Continuous Integration |
Released | UNRELEASED |
Tags | No category tags. |
Contributing |
Help Wanted (0)
Good First Issues (0) Pull Requests to Review (0) |
Packages
Name | Version |
---|---|
mep3_behavior | 0.1.0 |
mep3_bringup | 0.0.0 |
mep3_controllers | 0.0.0 |
mep3_hardware | 0.0.0 |
mep3_localization | 0.0.0 |
mep3_msgs | 0.0.0 |
mep3_navigation | 0.1.0 |
mep3_simulation | 0.0.0 |
README
mep3
Memristor Eurobot Platform based on ROS 2
Installation
Make sure you have ROS 2 Humble installed and follow the steps below:
# Source ROS 2
source /opt/ros/humble/local_setup.bash
# Create a workspace
mkdir -p ~/ros2_ws/src
cd ~/ros2_ws
git clone git@github.com:memristor/mep3.git src/mep3
# On embedded device: touch src/mep3/mep3_simulation/COLCON_IGNORE
# Install dependencies
sudo apt install python3-vcstool
# vcs import src < src/mep3/mep3.repos
rosdep update
rosdep install --from-paths src --ignore-src -r
# Build the packages
colcon build --symlink-install --cmake-args -DCMAKE_BUILD_TYPE=RelWithDebInfo
# Source this workspace
source install/local_setup.bash
⚠️ Recommended: Please check alternative installation methods here.
Bringup
Start the ROS app on a physical robot or a simulation with multiple robots.
Physical
Start the ROS app on SBC (we support Raspberry Pi):
ros2 launch mep3_bringup robot_launch.py bt:=false color:=blue
Important parameters are:
-
namespace
: Whether to load a configuration for a big or small robot (can bebig
orsmall
). -
color
: Team color (can beblue
orgreen
). -
bt
: Whether to run a behavior tree (can betrue
orfalse
). -
strategy
: Name of the behavior tree you want run.
Simulation
Start the simulation on a PC:
ros2 launch mep3_bringup simulation_launch.py
Important parameters are:
-
color
: Team color (can beblue
orgreen
). -
bt
: Whether to run a behavior tree (can betrue
orfalse
). -
big_strategy
: Name of the behavior tree you want run for the big robot. -
small_strategy
: Name of the behavior tree you want run for the small robot.
Demo
Teleoperation
[!NOTE] Run simulation without behavior tree
ros2 run teleop_twist_keyboard teleop_twist_keyboard --ros-args -r cmd_vel:=big/cmd_vel
(use i
, j
, l
, and ,
keys move to the robot)
Visualization & navigation
ros2 launch mep3_bringup rviz_launch.py namespace:=big
(use 2D Goal Pose
to navigate the robot)
Tips
Live strategies
To iterate quickly on behaviors you can load any strategy that contains live
in the name.
As soon as any of the files in the mep3_behavior/strategies
directory is changed the behavior node will reload.
Webots world simulation
- Open
mep3_simulation/webots_data/worlds/eurobot.wbt
in Webots
webots ~/ros2_ws/src/mep3/mep3_simulation/webots_data/worlds/eurobot.wbt
- Stop simulation and set time to
00:00:00
- Save changes
- Commit all changes except for
Viewpoint
Testing
- Change working directory to
~/ros2_ws
- Run the following command:
source /opt/ros/humble/local_setup.bash
colcon test --event-handlers console_cohesion+ --return-code-on-test-failure
CONTRIBUTING
No CONTRIBUTING.md found.
No version for distro noetic. Known supported distros are highlighted in the buttons above.
No version for distro ardent. Known supported distros are highlighted in the buttons above.
No version for distro bouncy. Known supported distros are highlighted in the buttons above.
No version for distro crystal. Known supported distros are highlighted in the buttons above.
No version for distro eloquent. Known supported distros are highlighted in the buttons above.
No version for distro dashing. Known supported distros are highlighted in the buttons above.
No version for distro galactic. Known supported distros are highlighted in the buttons above.
No version for distro foxy. Known supported distros are highlighted in the buttons above.
No version for distro iron. Known supported distros are highlighted in the buttons above.
No version for distro lunar. Known supported distros are highlighted in the buttons above.
No version for distro jade. Known supported distros are highlighted in the buttons above.
No version for distro indigo. Known supported distros are highlighted in the buttons above.
No version for distro hydro. Known supported distros are highlighted in the buttons above.
No version for distro kinetic. Known supported distros are highlighted in the buttons above.
No version for distro melodic. Known supported distros are highlighted in the buttons above.