Next Article in Journal
Auction-Based Learning for Question Answering over Knowledge Graphs
Next Article in Special Issue
Breast Cancer Detection in Mammography Images: A CNN-Based Approach with Feature Selection
Previous Article in Journal
Enabled Artificial Intelligence (AI) to Develop Sehhaty Wa Daghty App of Self-Management for Saudi Patients with Hypertension: A Qualitative Study
Previous Article in Special Issue
Deep Feature Pyramid Hashing for Efficient Image Retrieval
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Hierarchical System for Recognition of Traffic Signs Based on Segmentation of Their Images

by
Sergey Victorovich Belim
1,2,*,
Svetlana Yuryevna Belim
1 and
Evgeniy Victorovich Khiryanov
2
1
Radio Engineering Department, Omsk State Technical University, Omsk 644050, Russia
2
Department of Digital Technology, Siberian State Automobile and Highway University, Omsk 644080, Russia
*
Author to whom correspondence should be addressed.
Information 2023, 14(6), 335; https://doi.org/10.3390/info14060335
Submission received: 10 May 2023 / Revised: 3 June 2023 / Accepted: 13 June 2023 / Published: 15 June 2023
(This article belongs to the Special Issue Advances in Object-Based Image Segmentation and Retrieval)

Abstract

:
This article proposes an algorithm for recognizing road signs based on a determination of their color and shape. It first searches for the edge segment of the road sign. The boundary curve of the road sign is defined by the boundary of the edge segment. Approximating the boundaries of a road sign reveals its shape. The hierarchical road sign recognition system forms classes in the form of a sign. Six classes are at the first level. Two classes contain only one road sign. Signs are classified by the color of the edge segment at the second level of the hierarchy. The image inside the edge segment is cut at the third level of the hierarchy. The sign is then identified based on a comparison of the pattern. A computer experiment was carried out on two collections of road signs. The proposed algorithm has a high operating speed and a low percentage of errors.

1. Introduction

Traffic sign recognition algorithms in an image are part of many technical computer vision systems. Technical systems have different requirements for the properties of these algorithms. Methods of comparing algorithms are based on two main properties: speed and the number of resources. Automatic mobile objects require a short operating time for the algorithm. Automatic road inventory systems impose less stringent requirements. Video analysis systems from cars are the least demanding. The system described in this article is an integral part of automatic road inventory software.
There are three types of image processing algorithms that contain traffic signs. The first type of algorithm detects traffic signs in an image of a road scene [1,2]. The second type of algorithm classifies road signs by their localized image [3,4]. The third type of algorithm includes the features of the first two. These algorithms detect traffic signs based on attempts to classify fragments of road scenes [5,6]. The third type of algorithm requires the most computational resources. Most vision systems separate the problems of detecting and classifying traffic signs. In this article, we consider only the problem of classifying traffic signs. A localized traffic sign image is input into the algorithm. There are several collections of such images for testing algorithms. The most widespread is the German Traffic Sign Recognition Benchmark (GTSRB) [7].
The main achievements in the recognition of traffic signs from images are related to the use of neural networks. The recognition of road signs boils down to their classification. A multi-column neural network recognition and image preprocessing system [8] shows a high efficiency (99.46%) in the GTSRB collection. This system uses 25 different neural networks. Each neural network has its own training data set. The system performance is low. The system is slow due to the large number of parameters (90 million). Preliminary spatial transformations reduce the number of neural network parameters. The authors of [9,10] reduced the number of parameters to 14 million. The architecture of such a neural network has three layers. Each layer performs spatial transformations. These operations eliminate background and geometric noise. The system shows an efficiency of 99.71% in in the GTSRB collection. Another approach builds a neural network not in layers, but on the basis of a hierarchical tree [11]. The number of parameters for such a network is 6.256 million. The recognition efficiency remains high (99.33%) in the GTSRB collection. A hierarchical neural network can be built on the basis of dividing many traffic signs into subsets [12]. The neural network is trained separately for each subset. The effectiveness of this method is 99.67% in the GTSRB collection. An expert must perform a subset split before this algorithm can work. The learning process also has an impact on the number of neural network parameters. The authors of [13] learned the “teacher” neural network. This network has 7.4 million parameters. The “teacher” neural network learns the “student” neural network. This neural network has 0.8 million parameters. The “student” neural network recognizes traffic signs. The efficiency of this two-stage system is 99.61% in the GTSRB collection. This approach can lead to divergence during the transition between neural networks. The system is very sensitive to insufficient training of the “teacher” neural network. In this case, the efficiency of work is greatly reduced.
There are several problems when using neural networks to recognize traffic signs: the need for high performance, low efficiency in real time, and a large amount of input data [14]. Sensitivity to uncontrolled environments is also a characteristic of neural-network-based traffic sign recognition systems [15]. The problem of reducing our dependence on neural networks is urgent. One solution is to split an image of a road sign into parts using a segmentation algorithm. Segmentation algorithms are used primarily to detect traffic signs. Traffic sign detection methods cluster a road scene into one of the following color spaces: RGB [16], HSV [17], and YUV [4].
The results obtained for the neural network approach can be used to build classifiers without using neural networks. Hierarchical representation for traffic sign sets reduces the number of classifier parameters. Splitting an image of a traffic sign into segments speeds up the classification process.
This article suggests a hierarchical algorithm for the recognition of traffic signs based on the segmentation of an image and a comparison with standards.

