Parking Slot Detection Deep Learning

broken image


Secondly, a learning based parking-slot detection approach is proposed. With this approach, given a test image, the marking-points will be detected at first and then the valid parking-slots can be inferred. Its efficacy and efficiency have been corroborated on our database. Tongji Parking-slot Dataset 1.0. The self-parking system plays an important role in autonomous driving, and one of its critical issues is parking-slot detection. Key MethodInstead of utilizing multiple off-the-shelf models, DMPR-PS uses a novel CNN-based model specially designed for directional marking-point regression. Published by Elsevier B.V. Peer-review under responsibility of the scientific committee of the 22nd EURO Working Group on Transportation Meeting. 22nd EURO Working Group on Transportation Meeting, EWGT 2019, 18-20 September 2019, Barcelona, Spain Improving Parking Availability Information Using Deep Learning Techniques Jamie Arjona a. Deep Learning 1: 2020-10-21. SPFCN: Select and Prune the Fully Convolutional Networks for Real-Time Parking Slot Detection: Vision Sensing and Perception 7.

  1. Parking Slot Detection Deep Learning Algorithms
  2. Parking Slot Detection Deep Learning Tool
  3. Parking Slot Detection Deep Learning
2019-11-04
Highly accurate parking slot detection methods are crucial for Automated Valet Parking (AVP) systems, to meet their demanding safety and functional requirements. While previous efforts have mostly focused on the algorithms' capabilities to detect different types of slots under varying conditions, i.e. the detection rate, their accuracy has received little attention at this time. This paper highlights the importance of trustworthy slot detection methods, which address both the detection rate and the detection accuracy. To achieve this goal, an accurate slot detection method and a reliable ground-truth slot measurement method have been proposed in this paper. First, based on a 2D laser range finder, datapoints of obstacle vehicles on both sides of a slot have been collected and preprocessed. Second, the Density-Based Spatial Clustering of Applications with Noise (DBSCAN) algorithm has been improved to efficiently cluster these unevenly-distributed datapoints. After that, the Random Sample Consensus (RANSAC) algorithm has been improved to accurately fit the vehicles' longitudinal contours. Finally, the candidate slot has been constructed and checked for its rationality. The final slot detection results have been defined in a way that contains both the slot size information and the slot relative position to the ego vehicle, which increases the requirement for detection accuracy. The performance of the proposed slot detection method has been verified on a test vehicle, and the experimental results show that the maximum errors in the detected slots under different conditions are 11.86 cm (position) and 3.35 deg (orientation).
DOI: https://doi.org/10.4271/2019-01-5061
Citation: Yang, Q., Chen, H., Su, J., and Li, J., 'Towards High Accuracy Parking Slot Detection for Automated Valet Parking System,' SAE Technical Paper 2019-01-5061, 2019, https://doi.org/10.4271/2019-01-5061.
Download Citation
Author(s): Qinghua Yang, Hui Chen, Junzhe Su, Jie Li
Pages: 10
Event: New Energy & Intelligent Connected Vehicle Technology Conference
e-ISSN: 2688-3627
Related Topics:

SAE MOBILUS

Subscribers can view annotate, and download all of SAE's content. Learn More »

Abstract:A small example of Opencv + tensorflow~

introduce

Parking slot detection deep learning algorithms

Do you often look around the parking lot to find parking spaces? If your cell phone can tell you exactly where the nearest parking space is, is it very cool? Facts have proved that it is relatively easy to solve this problem based on deep learning and OpenCV. The following GIF images highlight all available parking spaces on the parking lot and show the number of available parking spaces. The key is that the process is real-time.

You can find the code I used in Github repo.

Parking slot detection deep learning algorithms

Parking Slot Detection Deep Learning Algorithms

Summary of steps

There are two main steps to build this parking detection model:

1. Check all available parking spaces;

2. Determine whether the parking space is empty or occupied;

Because the camera view is installed, we can use OpenCV to map each parking space once. Once you know the location of each parking space, you can use deep learning to predict whether it is empty or not. I have shared an overview of a high-level step involved on my blog. If you are interested in detailed code, please check out my blog.

Detection of all available parking spaces

The basic idea of parking space detection is that all parking points are divided by horizontal lines, and the spacing between parking points in a row is roughly equal. Firstly, Canny edge detection is used to obtain the edge image. I've covered up the area where I haven't parked yet. As follows:

Parking Slot Detection Deep Learning Tool

Then I did a transformation on the edge image and drew all the lines that it could recognize. I only choose lines with slopes close to zero to isolate horizontal lines. The output of the transformation is as follows:

As you can see, the Hof transform has done quite well in identifying parking lines, but the output is noisy – several stop lines have been detected many times, and some have been omitted. So how do we solve this problem? Then I start with observation and intuition, and use the coordinates returned by the transformation to gather the X coordinates to determine the main parking lane. Clustering logic is used to identify the interval of lane line x coordinates. So you can identify 12 lanes here. As follows:

If all this looks complicated, don't worry about 5 — I've documented the code step by step on github's jupyter notebook. Now that I know where all the parking lanes are, I can identify each individual parking space by reasonably assuming that all parking spaces are the same size. I observed the results carefully to ensure that the boundary between points was captured as accurately as possible. At last I was able to mark every parking space. As follows:

