[Solved] ECSE211-Lab 5 Search and Localize

$25

File Name: ECSE211_Lab_5_Search_and_Localize.zip
File Size: 310.86 KB

SKU: [Solved] ECSE211-Lab 5 Search and Localize Category: Tag:
5/5 - (1 vote)
  1. Implement a robot with ultrasonic and color sensors for determining the location and color of a ring without physical contact.
  2. Starting in a known corner, localizing to the grid, and performing a search along a specific path for a colored ring of known dimensions

Design requirements

The following design requirements must be met:

  • The system must satisfy the design requirements from Lab 3 with respect to localization:
    • You must follow the (X , Y, ) convention specific to this lab (refer to Figure 2 ). o You are free to use any localization method (with or without light localization).
    • You are not required to provide a way of selecting rising or falling edge. o You do not have to wait for user input after completing ultrasonic or light localization. The system must follow the same navigation requirements as in Lab 4:
    • The robot must navigate through a series of specified points using the minimal distance.
    • A list of waypoints must be provided in one location in the code.
    • The robot must use the grid system found on the play floor, where the origin is the starting corner of a tile.
    • Waypoints will be given with respect to the tile grid system. For example, (1, 0) will be located 30.48 cm to the right of the origin (0, 0).
    • When turning to a waypoint, the robot must use the minimal angle needed to turn to it.

12th

  • Your robot must be able to localize in the starting corner, navigate through the given waypoints, detect the color of every ring along its path, and signify when it has reached the end of its course with 3
  • Your robot must complete its demonstration procedure in a maximum of 5 minutes.

Color Calibration

The color assignments of the rings are 1: Green , 2: Blue , 3: Yellow , 5: Orange , as defined her e.

Part of the preparation for this experiment is calibrating your color sensor against the sample rings in the lab. This is an important step in the design process because it will allow for greater color detection accuracy than using constant values or the given leJOS methodology. Calibrating and validating sensor behaviour before testing the robot as a whole will make the entire process easier! Each color corresponds to a distribution of Red , Green , and Blue values.

For each ring, you need to take several measurements of the R G B values returned by the sensor. These measurement values will be used to build a statistical model for each rings color.

Quick Tip: This color calibration should be done and tested in both TR0110 and TR0090, since they have different lightings and could potentially yield different results! The demos will be conducted in TR0090 (the small lab), so testing color calibration in that room especially would be ideal.

A particularly simple approach is to model each R G B channel as a Gaussian distribution, i.e. empirically compute the mean and standard deviation for the Red , Green , and Blue channels for each ring from the measurement samples. Therefore, each ring can be represented by its mean RG B values. A simple means of classifying each ring is to compute the Euclidean distance, d, between the R G B values of a measured sample, sR , sG , and sB , and a target rings mean R G B values, R , G and B , and. A ring is then deemed to be the match when the minimum Euclidean distance value is met.

2 2 2 d = (sR R) + (sG G) + (sB B)

However, in a real-world scenario, this approach may not work accurately. Given the Gaussian distribution for each channel, an easy way to distinguish ring colors from each other is to use their standard deviations, i.e. R , G , and B , precomputed from the measurement samples. For example, if a sample distance is greater than 2 or 3 standard deviations from its mean, that ring is probably not the target. This method uses a probabilistic measure by introducing a level of uncertainty when dealing with the color sensor samples.

Figure 1. Normalized Gaussian distribution: 68% within 1, 95.4% within 2.

In computing your mean statistics, i.e., R mi, G mi, B mi, R s, G s, and B s, variations will creep in due to

changes in ambient lighting. One way of mitigating this is to normalize the mean in a particular

channel by the average over all 3 channels, shown for Rs, Gs, and Bs below,

and similarly for R mi, G mi, and B mi .

Demonstration

The design must satisfy the requirements by completing the demonstration outlined below.

Design presentation

Before demoing the design, your group will be asked some questions for approximately 5 minutes. You will present your design (hardware and software) and answer questions to test your understanding of the lab concepts. Grades will apply to the entire group, although TAs reserve the right to grade individually if they deem it necessary.

You must present your workflow, an overview of the hardware design, and an overview of the software functionality. Visualizing software with graphics such as flowcharts is valuable.

Color Classification

The TA will check whether your robot can correctly classify the Blue, Green, Yellow and Orange rings. When any object is brought close to your sensor(s), the LCD must display Object

Detected on the first line. The next line should read Blue , Green , Yellow and Orange for a target ring. Nothing should be displayed on the LCD if no object is detected. You can decide the distance between the tested ring and the sensor. This color classification should not take more than 10 seconds per trial for 5 successive trials using the rings in the lab. False positives and negatives are considered incorrect. Hence, the following points are awarded:

  • 1 point for each time the robot correctly classifies a ring (i.e. Object Detected and color ).

Field Test

The field test will be set up on an 88 grid as shown below in Figure 2 . There will be at least 2 and at most 5 rings in the navigation path.

Figure 2: Search and Localize demo setup (with Map 4 and 4 rings)