2. Hierarchical Classification of Traffic Sign Images

One of the main problems in the classification of traffic signs is the large number of their standard types. The total number of standard types for traffic signs is more than one hundred. Classifier efficiency is improved by reducing the number of object classes. The classification of traffic signs can be carried out by the method of sequential approximation. The classifier sequentially clarifies the information about a traffic sign by its image. The number of classes at each stage must be small. The shape and color of a traffic sign is specified in the first two stages. The details of the internal image are specified in the third step. The number of stages and their content differ for different types of traffic signs. The hierarchical system of traffic sign recognition methods corresponds to such a task. There is a hierarchy of traffic signs according to their effect on road traffic. This hierarchy cannot be used in a traffic sign recognition system. There is no complete correlation between the shape and color of a traffic sign and its value.
A zero-level classification is related to the geometric shape of the signs. The first class at this level includes traffic signs that can be inscribed in a square (square, round, triangular, octagonal, rhombic). These traffic signs perform prescriptive and prohibitive functions. The second grade at level zero includes rectangular-shaped traffic signs. These signs inform drivers. Our classifier only works with zero-level first-class signs. Traffic signs in this class are critical to traffic management. Our classifier can easily be extended to work with second-class signs. This task requires the development of additional templates.
A hierarchical road sign recognition system requires the development of classifiers for each level of the hierarchical tree. The classifiers may be the same for the type of algorithms used. However, each classifier requires its own training set.
A first-level classifier recognizes the shape of a traffic sign. We denote the first-level classifier as Z . Classifier Z distributes traffic signs into six classes as follows: z 1 —rhombus, z 2 —octagon, z 3 —inverted triangle, z 4 —circle, z 5 —square, and z 6 —triangle. The first level for the hierarchical classifier tree is shown in Figure 1.
Some second-level classes do not contain the next-level classifiers. Classes z 2 and z 3 include one traffic sign each (Figure 2). These nodes are the leaves in a hierarchical tree. If the classifier Z assigns a traffic sign to one of these classes, then the recognition problem is solved.
The class z 1 contains only two traffic signs (Figure 3). The identification of class z1 traffic signs requires one additional step. Recognition in this class can also be performed based on character outline highlighting.
The class z 4 includes five subclasses (Figure 4). Subclasses z 41 and z 45 can be separated from the others with red along the contour. Subclass z 45 differs from subclass z 41 in the number of pixels in red. Node z 45 is a leaf. If a road sign is assigned to this class, then the recognition problem is solved. Class z 41 includes 32 traffic signs. These signs have a different image of black on a white background. Classes z 43 and z 44 are highlighted by the presence of an area of blue. Class z44 is separated from class z 43 by a red stripe. Class z 42 includes nine traffic signs. Seven traffic signs in this class contain images of numbers. Class z 43 includes 18 traffic signs. These traffic signs contain a white image on a blue background.
An additional hierarchy level in class z 4 simplifies the classification task. We introduce three additional classes (Figure 5). The z 4 ( 1 ) class combines subclasses z 41 and z 45 . The z 4 ( 2 ) class includes only subclass z 42 . The z 4 ( 3 ) class combines subclasses z 43 and z 44 .
An edge segment is a segment of a traffic sign image that includes its outer boundary. Traffic signs in class z 4 ( 1 ) have a red edge segment. Traffic signs in class z 4 ( 2 ) have a white edge segment. Traffic signs of class z 4 ( 3 ) have a blue edge segment.
Splitting the z 4 ( 1 ) class into two classes, z 41 and z 45 , is easy. The area of the edge segment in class z 45 is more than twice the area of the edge segment in class z 41 . Class z 45 is a leaf.
The inner segment of traffic signs in class z 41 is highlighted by removing the edge segment and the entire image outside the sign from the image. The inside of the sign is a black and white image without grayscale. A binarization operation is applied to the inner segment of the traffic sign. The binary shape of the image is easily compared to the pattern.
Class z 5 includes three subclasses (Figure 6). The main difference between these classes is the colors used. The subclass z 51 includes six traffic signs. These signs define the direction of the main road. The inner segment of these classes consists of black lines. Subclass z 52 contains 33 traffic signs. Subclass z 53 contains seven traffic signs.
The edge segment type requires an additional hierarchy level for class z 5 . The first subclass z 5 ( 1 ) contains traffic signs with a white edge segment. The second subclass of z 5 ( 2 ) includes traffic signs with a blue edge segment (Figure 7). The RGB model makes it easy to distinguish between these classes.
All traffic signs in class z 6 have the same shape and edge segment (Figure 8). Class z 61 includes 42 traffic signs.
The color of the edge segment in class z61 does not affect the recognition of the traffic sign. The algorithm shall determine the shape of the traffic sign. The edge segment and the entire exterior environment are removed from the image. The inner segment of the road sign is a black and white image without grayscale. The contents of an internal segment can be defined based on a comparison with a template.
An analysis of the image hierarchy for traffic signs shows that the recognition of traffic signs based on their segmentation includes five algorithms:
1. Algorithm for obtaining an edge segment and determining its color (red, blue, white);
2. Algorithm for determining the area of the edge segment;
3. Algorithm for determining the shape of a traffic sign by its edge segment;
4. Algorithm for obtaining an inner segment of a traffic sign and its binarization;
5. Algorithm for identifying the internal image of a traffic sign.

