Embedded Motion Control 2017 Group 3: Difference between revisions
| Line 41: | Line 41: | ||
| # Components | # Components | ||
| # Interfaces | # Interfaces | ||
| ==Requirements== | |||
| After brainstorming section, requirements are listed for our robot (PICO) to complete maze successfully and is as follows: | |||
| # PICO may not touch the walls or any other obstacle in the maze at any time | |||
| # PICO must operate fully autonomous (i.e. without input from the team) | |||
| # PICO may not be idle for more than 3 seconds from the start of program unless it has passed the exit | |||
| # PICO must be able to detect available space using the Laser Range Finder (LRF) and move to the detected space according to the motion planning algorithm | |||
| # PICO must be able to find the exit in finite time (≤ 7 sec for maze and ≤ 5 sec for corridor.) | |||
| # PICO must be able to detect the objects (dead ends) that have a high probability of being a door | |||
| # PICO must be able to open the door in the maze and pass through it | |||
| ==Functions== | |||
| The functions are separate modules called supervisors where, the supervisor unknown of what is inside the other supervisor. This approach makes software architecture simpler, it is also easier to edit and error count will be less since no direct interaction of modules. Supervisors are listed below: | |||
| # Path-finding Supervisor | |||
| # Door Handling Supervisor | |||
| # Wall / Path Detection | |||
| # Motion Supervisor | |||
| # Actuator Supervisor | |||
| ===Path-finding Supervisor=== | |||
| ====1-Pledge Algorithm==== | |||
| Takes in the extracted wall information as input and sets a movement goal for the PICO and move towards it. This algorithm is useful when the robot is challenged to solve loop inside the maze. The algorithm functions as a continuous loop. (Maze challenge) | |||
| ====2-Cornering==== | |||
| Take the corner using the wall information as input. (Corridor challenge) | |||
| ===Door Supervisor=== | |||
| ====1-Ring Bell==== | |||
| Ring the bell if it detect the door possible deadends | |||
| ====2-Standstill==== | |||
| Wait for 5 sec to for the door openingsequence. | |||
| ===Wall / Path Detection=== | |||
| ====1-Read LRF data==== | |||
| Gets raw data from the LRF sensor | |||
| ====2-Filter LRF data==== | |||
| Reduces noise from raw LRF data and splits it into 3 directions (left, right and front). | |||
Revision as of 09:08, 22 May 2017
Group Members
| 1032791 | Ayisha wafa | ayisha.wafa@student.tue.nl | 
| 0980790 | Aparnasri Sekar | @student.tue.nl | 
| 0976940 | Nick Peters | @student.tue.nl | 
| 0976467 | Jelte Borsboom | @student.tue.nl | 
| Tutor | Wouter Kuijpers | w.j.p.kuijpers@tue.nl | 
Documents
Here given is the initial design document namely, File:Emc-design-specification.pdf that points the approaches taken towards problem, algorithms used and system design for the robot to navigate through maze and find the exit autonomously.
The slides for the initial design presentation can be found here: File:Group3 2017 Initial design presentation.pdf
Overview
This article presents a summary of the software design to solve the following challenges with the Pico robot.
- Corridor competition: To follow a corridor and take the first exit.
- Maze competition: To solve and exit an unknown maze.
The project is divided in the following aspects:
- Requirements
- Specifications
- Functions
- Components
- Interfaces
Requirements
After brainstorming section, requirements are listed for our robot (PICO) to complete maze successfully and is as follows:
- PICO may not touch the walls or any other obstacle in the maze at any time
- PICO must operate fully autonomous (i.e. without input from the team)
- PICO may not be idle for more than 3 seconds from the start of program unless it has passed the exit
- PICO must be able to detect available space using the Laser Range Finder (LRF) and move to the detected space according to the motion planning algorithm
- PICO must be able to find the exit in finite time (≤ 7 sec for maze and ≤ 5 sec for corridor.)
- PICO must be able to detect the objects (dead ends) that have a high probability of being a door
- PICO must be able to open the door in the maze and pass through it
Functions
The functions are separate modules called supervisors where, the supervisor unknown of what is inside the other supervisor. This approach makes software architecture simpler, it is also easier to edit and error count will be less since no direct interaction of modules. Supervisors are listed below:
- Path-finding Supervisor
- Door Handling Supervisor
- Wall / Path Detection
- Motion Supervisor
- Actuator Supervisor
Path-finding Supervisor
1-Pledge Algorithm
Takes in the extracted wall information as input and sets a movement goal for the PICO and move towards it. This algorithm is useful when the robot is challenged to solve loop inside the maze. The algorithm functions as a continuous loop. (Maze challenge)
2-Cornering
Take the corner using the wall information as input. (Corridor challenge)
Door Supervisor
1-Ring Bell
Ring the bell if it detect the door possible deadends
2-Standstill
Wait for 5 sec to for the door openingsequence.
Wall / Path Detection
1-Read LRF data
Gets raw data from the LRF sensor
2-Filter LRF data
Reduces noise from raw LRF data and splits it into 3 directions (left, right and front).