Skip to content
/ MARIO Public

Official Repository for ROS-based Manipulator, implemented with ESP32

License

Notifications You must be signed in to change notification settings

SRA-VJTI/MARIO

Repository files navigation

MARIO WORKSHOP 2.3

Downloads License: MIT GitHub star chart Dependency Status Open Issues Open in GitHub Codespaces

MARIO abbreviation for Manipulator on ROS Based Input Output is a bot with 3 Degree of Freedom. It consists of two SG90 micro servo and one MG995 metal gear servo motor. The servo motors are placed on base, elbow and shoulder enabling it with 3 Degrees of Freedom.

Given below are instructions for ROS2-Humble and micro-ROS installations. For ROS1 and Rosserial based MARIO, refer to the following instructions.

Sneak Peek

Working of the Mario Bot

Mario bot simulated using Gazebo

File Structure

├── 1_chatter_listener                        # talker and listener script to understand the nodes and communications in ROS
├── 2_simulation_dh                           # simulation of DH paramteres
├── 3_simulation_rviz                         # simulation of MARIO bot on rviz
├── 4_simulation_gazebo                       # simulation of MARIO bot on gazebo
├── assets                                    # contains necessary gifs, images 
├── firmware                                  # contains ESP-IDF examples for controlling servo motors and micro-ROS
│   ├── 1_servo_set_zero                      # example in ESP-IDF to set angles of all servo motor zero
│   ├── 2_servo_sweep                         # example in ESP-IDF to set variable angles in servo motor
│   ├── 3_microros_rviz                       # example in ESP-IDF to interface with rviz environment as well as ESP32
│   ├── 4_microros_gazebo                     # example in ESP-IDF to interface with gazebo environment as well as ESP32
│   ├── 5_servo_test_webserver                # example in ESP-IDF to set angles of servo over the webserver interface
│   └── components                            # contains all the dependencies required for the above examples
│       ├── micro_ros_espidf_component        # library to interface between micro-ROS environment and ESP32
│       └── sra-board-component               # library to interface with SRA board
├── LICENSE
└── README.md 

Kinematics

  • MARIO workshop aims to provide the basic knowledge about the DH parameters, forward kinematics , inverse kinematics.
    • DH Parameters :- Denavit–Hartenberg parameters (also called DH parameters) are the four parameters associated with a particular convention for attaching reference frames to the links of a spatial kinematic chain, or robot manipulator
    • Forward Kinematics :- Forward kinematics refers to the use of the kinematic equations of a robot to compute the position of the end-effector from specified values for the joint parameters. The kinematics equations of the robot are used in robotics, computer games, and animation.
    • Inverse Kinematics :- inverse kinematics is the mathematical process of calculating the variable joint parameters needed to place the end of a kinematic chain, such as a robot manipulator or animation character's skeleton, in a given position and orientation relative to the start of the chain.

ROS-2

ROS2 is the ultimate toolkit for robotics enthusiasts and professionals alike. Seamlessly integrating hardware and software, ROS2 streamlines development workflows, accelerates prototyping, and enables rapid iteration. With its modular architecture and extensive library of reusable components, ROS2 simplifies the creation of complex robotics projects, from autonomous drones to collaborative robot arms.

Publisher and Subscriber

Publish/Subscribe is a messaging pattern that aims to decouple the sending (Publisher) and receiving (Subscriber) party. A real world example could be a sport mobile app that shows you up-to-date information of a particular football game you're interested in. In this case you are the subscriber, as you express interest in this specific game. On the other side sits the publisher, which is an online reporter that feeds a system with the actual match data. This system, which is often referred as the message broker brings the two parties together by sending the new data to all interested subscribers.

While ROS2 works on the same system, this system is also used in various other libraries like MQTT.

MICRO-ROS

micro-ROS is a robotic framework targeting embedded and deep-embedded robot components with extremely constrained computational resources. These devices have special characteristics: a minimum real-time operating system or no operating system, battery-powered, wireless low bandwidth connections, and intermittent operation with sleep periods.

ESP-IDF

ESP-IDF is the development framework for Espressif SoCs.The SRA Board uses ESP32 as microcontroller, hence ESPIDF is required to code the ESP32. Examples included inside firmware directory has been written in ESPIDF version 5.1 .

Installation of ROS2 and other dependencies

  • Copy and execute the following command in your bash terminal
wget -O - https://raw.githubusercontent.com/SRA-VJTI/MARIO/humble/installations.sh | bash
  • As an alternative, you can also install the required packages on your local machine by following the instructions below.

    • Clone SRA-VJTI's MARIO repository on your system
    git clone --recursive https://github.com/SRA-VJTI/MARIO.git
    • Change terminal directory inside the cloned repository
    cd MARIO/
    • Run the installation script
    ./installations.sh