3. Segmentation Algorithm

The edge segment is searched for a localized traffic sign. We do not solve the problem of localizing the traffic sign on the road scene. Various algorithms can be used to localize a traffic sign in a square window. There are localization algorithms for similar tasks [18,19]. These algorithms can be adapted for traffic signs. The task of finding traffic signs in an image requires separate research. A square window including a traffic sign is a window for localizing a traffic sign.
We use the segmentation algorithm developed earlier to highlight the road contour [20,21,22]. This segmentation algorithm highlights segments that have both a uniform color fill and a gradient color fill. This factor is important in the processing of real traffic signs. The illumination of the sign is never uniform. This results in color gradients in images of real traffic signs. Our algorithm has a quadratic complexity. The segmentation algorithm is based on the method of growing areas. The method of growing areas has a quadratic labor intensity. Each iteration of the algorithm performs a number of operations not exceeding the number of image points. The total number of iterations does not exceed the number of image points. The speed of the algorithm is large enough for use in the designed system. The size of the input images of the algorithm does not exceed 200 × 200 pixels. The segmentation target in this case is the edge segment of the traffic sign. An edge segment is a segment of a traffic sign image having an outer boundary coinciding with the boundary of a traffic sign. All points of this segment have the same color in the ideal image of the traffic sign. Real images distort the color of individual pixels due to lighting features. Foreign objects and shadows change the outer boundary of the edge segment. These factors complicate the segmentation task. We enter the symbol C for the set of edge segment points.
The segmentation algorithm is based on the method of growing areas. The grain of the algorithm is one pixel. The dimensions of the traffic sign localization window are N × N pixels. We select the starting pixel of the segment at p 0 = ( N / 2 , b ) . The coordinates of this point are determined from the upper-left corner. The value of the first coordinate for point p 0 is based on the symmetry of all traffic signs with respect to the vertical axis through their center. The traffic sign localization algorithm determines the second coordinate b . The value of this coordinate depends on the accuracy of finding the signs’ boundaries. This coordinate should not have a large value, otherwise the selection of a narrow red strip of prohibitory traffic signs is impossible. b = 0.1 N must be taken for the GTSRB collection.
An undirected weighted graph can be mapped to each image. The nodes of this graph are the pixels of the image. V is the set of the graph nodes. The edges of the graph connect the nodes. We consider a fully connected graph at the beginning of the algorithm’s construction. The edge weight determines the color difference of the image pixels corresponding to the graph nodes. The RGB model is used for representing the color of the pixels. Each pixel has five coordinates. Two coordinates ( x , y ) determine its position in the image. Three coordinates ( r ( x , y ) , g ( x , y ) , b ( x , y ) ) determine its color characteristics. r ( x , y ) is the intensity of red. g ( x , y ) is the intensity of green. b ( x , y ) is the intensity of blue. We define the distance in terms of the five-dimensional space d ( p , p ) between the pixels p = ( x , y , r , g , b ) and p = ( x , y , r , g , b ) .
d ( p , p ) = x x 2 + y y 2 e x p r r 2 + g g 2 + b b 2 1 .
The five-dimensional distance between the pixels increases if the distance between the pixels in the image grows or the difference in color increases.
The image segmentation problem is equivalent to partitioning a graph into communities [23]. A community must include the nodes of the graph whose pixels are located a short distance from each other and have a similar color. Having a small distance is a necessary requirement for segment connectivity. The similar colors ensure the edge segment is highlighted. The edge segment of the traffic sign has one color. The edge weight of the graph should decrease when moving away from the pixel and when the color changes sharply. The edge weight is calculated based on the distance between pixels p and p . If node v corresponds to pixel p and node v corresponds to pixel p , then the weight of the arc between nodes v and v is calculated using the following formula:
w v , v = 1 1 + d p , p .
This function for the edge weight is 1 if the neighboring pixels and their pixel colors match. If the neighboring pixels have different colors, then w v , v < 1 . The function w v , v rapidly decreases as the distance between pixels increases. Accounting for the edges between nodes for pixels very far from each other is not necessary. We enter the correlation radius R . This value indicates the largest geometric distance between pixels whose nodes are connected by an edge. The edges between nodes that are located in the image more than R are removed from the graph. The correlation radius determines the number of neighbors for a node.
A community search is required to highlight a segment. We use the method of growing regions on a graph. Community H with strongly connected nodes is the result of the algorithm. Community H includes one node v 0 at the zero step of the algorithm. This node v 0 corresponds to pixel p 0 . The algorithm at each stage calculates the average edge weight in community H .
w H = 1 n v , v H w v , v .
n is the number of nodes in community H .
The algorithm step is to enumerate all nodes connected by an edge to at least one community H node. If node v i is a candidate for inclusion in community H , then the total association of this node with nodes of community H is as follows:
w i = v H w v i , v .
If the w i does not exceed the threshold w 0 ( H ) , then node v i is included in community H . The threshold value w 0 H is calculated based on the average weight of the community edges.
w 0 H = h w H .
The parameter h is determined in a computer experiment. This parameter depends on the type of images. The algorithm achieves the best results for traffic signs at h = 0.07 .
The algorithm stops if no node satisfies the condition of inclusion in community H . The complexity of the algorithm depends on the number of pixels in the image according to the quadratic law. If the traffic sign localization window has a size of N × N pixels, then the complexity of the algorithm grows according to the law O ( N 4 ) . The edge segment C consists of pixels corresponding to nodes in community H .
The outer boundary of the edge segment is the boundary of the traffic sign. The edge segment boundary algorithm is reduced to determine the number of neighbors for each pixel in segment C . If a pixel in segment C has less than eight neighbors from that segment, then it is boundary. The outer edge of the edge segment is separated from the inner edge by the geometric coordinates of the points. The sign boundary in this algorithm has a thickness of one pixel. Examples of edge segments and boundary definition for traffic signs are shown in Figure 9.
The color of the edge segment is determined by comparing the average value of the color coordinates for its pixels. There are three colors of the edge segment (red, blue, white). We calculate the average value of the red and blue components for pixels in the edge segment.
R C = 1 K p C r p , B C = 1 K p C b p .
K is the number of pixels in the edge segment C . r p is the intensity of red for pixel p . b p is the intensity of blue for pixel p . The mean difference determines the color of the edge segment.
C = R C B C .
We compare the difference in average values C with the depth of palette M . If C > M / 3 , the edge segment is red. If C < M / 3 , the edge segment is blue. If M / 3 < C < M / 3 , the edge segment is white. In this case, the intensities of red and blue are approximately equal. The green component of the pixels is not considered, since there are no green road signs.

