概述
Vehicle Color Recognition using Convolutional Neural Network
Reza Fuad Rachmadi, I Ketut Eddy Purnama
Department of Multimedia and Networking Engineering, Institut Teknologi Sepuluh Nopember, Surabaya, Indonesia 60111
Institut Teknologi Sepuluh Nopember (ITS) is an Indonesian public university located in Surabaya, East Java, with a strong emphasis on scientific, engineering, and technological education and research.
Surabaya [,suərə'bɑ:jə; ,su:rɑ:'bɑ:jɑ:]:n. 泗水 (印尼城市名),苏腊巴亚
Indonesia ['indəu'ni:zjə,-ʒə]:n. 印尼,印度尼西亚
Abstract
Vehicle color information is one of the important elements in ITS (Intelligent Traffic System). In this paper, we present a vehicle color recognition method using convolutional neural network (CNN). Naturally, CNN is designed to learn classification method based on shape information, but we proved that CNN can also learn classification based on color distribution. In our method, we convert the input image to two different color spaces, HSV and CIE Lab, and run it to some CNN architecture. The training process follow procedure introduce by Krizhevsky, that learning rate is decreasing by factor of 10 after some iterations. To test our method, we use publicly vehicle color recognition dataset provided by Chen. The results, our model outperform the original system provide by Chen with 2% higher overall accuracy.
intelligent transportation system,ITS:智能运输系统
intelligent traffic system,ITS:智能交通系统
hue, saturation, lightness,HSL
hue, saturation, value,HSV
red, green, blue,RGB
International Commission on Illumination (French name: Commission internationale de l'éclairage),CIE
The CIELAB color space (CIE L*a*b* or Lab color space) is a color space defined by the International Commission on Illumination (CIE) in 1976.
I. INTRODUCTION
Intelligent Transport System (ITS) is a system that manages transportation from traffic management to law enforcement. One important object that widely explored by ITS is a vehicle and their properties, including type, color, and license plate. Vehicle color is an important property for vehicle identification and provide visual cues for fast action law enforcement. Recognize vehicle color is very challenging task because several factors including weather condition, quality of video/image acquisition, and strip combination of the vehicle. The first factor, weather condition, may dramatically change the color illumination of the acquisition image. For example, if the image/video taken at haze condition then there a lot of ”soft” white noise added to the image. Soft white noise means that the noise is not random but continues and blended with the foreground and background objects. The quality of video/image acquisition is affected the final decision of the vehicle color recognition system and its depends of the optical sensor in the camera. Camera that can capture object at high speed is recommended for ITS, but not all installed camera in the road can do that. A lot of cameras installed in the road only used to monitor the traffic, pedestrians, and street conditions. The last factor is strip combination of the vehicle, which is very affected to the vehicle recognition system. Region selection is very important to tackle the problem.
law enforcement:n. 法律的实施,执法机关
cue [kjuː]:n. 提示,暗示,线索 vt. 给...暗示
blend [blend]:vt. 混合 vi. 混合,协调 n. 混合,掺合物
tackle ['tæk(ə)l]:n. 滑车,装备,用具,扭倒 vt. 处理,抓住,固定,与...交涉 vi. 扭倒,拦截抢球
There are some research paper published to tackle vehicle color recognition problem, like in [1], [2], [6], [8], [9]. Chen et al. [2] use feature context and linear SVM classifier to tackle the problem. Feature context is a collection of histogram that build with several areas, like spatial pyramid structure but with different region configuration. In other paper [6], they try to tackle vehicle color recognition problem using 2D histogram with some ROI configuration as features and neural network as classifier. Baek et al. [8] also use 2D histogram but without ROI configuration and SVM as classifier. Another approach is described by Son et al. [9] which using convolution kernel to extract similarity between positive and negative images and then feed up those similarity score to SVM classifier.
region of interest,ROI:感兴趣区域
Color spaces are very important to color recognition applications, like vehicle color recognition. The selection of color space will impact the recognition performance. The most usable color space in digital photography is RGB color space, but RGB color space has problem to color recognition because channel of RGB color space contribute equal for each channel so to distinct color is more difficult. Usually, researcher will not use RGB as their primary color space and convert it to other color spaces that separate illumination and color, like CIE Lab or HSV [6], [8], [9]. Another approach is to make 2D histogram of two channels, like H and S channel in HSV color space, and do classification using those 2D histogram.
distinct [dɪ'stɪŋ(k)t]:adj. 明显的,独特的,清楚的,有区别的
illumination [ɪ,ljuːmɪ'neɪʃən]:n. 照明,照度,启发,阐明
In this paper, we present vehicle color recognition method using convolutional neural network (CNN). CNN is type of neural network but instead of using fully connected layer, CNN use layer called convolution layer to extract features from data. The training mechanism is very similar to normal neural network and use stochastic gradient descent as training algorithm. CNN is become very popular after winning the ILSVRC (ImageNet Large Scale Visual Recognition Challenge) 2012 [5]. In those paper, they use more than 600,000 neuron and 7 hidden layer to provide good model of the data. To avoid overfitting Krizhevsky et al. [5] employed regularization method called dropout to the fully connected layer [3]. The Krizhevsky model is huge and as reported in the paper, the model trained in six day for 450,000 iteration in GPU hardware. Before going into details, in section two we describe details related works in color recognition. Section two describe details architecture of our CNN model. Section three reports the experiments we have done and discuss the results.
stochastic gradient descent,SGD:随机梯度下降
ImageNet Large Scale Visual Recognition Challenge,ILSVRC
regularization [,rɛɡjʊlərɪ'zeʃən]:n. 规则化,调整,合法化
II. RELATED WORKS
There are several research that try to tackle vehicle color recognition problem including in [1], [2], [6], [8], [9]. The newest research is describe by Chen et al. [2] in 2014 and Hsieh et al. [1] in 2015. Chen et al. use feature context (FC) with selected configuration to divide the images into subregions, create histogram for each subregion, and learned it using linear SVM. Not all value in histogram is used to classify the vehicle color but the values clustered to form codebook for the problem and then choose the codebook as feature for the classifier. This mechanism know as Bag-of-Word (BoW) method. Chen et al. done preprocessing using haze removal method [7] and color contrast normalization method. The accuracy of system proposed by Chen et al. is very high, over 92%.
mechanism ['mek(ə)nɪz(ə)m]:n. 机制,原理,途径,进程,机械装置,技巧
The bag-of-words model is a simplifying representation used in natural language processing and information retrieval (IR).
Another paper by Hsieh et al. [1] proposed color correction using background image and two frame image of car. Not only color correction method, Hsieh et al. also proposed window removal method that remove the window part of the car images and classify vehicle color using lower part, like bumper and doors, of the car. The window removal done by taking the orientation of the car, fit the detail segmented car image by ellipse shape and cut a half of the ellipse. Hsieh et al. done the experiments using three different classifier, G-Classifier, DC-Classifier, and DG-Classifier. G-Classifier responsible for classify gray and non-gray color. The method is very simple threshold method with assumption that for gray color the avarage of three channel, RGB, is very close with color value of each channel. The DC-Classifier and DG-Classifier trained using SVM with features extracted from RGB and CIE Lab color space. Red, green, blue, and yellow color class classified using DC-Classifier and the rest of the color class classified using DG-Classifier. From the experiments, Hsieh et al. report that the average accuracy for the system is 93.59% with 7 color class including black, silver, white, yellow, red, green, and blue.
bumper ['bʌmpə]:adj. 丰盛的,丰富的 n. 缓冲器,保险杆,减震物 vt. 装满,为...祝酒 vi. 干杯
FC also used by Dule et al. [6] to tackle vehicle color recognition problem. The different between FC used by Chen et al. and Dule et al. is that Dule et al. only used two ROI (smooth hood peace and semi front vehicle). ROI is selected automatically using plate detection method and otsu thresholding to search smooth hood peace and heuristic approach for semi front vehicle. The classifier used by Dule et al. are KNN, ANN, and SVM. The best accuracy that reported in Dule et al. paper is 83.5% with configuration of 8 bin histogram, several combination of color spaces, and ANN classifier.
hood [hʊd]:n. 头巾,覆盖,兜帽 vt. 罩上,以头巾覆盖
heuristic [,hjʊ(ə)'rɪstɪk]:adj. 启发式的,探索的 n. 启发式教育法
Otsu's method, named after Nobuyuki Otsu, is used to automatically perform clustering-based image thresholding, or, the reduction of a graylevel image to a binary image.
Other approach for vehicle color recognition problem is classify vehicle color using 2D histogram features. Baek et al. [8] proposed the vehicle color recognition system using 2D histogram features and SVM classifier. Hue and saturation in HSV color space is used for creating the 2D histogram. From the experiments, the average accuracy of the system is 94.92%. The dataset used in the experiment has 500 outdoor vehicle images with five color class including black, white, red, yellow, and blue color class.
histogram ['hɪstəgræm];n. 直方图,柱状图
Son et al. [9] proposed other possible approach for color recognition using similarity method. The system using grid kernel that run on hue and saturation channel of HSV color space. The same dataset as in [8] is used in the experiments. Son et al. reported only precision and recall for each color class. The percentage of precision and recall from the experiments is very high and close to 100%. High precision and high recall indicate that the model has good accuracy.
saturation [sætʃə'reɪʃ(ə)n]:n. 饱和,色饱和度,浸透,磁化饱和
Fig. 1. The CNN architecture used in our system consist 8 layers with 2 base networks with total 16 layers. First two layers and fifth layer does normalization and pooling after convolution process. The third and fourth layer does only convolution process. Before feed up to fully-connected layers, the networks do channel concatenation process. Sample of input image is taken from Chen [2] dataset.
III. THE CNN ARCHITECTURE
The architecture of our CNN can viewed in figure 1. Our CNN architecture consists 2 base networks and 8 layers for each base network with total 16 layers. The first two layers of our CNN architecture is a convlutional layer and it does convolution process following by normalization and pooling. Convolutional layer is a layer that do convolution process that same as convolution process in image processing algorithm. For I i I_i Ii is an input image and h h h is a some convolution kernel, output image for convolution process I o I_o Io can be written as
with [m, n] is pixel value at coordinate (m, n). Training process of CNN will learn h h h, may called as kernel, as parameters of convolutional layer. The choice of activation function in convolutional layer have huge impact for the networks. There a several choice of activation function including t a n h tanh tanh and R e L U ReLU ReLU (Rectified Linear Unit). In our CNN networks we use R e L U ReLU ReLU activation function for all layers including the fully-connected layers. The normalization process done by following equation 2 with α = 1 0 − 4 α = 10^{−4} α=10−4, β = 0.75 β = 0.75 β=0.75, and n = 5 n = 5 n=5.
with l x , y i l^{i}_{x,y} lx,yi is normalization result and k x , y i k_{x,y}^{i} kx,yi is output of layer activation function for convolution at coordinate ( x , y ) (x, y) (x,y). Using those normalization, the accuracy of CNN increase about 2% according to [5]. The last process in two first layers is pooling process. There are two type of pooling, max pooling and mean pooling. Each type has different approach, max pooling will take maximum response from the convolutional process which is shape with sharp edges and mean pooling will take the average of the convolutional process response which is summarize the shape in neighborhood. In our CNN architecture, we use max pooling with size 3x3 and stride 2 for overlapping pooling. The second, fourth and fifth layer are grouping into two group which each group is independent each others. The third and fourth layer is also a convolutional layer but without pooling and normalization process. Output of third and fourth layer is same as input because we use 3x3 kernel with pad 1 added for each border. The fifth layer is convolutional layer with only pooling process without normalization.
Before going into a fully-connected layers, the pooling output of the fifth layer from two base networks is concatenate and flattened into one long vector. The sixth and seventh layer is a fully-connected layer employed dropout regularization method to reduce overfitting. The last layer is the softmax regression layer which can describe in the following equation
with p ( y ( i ) = j ∣ x ( i ) ; θ ) p(y^{(i)} = j|x^{(i)}; θ) p(y(i)=j∣x(i);θ) is probability of y ( i ) y^{(i)} y(i) being class j j j given input x ( i ) x^{(i)} x(i) with weight parameter θ θ θ.
Overall, our CNN architecture consists 2 base networks, 8 layers each with total 16 layers. First layer use 11x11@3 kernel with total 48 kernels, second layer use 3x3@48 kernel with total 128 kernels, third use 3x3@128 kernel with total 192 kernels, fourth layer use 3x3@192 kernel with total 192 kernels, and fifth layer use 3x3@192 with total 128 kernels. Pooling process is employed in first, second, and fifth layer with same parameter, pooling size of 3x3 with 2 pixel stride. Sixth, seventh, and eight layers is fully-connected layers with each 4096-4096-8 neuron with dropout regularization method employed in sixth and seventh layer. The network’s input is a 3 channel image with 150,228 dimensional or 227x227@3 resolution. Total neuron involved in the networks is 658,280 neurons.
neuron ['njʊərɒn];n. 神经元,神经单位
constancy ['kɒnst(ə)nsɪ]:n. 坚定不移,恒久不变
IV. THE EXPERIMENTS
A. Training Process
Our models trained using stochastic gradient descent with 115 examples per batch, momentum of 0.9 and weight decay of 0.0005. For the experiments, we use Chen dataset [2] and some sample images of the dataset can be viewed in figure 2. The dataset contains 15601 vehicle images with 8 classes of vehicle color, which are black, blue, cyan, gray, green, red, white, and yellow. In the training process, half of class examples are used. Each example is resized into 256x256@3 resolution with certain color spaces. We use four different color spaces, RGB, CIE Lab, CIE XYZ, and HSV. Before the data processed for training, it cropped to 227x227@3 and subtracted by mean image of the training data. In training process the data randomly mirrored to increase the classifier accuracy. We use learning rate of 0.01 and reduced continuously by a factor of 10 at multiple iteration of 50,000 with maximum iteration of 200,000. We use caffe framework [4] to implement our models. The weights of the networks are initialized using a gaussian function with δ = 0.01 for connecting weights and fixed value of 0.1 for bias value.
Fig. 2. Sample images from Chen dataset [2]. Some images are suffering from noise and brightness constancy.
The stochastic gradient descent method, SGD for short, is an optimization method that want to find minimum or maximum value of some function. SGD will work for all function that have gradient or first derivative. Usually the system use SGD for minimizing the error or loss function and update the weight parameters based on following function
with w i w_{i} wi is current weight parameters, α α α is learning rate, and ▽ L ( z , w i ) bigtriangledown L(z, w_{i}) ▽L(z,wi) is the gradient of loss function L L L with respect to input examples z z z. For faster model convergence, the weight decay and momentum are added to the update equation. The final equation of update function in SGD method is describe following
with γ γ γ is momentum variable and ζ ζ ζ is weight decay. Changing momentum and weight decay may accelerate the training process.
derivative [dɪ'rɪvətɪv]:n. 衍生物,派生物,导数 adj. 派生的,引出的
The training process done in GPU hardware to reduce the training time. Our GPU hardware consists 14 multiprocessor within 3 GB memory. There are two limitations of our GPU hardware for training process, the memory limiting the size of the networks or the batch size used in the training process and the maximum dimension of the grid block execution (parallel execution configuration) also limiting the batch size used in the training process. The training process taken over 2 GB GPU memory for the data and the networks with 4 days of execution time.
B. Results and Discussion
For testing purpose, we use 50% examples of dataset that not used in the training process. Table I summarize our testing results with four different color spaces and compare the results with the system provide by Chen et al. [2]. Each class consists different number of examples from 141 to 2371. From table I, it can see that RGB color space achieve the highest accuracy of the testing process with average accuracy of 94.47%. Four color spaces used in the models have high accuracy, more than 90%, with narrow deviation. The results show that our CNN model outperform the original system of dataset provide by Chen et al. [2]. Our models outperform Chen et al. system in yellow, white, blue, red, gray, black, and green color class. Only on cyan color class our system had lower accuracy comparing to the Chen et al. system but with different only 0.7%. Figure 3 is a confusion matrix for our model using RGB color space. The confusion matrix shows that the most worst accuracy of our model is in green and gray color class. Some examples of green class is misclassified as gray class and its above 10%. As seen in the dataset, some green color class examples has color that very close to gray, more like greengray color than green, so the classifier may have it wrong classified as a gray color class. The same case appears in gray color class which some gray color class examples misclassified as white color class. Thus may appears because of very bright sunlight reflection on metallic paint or the color is too light so it’s very close to another color as well.
deviation [diːvɪ'eɪʃ(ə)n]:n. 偏差,误差,背离
metallic [mɪ'tælɪk]:adj. 金属的,含金属的
TABLE I. ACCURACY OF OUR MODELS WITH 4 DIFFERENT COLOR SPACES AND ACCURACY FROM CHEN ET AL. [2] FOR COMPARATION.
Fig. 3. Confusion matrix from our model with RGB color space. Each cell describe accuracy for each class measure in percentage.
Another issue to tackle is execution time used to classify vehicle color. We implement the models using two different hardware, the first one the model running on 1 core CPU and the second one the model running on 448 cores GPU with NVIDIA Tesla C2050. Table II summarize average execution time for all testing examples. As shown in table II, the models that run on GPU have more than 20x faster than the models that run on CPU, so the issue of execution time is solved if the models running on appropriate hardware configuration. The initialization time is a time for the system to prepare the model, load it to the memory, and load mean image. For the practical implementation, we recommend using the client server mechanism, send the vehicle detection result to the server, do the vehicle color classification in server backend using GPU hardware, and send back the result to the Intelligent Transportation System for further processing.
TABLE II. EXECUTION TIME FOR OUR MODEL USING CPU AND GPU HARDWARE.
To see how our models capturing color information in the data, we visualize a several layer of our CNN models. The first convolutional layer is an important part of the network to extract low-level features. Figure 4 is a visualization of all kernels in the first convolutional layer and an example output of the pooling process in layer conv1 and conv2 of our CNN architecture. As seen in figure 4, the first convolutional layer capture rich color features in the input image. All vehicle color variations in dataset are present in the kernels. The kernels from network 1, figure 4a, capture a lot of cyan-like color. Cyan-like color that appears in the kernel may contribute to the red color class or cyan color class. Another color that appears repeatedly in the kernel are red-blue color, greengray color, and orange-like color. For further investigation, we capture respond from convolutional layer continuing with normalization and pooling process and it can see in figure 4c. We test our models using one of the test images and try to analyze the behaviour of our models. Figure 4c show that for yellow color class a lot of the green-like color kernel neuron is active and its looks like our models learned that color can be recognize from the hood color or the top color of the car. This behaviour occurs because most all of the images in dataset take image of the front of the car from some height and a little deviation of angle, so the side of the car is not cover very much. The camera configuration of taken images in dataset simulate the CCTV or other street camera that relatively used such that configuration.
cyan ['saɪən]:n. 蓝绿色 adj. 蓝绿色的
closed-circuit television,CCTV:闭路电视
Fig. 4. 96 kernel with 11x11@3 resolution learned by our first convolutional layer with input resolution 224x224@3 and output example from pooling process. (a) 48 kernel from network 1, (b) 48 kernel from network 2, © output from pooling process in layer conv1 and conv2.
V. CONCLUSION
In the paper, we present the vehicle color recognition system using convolutional neural network. Our model successfully capturing vehicle color in very high accuracy, 94.47%, and outperform the original system provide by Chen [2]. From the experiment, the best accuracy is achieve using RGB color space and this is contradictive with several papers that not recomend RGB color space for color recognition and using another color space like HSV or YUV. Execution time for our models is about 3 s for CPU (1 core) and 0.156 s for GPU (448 cores), although the execution time is slower than system provide by Chen [2] but its still can be used for practical implementation with several adjustment.
contradictive [,kɒntrə'dɪktɪv]:adj. 倾向于矛盾的,抵触的
YUV is a color encoding system typically used as part of a color image pipeline.
References
Vehicle Color Recognition on an Urban Road by Feature Context
Vehicle Color Classification Under Different Lighting Conditions Through Color Correction
Vehicle Color Classification Based on the Support Vector Machine Method
Dropout: A Simple Way to Prevent Neural Networks from Overfitting
ImageNet Classification with Deep Convolutional Neural Networks
WORDBOOK
closed-circuit television,CCTV:闭路电视
KEY POINTS
Naturally, CNN is designed to learn classification method based on shape information, but we proved that CNN can also learn classification based on color distribution. In our method, we convert the input image to two different color spaces, HSV and CIE Lab, and run it to some CNN architecture. The training process follow procedure introduce by Krizhevsky, that learning rate is decreasing by factor of 10 after some iterations. To test our method, we use publicly vehicle color recognition dataset provided by Chen.
The selection of color space will impact the recognition performance. The most usable color space in digital photography is RGB color space, but RGB color space has problem to color recognition because channel of RGB color space contribute equal for each channel so to distinct color is more difficult.
To avoid overfitting Krizhevsky et al. [5] employed regularization method called dropout to the fully connected layer [3].
From the experiments, Hsieh et al. report that the average accuracy for the system is 93.59% with 7 color class including black, silver, white, yellow, red, green, and blue.
The dataset used in the experiment has 500 outdoor vehicle images with five color class including black, white, red, yellow, and blue color class.
We use learning rate of 0.01 and reduced continuously by a factor of 10 at multiple iteration of 50,000 with maximum iteration of 200,000.
From the experiment, the best accuracy is achieve using RGB color space and this is contradictive with several papers that not recomend RGB color space for color recognition and using another color space like HSV or YUV.
The dataset contains 15601 vehicle images with 8 classes of vehicle color, which are black, blue, cyan, gray, green, red, white, and yellow.
The first convolutional layer is an important part of the network to extract low-level features.
最后
以上就是开朗小土豆为你收集整理的Vehicle Color Recognition using Convolutional Neural NetworkVehicle Color Recognition using Convolutional Neural Network的全部内容,希望文章能够帮你解决Vehicle Color Recognition using Convolutional Neural NetworkVehicle Color Recognition using Convolutional Neural Network所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复