For a successful field test, the following steps must be followed:

  • Enter the given path as decided by the TA:
    • As in Lab 4, we ask that you encode the given maps (in the FAQ section below) so you can easily select the correct map to use at demo time.
  • Place your robot in the starting corner (0, 0).
  • Start your robot upon a button push. At this point, the program should already be fully loaded and all the sensors initialized.
  • Your robot must proceed to localize and navigate through the waypoints.
  • While navigating, the robot must then detect rings and their colors:
    • If a ring is detected, the robot must stop and display the words Object Detected on the top line of the LCD.
    • Once the color of the ring has been determined, the robot must display the color on the second line of the LCD display, BEEP TWICE, and then pause for about 10 seconds (to allow a TA to remove the ring from the path) before continuing its navigation.
    • Once the ring and color have been detected, the ring will be removed from the robots path so as not to disrupt navigation.
  • Once the robot reaches its final waypoint, it should BEEP THREE TIMES and stop.
    • For the ease of the demo, the robot should display these two parameters once it has stopped:

On the first line: The number of rings detected throughout the demo

On the second line: The color of the rings detected, in order from first to last. ▪ For example, for Figure 2 it should display:

Number detected: 4

Colors detected: Blue, Yellow, Orange, Green

  • All these steps must be completed within 5 minutes.

Hence, the following points are awarded for the field test:

  • are awarded for localization and navigation to the point (1, 1) before navigation begins.
  • are awarded for correctly identifying all rings along the path and not misidentifying their colors. Partial marks will be awarded as deemed by the number of rings detected and by the TA.
  • are awarded for navigating through all the waypoints and for finishing within approximately half a tile of the last point.

We recommend referring to the FAQ section for details on some specific limitations.

Report Requirements

The following sections must be included in your report. Answer all questions in the report and copy them into your report. For more information, refer to the submission instructions. Always provide justifications and explanations for all your answers.

Important Note about Grading:

The grading rubric of this report has been altered. Section 1 (Design Evaluation) will now count for 10 of the 50 marks, and Section 5 (Further Improvements) will count for 5 out of the 50 marks.

Section 1: Design Evaluation

For Lab 5, we are asking that this section be longer than the half a page required for previous labs. Now that you will be working in larger groups, more thought should be put into the design process, workflow, and teamwork of this lab. This section now has a limit of about 2 pages.

Workflow

  • How did you distribute tasks amongst team members? How did this distribution of work aid in the design process?
  • What was the timeline of your work? Did any aspect of the lab take you longer than expected?
  • Did your design process or workflow change drastically with more group members? How did you deal with this change in environment?
  • Include any flowcharts or graphics to help describe your workflow.

Hardware Design

  • Give a general overview of the hardware design. Include graphics or any images taken of your robot here.
  • How did you validate this hardware design prior to building it? If you did not, how could you include this step in the future?

Software Design

  • Give a general overview of the software design. Include graphics and diagrams here.
  • How did you validate your software design prior to running it on the robot? If you did not, how could you include this step in the future?

Section 2: Test Data

This section describes what data must be collected to evaluate your design requirements. Collect the data using the methodology described below and present it in your report.

Model Acquisition (4 x10 independent trials)

  • Collect a minimum of 10 R G B color values for each ring color (i.e. Blue , Green , Yellow , and Orange).
  • The ring-to-sensor distance should be within the working range of the sensor (which you need to determine). You should ensure to sample different points on the surface.

Color and Position Identification (4 independent runs)

  • Set the robot to follow the navigation path from Map 4 (Figure 2).
  • Place all 4 rings in the search region as shown in Figure 2.
  • Run the field test 4 times:
    • In each run, record (XF, Y F) , the final position of the robot.
    • In each run, record the sample R G B values (sR , sG , sB ) for all the identified rings.

These are used to evaluate your classifiers performance.

  • In each run, record how many of the rings were detected and correctly color-identified.
  • Hint: you can write your measurements to the LCD or remote console program.

Section 3: Test Analysis

Color Calibration

  • Compute the R G B mean and standard deviation values for each of the 4 ring colors.
  • For each color, plot the corresponding R G B normalized Gaussian distributions and draw vertical lines at , 1 from , and 2 from .
  • Ensure that your plots are labelled and captioned in sufficient detail.

Color and Position Identification

  • For each field test run, compute the Euclidean distance, d, of all recorded R G B This should result in 4 distance values for each recorded sample. Then, rank order the distances for each ring index in ascending order. For each entry in the rank order table, list the classification that your algorithm returns (i.e. was a Red ring detected as Red ?).
  • For each run, compute the Euclidean error distance between (XF, YF) and the expected

destination waypoint (XD, YD).

Section 4: Observations and Conclusions

  • Are rank-ordering Euclidean distances a sufficient means of identifying ring colors? Explain in detail why or why not.
  • Is the standard deviation a useful metric for detecting false positives? In other words, if the ring color determined using the Euclidean distance metric, d, is incorrect, can this false positive be detected by using 1 or 2 values instead?
  • Under what conditions does the color sensor work best for correctly distinguishing colors?

Section 5: Further Improvements

  • Depending on how you implemented your color classifier, can your results be improved by using one or more of the noise filtering methods discussed in class? How could you improve the accuracy of your target detection?

Reviews

There are no reviews yet.

Only logged in customers who have purchased this product may leave a review.

Shopping Cart
[Solved] ECSE211-Lab 5 Search and Localize[Solved] ECSE211-Lab 5 Search and Localize
$25