4. Recognition of the Traffic Sign Shape

We use templates to recognize the shape of a traffic sign. There are six different templates: rhombus (t1), octagon (t2), inverted triangle (t3), circle (t4), square (t5), and triangle (t6). The traffic sign outline is mapped to all the templates. The decision on the shape of the sign is made as closely as possible to one of the templates. There are three main problems when comparing the outline of a traffic sign with templates. The first problem is the variability in the dimensions of the sign in the image. The solution to this problem is templates scaling. The second problem is the distortion of the traffic sign when shooting at an angle. The solution to this problem is to use deformable templates. The two main characteristics of the template are the number of angles and the location on the plane. The third problem is the distortion of straight lines when obtaining the contour of a traffic sign. The features of real images prevent smooth lines and curves.
The first step in determining the shape of a traffic sign is to calculate its center. All geometric figures of traffic signs have central symmetry. For all traffic sign shapes, the center of symmetry coincides with the center of mass. We enter the designation D for the set of points for the traffic sign outline obtained using the segmentation algorithm. Formulas for the center of mass ( x c , y c ) for the set of points with the same mass are used when finding the center of the traffic sign image.
x c = 1 M x i , y i D x i , y c = 1 M x i , y i D y i .
M is the number of points in set D .
Each template t j   ( j = 1 , 2 , 3 , 4 , 5 , 6 ) is described by an equation.
P j x , y = 0 . ( j = 1 , 2 , 3 , 4 , 5 , 6 )
The points of set D do not satisfy any template equation. The deviation e j of the coordinate for the points of set D from the template equation P j x , y determines the proximity of the shape to the template t j .
e j = 1 M x i , y i D P j x i , y i 2 . ( j = 1 , 2 , 3 , 4 , 5 , 6 )
P j x i , y i is the deviation at the location of point x i , y i from the curve for the template P j x , y . The minimum e j defines the template t j to which the sign belongs.
Next, we consider the features of creating adaptable templates for various shapes.

4.1. Circle Template ( t 4 )

A circular traffic sign is very rarely circle-shaped in a real image. Angled shooting turns the circular sign into an ellipse in the image. The main axes of the ellipse can be oriented arbitrarily. Analyses of various images for traffic signs have shown that when shooting from a car, the positions of the ellipse axes are close to vertical and horizontal. We use the ellipse equation in this case.
P 4 x , y = x 2 a 2 + y 2 b 2 1 .
The lengths of the major semi-axes a and b of the ellipse are key information in this equation. The algorithm determines the point of set D furthest from the center of the ellipse ( x c , y c ) . The distance from this point to the center is b if the horizontal coordinate of the point is close to x c ; otherwise, it is a . After that, the algorithm is the closest point to the center of the ellipse. The distance from this point to the center defines the second semi-axis. Substituting these values into Formula (10) gives us the t 4 template equation for an ellipse P 4 x , y .
The deviation of location for the points x i , y i from a template P 4 x i , y i is calculated by the substitution of the coordinates for this point in the ellipse equation P 4 x , y .
P 4 x i , y i = P 4 x i , y i .

4.2. Triangle Template ( t 3 , t 6 )

