The present invention relates to a method for the semantic segmentation of an image having a two-dimensional arrangement of pixels.
Automated scene understanding is an important goal in the field of modern computer vision. One way to achieve automated scene understanding is the semantic segmentation of an image, wherein each pixel of the image is labelled according to semantic categories. Such a semantic segmentation of an image is especially useful in the context of object detection for advanced driver assistance systems (ADAS). For example, the semantic segmentation of an image could comprise the division of the pixels into regions belonging to the road and regions that don't belong to the road. In this case, the semantic categories are “road” and “non-road”. Depending on the application, there can be more than two semantic categories, for example “pedestrian”, “car”, “traffic sign” and the like. Since the appearance of pre-defined regions such as road regions is variable, it is a challenging task to correctly label the pixels.
Machine learning techniques enable a visual understanding of image scenes and are helpful for a variety of object detection and classification tasks. Such techniques may use convolutional networks. Currently, there are two major approaches to train network-based image processing systems. The two approaches differ with respect to the input data model. One of the approaches is based on a patch-wise analysis of the images, i.e. an extraction and classification of rectangular regions having a fixed size for every single image. Due to the incomplete information about spatial context, such methods have only a limited performance. A specific problem is the possibility of undesired pairings in the nearest neighbor search. Moreover, the fixed patches can span multiple distinct image regions, which can degrade the classification performance.
There are also approaches which are based on full image resolution, wherein all pixels of an image in the original size are analyzed. Such methods are, however, prone to noise and require a considerable amount of computational resources. Specifically, deep and complex convolutional networks are needed for full image resolution. Such networks require powerful processing units and are not suitable for real-time applications. In particular, deep and complex convolutional networks are not suitable for embedded devices in self-driving vehicles.
The paper “Ground Plane Detection with a Local Descriptor” by Kangru Wang et al., XP055406076, URL:http://arxiv.org/vc/arxiv/papers/1609/1609.08436v6.pdf, 2017 Apr. 19, discloses a method for detecting a road plane in an image. The method comprises the steps of computing a disparity texture map, defining a descriptor for each pixel based on the disparity character, segmenting the disparity texture map and applying a convolutional neural network to label the road region.
Described herein a method for the semantic segmentation of an image which is in a position to deliver accurate results with a low computing effort.
A method in accordance with the invention includes the steps of: segmenting at least a part of the image into superpixels, wherein the superpixels are coherent image regions comprising a plurality of pixels having similar image features, determining image descriptors for the superpixels, wherein each image descriptor comprises a plurality of image features, feeding the image descriptors of the superpixels to a convolutional network, and labeling the pixels of the image according to semantic categories by means of the convolutional network. The superpixels are assigned to corresponding positions of a regular grid structure extending across the image and the image descriptors are fed to the convolutional network based on the assignment.
The assigning of the superpixels to corresponding positions of the regular grid structure is carried out by means of a grid projection process. Such a projection process can be carried out in a quick and easy manner. Preferably, the projection is centered in the regular grid structure.
Superpixels are obtained from an over-segmentation of an image and aggregate visually homogeneous pixels while respecting natural boundaries. In other words, superpixels are the result of a local grouping of pixels based on features like color, brightness or the like. Thus, they capture redundancy in the image. Contrary to rectangular patches of a fixed size, superpixels enable the preservation of information about the spatial context and the avoidance of the above mentioned problem of pairings in the nearest neighbor search. Compared to full image resolution, a division of the images into superpixels enables a considerable reduction of computational effort.
Usually, superpixels have different sizes and irregularly shaped boundaries. An image analysis based on superpixels is therefore not suitable as an input data model for a convolutional network. A regular topology is needed to convolute the input data with kernels. However, the regular grid structure enables to establish an input matrix for a convolutional network despite the superpixels having different sizes and irregularly shaped boundaries. By means of the regular grid structure, the superpixels are “re-arranged” or “re-aligned” such that a proper input into a convolutional network is possible.
Advantageous embodiments of the invention can be seen from the dependent claims and from the following description.
The image descriptors are preferably fed to a convolutional neural network (CNN). Convolutional neural networks are efficient machine learning tools suitable for a variety of tasks and having a low error rate.
Preferably, the segmentation of at least a part of the image into superpixels is carried out by means of an iterative clustering algorithm, in particular by means of a simple linear iterative clustering algorithm (SLIC algorithm). A simple linear iterative clustering algorithm is disclosed, for example, in the paper “SLIC Superpixels” by Achanta R. et al., EPFL Technical Report 149300, June 2010. The SLIC algorithm uses a distance measure that enforces compactness and regularity in the superpixel shapes. It has turned out that the regularity of the superpixels generated by a SLIC algorithm is sufficient for projecting the superpixel centers onto a regular lattice or grid.
In accordance with an embodiment of the invention, the iterative clustering algorithm comprises a plurality of iteration steps, in particular at least 5 iteration steps, wherein the regular grid structure is extracted from the first iteration step. The first iteration step of a SLIC algorithm delivers a grid or lattice, for example defined by the centers of the superpixels. This grid has a sufficient regularity to be used as the regular grid structure. Thus, the grid extracted from the first iteration step can be used in an advantageous manner to establish a regular topology for the final superpixels, i.e. the superpixels generated by the last iteration step.
Specifically, the superpixels generated by the last iteration step can be matched to the regular grid structure extracted from the first iteration step.
The regular grid structure can be generated based on the positions of the centers of those superpixels which are generated by the first iteration step. It has turned out that the grid structure is only slightly distorted in the course of the further iterations.
In accordance with a further embodiment of the invention, the convolutional network includes 10 or less layers, preferably 5 or less layers. In other words, it is preferred to not use a deep network. This enables a considerable reduction of computational effort.
In particular, the convolutional network can be composed of two convolutional layers and two fully-connected layers. It has turned out that such a network is sufficient for reliable results.
In accordance with a further embodiment of the invention, each of the image descriptors comprises at least 30, preferably at least 50 and more preferably at least 80 image features. In other words, it is preferred to use a high-dimensional descriptor space. This provides for high accuracy and reliability.
In particular, each of the image descriptors can comprise a plurality of “histogram of oriented gradients”-features (HOG-features) and/or a plurality of “local binary pattern”-features (LBP-features).
The invention also relates to a method for the recognition of objects in an image of a vehicle environment comprising a semantic segmentation method as described above.
A further subject of the invention is a system for the recognition of objects from a motor vehicle, wherein the system includes a camera to be arranged at the motor vehicle and an image processing device for processing images captured by the camera.
According to the invention, the image processing device is configured for carrying out a method as described above. Due to the reduction of computational effort achieved by combining the superpixel segmentation and the use of a convolutional network, the image processing device can be configured sufficiently simple to be embedded in an autonomous driving system or an advanced driver assistance system.
Preferably, the camera is configured for repeatedly or continuously capturing images and the image processing device is configured for a real-time processing of the captured images. It has turned out that a superpixel-based approach is sufficiently fast for a real-time processing.
A computer program product is also a subject of the invention including executable program code which, when executed, carries out a method in accordance with the invention.
Further features and advantages will appear more clearly on a reading of the following detailed description of the preferred embodiment, which is given by way of non-limiting example only and with reference to the accompanying drawings.
The present invention will now be described, by way of example with reference to the accompanying drawings, in which:
Reference will now be made in detail to embodiments, examples of which are illustrated in the accompanying drawings. In the following detailed description, numerous specific details are set forth in order to provide a thorough understanding of the various described embodiments. However, it will be apparent to one of ordinary skill in the art that the various described embodiments may be practiced without these specific details. In other instances, well-known methods, procedures, components, circuits, and networks have not been described in detail so as not to unnecessarily obscure aspects of the embodiments.
‘One or more’ includes a function being performed by one element, a function being performed by more than one element, e.g., in a distributed fashion, several functions being performed by one element, several functions being performed by several elements, or any combination of the above.
It will also be understood that, although the terms first, second, etc. are, in some instances, used herein to describe various elements, these elements should not be limited by these terms. These terms are only used to distinguish one element from another. For example, a first contact could be termed a second contact, and, similarly, a second contact could be termed a first contact, without departing from the scope of the various described embodiments. The first contact and the second contact are both contacts, but they are not the same contact.
The terminology used in the description of the various described embodiments herein is for the purpose of describing particular embodiments only and is not intended to be limiting. As used in the description of the various described embodiments and the appended claims, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will also be understood that the term “and/or” as used herein refers to and encompasses any and all possible combinations of one or more of the associated listed items. It will be further understood that the terms “includes,” “including,” “comprises,” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof.
As used herein, the term “if” is, optionally, construed to mean “when” or “upon” or “in response to determining” or “in response to detecting,” depending on the context. Similarly, the phrase “if it is determined” or “if [a stated condition or event] is detected” is, optionally, construed to mean “upon determining” or “in response to determining” or “upon detecting [the stated condition or event]” or “in response to detecting [the stated condition or event],” depending on the context.
In
In accordance with the invention, a method for the semantic segmentation of a captured original image 20 comprises the step of segmenting the original image 20 into superpixels 30 as shown in
As shown in
When the simple linear iterative clustering algorithm is completed, the final superpixels 30, i.e. the superpixels 30 generated by the last iteration step, are overlaid with the grid structure 37 by means of a grid projection centered in the grid structure 37. Further, local image descriptors are determined for each of the superpixels 30 in a descriptor determination step 38, wherein each image descriptor comprises a plurality of image features, preferably 70 image features or more. Depending on the application, each of the image descriptors can comprise a plurality of “histogram of oriented gradients”-features (HOG-features) and/or a plurality of “local binary pattern”-features (LBP-features).
Based on the projection of the final superpixels 30 centered in the grid structure 37, the image descriptors of the final superpixels 30 are fed as input data 39 to a convolutional neural network (CNN) 40. Preferably, the convolutional neural network 40 has only few layers, for example 5 or less layers. By means of the convolutional neural network (CNN) 40, the pixels of the original image 20 are labeled according to semantic categories. As an example,
Since the convolutional neural network (CNN) 40 is rather simple, the accurate results can be achieved without complex computer hardware and even in embedded real-time systems.
While this invention has been described in terms of the preferred embodiments thereof, it is not intended to be so limited, but rather only to the extent set forth in the claims that follow.
Number | Date | Country | Kind |
---|---|---|---|
17167514.3 | Apr 2017 | EP | regional |