Skip to content

Involves the OpenCV based C++ implementation to detect and track roads for almost realtime performance

Notifications You must be signed in to change notification settings

kpandey008/Road-detection-and-tracking

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 

Repository files navigation

Road-detection-and-tracking

The project is an implementation of the paper ‘Efficient Road detection and tracking’ by Zhou et al. The algorithm has been implemented in C++ using the OpenCV library setup in CodeBlocks developement environment.

Prerequisites

For running the project, OpenCV needs to be setup. There are many blogs and resources available for setting up OpenCV either in Windows or Linux OS. I personally prefer Linux as everything is much easier to set up.

General Methodology

Road detection Methodology

The algorithmic flow for Road detection can be described as follows:

alt text

Road detection Demo

Step 1: Get an Initial Road segmentation by selecting a ROI. The segmentation method used is the GrabCut segmentation

alt text

After selecting the ROI we get an initial segmentation. Note that the segmentation is not proper.

alt text

Step 2: Mask some pixels as background to get a proper segmentation

alt text

After masking the initial segmentation we get a refined segmentation

alt text

Step 4: Apply post processing steps like Connected Component Analysis, Hole filling and Otsu’s Thresholding to get the final image segmentation

alt text

alt text

Road tracking methodology

The algorithmic flow for Road detection can be described as follows:

alt text

Road tracking demo:

Step 1: Locate the FAST features in two subsequent frames.Compute the features in one frame and track them in the next frame using Optical Flow or the KL tracker(This is used to compute the Homography matrix between those two frames using the RANSAC method)

Fast features in the present frame alt text

alt text

Step 2: Track the roads in the previous frame to the new frame-starting from the final road segmentation-by projecting the detected road pixels in the first frame to the next frame.

alt text

Step 3: Detect the new road in the present frame(using skeleton analysis and center of skeleton methodolgies. Implementation in progress!!!).

Conclusion

Refer to the paper for more details into the algorithm

Releases

No releases published

Packages

No packages published

Languages