The two templates for triangular traffic signs t 3 and t 6 differ in the mutual arrangement of the vertices. The two vertices of the triangle have a close coordinate y value. The third vertex has a smaller coordinate y value for the template t 6 . The third vertex has a larger coordinate y value for the template t 3 .
The first step of the algorithm determines the coordinates of the vertices for the triangle x 1 , y 1 , x 2 , y 2 , x 3 , y 3 , and x 4 , y 4 . The traffic sign localization window is divided into six areas (Figure 10).
The algorithm determines a point of set D with the maximum distance from the center of the traffic sign contour ( x c , y c ) . The algorithm searches the locality of the point ( 0,0 ) . This point is the first vertex of the triangle x 1 , y 1 . If the first vertex of the triangle is located in region 1, then the algorithm looks for two other vertices in regions 3 and 5. This vertex location corresponds to the template t 6 . If the first vertex of the triangle is located in region 2, then the algorithm looks for two other vertices in regions 4 and 6. This vertex location corresponds to the template t 3 . The points most distant from the center of the traffic sign in the desired area correspond to the vertices of the triangle.
Triangle side equations are necessary to calculate the deviation of points from the template. The equation of a line is written through the coordinates of the two vertices lying on that line. The distances to these three lines are calculated for each point ( x i , y i ) of contour D .
d 1 x i , y i = y 1 y 2 x i x 1 + y i y 1 x 1 x 2 y 1 y 2 2 + x 1 x 2 2 , d 2 x i , y i = y 1 y 3 x i x 1 + y i y 1 x 1 x 3 y 1 y 3 2 + x 1 x 3 2 , d 3 x i , y i = y 2 y 3 x i x 2 + y i y 2 x 2 x 3 y 2 y 3 2 + x 2 x 3 2 .
The contour point must be mapped to the nearest side of the triangular template. The deviation from the template for point x i , y i is equal to the distance to the nearest side of the template.
P j x i , y i = min d 1 x i , y i , d 2 x i , y i , d 3 x i , y i . ( j = 3 , 6 )

4.3. Quadrangle Template ( t 1 , t 5 )

The two types of quadrangular templates t 1 and t 5 differ from each other in the mutual arrangement of vertices. For a rhombus t 1 , two vertices have the same y coordinates. The other two vertices have a coordinate y greater than and less than this. A square has two pairs of vertices with the same y coordinate. The first step of the algorithm determines the coordinates of the vertices for the quadrangle x 1 , y 1 , x 2 , y 2 , x 3 , y 3 , and x 4 , y 4 . The traffic sign localization window is divided into nine areas (Figure 11).
The algorithm determines a point from the set D with the maximum distance from the center of the traffic sign contour ( x c , y c ) . This point is searched in the vicinity of the origin ( 0,0 ) . The point found is the first vertex of the quadrangle x 1 , y 1 . If the first vertex of the quadrangle is located in region 1, then the algorithm looks for three vertices in regions 3, 7, and 9. This vertex location corresponds to the template t 5 . If the first vertex of the quadrangle is located in region 2, then the algorithm looks for the remaining vertices in regions 4, 6, and 8. This vertex location corresponds to the template t 1 . The points most distant from the center of the traffic sign in the desired area correspond to the vertices of the quadrangle.
Quadrangle side equations are used to calculate the deviation of points from the template. The equation of a line is written through the coordinates of the two vertices lying on that line. The distances to these four lines are calculated for each point ( x i , y i ) of contour D .
d 1 x i , y i = y 1 y 2 x i x 1 + y i y 1 x 1 x 2 y 1 y 2 2 + x 1 x 2 2 , d 2 x i , y i = y 1 y 4 x i x 1 + y i y 1 x 1 x 4 y 1 y 4 2 + x 1 x 4 2 , d 3 x i , y i = y 2 y 3 x i x 2 + y i y 2 x 2 x 3 y 2 y 3 2 + x 2 x 3 2 , d 4 x i , y i = y 3 y 4 x i x 3 + y i y 3 x 3 x 4 y 3 y 4 2 + x 3 x 4 2 .
The contour point must be mapped to the nearest side of the quadrangle template. The deviation from the template for point ( x i , y i ) is equal to the distance to the nearest side of the template.
P j x i , y i = min d 1 x i , y i , d 2 x i , y i , d 3 x i , y i , d 4 x i , y i . ( j = 1 , 5 )

4.4. Octagon Template ( t 1 )

Creating an adaptive octagon template is the most difficult task. The traffic sign localization window is divided into eight areas (Figure 12). The algorithm looks for the farthest contour points from the center ( x c , y c ) . These points are the vertices of the octagon ( x k , y k ) ( k = 1 , , 8 ).
Octagon side equations are also written through vertex coordinates. The distances to the sides of the octagon are calculated for each point ( x i , y i ) of contour D .
d k x i , y i = y k y l x i x k + y i y k x k x l y k y l 2 + x k x l 2 , l = k m o d   8 + 1 , k = 1 , , 8 .
The contour point must be mapped to the nearest side of the octagonal template. The deviation from the template for point ( x i , y i ) is equal to the distance to the nearest side of the template.
P 2 x i , y i = min k d k x i , y i . ( k = 1 8 )

5. Internal Image Recognition

