Embedded Motion Control 2016 Group 5: Difference between revisions
| Line 166: | Line 166: | ||
| =Final Design= | =Final Design= | ||
| [[File:Software_structure.PNG|border|right|top| | [[File:Software_structure.PNG|border|right|top|600px]] | ||
| The Final Design included software to negotiate the maze for the Amazing-maze challenge. Having encountered numerous drawbacks and errors with functions, the team decided to implement classes into the software. | |||
Revision as of 14:16, 7 June 2016
Group Members
| 0976517 | Rohan Lakhotia | r dot lakhotia at student dot tue dot nl | 
| 0976553 | Parth Sharma | p dot sharma at student dot tue dot nl | 
| 0977462 | Xixiao Wang | y dot wang dot 7 at student dot tue dot nl | 
| 0977242 | Satyaki Chaudhuri | s.chaudhuri@student.tue.nl | 
Basic Design Idea
Requirements
For this assignment, we are expected to develop and implement a software code so that Pico can autonomously solve a maze. The assignment consists of the following challenges:
- Corridor Challenge
- Pico must drive through a corridor and take the first exit.
- It must not touch the wall.
- Must detect the exit on its own.
- We have total 5 minutes to complete the challenge.
 
- Maze Challenge
- Pico must be able to solve the maze and find the exit point which is not known.
- It should detect the door and send the request command for the door to open.
- The door opens when the robot is stationary.
- We have total 7 minutes to complete the challenge.
 
Functionality
Based on the requirements mentioned above, certain functionalities of the robot at task were detected. Based on levels of complexity these can be divided into 3 main groups:
- Highest Abstraction Level- Tasks
These tasks directly lead to the realization of the goal, they are considerably complex and use various combination of skills for their accomplishment.
- Maze Solving Algorithm
 
This is the highest level of logic, decision algorithms which enable the autonomous system to negotiate the maze in the shortest time possible. Critical decisions like recognizing dead-ends and intersections and the optimum turning direction fall in this category. This involved various skill selection at different stages of the maze.
- Track Position of Robot: The robot should be able to track the time variance of its
 
position with respect to a Global Coordinate System (planer). This will be beneficial in avoiding movement in closed loop trajectories.
Skills are localized decision making event which enable realization of Tasks, they are of a lower complexity level and often involve computation in a specific situation.
- Avoid Collision with walls: The robot is required to maintain a safe distance from the walls at all points of time. This skill will typically be incorporated at all points of the maze and corridor challenge.
- Recognizing Intersections: The robot should be able to detect intersection of walls. In case of a simple turn in the maze, the robot will be able to decide the correct turning direction. A three way intersection will have to be judged based on the position trajectory of the robot.
- Recognizing Dead-Ends: The robot identifies a dead-end and beeps for a door to be opened. It has to wait a certain amount of time and monitor the walls for them to open.
- Detect End of the Maze: The robot should be able to detect the end of the maze once it appears and complete it eventually.
 
- Lowest Abstraction Level Functions:
These are the very basic functions of the robot which enable the realization of the skills and eventually the tasks. These are the fundamental abilities of the robot which do not involve development of any algorithms on our part.
- Mobility: The robot is equipped with holonomic wheels which enable it to translate and rotate on a planar field. Due to the nature of the challenge, these actuators are sufficient for the robot to complete the maze.
- Sensors: The robot is equipped with Laser Range Finder and Wide Angle Camera to perceive its environment and be able to relay this information to higher levels of functional abstractions.
 
Components and Specifications
- Hardware components:
- Laser Range Finder: A laser range finder uses a laser beam to determine the distance to an object. Here, the laser range finder will be used to calculate the distance between Pico and the walls.
- Wheel encoders/Rotary encoder/Shaft encoder: It is an electro-mechanical device that converts the angular position or motion of a shaft or axle to an analog or digital code. Here, it can be used to get information of robot such as speed, distance and position.
- Wide Angle Camera: With good image processing algorithm, it can be used to localize the position of the robot with respect to the surrounding environment, also to differentiate between walls and door and to interpret different signs (if there is a visual difference between the two).
- Computer with intel i7 processor
- Actuators
- Wheels & Motors: Omni wheels. The effect is that the wheel can be driven with full force, but will also slide laterally with great ease.
- Pan/ Tilt Head: The head can be moved to look around for obstacles.
 
 
- Software Components
- Ubuntu 14.04
- Qt Creator
 
Interface
The control of robots can be done by calling the functions in the emc library, which will communicate with ROS topics for data exchange. By running C++ programs, data can be obtained, processed and transmitted from and to certain topics.
- The libraries are: < emc=rate:h > < emc=io:h >
- The sensor data can be obtained by: io.readLaserData(), io.readOdometryData().
- The structures of data are saved in: emc::LaserData, emc::OdometryData.
- For driving the robot: io.sendBaseReference & io.sendBaseVelocity.
The figure below shows the interface:

Design Document Download
The design document can be downloaded here
First Design Presentation
Functionality
We realised that a detailed inspection and understanding of the robot functionalities was essential, this would enable us to design the software structure. On the most generic level, functionality was divided into Functions, Skills and Tasks as described in our Design Idea. Skills consisted of a tasks which were of wide complexity, we have further divided that into three different segments.
- Basic Complexity: This consists Processing Laser Range-finder and Odometer data. This skill segment enables PICO to understand the environment and also provide data for high levels of skill-sets.
- Medium Complexity: This skill-set performs the safety function. It consists of two actions. The first one is to align and center the robot at all points of its travel in the corridor. The second one is to maintain a certain amount of distance from walls at all points of time, it avoids collision.
- Higher Complexity: This skill-set uses the environment data to detect intersections and their nature. In the corridor challenge, it will consist of software which will detect the exit and respond accordingly. While in the maze challenge, the software will have to map the robot position in the maze, in order to avoid travelling in loops.It will also enable PICO to find the exit to the maze.
Composition Pattern
The software aims to evaluate the robot's surrounding and accordingly provide motion instruction and monitor the execution. In order to understand and implement this software, we have used a structured system architecture. The system is divided in to structure, behaviour and action. Behaviour is the system reaction to the environment, action is the implementation of what the algorithm instructs the robot to perform. Structure is the realisation between behaviour and action. The task-skill-motion diagram helps us explain the behaviour of the system.
- Task Context : The decision making process works in a loop. Starting with the "Action to be Performed", the system decides on a certain immediate goal. A skill-set is decided upon to realise the goal. "Task Monitoring" & "Task Feedback" process data from the Environment and Skills Context to evaluate the execution of the decision and also the current position of the robot.
- Skills Context : Contains all skill sets as mentioned in the Functionality Diagram. The skills are performed in increasing order of complexity.
- Robot Context : It consists the hardware capabilities of the robot. The Laser Range-Finder and the Odometer relay environment data to the Task Context while the motion instruction data is provide to the Holonomic wheels to actuate the robot.
- Environment Context : This consists of two blocks. The Local Environment pertains to the immediate surrounding of the robot, this information is used to avoid collision with the walls, center and align the robot and also detect intersections and their nature. The Global Environment data is used to generate an understanding of the maze structure, avoid travelling in loops and eventually find the exit of the maze.
The design presentation can be downloaded here
Corridor Challenge
The corridor challenge requires the robot to travel through a corridor without any wall collision. It needs to detect an exit either on the right or the left and perform the exit operation. The team decided to break down the various tasks in to simple function blocks. The environment is being studied in the main while loop, based on the conditions the relevant function blocks would be activated. The LRF Data was used to inspect the surroundings in order to understand local position and orientation. Odometer data was used only to track small changes in the displacement of the robot. We understood that due to wheel-slip, odometer data would be unreliable for larger motion. In the corridor challenge, the map was divided into two parts. One was the corridor where the robot was expected to travel straight with out any collision. The other part included the junction of the corridor an the exit.
 header files 
 .
 .
 double Safety()          // Collision Avoidance - Centring and Alignment. 
 double Turn()            // Take a right or a left turn based on the Laser Scanner Readings. 
 double GoStraight()      // Continue moving straight. 
 .
 .
 int main(){
 .
 .
 while (condition 1);     // Call specific functions based on the environment conditions.
 .
 while (condition 2);
 .
 .
 .
 sendBaseReference(x,y,θ)
 .}
Some of the relevant function blocks and working principles have been discussed below.
- Safety: The safety function included software to center the robot, align it along the wall and also avoid collision with the walls. It was active during the corridor part of the maze. Two laser data bundles were averaged to obtain the values (Average Value Right)AVR and (Average Value Left)AVL as illustrated in the diagram below. The difference between these values were considered to be the centering error, based on which the robot was provided with an appropriate lateral velocity. For the align task, we inspect the bundle of data from 0 degs (front of PICO) to the last laser data on the right hand side. The alignment correction angle is equal to the difference between the shortest distance data and the data to the right ( no. 107 ). based on the angle of the shortest distance, the decision to turn either left or right is used.
- Turn: Average Value Right 1(AVR1) and Average Value Left 1(AVL1) are smaller laser data bundles as depicted in the image below. A sharp rise in any of these values indicate the presence of an exit. Once an exit is detected, the safety function is turned off using a flag. The robot is made to move forward by a certain distance which is measured using the odometer data, turn left or right by 90 degs followed by a measured movement in the straight direction. Once the robot has exited the junction of the exit, the safety function is turned on till the robot make the final exit form the corridor.
The images below depict the detection of the corridor exit and the exit methodology used in the corridor challenge.
Simulation Video
Evaluation of Corridor Challenge'
Final Design
The Final Design included software to negotiate the maze for the Amazing-maze challenge. Having encountered numerous drawbacks and errors with functions, the team decided to implement classes into the software.