Vision based perception is a fundamental aspect of navigation with Autonomous Mobile Robots, self driving cars being one of its applications. For any good self-driving car, the first and foremost task would be to detect lanes on the road. This detection will help with localizing the car primarily and this information will help drive the car, make turns as necessary and do everything that comes along with it. It is quite literally the eyes of the car.
Here we are provided with two video datasets and we perform lane detection first of all and then in the second video we also integrate it with turn prediction based on the radius of curvature of the road.
- Create a capture object and capture the image frame by frame
- Convert it to grayscale, and apply Gaussian blur
- Detect edges using cv.Canny edge detector
- Select a region of interest (triangular in this case)
- First we detect only solid lines
- Using cv.HoughLinesP and setting minium length very high to eliminate small lines to detect only solid lines
- Average out the beginning and end coordinates of the line to get single coordinates of beginning and end points
- Find its slope and intercept
- Using the slope and intercept to fit the entire frame along the line and finding new extreme points
- Using these extreme lines to draw a green line denoting a solid line
- Now to detect only dashed lines
- Using cv.HoughLinesP to detect all lines
- Using step 8, we have the slope of solid lines
- If slope of solid lines is positive only save those lines whose slope is negative (denotes dashed line)
- If slope of solid lines is negative only save those lines whose slope is positive (denotes dashed line)
- Average out the beginning and end coordinates of the line to get single coordinates of beginning and end points
- Find its slope and intercept
- Using the slope and intercept to fit the entire frame along the line and finding new extreme points
- Using these extreme lines to draw a red line denoting a dashed line
- Create a capture object and capture the image frame by frame
- Convert to grayscale and threshold the image
- Create a three channel threshold to show in final output
- Using cv.findHomography and cv.warpPerspective perform homography of a selected region of the frame and warp its perspective
- Convert the warped perspective image into a grayscale, threshold it and convert it to a three channel threshold to perform further operation
- The orginal three channel threshold from step 5 will be added to the final output, we make a copy of it for futher processing
- Creating a blank image like the warped image
- First we detect the lane with white colour
- Convert the warped image into grayscale and threshold it
- Using np.where find the coordinates of pixels whose values are 255 which correspond to white pixels
- Using np.polyfit fit a polynomial curve of degree 2 on these points
- Find out the x and y coordinates of points aloing the curve and make it into an array
- Using cv.polylines draw the curve on a.) blank image & b.) copy of the warped three channel threshold image
- Using cv.circle draw circles along the detected points for the white line
- Calculate the radius of curvature of white lane
- Next, we detect the lane with yellow colour
- Convert the image into the HSV domain to get only yellow lines
- Using np.where find the coordinates of pixels whose values are 255 which correspond to yellow pixels
- Using np.polyfit fit a polynomial curve of degree 2 on these points
- Find out the x and y coordinates of points aloing the curve and make it into an array
- Using cv.polylines draw the curve on a.) blank image & b.) copy of the warped three channel threshold image
- Using cv.circle draw circles along the detected points for the yellow line
- Calculate the radius of curvature of yellow lane
- Take average of both the radii of curvatures to get the radius of curvature of the road
- Using cv.fillPoly, fill the area between both the lanes i.e the road into red
- Perform inverse homography and inverse warp perspective to put all the detected lines and plots and overlay using cv.add to the original frame
- Based on the curvature predict the turn of the road
- Put all the necessary outputs into smaller windows and create a frame of multiple outputs
- Annotate each window with necessary window names and mention them and also the radius of curvature of the road
- Clone the repo to your local machine
git clone https://github.com/HemanthJoseph/Lane-Detection-with-Turn-Prediction-for-Self-Driving.git
- Change Directory
cd src
- Run the python file
python Lane_Detect.py
python Turn_Predict.py
- Python 3.9.12
- OpenCV '4.7.0'
- Numpy '1.24.2'