We perform two traffic sign transformations to recognize the internal image. The first transformation removes the edge segment and the entire image in the localization window. The result of this operation is an internal image of the traffic sign. The second transformation scales the internal image to the size of the template. The scaling factor k is equal to the average distance between the vertices of the sign outline to the template size.
For example, for a triangular sign, the scaling factor k is calculated based on the length of the side of the pattern r .
k = a 1 + a 2 + a 3 3 r , a 1 = ( y 1 y 2 ) 2 + ( x 1 x 2 ) 2 , a 2 = ( y 1 y 3 ) 2 + ( x 1 x 3 ) 2 , a 3 = ( y 3 y 2 ) 2 + ( x 3 x 2 ) 2 .
( x 1 , y 1 ) , ( x 2 , y 2 ) , and ( x 3 , y 3 ) are the coordinates of the vertices for the adaptive template when recognizing the shape of the sign.
Standard internal traffic sign images have two tones. A black picture on a white background is depicted on most traffic signs. Some images have a white picture on a blue background. The algorithm binarizes the internal image to eliminate unnecessary details. The threshold circuit converts the internal image into a binary matrix B . The size m × m of matrix B is chosen so that it is minimal and the entire traffic sign can be placed in it.
The templates of the internal traffic sign images T ( l ) are square matrices m × m . l is the template number. Templates T ( l ) are binary matrices. Matrices T ( l ) are formed based on reference images of traffic signs. The Hamming distance is used to match the internal image of the traffic sign B and the template T ( l ) .
b l = i , j = 1 n B i j T i j ( l ) .
The algorithm compares the internal image with all possible templates. The internal traffic sign image corresponds to pattern T ( l ) if b l is minimal. Examples of the algorithm operation to select the edge segment and the internal image are shown in Figure 13.

6. Results

We used a regular desktop computer. The software package was implemented in C++. The experiment was carried out on a computer with 12 nuclear processors and 16 GB of RAM. The processing time of one image did not exceed 2 ms. The processing time depended on the type of traffic sign. Some traffic signs were identified only by their shape. The processing time of these was halved. The first-level classifier worked on forming a comparison to the adaptive templates. The efficiency of determining the shape for the sign was 99.8% in the GTSRB collection. The percentage of false positives was 0.4%. Errors in the definition of the shape occur when overlapping the contour of the traffic sign with foreign objects or sharp shadows. Fragmentation of the edge segment occurs in these cases. An incomplete edge segment is mapped to an erroneous adaptive template. The proposed algorithm for sign shape recognition shows resistance to image blurring. This stability allows different filters to be used for image preprocessing.
The color classifier of the edge segment unmistakably works. Its high performance is associated with the structure of traffic signs.
The internal image recognition for traffic signs was also highly efficient. The algorithm correctly determined 99.6% of the images in the GTSRB collection. Errors can occur in low light or with high-angle shooting. Poor illumination requires a careful selection of the image binarization threshold. High-angle shooting effects can be eliminated by geometric transformations of the image. These transformations should include rotating the image by an angle, not just scaling. This question requires more research and is not included in this article.
The algorithm was tested for a collection of real images. The camera on the windshield of the car received pictures of road scenes. The shooting was carried out in various levels of light in the daytime and evening. The total number of signs in the collection was 500. The collection of test images included all possible signs. The frequency of recurrence for the signs in the collection corresponds to the frequency of their occurrence on the roads. The distortion of signs with poor illumination is not related to the shape of the signs and is random in nature. The size of the images ranged from 50 × 50 pixels to 200 × 200 pixels. The recognition efficiency was 96%. Recognition errors occur when there are objects that cover part of the sign. The algorithm has the greatest difficulty with the overlapping parts of the boundary segment of a traffic sign. Sharp shadows from objects prevent the algorithm from working as well as objects that overlap part of the sign. The algorithm copes with the unevenness of the illumination of the traffic sign image. The segmentation algorithm highlights edge segments with a gradient fill. The threshold template comparison scheme is insensitive to gradient color changes.
Our traffic sign image recognition system uses memory to store templates for internal images. The total number of templates is 132. Each template is 1 KB in size. The total size of the template set is 132 KB. The size of the template base is significantly less than the volume of neural network parameters, which is equal to several megabytes. The template base is easily scalable. The size of one template is small enough that the template base is not large.

7. Conclusions

We propose an algorithm for recognizing traffic signs by their images. The proposed algorithm uses additional information about the structure of traffic signs. This information allows to build a hierarchy of traffic sign classes. The advantage of the proposed approach is that it reduces the amount of information to make a decision. Reducing the amount of classifier input is an important factor in the task of recognizing traffic signs. Our algorithm requires fewer computational resources.
Real images for traffic signs are very different from their ideal standards. The main three problems in recognizing the images of traffic signs are the distortion of shapes in the images, color changes in natural light, and overlapping parts of images of signs with foreign objects or shadows from them. Our algorithm solves the problem of distorting the shape of a sign using adaptable patterns. Geometric transformations correct the internal image of signs and improve the effectiveness of the comparison with templates. The irregularity of the lighting leads to a distortion of the color of the traffic sign. The algorithm works with the color of a traffic sign to determine its shape and type. Uneven illumination changes a uniform fill to a gradient fill. The intensity gradient of the color for the sign can have a complex structure. Our segmentation method contains an adaptive parameter of the pixel color proximity measure. This approach selects gradient fill segments. Objects blocking part of the traffic sign image create the greatest difficulties for the algorithm. The algorithm considers such items as the boundaries of the edge segment. If the edge segment is not defined correctly, then the algorithm does not correctly determine the shape of the traffic sign. The character recognition is incorrect. Foreign objects and contrasting shadows are a common problem for all traffic sign recognition algorithms. Effective methods to overcome this problem do not exist today.
The high accuracy of our algorithm makes it suitable for use in real systems. Its low demand for computing resources allows us to use complex software in mobile laboratories. The high performance of the algorithm and its high efficiency increase the reliability of the input information in decision-making systems of unmanned vehicles and make them more reliable.

