Embedded Motion Control 2017 Group 9: Difference between revisions
| Line 131: | Line 131: | ||
| In the following picture, it is clear that three laser bundles in forward, minus ninety degree and plus ninety degree are selected to detect the junction. In order to find junction in perfect way, the detection radius and detection angle need to be well calculated. The detection angle is set to be 24 since the maximum detection range is from minus 114 degree to plus 114 degree.   | In the following picture, it is clear that three laser bundles in forward, minus ninety degree and plus ninety degree are selected to detect the junction. In order to find junction in perfect way, the detection radius and detection angle need to be well calculated. The detection angle is set to be 24 since the maximum detection range is from minus 114 degree to plus 114 degree.   | ||
| &trade | |||
| As a result, the boundaries of three laser bundles are: | As a result, the boundaries of three laser bundles are: | ||
| * Left bundle: ± 114 degree and ± 66 degree | * Left bundle: ± 114 degree and ± 66 degree | ||
Revision as of 21:05, 14 June 2017
Group Members
| Name: | Student id: | 
| Mian Wei | X | 
| Zhihao Wu | X | 
| Petrus Teguh Handoko | X | 
| Bo Deng | X | 
| Bo Cong | X | 
| Jian Wen Kok | X | 
| Nico Huebel | Tutor | 
Initial Design
The initial design for the maze challenge is elaborated below. It includes the requirements, functions, components, schematic of program structure, specifications and interfaces to define the working of PICO. The file for the initial design is included here: File:Assignment-for-week1.pdf
Requirements
➢  PICO drives autonomously through maze
➢  Being able to take a turn without touching a wall
➢  Being able to detect a turn or branching corridors
➢ Avoiding collisions with obstacles (including the walls)
➢  Driving straight and rotating smoothly 
➢  PICO should not stand still for 30 seconds
➢  Avoid getting trapped in a loop of the maze
➢  Being able to recognize the door
Functions
Components
drive control 
‐Holonomic base (omni‐wheels) 
‐Pan‐tilt unit for head 
detection 
‐170◦ wide‐angle camer 
‐Laser Range Finder (LRF) 
‐Wheel encoders (odometry) 
‐Asus Xtion Depth sensor 
world model 
computer 
‐Intel I7 
‐Ubuntu 14.04
Specifications
- maximum translational speed of 0.5 m/s 
‐ maximum rotational speed of 1.2 rad/s 
‐ Door template: length of 0.5 ‐ 1.5m and with side walls of approximately 30cm, see figure below 
‐ LRF accuracy and range unknown 
‐ odometer accuracy unknown 
Interfaces
The odometer and LRF generates data for mapping the environment. 
The algorithm sets nodes on the junction as a setpoint for navigation, plans the route and put the actuators to work accordingly. 
The odometer and LRF keeps on keeping track of the environment and the software recognizes obstructions, dead ends that might be doors and junction.
Corridor challenge
design
At first, PICO moves forward with a modified potential field.
When it detects the junction, the potential field goes off and stops when it is in the middle of the junction.
PICO then rotates 90 degree and moves forward.
When PICO detects that it is inside the junction, the potential field goes on and finishes the challenge.
result
The corridor challenge failed
In the first trial PICO  moved straight forward without potential field. 
When it detects the junction it stopped and rotated 90 degrees in the wrong direction. 
This inevitably resulted into crashing into the walls.
The second trial PICO did not detect the junction and drove straight forward, this was the latest program.
evaluation
The first trial used our old program that has proven itself as seen in the video below. Unfortunately we did not push the correct version to PICO. 
 
The second trial used our latest program. Potential field is added because there exists a chance that PICO would run into the walls without it. 
The new program works in the simulation, it has been tested in the real setting and we had problems with the odometer to correctly make the turning. 
The program had to run without debugging in the real setting. Later on, a bug was found in the junction detection.
Maze challenge
design
architecture
main flow
detection
door detection
junction detection
In the following picture, it is clear that three laser bundles in forward, minus ninety degree and plus ninety degree are selected to detect the junction. In order to find junction in perfect way, the detection radius and detection angle need to be well calculated. The detection angle is set to be 24 since the maximum detection range is from minus 114 degree to plus 114 degree.
&trade As a result, the boundaries of three laser bundles are:
- Left bundle: ± 114 degree and ± 66 degree
- Forward bundle: plus 24 degree and minus 24 degree
- Right bundle: minus 114 degree and minus 66 degree
The width of the corridor is between 0.5m to 1.5m. In order to detect the widthest corridor, the following equation need to be satisfied:
[math]\displaystyle{ Insert formula here }[/math]
Also the width of a junction should be bigger than PICO's width, so:
[math]\displaystyle{ Insert formula here }[/math]
These two equations will make sure the pico can find junction in the widthest corridor and also could go through the junction in open loop. Finally, the detection radius is set to be 0.85.
To increase the robustness of the detection, all the distance of the laser line inside the laser bundle will be measured, if 80% laser line has longer distance than the detection radius, PICO will consider there is a junction.
Two flag are used to describe the exist and feature of junctions: the junction flag and the direction flag.
- Junction flag is used to describe the exist of junctions
- 0: no junction or only forward junction
- 1: existence of left or right junction
 
- Direction flag D[3] is an array, and each number represent a direction
- D[0]=true: right direction available
- D[1]=true: forward direction available
- D[2]=true: left direction available
 
If junction flag has been setted to 1, the decision block will be triggered and decide a direction to move based on the direction flag.
door open detection
movement
door movement
junction movement
The Junction Movement function consist of five cases: turnStraight,TurnRight,TurnLeft,Protection and movForward.
turnstraight: 
PICO shortly moves straight for 0.5m or when counters time[3s] has passed and continues with the moveForward function. The counter is needed to prevent the program go into a loop when PICO is not able to move the distance. The forward movement is protected by 5 laser sectors. When it is too close to the wall or obstruction, the forward movement will move backwards with an speed of -0.2m/s. When the beams:.... detects that PICO is too close to the wall, the program goes into the state of protection and will not go out of the state if PICO has not moved out of the unsafe position 
turnRight and turnLeft: 
Both cases turnRight and turnLeft rotates 90 degrees to the corresponding direction and measures the rotation with the odometer to determine when to stop. To make sure that the odometer is accurate enough, the rotating speed is set at 0.2 rad/s. 
movForward:
 
With movForward, PICO moves straight for 5m or stops when counters time[5s] has passed. 
 
protection: 
 
protection: when at turnStraight or movForward detects obstruction, then pico stops and moves sideways to avoid the obstruction.
 
The code snippet is included below: code snippet: junction_movement.cpp
move forward
Similarly to the junction_movement.cpp, move_forward.cpp uses three front laser sectors to adjust the speed. The forward speed is either 0.5m/s when the detection allows or -0.2 m/s otherwise. What differs from the junction_movement.cpp is that the forward movement will not stop when it adjusts with the side movement to avoid obstruction. With 6 laser sectors, 3 at both sides, it adjusts the sidewards speed. When it detects a obstruction, it will move sidewards to avoid the obstruction.
code snippet: move_forward.cpp
mapping
protection
open space
result
evaluation
Evaluation group9 EMC 2017
Code snippets
Movement
code snippet: move_forward.cpp
code snippet: junction_movement.cpp








