<< Chapter < Page Chapter >> Page >

After masking for the yellow balls, we need to filter out any noise so that the circle detector doesn't detect any false balls. We first erode, then dilate the image to get rid of most extraneous noise. This is followed by a simple Gaussian blur to help the circle detector even further.

Circle detection is done using OpenCV. We could have used the circle detector that we wrote ourselves, but it runs much slower than the one provided in OpenCV. The function

cv2.HoughCircles(dp,minDist,param1,param2,minRadius,maxRadius)

has 6 parameters that we can adjust. The dp argument corresponds to the resolution of the accumulator threshold as a simple inverse ratio between the image resolution and the accumulator resolution. The minDist argument is the minimum distance allowed between two detected circles. param1 is the threshold to be used for the Canny edge detector which is built into the function. param2 corresponds to the accumulator threshold. The smaller param2 is, the more false circles may be detected. Finally minRadius and maxRadius are the smallest and largest balls that are allowed to be detected.

Yellow ball detection

What the Pi sees
These are 5 images of what the Raspberry Pi can see. Each image follows a different step of the color masking and ball detection process.

Once circles are detected, the system must output an angle over UART. In this instance, there are two cases:

  1. The first case is where no circles are detected. In this case, the system will output and angle of 0 and a 0 bit for circle detection. However, occasionally a circle will miss detection for one or two frames. For this reason, we have implemented a counter that will only say that no ball was detected if the ball isn't detected for at least 4 frames.
  2. The second case is where at least one ball is detected. In this case, the program chooses the largest detected yellow ball and calculates and angle to send over UART once per frame.

Once data is sent over UART, the next image is captured on the Raspberry Pi. At our chosen resolution, we can send data 5 times per second. It is then up to the Vex Cortex to drive the motors.

3.2 robot behavior

Finally, we will take a look at the robot itself, and how it uses the UART input in order to track and approach the ball.

The robot's vision function is a state machine with 3 states, as described below. Note that State 2 is managed by a PID control structure, using the gyroscope's current value as the input, and a setpoint of the gyroscope's value plus the angle delivered from the Raspberry Pi.

  • If the Raspberry Pi reports that there is no ball in sight, the robot will not move.
  • If a ball is detected, but the robot is not within 2 degrees of facing it, the robot will rotate to face the ball.
  • If the robot is facing the ball within tolerance, it will drive forward towards the ball.
void vision() { gyroReset(gyro->g); gyroPid->running = 1; int targetAngle = gyro->value; //UART angle goeth here. int seesBall = 0; //UART ball in sightint turnPow = 20; int drivePow = 30;for(ever) { if(joystickGetDigital(1, 8, JOY_UP)) operatorControl();char* sInput = fgets(uartIn, 6, uart1); if(sInput) {//Decode UART input char* sAngle = strtok(sInput, " ");char* sBalls = strtok(NULL, " "); seesBall = atoi(sBalls);if(seesBall) targetAngle = gyro->value + atoi(sAngle); }gyroPid->setPoint = targetAngle; turnPow = seesBall ? gyroPid->output : 0; printf("Gyro: %d/%d, atSetpoint: %d, output: %d\n\r", gyro->value, gyroPid->setPoint, gyroPid->atSetpoint, gyroPid->output); if(!gyroPid->atSetpoint) { MOTDTFrontLeft->out = -turnPow; MOTDTFrontRight->out = turnPow; MOTDTBackLeft->out = -turnPow; MOTDTBackRight->out = turnPow; }else if(seesBall){ MOTDTFrontLeft->out = drivePow; MOTDTFrontRight->out = drivePow; MOTDTBackLeft->out = drivePow; MOTDTBackRight->out = drivePow; }if(!seesBall) { targetAngle = gyro->value; }delay(20); }}
This code uses a custom library written by the Rice Robotics Club in order to handle output to the motors, and the PID control. The source for this library can be found in Section 4.2 Additional Resources

Get Jobilize Job Search Mobile App in your pocket Now!

Get it on Google Play Download on the App Store Now




Source:  OpenStax, Elec 301 projects fall 2015. OpenStax CNX. Jan 04, 2016 Download for free at https://legacy.cnx.org/content/col11950/1.1
Google Play and the Google Play logo are trademarks of Google Inc.

Notification Switch

Would you like to follow the 'Elec 301 projects fall 2015' conversation and receive update notifications?

Ask