Author Contributions

Conceptualization, S.V.B.; methodology, S.V.B. and S.Y.B.; software, S.V.B. and E.V.K.; formal analysis, S.Y.B.; data curation, E.V.K.; writing—original draft preparation, S.V.B.; visualization, E.V.K.; project administration, S.V.B. All authors have read and agreed to the published version of the manuscript.

Funding

This research was funded by Siberian State Automobile and Highway University.

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Ellahyani, A.; El Ansari, M. Mean shift and log-polar transform for road sign detection. Multimed. Tools Appl. 2016, 76, 24495–24513. [Google Scholar] [CrossRef]
  2. Bouti, A.; Mahraz, M.A.; Riffi, J.; Tairi, H. A Robust System for Road Sign Detection and Classification Using LeNet Architecture Based on Convolutional Neural Network. Soft Comput. 2020, 2, 57–75. [Google Scholar] [CrossRef]
  3. Salti, S.; Petrelli, A.; Tombari, F.; Fioraio, N.; Di Stefano, L. Traffic sign detection via interest region extraction. Pattern Recognit. 2015, 48, 1039–1049. [Google Scholar] [CrossRef]
  4. Miura, J.; Kanda, T.; Shirai, Y. An active vision system for real-time traffic sign recognition. In Proceedings of the ITSC2000. 2000 IEEE Intelligent Transportation Systems. Proceedings (Cat. No.00TH8493), Dearborn, MI, USA, 1–3 October 2002. [Google Scholar] [CrossRef]
  5. Ellahyani, A.; El Ansari, M.; El Jaafari, I. Traffic sign detection and recognition based on random forests. Appl. Soft Comput. 2016, 46, 805–815. [Google Scholar] [CrossRef]
  6. Zhu, Z.; Liang, D.; Zhang, S.; Huang, X.; Li, B.; Hu, S. Traffic sign detection and classification in the wild. In Proceedings of the IEEE Conference on Computer Vision and Pattern Recognition (CVPR), Las Vegas, NV, USA, 27–30 June 2016; pp. 2110–2118. [Google Scholar]
  7. Stallkamp, J.; Schlipsing, M.; Salmen, J.; Igel, C. Man vs. computer: Benchmarking machine learning algorithms for traffic sign recognition. Neural Netw. 2012, 32, 323–332. [Google Scholar] [CrossRef] [PubMed]
  8. Cireşan, D.; Meier, U.; Masci, J.; Schmidhuber, J. Multi-column deep neural network for traffic sign classification. Neural Netw. 2012, 32, 333–338. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  9. Garcia, A.A.; Alvarez, J.A.; Soria-Morillo, L.M. Deep neural network for traffic sign recognition systems: An analysis of spatial transformers and stochastic optimization methods. Neural Netw. 2018, 99, 158–165. [Google Scholar] [CrossRef] [PubMed] [Green Version]
  10. Jaderberg, M.; Simonyan, K.; Zisserman, A.; Kavukcuoglu, K. Spatial Transformer Networks. In Proceedings of the Advances in Neural Information Processing Systems (NIPS 2015), Montreal, QC, Canada, 7–12 December 2015; pp. 1–9. [Google Scholar]
  11. Saha, S.; Kamran, S.A.; Sabbir, A.S. Total recall: Understanding traffic signs using deep hierarchical convolutional neural networks. In Proceedings of the 21st International Conference of Computer and Information Technology (ICCIT), Dhaka, Bangladesh, 21–23 December 2018; pp. 1–6. [Google Scholar]
  12. Mao, X.; Hijazi, S.; Casas, R.; Kaul, P.; Kumar, R.; Rowen, C. Hierarchical CNN for traffic sign recognition. In Proceedings of the 2016 IEEE Intelligent Vehicles Symposium (IV), Gothenburg, Sweden, 19–22 June 2016; pp. 130–135. [Google Scholar] [CrossRef]
  13. Zhang, J.; Wang, W.; Lu, C.; Wang, J.; Sangaiah, A.K. Lightweight deep network for traffic sign classification. Ann. Telecommun. 2019, 75, 369–379. [Google Scholar] [CrossRef]
  14. Jose, A.; Thodupunoori, H.; Nair, B.B. A novel traffic sign recognition system combining viola-jones framework and deep learning. In Proceedings of the International Conference on Soft Computing and Signal Processing (ICSCSP), Hyderabad, India, 22–23 June 2018; pp. 507–517. [Google Scholar]
  15. Li, Y.; Ma, L.; Huang, Y.; Li, J. Segment-based traffic sign detection from mobile laser scanning data. In Proceedings of the 38th Annual IEEE International Geoscience and Remote Sensing Symposium (IGARSS), Valencia, Spain, 22–27 July 2018; pp. 4607–4610. [Google Scholar]
  16. Ruta, A.; Li, Y.; Liu, X. Real-time traffic sign recognition from video by class-specific discriminative features. Pattern Recognit. 2010, 43, 416–430. [Google Scholar] [CrossRef]
  17. Lillo-Castellano, J.; Mora-Jiménez, I.; Figuera-Pozuelo, C.; Rojo-Álvarez, J. Traffic sign segmentation and classification using statistical learning methods. Neurocomputing 2015, 153, 286–299. [Google Scholar] [CrossRef]
  18. Li, L.; Mu, X.; Li, S.; Peng, H. A Review of Face Recognition Technology. IEEE Access 2020, 8, 139110–139120. [Google Scholar] [CrossRef]
  19. Saidallah, M.; Taki, F.; Alaoui, B.E.; Fergougui, A.E. Classification and comparison of license plates localization algorithms. Signal Image Process. Int. J. 2021, 12, 1–11. [Google Scholar] [CrossRef]
  20. Belim, S.V.; Belim, S.Y. Images Segmentation Based on Cutting the Graph into Communities. Algorithms 2022, 15, 312. [Google Scholar] [CrossRef]
  21. Belim, S.V.; Kutlunin, P.E. Boundary extraction in images using a clustering algorithm. Comput. Opt. 2015, 39, 119–124. [Google Scholar] [CrossRef]
  22. Belim, S.V.; Larionov, S.B. An algorithm of image segmentation based on community detection in graphs. Comput. Opt. 2016, 40, 904–910. [Google Scholar] [CrossRef]
  23. Yazdanparast, S.; Jamalabdollahi, M.; Havens, T.C. Linear Time Community Detection by a Novel Modularity Gain Acceleration in Label Propagation. IEEE Trans. Big Data 2020, 7, 961–966. [Google Scholar] [CrossRef]
