Fatigue Driver Detection System Using a Combination of Blinking Rate and Driving Inactivity

According to the results, the graph analysis on ten sets of 1-minute samples show that the typical blink of human contains alternating inter-blink periods of shorter and longer durations depend on the driver’s state. Although the results show that our method works well for the images taken under controlled environments and changes of illumination in less quantity, some issues are discussed below 1. The algorithm may be failed to detect eye blink when the rotation of the driver’s head is over 30 degrees. Therefore, the installation of the camera is suggested to be in the front of the driver to prevent such a problem. 2. When illumination of the face has changed in large quantity, it causes the face and eyes area to become dark. The detection of eye blinks may fail and causes an error in the count of blinks. For the fatigue detection from driving behavior, the experiment and results showed that our algorithm can effectively classify and analyze the driving behavior. However the results show that our method cannot work well under situations where traffic jam or waiting for traffic light for a long time. For the solution to improve the accuracy of the algorithm can be achieved by increasing the duration of data storage but the disadvantage of this solution is the algorithm will use a long time before it can measure the driver’s state. This is the main reason why both methods have to be combined in order to support each other.

pdf7 trang | Chia sẻ: huongthu9 | Lượt xem: 579 | Lượt tải: 0download
Bạn đang xem nội dung tài liệu Fatigue Driver Detection System Using a Combination of Blinking Rate and Driving Inactivity, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
Fatigue Driver Detection System Using a Combination of Blinking Rate and Driving Inactivity Wasan Tansakul and Poj Tangamchit Control System and Instrumentation Engineering Department King Mongkut’s University of Technology Thonburi, Bangkok, Thailand Email: wasan.tans@gmail.com, ipojchit@kmutt.ac.th Abstract—We implemented a fatigue driver detection system using a combination of driver’s state and driving behavior indicators. For driver’s state, the system monitored the eyes’ blinking rate and the blinking duration. Fatigue drivers have these values higher than normal levels. We used a camera with machine vision techniques to locate and observe driver’s blinking behavior. Harr’s cascade classifier was used to first locate the eye’s area, and once found, a template matching was used to track the eye for faster processing. For driving behavior, we acquired the vehicle’s state from inertial measurement unit (IMU) and gas pedal sensors. The principle component analysis (PCA) was used to select the components that have high variance. The variance values were used to differentiate fatigue drivers, which are assumed to have higher driving activities, from normal drivers.  Index Terms—fatigue driving, blink detection, driving behavior I. INTRODUCTION A study of car accidents indicates that almost 20% of the cause of crash results from non-readiness of drivers such as distraction, fatigue and lack of sleep. When drivers are asleep, the accidents tend to more severe because the drivers cannot react and maneuver the vehicle to avoid crashes. A prompt detection of sleepy drivers is therefore very useful. There are mainly two types of indicators used to detect fatigue drivers: driver’s state and driving behavior. Driver’s state is a direct indicator to driver’s fatigue. However, it can be difficult to measure effectively, because it involves human factors which can be unpredictable. For example, a truck driver who wants to avoid being caught that he is asleep in his duty can easily take away or fake the sensors that measure his state. The driving behavior, on the other hand, can be measured with sensors installed in a vehicle, which cannot easily be tampered with. This paper combines both driver’s state and driving behavior detection to get the benefits of both methods. This will make the detection system more practical than using only one indicator. For driver’s state indicator, we use a clue Manuscript received September 21, 2014; revised December 17, 2014. from the driver’s eyes. Eye behavior contains a useful clue for drowsiness. There are two approaches for detecting eye clues: Active and passive approaches. The active approach uses infrared light shining toward the eyes and detecting reflection. The passive approach relies on ambient light and detects eyes’ behavior. The drawback for the active light is that the light source, although infrared, has to be strong so that its reflection is clearly visible. This will create eye strain when using it on the driver’s eyes for a long period of time. Our work, on the other hand, chose the passive approach, which use ambient light or gentle light source. We use eye detection and tracking algorithm to detect blinking rate and duration. Fatigue drivers will have high blinking rate and longer duration than normal drivers. For driving behavior indicator, we install a 9-DOF inertial measurement unit (IMU) together with a gas pedal sensor. These sensors are used to measure the level of driving activity. The assumption we used is that fatigue drivers will have low level of activity, which will be reflected by the smoothness of sensor values. Since, there are many features from the sensors, we implement the principle component analysis (PCA) to reduce the dimension of data. Then, we measure the fluctuation of data by using the standard deviation to differentiate between normal drivers and fatigue drivers. II. RELATED WORK Possible techniques for detecting drowsiness in drivers can be broadly divided into four major categories: • Methods based on driver’s current state, relating to the eye and eyelid movements [1]-[3]. • Methods based on driver performance and driving behavior [4]-[6]. • Methods based on physiological signals [7]. • Methods based on combination of the multiple parameters [8]. There has been lots of literature on detection of fatigue effects and the driver’s current state specifically focused on changes and movements in the eye. This includes assessing changes in the driver’s direction of gaze, blinking rate and actual eye closure. Generally, eyes detection consists of two steps: Locating face to extract eye regions and eye detection from eye’s windows. 33 Journal of Automation and Control Engineering Vol. 4, No. 1, February 2016 ©2016 Journal of Automation and Control Engineering doi: 10.12720/joace.4.1.33-39 Several researches use Haar-Like feature and AdaBoost algorithm for detecting face and eyes and use PERCLOS to evaluate driving fatigue. PERCLOS (Percent Eye Closure), a video based method that measures eye closure, is a reliable and valid determination of a driver’s alertness level. PERCLOS is the proportion of total time that the driver’s eyelids are closed 80% or more and reflects slow eyelid closures rather than blinks. For example, W. Qing et al. [1] and Y. Kurylyak et al. [3] detected face and eyes region using Haar-Like feature and AdaBoost algorithm. W. Qing et al. use an improved template matching method to detect eye states and selected PERCLOS to evaluate driving fatigue, while Y. Kurylyak et al. used the frames differencing in combination with a thresholding method to detect the eyes closure and opening. They used the transition of eyes state to detect eyes’ blink. B. Alshaqaqi et al. [2] designed an Advanced Driver Assistance System (ADAS) to reduce accidents due to drivers’ fatigue. In this system, they proposed an algorithm to locate, track, and analyze the driver face and eyes to measure PERCLOS. Then they performed scientifically supported measure of drowsiness associated with slow eye closure. Other measurements that are capable of measuring drivers’ performance and physiological state are also proposed. Examples of these were: road boundary and tracking, fatigue driving detection system design based on driving behavior, EEG recording. A detail presentation is given below. W. S. Wijesoma et al. [4] developed a road boundary and tracking system by using ladar sensing. They proposed a method based on the extended Kalman filtering filtering for fast detection and tracking of road curbs using successive range/bearing readings obtained from a scanning two-dimensional ladar measurement system. W. Hailin et al. [5] and T. C. Chieh et al. [6] implemented a fatigue driving detection system design based on driving behaviors. W. Hailin et al. detected the changing signals of accelerate, brake, shift and steering to analyze driver’s states. T.C. Chieh et al. detected driving fatigue by monitoring the driver’s grip force on the steering wheel alone. The data was obtained by using two resistive force sensors attached to the steering wheel and connected to a computer and a data acquisition module. For an EEG reading, L. Ming-ai et al. [7] studied the characteristic of EEG signal in a drowsy driving state by using a method based on the power spectrum analysis and FastICA algorithm in order to determine the fatigue degree. It can differentiate between two states: sober and drowsy. The multichannel signals were analyzed with the FastICA algorithm, and the power spectral densities were calculated after FFT and then the fatigue index F was determined. According to the analysis above, the approaches that combine driver state and driver performance will improve the sensibility and reliability in fatigue detection. J. Wang et al. [8] developed a real-time driving danger level prediction system by using a level prediction system that uses multiple sensor inputs. They used a statistical model to predict the driving risk. They used three types of features: the vehicle dynamic parameter, the driver’s physiological data, and the driver’s behavior. In this system, they used hidden Markov model, conditional random field and reinforcement learning to model the temporal patterns that lead to safe/dangerous driving state. III. SYSTEM OVERVIEW We designed our system to detect fatigue base on two clues: driver’s state and driving behavior. Our system consists of two parts i) Fatigue detection from eyes movement, ii) Fatigue detection from driving behavior as shown in Fig. 1. Figure 1. Fatigue detection overview A. Fatigue Detection From Eyes Movement The proposed blink detection procedure includes the following steps: i) face and eyes detection, ii) eyes tracking, iii) eye closure detection and evaluation of the blink rate by steps as shown in Fig. 2. Figure 2. The proposed algorithm 34 Journal of Automation and Control Engineering Vol. 4, No. 1, February 2016 ©2016 Journal of Automation and Control Engineering 1) Face & eyes detection The first step in analyzing the blink of a driver is to locate the face and the eyes. We applied Haar Cascade Classifier for face and eyes detection. First, we detected the face to get the face location. Then, within the face region, we search for the eyes and get eyes’ location. Fig. 3 illustrates the output of the cascade detector. Figure 3. Output of the Harr cascade detector. Where green rectangles are the eyes and face location. The drawback of Harr cascade is that it is computational expensive. It gave slow refresh rate compared to the speed of eyes’ blink. Therefore, we applied template matching for eyes tracking. We got eyes template image from eyes location of cascade detector output and then system will track eye in the green rectangles as shown in Fig. 4. Figure 4. Eye template image and output of template matching. Finally, we obtained a region of interest (ROI) around the eyes from output of template matching, and derive a measurement value which is used to determine the eye state. 2) Blink detection We proposed the detection of blinking and the analysis of blink duration in this section. We utilized the color feature to detect eye closure by we will convert color space of eye ROI image from RGB to HSV and split image to V-channel to monitor the value change of lightness in ROI image. When user change state of eye from open to close, that will result in the lightness increases because eye-closed state have the size of black eye is smaller than the eye open state so lightness value in eye-opened state will less than eye-closed state. Fig. 5 illustrates the output image after convert colors space. Figure 5. Eyes in different states in RGB (upper row) and the corresponding images transformed to the V-channel of the HSV- Color space (lower row). After converting color space of eye ROI image from RGB to HSV. We can get the lightness value (V-value in HSV) and plot it on the time axis as in Fig. 6. Figure 6. The plot shows V-Value compare with time From lightness value in Fig. 6, we can detect blink and calculate blink duration by the flowchart in Fig. 7. The objective of the algorithm is to find the sharp slope of V- Value, and define it as the transition points. First, we will find positive slope. If the values of positive slope higher than “Th_close” system will judgment eye state to close and increase time of eye blink duration until the values of negative slope higher than “Th_open” and then system will stop increase time of eye blink duration and judgment eye state to open. Next, the system will count up blink and start find slope of V-Value again. For the eye state, “Stateeye” is defined by testing the value “V-Value” by a threshold and we can derive by the following (1): eye Th Close Th open dV Closed if dt dV Open if dt State        (1) 35 Journal of Automation and Control Engineering Vol. 4, No. 1, February 2016 ©2016 Journal of Automation and Control Engineering Figure 7. The proposed algorithm to detect blink and calculate blink duration B. Fatigue Detection from Driving Behavior The proposed driving fatigue detection based on driving behavior procedure includes the following steps: i) data acquisition from sensor, ii) analyze the driver’s driving behavior by steps as shown in Fig. 8. Figure 8. The proposed driving fatigue detection based on driving behavior. Figure 9. System overview Fig. 9 shows all of the system hardware that includes the following devices i) FreeIMU module(GY-87), ii) Resistive Sensor, iii) MCU(Freeduino V1.16 Board), iiii) Computer. 1) Data acquisition from sensor The force resistive sensor was mounted on the acceleration pedal. The sensor gives out a voltage value according to the force received. When driver does not apply pedal, the output voltage is 0V. When driver apply a full force to the pedal, the output voltage is 3.3V. The change of voltage reflects the pedal’s movement. We use it as a input to construct the model of driving behaviors. Fig. 10 shows the resistive sensor and the position of it on an acceleration pedal. Figure 10. Force resistive sensor and its position on the pedal. The car movement was measured from the FreeIMU module (GY-87), which is a combined accelerometer, gyroscope, and compass. Its signal includes the following 9 parameters i) 3-axis parameter from Gyro meter, ii) 3- axis parameter from Accelerometer, iii) 3-axis parameters from Magnetic Field. The protocol for sending and receiving data between IMU module and MCU was communicated by SPI protocol. Fig. 11 is shown FreeIMU module and setup position on console. The data from sensor was separated into two set are i) Training data, ii) Test data. Figure 11. FreeIMU module and setup position on console. 2) Analyze the driver’s driving behavior Start Receive data from sensor Data Normalization Use Principal Component Analysis Storage Mean, Standard deviation and Coefficient Calculate Mean value of data Calculate Standard deviation values of data End Figure 12. The proposed algorithm to calculate Mean, Standard Deviation and Coefficient values. 36 Journal of Automation and Control Engineering Vol. 4, No. 1, February 2016 ©2016 Journal of Automation and Control Engineering According to the data collected from resistive sensor and FreeIMU module (Sampling rate 1ms) we used principal component analysis to simplify the data and construct a fatigue driving identification model to analyze the driver’s driving behavior. For analyze the driver’s driving behavior includes two steps i) Calculate Mean, Standard Deviation and Coefficient value from training data for using to model the driver statement ,ii) Calculate Variances of Test data by using Mean, Standard Deviation and Coefficient of training data. We can calculate Mean, Standard Deviation and Coefficient value by the following flowchart in Fig. 12. The fatigue driving identification is showed as in Fig. 13. First, the dataset from resistive sensor and FreeIMU module were normalization by using z-score and then the data were analyzed by Principal Component Analysis to reduce the dimensionality of a data set. Next, the variances were calculated from variable score from PCA (Principal Component Analysis) by using Mean, Standard Deviation and Coefficient value from training data. Finally, the combined variances of five columns were selected. If the combined variance is higher than a threshold, the algorithm will judge the driver state to normal state. But, if it is less than the threshold, the algorithm will judge the driver state to the fatigue state. Start Receive data from sensor Data Normalization Use Principal Component Analysis Calculate Variances Variances > Threshold Normal State Fatigue State Yes No Figure 13. The proposed algorithm to identification driving state. IV. EXPERIMENT AND RESULT For driving fatigue detection from eyes movement, we implemented all of the algorithms and tested in Microsoft Visual Studio 2010 in Windows 8 working on Computer with AMD A10 CPU and 8 GB RAM. Video was captured from Logitech Webcam Pro9000 and using OpenCV as an image processing and computer vision library. To validate our system, we made experiments using 10 users at same location to evaluate the performance of the proposed system. First, we set up Logitech Webcam Pro9000 to Computer as shown in Fig. 14. Next, we set the user position is sitting in front of a computer screen as shown in Fig. 15 and then we detected eye blink from user by using our proposed algorithm and use driving simulation video to test and we use time interval to collect eye blink data for 60s. While collecting data we have observers to collect data of eye blink from looking with the eyes for comparing the results from our proposed algorithm and results from observers to calculate the accuracy of algorithm. Fig. 16 illustrates the experiment setup. Figure 14. Set up logitech webcam Pro9000 to computer Figure 15. Set up user position Figure 16. The experiment setup and observers Fig. 17 shows the time intervals when there was detected closing and opening of eye in a test video for 60s. Such moments are shown as peaks. The final result of blink detection is shown in Fig. 18 that can be calculated from (1), where high value represents the time interval when the eye was detected closed and low when detected opened. The duration of eye blink can be calculated as well. During the video capturing there were done 21 blinks, one of which between 21s and 25s has a blink lasted 4s. V-Value 37 Journal of Automation and Control Engineering Vol. 4, No. 1, February 2016 ©2016 Journal of Automation and Control Engineering Figure 17. The time intervals when there was detected closing and opening Figure 18. Detected blinks The result of eye blink detection in the same location and driving simulation video are illustrated in Table I, We show the accuracy rates of our proposed eye blink detection methods. TABLE I. THE RESULTS OF EYE BLINK DETECTION User Blink Rate from algorithm (Number/minute) Blink Rate from Observer (Number/minute) Accuracy (%) 1 15 16 93.75 2 12 14 85.72 3 14 17 82.36 4 15 18 83.34 5 19 21 90.48 6 13 14 92.86 7 13 15 86.67 8 10 11 90.91 9 11 13 84.62 10 12 12 100 The algorithm for driving fatigue detection from driving behavior were implemented and tested on Computer with AMD A10 CPU and 8 GB RAM and MCU (Freeduino V1.16 Board) to get data from sensor. The experiment was performed by setting the resistive sensor to pedal, FreeIMU on console and Computer for getting data to analyze when we drive in real situation. The drivers were asked to acts as normal and sleepy. The driver states were assumed include following states i) Normal state, ii) Fatigue state. Fig. 19 shows the system installation. The final result of the driving behavior is shown in Table II. We can calculate variances from variable scores in PCA, and then the driver state was determined by thresholding the sum of variances. Figure 19. All of device position TABLE II. THE RESULTS OF DRIVING BEHAVIOR Variances (Normal State) Variances (Fatigue State) 6.761058 1.424458 8.368608 0.889508 4.883198 3.318376 13.5185 4.582522 5.736565 1.942485 3.963947 1.74425 7.718399 6.460666 2.907499 2.500966 11.67473 2.02656 11.40921 2.383842 The driver state was determined by comparing the data from Table II with threshold value. The appropriate threshold value was set to 5, so, we have 3 values in normal state of Table II that value less than 5 are value in row 3, 6 and 8. The reason for this error is because it was the time period while the car was waiting for a traffic light or traffic jams. V. DISCUSSION AND CONCLUSION In this paper, we proposed an algorithm to detect driving fatigue, which consist of two parts: driving fatigue detection from eyes movement and driving fatigue detection from driving behavior. For the fatigue detection from eye blinks, the algorithm detects eye blinks, calculates the blink rate, and the duration time. We performed an experiment using a video-based method. The results showed that our algorithm can work efficiently in nearly real-time, because our algorithm has high frame rate processing of approximately 20 fps. We compared the output from the algorithm with the blinks observed from a human observer. The results provide the average accuracy of approximately 89%. 38 Journal of Automation and Control Engineering Vol. 4, No. 1, February 2016 ©2016 Journal of Automation and Control Engineering According to the results, the graph analysis on ten sets of 1-minute samples show that the typical blink of human contains alternating inter-blink periods of shorter and longer durations depend on the driver’s state. Although the results show that our method works well for the images taken under controlled environments and changes of illumination in less quantity, some issues are discussed below 1. The algorithm may be failed to detect eye blink when the rotation of the driver’s head is over 30 degrees. Therefore, the installation of the camera is suggested to be in the front of the driver to prevent such a problem. 2. When illumination of the face has changed in large quantity, it causes the face and eyes area to become dark. The detection of eye blinks may fail and causes an error in the count of blinks. For the fatigue detection from driving behavior, the experiment and results showed that our algorithm can effectively classify and analyze the driving behavior. However the results show that our method cannot work well under situations where traffic jam or waiting for traffic light for a long time. For the solution to improve the accuracy of the algorithm can be achieved by increasing the duration of data storage but the disadvantage of this solution is the algorithm will use a long time before it can measure the driver’s state. This is the main reason why both methods have to be combined in order to support each other. ACKNOWLEDGMENTS This work was supported by the Higher Education Research Promotion and National Research University Project of Thailand, Office of the Higher Education Commission. REFERENCES [1] Q. Wu, B. X. Sun, B. Xie, and J. J. Zhao, “A perclos-based driver fatigue recognition application for smart vehicle space,” in Proc. 2010 Third International Symposium on Information Processing (ISIP), 2010, pp. 437–441. [2] B. Alshaqaqi, A. S. Baquhaizel, M. E. Amine UOIS, M. Boumehed, A. Ouamri, and M. Keche, “Driver drowsiness detection system,” in Proc. 2013 8th International Workshop on Systems, Signal Processing and Their Applications (WoSSPA), 2013, pp. 151-155. [3] Y. Kurylyak, F. Lamonaca, and G. Mirabelli, “Detection of the eye blinks for human’s fatigue monitoring,” in 2012 IEEE International Symposium on Medical Measurements and Applications Proceedings (MeMeA), 2012, pp. 1-4. [4] W. S. Wijesoma, K. R. S. Kodagoda, and A. P. Balasuriya, “Road- boundary detection and tracking using ladar sensing,” IEEE Transactions on Robotics and Automation, vol. 20, no. 3, June 2004. [5] H. L. Wang, H. H. Liu, and Z. M. Song, “Fatigue driving detection system design based on driving behavior,” in Proc. 2010 International Conference on Optoelectronics and Image Processing (ICOIP), pp. 549 – 552. [6] T. C. Chieh, M. M. Mustafa, A. Hussain, E. Zahedi, and B. Y. Majlis, "Driver fatigue detection using steering grip force," in Proc. Student Conf. on Research and Development (SCORED 2003), Aug. 2003, pp. 45-48. [7] M. A. Li, C. Zhang, and J. F. Yang, “An EEG-based method for detecting drowsy driving state,” in Proc. 2010 Seventh International Conference on Fuzzy Systems and Knowledge Discovery (FSKD), 2010, pp. 2164-2167. [8] J. J. Wang, W. Xu, and Y. H. Gong, “Real-time driving danger- level prediction,” Engineering Applications of Artificial Intelligence, pp. 1247–1254, 2010. Wasan Tansakul received his B.Eng. Degree in Control System and Instrumentation Engineering from King Mongkut’s University of Technology Thonburi, Bangkok, Thailand in 2012, where he is currently a Master’s student. His research topic involves improvement of a driver fatigue detection device. Poj Tangamchit received his Ph.D. degree in Electrical and Computer Eng. (2003) from Carnegie Mellon University, USA. He is currently an associate professor at the department of Control System and Instrumentation Engineering at King Mongkut’s University of Technology Thonburi, Bangkok, Thailand. His research involves AI, robotics, and ITS. 39 Journal of Automation and Control Engineering Vol. 4, No. 1, February 2016 ©2016 Journal of Automation and Control Engineering

Các file đính kèm theo tài liệu này:

  • pdffatigue_driver_detection_system_using_a_combination_of_blink.pdf