After locating each parking space, we can assign an ID to each point, save its coordinates in the dictionary and pick it up so that it can be retrieved later. This is possible because with the camera installed, we don't need to calculate the position of each point in the view over and over again. For more details, please log on to my blog.

Identify whether the parking space is marked or not

Now that we have a map of each parking space, we can determine whether the parking space is occupied in the following ways:

1. Use OpenCV to check whether the pixel color of parking space in video image is the same as that of empty parking space. This is a simple method, but easy to make mistakes. For example, changes in lighting will change the color of an empty parking space, and this method will not work correctly in a day of light changes. If possible, this logic would treat gray cars as empty parking spaces.

2. Use target detection to identify all cars, and then check whether the car's position overlaps with the parking space. I made an attempt to find that real-time detection model is really difficult to detect small objects, and the detected vehicles are not more than 30%.

3. Using CNN to detect each parking space and predict whether someone is parking, this method has the best effect.

Parking Slot Detection Deep Learning

Do you often look around the parking lot to find parking spaces? If your cell phone can tell you exactly where the nearest parking space is, is it very cool? Facts have proved that it is relatively easy to solve this problem based on deep learning and OpenCV. The following GIF images highlight all available parking spaces on the parking lot and show the number of available parking spaces. The key is that the process is real-time.

You can find the code I used in Github repo.

Parking Slot Detection Deep Learning Algorithms

Summary of steps

There are two main steps to build this parking detection model:

1. Check all available parking spaces;

2. Determine whether the parking space is empty or occupied;

Because the camera view is installed, we can use OpenCV to map each parking space once. Once you know the location of each parking space, you can use deep learning to predict whether it is empty or not. I have shared an overview of a high-level step involved on my blog. If you are interested in detailed code, please check out my blog.

Detection of all available parking spaces

The basic idea of parking space detection is that all parking points are divided by horizontal lines, and the spacing between parking points in a row is roughly equal. Firstly, Canny edge detection is used to obtain the edge image. I've covered up the area where I haven't parked yet. As follows:

Parking Slot Detection Deep Learning Tool

Then I did a transformation on the edge image and drew all the lines that it could recognize. I only choose lines with slopes close to zero to isolate horizontal lines. The output of the transformation is as follows:

As you can see, the Hof transform has done quite well in identifying parking lines, but the output is noisy – several stop lines have been detected many times, and some have been omitted. So how do we solve this problem? Then I start with observation and intuition, and use the coordinates returned by the transformation to gather the X coordinates to determine the main parking lane. Clustering logic is used to identify the interval of lane line x coordinates. So you can identify 12 lanes here. As follows:

If all this looks complicated, don't worry about 5 — I've documented the code step by step on github's jupyter notebook. Now that I know where all the parking lanes are, I can identify each individual parking space by reasonably assuming that all parking spaces are the same size. I observed the results carefully to ensure that the boundary between points was captured as accurately as possible. At last I was able to mark every parking space. As follows:

After locating each parking space, we can assign an ID to each point, save its coordinates in the dictionary and pick it up so that it can be retrieved later. This is possible because with the camera installed, we don't need to calculate the position of each point in the view over and over again. For more details, please log on to my blog.

Identify whether the parking space is marked or not

Now that we have a map of each parking space, we can determine whether the parking space is occupied in the following ways:

1. Use OpenCV to check whether the pixel color of parking space in video image is the same as that of empty parking space. This is a simple method, but easy to make mistakes. For example, changes in lighting will change the color of an empty parking space, and this method will not work correctly in a day of light changes. If possible, this logic would treat gray cars as empty parking spaces.

2. Use target detection to identify all cars, and then check whether the car's position overlaps with the parking space. I made an attempt to find that real-time detection model is really difficult to detect small objects, and the detected vehicles are not more than 30%.

3. Using CNN to detect each parking space and predict whether someone is parking, this method has the best effect.

To build a CNN, we need images of parking spaces with and without cars. I extracted the image of each parking space, saved it in the folder, and then grouped the images. I also shared this training folder on Github.

Because there are nearly 550 parking spaces in 1280×720 pixel images, the size of each parking space is only about 15×60 pixels. Below are the images of empty and occupied parking spaces:

However, because occupied parking spaces and empty parking spaces look very different, this should not be a challenging issue for CNN.

Parking Slot Detection Deep Learning

However, I only have about 550 pictures of these two classes, so I decided to use the first 10 layers of VGG and add a single soft Max layer to the output of the VGG model for migration learning. You can find the code of this migration learning model here, with an accuracy of 94%. See below:

Now, I combine parking detection with CNN predictor to construct a parking detector with high accuracy.

I also recorded the code running this on the video stream in notebook.

conclusion

I was amazed at how easy it was to combine different tools and use in-depth learning to build practical applications, and I finished this work in two afternoons.

Several other ideas for further exploration:

1. if it is possible to extend the parking detection logic to any parking map that may use deep learning, it is great that OpenCV restrictive use of each use case.

2. The VGG model used by CNN is a weighting model. We want to try a lighter model.

Cloud server 99 yuan group buying! Laxin can also win cash red envelope! Three million waiting for you to split up!
One Click to win the red envelope immediately: http://click.aliyun.com/m/1000019899/


Author: [Direction]

Read the original text

This article is the original content of Yunqi Community, which can not be reproduced without permission.





broken image