Figure 1. First level of traffic sign classification hierarchy. Z is the first-level classifier.
Figure 1. First level of traffic sign classification hierarchy. Z is the first-level classifier.
Information 14 00335 g001
Figure 2. Classes that include one traffic sign: (a) z 2 ; (b) z 3 .
Figure 2. Classes that include one traffic sign: (a) z 2 ; (b) z 3 .
Information 14 00335 g002
Figure 3. Class z1 with two traffic signs.
Figure 3. Class z1 with two traffic signs.
Information 14 00335 g003
Figure 4. Subclasses of class z 4 .
Figure 4. Subclasses of class z 4 .
Information 14 00335 g004
Figure 5. Additional hierarchy level in class z 4 .
Figure 5. Additional hierarchy level in class z 4 .
Information 14 00335 g005
Figure 6. Class z 5 subclasses.
Figure 6. Class z 5 subclasses.
Information 14 00335 g006
Figure 7. Additional hierarchy level in class z 5 .
Figure 7. Additional hierarchy level in class z 5 .
Information 14 00335 g007
Figure 8. The class z6.
Figure 8. The class z6.
Information 14 00335 g008
Figure 9. Examples of edge segments and boundary definition for traffic signs: (a) traffic sign images, (b) edge segment of the traffic sign, and (c) traffic sign boundary.
Figure 9. Examples of edge segments and boundary definition for traffic signs: (a) traffic sign images, (b) edge segment of the traffic sign, and (c) traffic sign boundary.
Information 14 00335 g009aInformation 14 00335 g009b
Figure 10. Splits the traffic sign localization window to define the vertices of the triangle.
Figure 10. Splits the traffic sign localization window to define the vertices of the triangle.
Information 14 00335 g010
Figure 11. Splits the traffic sign localization window to define the vertices of the quadrangle.
Figure 11. Splits the traffic sign localization window to define the vertices of the quadrangle.
Information 14 00335 g011
Figure 12. Splits the traffic sign localization window to define the vertices of the octagon.
Figure 12. Splits the traffic sign localization window to define the vertices of the octagon.
Information 14 00335 g012
Figure 13. Examples of the algorithm operation for selecting an edge segment and an internal image: (a) a traffic sign image, (b) a traffic sign edge segment, (c) an internal traffic sign image, and (d) an internal image template.
Figure 13. Examples of the algorithm operation for selecting an edge segment and an internal image: (a) a traffic sign image, (b) a traffic sign edge segment, (c) an internal traffic sign image, and (d) an internal image template.
Information 14 00335 g013aInformation 14 00335 g013b
Disclaimer/Publisher’s Note: The statements, opinions and data contained in all publications are solely those of the individual author(s) and contributor(s) and not of MDPI and/or the editor(s). MDPI and/or the editor(s) disclaim responsibility for any injury to people or property resulting from any ideas, methods, instructions or products referred to in the content.

Share and Cite

MDPI and ACS Style

Belim, S.V.; Belim, S.Y.; Khiryanov, E.V. Hierarchical System for Recognition of Traffic Signs Based on Segmentation of Their Images. Information 2023, 14, 335. https://doi.org/10.3390/info14060335

AMA Style

Belim SV, Belim SY, Khiryanov EV. Hierarchical System for Recognition of Traffic Signs Based on Segmentation of Their Images. Information. 2023; 14(6):335. https://doi.org/10.3390/info14060335

Chicago/Turabian Style

Belim, Sergey Victorovich, Svetlana Yuryevna Belim, and Evgeniy Victorovich Khiryanov. 2023. "Hierarchical System for Recognition of Traffic Signs Based on Segmentation of Their Images" Information 14, no. 6: 335. https://doi.org/10.3390/info14060335

APA Style

Belim, S. V., Belim, S. Y., & Khiryanov, E. V. (2023). Hierarchical System for Recognition of Traffic Signs Based on Segmentation of Their Images. Information, 14(6), 335. https://doi.org/10.3390/info14060335

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop