[go: up one dir, main page]
More Web Proxy on the site http://driver.im/
Next Article in Journal
A Deadline-Aware Scheduling and Forwarding Scheme in Wireless Sensor Networks
Previous Article in Journal
Characterizations and Electrical Modelling of Sensory Samples Formed from Synthesized Vanadium (V) Oxide and Copper Oxide Graphene Quantum Tunneling Composites (GQTC) Applied in Electrotribology
You seem to have javascript disabled. Please note that many of the page functionalities won't work as expected without javascript enabled.
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Article

Estimation of Gaze Detection Accuracy Using the Calibration Information-Based Fuzzy System

Division of Electronics and Electrical Engineering, Dongguk University, 30, Pildong-ro 1-gil, Jung-gu, Seoul 100-715, Korea
*
Author to whom correspondence should be addressed.
Sensors 2016, 16(1), 60; https://doi.org/10.3390/s16010060
Submission received: 27 November 2015 / Revised: 30 December 2015 / Accepted: 31 December 2015 / Published: 5 January 2016
(This article belongs to the Section Physical Sensors)
Figure 1
<p>Flowchart of user calibration-information based gaze tracking estimation system.</p> ">
Figure 2
<p>Pupil center region detection process: (<b>a</b>) eye detection result based on corneal specular reflection from the original image, (<b>b</b>) eye region detected from the original image; (<b>c</b>) application of histogram stretching to the image of (b); (<b>d</b>) application of binarization to the image of (c); (<b>e</b>) application of morphology calculation to the image of (d); (<b>f</b>) application of component labeling to the image of (e); (<b>g</b>) application of canny edge detection to the image of (f); (<b>h</b>) application of a convex hull to the image of (g); (<b>i</b>) image that has binarized the reflection with the image of (c); (<b>j</b>) image that has removed the overlapped parts of (h,i) from the image of (h); (<b>k</b>) application of ellipse-fitting algorithm to the image of (j); and (<b>l</b>) the final detection result of the pupil center region.</p> ">
Figure 3
<p>Images of user’s eye region when gazing at nine calibration points on the screen.</p> ">
Figure 4
<p>Corresponding relations of four subregions defined by nine pupil centers and four subregions in a monitor defined using calibration points.</p> ">
Figure 5
<p>Example of correspondence between four pupil centers and four monitor corners when a user is gazing at the four corners of a monitor.</p> ">
Figure 6
<p>Process of estimating the gaze tracking accuracy of the user by applying a fuzzy algorithm.</p> ">
Figure 7
<p>The feature values that can be obtained during the calibration process.</p> ">
Figure 8
<p>Membership functions of calibration-information based gaze accuracy estimation system: (<b>a</b>) input and (<b>b</b>) output membership functions.</p> ">
Figure 9
<p>Example of obtaining an output value when one input value is input into the input membership function.</p> ">
Figure 10
<p>Examples of output value results through various defuzzification methods when an inference value is input: (<b>a</b>) FOM, LOM, MOM, MeOM, and (<b>b</b>) COG.</p> ">
Figure 11
<p>The gaze tracking system and experimental environment used in this study.</p> ">
Figure 12
<p>Various calibration marker types: (<b>a</b>) static and (<b>b</b>) dynamic markers.</p> ">
Figure 13
<p>Marker display methods: (<b>a</b>) sequential and (<b>b</b>) random marker displays.</p> ">
Figure 14
<p>Guiding display method: (<b>a</b>) an expression guiding to the next marker position of the calibration, and (<b>b</b>) an example of a marker’s movement path.</p> ">
Figure 15
<p>Changes to dynamic marker in the guiding display.</p> ">
Figure 16
<p>Results of a circular marker type expressed sequentially: (<b>a</b>) an inaccurate calibration, (<b>b</b>) an error in the gaze tracking accuracy of 1.223°; (<b>c</b>) an accurate calibration; and (<b>d</b>) an error in the gaze tracking accuracy of 0.407°.</p> ">
Figure 16 Cont.
<p>Results of a circular marker type expressed sequentially: (<b>a</b>) an inaccurate calibration, (<b>b</b>) an error in the gaze tracking accuracy of 1.223°; (<b>c</b>) an accurate calibration; and (<b>d</b>) an error in the gaze tracking accuracy of 0.407°.</p> ">
Figure 17
<p>Results of a cross-shaped marker type expressed sequentially: (<b>a</b>) an inaccurate calibration, (<b>b</b>) an error in the gaze tracking accuracy of 1.19°; (<b>c</b>) an accurate calibration; and (<b>d</b>) an error in the gaze tracking accuracy of 0.449°.</p> ">
Figure 17 Cont.
<p>Results of a cross-shaped marker type expressed sequentially: (<b>a</b>) an inaccurate calibration, (<b>b</b>) an error in the gaze tracking accuracy of 1.19°; (<b>c</b>) an accurate calibration; and (<b>d</b>) an error in the gaze tracking accuracy of 0.449°.</p> ">
Figure 18
<p>Results of a gradation marker type expressed sequentially: (<b>a</b>) an inaccurate calibration, (<b>b</b>) an error in the gaze tracking accuracy of 1.107°; (<b>c</b>) an accurate calibration; and (<b>d</b>) an error in the gaze tracking accuracy of 0.487°.</p> ">
Figure 18 Cont.
<p>Results of a gradation marker type expressed sequentially: (<b>a</b>) an inaccurate calibration, (<b>b</b>) an error in the gaze tracking accuracy of 1.107°; (<b>c</b>) an accurate calibration; and (<b>d</b>) an error in the gaze tracking accuracy of 0.487°.</p> ">
Figure 19
<p>The correlation values between the real gaze errors and each method of defuzzification using the Min or Max rule.</p> ">
Figure 20
<p>A <span class="html-italic">t</span>-test between defuzzification methods based on the correlation value ranking of <a href="#sensors-16-00060-f019" class="html-fig">Figure 19</a>: <span class="html-italic">t</span>-test between ranks (<b>a</b>) 1 and 2, (<b>b</b>) 2 and 3; (<b>c</b>) 3 and 4; (<b>d</b>) 4 and 5; (<b>e</b>) 5 and 6; (<b>f</b>) 6 and 7; (<b>g</b>) 7 and 8; (<b>h</b>) 8 and 9; and (<b>i</b>) 9 and 10.</p> ">
Figure 20 Cont.
<p>A <span class="html-italic">t</span>-test between defuzzification methods based on the correlation value ranking of <a href="#sensors-16-00060-f019" class="html-fig">Figure 19</a>: <span class="html-italic">t</span>-test between ranks (<b>a</b>) 1 and 2, (<b>b</b>) 2 and 3; (<b>c</b>) 3 and 4; (<b>d</b>) 4 and 5; (<b>e</b>) 5 and 6; (<b>f</b>) 6 and 7; (<b>g</b>) 7 and 8; (<b>h</b>) 8 and 9; and (<b>i</b>) 9 and 10.</p> ">
Versions Notes

Abstract

:
Gaze tracking is a camera-vision based technology for identifying the location where a user is looking. In general, a calibration process is applied at the initial stage of most gaze tracking systems. This process is necessary to calibrate for the differences in the eyeballs and cornea size of the user, as well as the angle kappa, and to find the relationship between the user’s eye and screen coordinates. It is applied on the basis of the information of the user’s pupil and corneal specular reflection obtained while the user is looking at several predetermined positions on a screen. In previous studies, user calibration was performed using various types of markers and marker display methods. However, studies on estimating the accuracy of gaze detection through the results obtained during the calibration process have yet to be carried out. Therefore, we propose the method for estimating the accuracy of a final gaze tracking system with a near-infrared (NIR) camera by using a fuzzy system based on the user calibration information. Here, the accuracy of the final gaze tracking system ensures the gaze detection accuracy during the testing stage of the gaze tracking system. Experiments were performed using a total of four types of markers and three types of marker display methods. From them, it was found that the proposed method correctly estimated the accuracy of the gaze tracking regardless of the various marker and marker display types applied.

1. Introduction

Studies have been actively carried out to accurately calculate a user’s gaze location based on the movement of their face or eyes [1,2]. In addition, studies are being carried out to apply a user’s gaze location as a more natural and convenient input device replacing a keyboard and mouse, which are commonly used input devices [3,4,5,6,7]. Because it is intuitive, a user’s gaze location can be easily used as an input information without a separate training process. In particular, input devices such as a keyboard, mouse, or remote control, which is commonly used by the disabled who cannot use their hands freely, are difficult to apply properly. Also, even when they can be used, they cannot be conveniently manipulated or precisely controlled.
In general, gaze tracking is a technology for identifying the position on a screen that the user is looking at. In most gaze tracking systems, a user’s gaze position is calculated based on the relative positions of the center of the user’s pupil and the corneal specular reflection. Here, for an accurate gaze tracking system, it is very important to accurately find the pupil center and corneal specular reflection. Along with this, a user calibration process is necessary for the accurate gaze tracking of the user. In general, a calibration process is applied at the initial stage of most gaze tracking systems. This process is necessary to calibrate for the differences in the eyeballs and cornea size of user, as well as the angle kappa, and to find the relationship between the user’s eye and screen coordinates. It is applied on the basis of the information of user’s pupil and corneal specular reflection obtained while the user is looking at several predetermined positions on a screen. Here, if the user’s calibration process is inaccurate, it will be difficult to accurately calculate the gaze position when a gaze tracking system is executed. Therefore, to achieve a gaze tracking system with high accuracy, an accurate user calibration process is as important as the accurate detection of the user’s pupil center and reflection. In other words, if the calibration process is accurate, an accurate gaze tracking can be achieved.
Past studies in this area can be mainly divided into two types: utilizing the estimation model of a user-calibration based gaze tracking result and not utilizing such a model. The latter can be divided into cases applying and not applying a calibration process. For cases using a calibration process, the calibration methods apply static markers, dynamic markers, or a dynamic marker display. For a method not applying a calibration [8], two stereo cameras and five illuminators are applied. In this case, because no calibration process is used, user convenience increases; however, because several cameras and illuminators have to be applied, the system complexity increases, as do the price and system size.
Next, for calibration using static markers, calibration methods applying five or nine points [9], nine calibration points [10,11,12,13,14], a single position calibration [15], and four point calibration [16,17] have been utilized. In general, as the number of reference points for the calibration increases, the gaze tracking error decreases. However, as the calibration points increase in number, the user convenience decreases. In addition, because several calibration points have to be gaze focused, if a single point among several points is not focused, a decrease in the gaze tracking accuracy will occur.
For calibration using dynamic markers and a dynamic display, one such method calibrates while the user’s gaze follows a dynamically moving point [18]. In this method, a moving target appears on the screen and the calibration is conducted as the user’s gaze follows it. This method can prevent an inaccurate calibration by unexpected external disturbances. That is because the user’s concentration is high compared to the use of static markers. However, when the moving path of a calibration marker is so complex that the user cannot predict the movement, the calibration accuracy may decrease because the user’s perceptual response velocity slows down. In addition, when the movements of the marker are complex, the user must spend more time training in advance, thereby leading to a decline in user convenience. In these previous studies, a user calibration was conducted by applying various types of markers and marker display methods. However, there have been no studies conducted on estimating the accuracy of a final gaze tracking system through the results obtained from the above calibration processes. Here, the accuracy of final gaze tracking system means the gaze tracking accuracy during the testing stage of the gaze tracking system. Therefore, in this study, using a fuzzy-based estimation model based on the results obtained during the user calibration, a method for estimating the accuracy of the final gaze tracking system is proposed. Because the accuracy estimation of a gaze tracking system is made possible based on the information obtained during the calibration, a quantitative performance can be determined for various calibration markers and display methods. Compared to conventional studies, the present study is novel in the following three ways.
  • The Euclidean distance is calculated between the user’s calculated gaze and the reference positions obtained during the user calibration. Then, the mean and standard deviations of the Euclidean distances are extracted as the first and second features, respectively. In addition, the change in gaze position for each frame, which is obtained during the user calibration, is extracted as the third feature.
  • Developing a fuzzy system that takes these three features as inputs and the accuracy of the final gaze tracking system as an output, the accuracy of the final gaze tracking system is estimated based on the results obtained during the user calibration.
  • The validity of the proposed fuzzy-based estimation system is verified experimentally using various types of markers such as static and dynamic markers, and various types of marker displays such as sequential, random, and guiding displays.
The advantages and disadvantages of this study compared to conventional studies are shown in Table 1.
Table 1. Comparison of the advantages/disadvantages between previous studies and the proposed method.
Table 1. Comparison of the advantages/disadvantages between previous studies and the proposed method.
CategoriesMethodAdvantageDisadvantage
Not using the estimation model of gaze tracking accuracyNot conducting a user calibrationRequiring two stereo cameras and five light sources [8]User convenience increases because of no calibration processDue to two cameras and multiple illuminators, the system complexity increases, as do the price and system size
Calibration using static markersCalibration by selecting five or nine points [9]As the number of calibration points increases, the gaze tracking accuracy becomes more accurateDecrease in user convenience
Nine calibration points [10,11,12,13,14]Gaze tracking accuracy is affected by the accurate calibration procedure
One point calibration [15]
Four point calibration [16,17]
Calibration using dynamic markers and displayCalibration by following a moving target with the eyes [18]Prevents an inaccurate calibration because the user’s concentration is high compared to the use of static markersWhen the movement line of the calibration marker is so complex that it cannot be predicted by the user, the calibration accuracy decreases
When the movements are complex, the user convenience decreases
Using the estimation model of gaze tracking accuracyGaze tracking accuracy can be estimated using fuzzy system based on the user calibration information from various calibration methods using static, dynamic markers and displayThe performance of gaze tracking system can be quantitatively predicted for various calibration markers and display methodsThe design of an additional fuzzy rule table and the membership function is necessary
(proposed method)
The remainder of this paper is organized as follows. In Section 2, the calibration-based estimation method of gaze tracking is described. In Section 3, the experimental results with various calibration methods and an analysis of these methods are provided. In Section 4, some concluding remarks and the direction for a follow-up study are given.

2. Proposed Method for Estimating the Accuracy of Gaze Tracking System

2.1. Detection of User’s Pupil Center and Corneal Specular Reflection, and Calculation of Gaze Position

Figure 1 shows a flowchart of the user calibration-information based gaze tracking estimation system proposed in this study. We refer to the previous research [19] for detecting the centers of pupils and corneal specular reflection.

2.1.1. Pupil Center Region Detection Process

The rough corneal specular reflection of the user is detected based on the bright pixel values in the image. Based on this reflection, the eye region of the user is detected, as shown in Figure 1 step (1) and Figure 2b. The image in Figure 2c is a result of applying a histogram stretching calculation to the image of Figure 2b to obtain a binarization result for a clearer distinction. The image in Figure 2d is a result of applying a binarization calculation to the image in Figure 2c. The image in Figure 2e is a result of removing small noises by applying a morphology calculation to the image in Figure 2d. The image in Figure 2f is a result of leaving only the image of the pupil shape by applying a component labeling to the image in Figure 2e. As shown in the image of Figure 2g, the edge of the pupil shape was detected by applying canny edge detection to the image in Figure 2f. In addition, applying a convex hull method [20,21,22] to the image in Figure 2g, the image in Figure 2h shows the result of compensating the pupil part damaged from the reflection occurring on the pupil. The image in Figure 2i is a binarized version of the image in Figure 2c centering on the reflection. Figure 2j shows an image, in which the overlapped part of Figure 2i,h images is removed from the image of Figure 2h. In the image in Figure 2j, because the pupil boundary and the corneal specular reflection boundary are touching each other, a concave portion is detected during the pupil boundary detection. Then, a shape different from the real pupil boundary is detected. To resolve this, we remove the overlapped parts in Figure 2h,i from the image in Figure 2h. Then, the pupil boundary that has removed the touching part can be detected, as shown in the image in Figure 2j. Figure 2k shows the detection of the final pupil boundary by applying an ellipse-fitting algorithm using the image in Figure 2j. Figure 2l shows the final resulting image.
Figure 1. Flowchart of user calibration-information based gaze tracking estimation system.
Figure 1. Flowchart of user calibration-information based gaze tracking estimation system.
Sensors 16 00060 g001
Based on the detected position of the pupil center, the searching area for detecting corneal specular reflection is defined. Then, the center of corneal specular reflection is located based on binarization and calculating the geometric center within this area.

2.1.2. Calculating the User’s Gaze Position

The gaze position of the user is calculated using the detected pupil center and reflection center coordinates. To compensate the differences in each person’s eyeball and cornea size, as well as the angle kappa, and to find the relationship between the user’s eye and screen coordinates, the calibration process is conducted before the gaze position is calculated. The gaze position is calculated using several geometric transform matrices obtained through the calibration process [19]. When nine reference points are gazed at during the calibration, by using each of the nine pupil center positions obtained as shown in Figure 3, the relationship between the screen and pupil center can be expressed as in Figure 4. As Figure 4 illustrates, when the user is looking at the nine calibration points, the pupil image plane can be mainly divided into four subregions by using the center position of the pupil. Each of the four pupil subregions can be mapped to four monitor subregions, which are divided into the nine calibration points of the monitor image plane. In addition, a geometric transform matrix corresponding to each subregion is obtained and used [19,23]. For example, pupil subregion 3 can be mapped into monitor subregion 3, and here, matrix 3 is used as shown in Figure 4.
Figure 2. Pupil center region detection process: (a) eye detection result based on corneal specular reflection from the original image, (b) eye region detected from the original image; (c) application of histogram stretching to the image of (b); (d) application of binarization to the image of (c); (e) application of morphology calculation to the image of (d); (f) application of component labeling to the image of (e); (g) application of canny edge detection to the image of (f); (h) application of a convex hull to the image of (g); (i) image that has binarized the reflection with the image of (c); (j) image that has removed the overlapped parts of (h,i) from the image of (h); (k) application of ellipse-fitting algorithm to the image of (j); and (l) the final detection result of the pupil center region.
Figure 2. Pupil center region detection process: (a) eye detection result based on corneal specular reflection from the original image, (b) eye region detected from the original image; (c) application of histogram stretching to the image of (b); (d) application of binarization to the image of (c); (e) application of morphology calculation to the image of (d); (f) application of component labeling to the image of (e); (g) application of canny edge detection to the image of (f); (h) application of a convex hull to the image of (g); (i) image that has binarized the reflection with the image of (c); (j) image that has removed the overlapped parts of (h,i) from the image of (h); (k) application of ellipse-fitting algorithm to the image of (j); and (l) the final detection result of the pupil center region.
Sensors 16 00060 g002
Figure 3. Images of user’s eye region when gazing at nine calibration points on the screen.
Figure 3. Images of user’s eye region when gazing at nine calibration points on the screen.
Sensors 16 00060 g003
When calculating the user’s gaze position, if the user’s pupil center exists at pupil subregion 2 (P2P3P6P5), the user’s gaze position is calculated using matrix 2 among the four geometric transforms. Here, the gaze position is calculated through the processes in Equations (1) and (2) [19]. Figure 5 shows the example of correspondence between four pupil centers and four monitor corners when a user is gazing at the four corners of a monitor.
[ M x 0 M x 1 M x 2 M x 3 M y 0 M y 1 M y 2 M y 3 ] = [ a b c d e f g h ] [ P x 0 P x 1 P x 2 P x 3 P y 0 P y 1 P y 2 P y 3 P x 0 P yo P x 1 P y 1 P x 2 P y 2 P x 3 P y 3 1 1 1 1 ]
[ M x M y ] = [ a b c d e f g h ] [ P x P y P x P y 1 ]
Figure 4. Corresponding relations of four subregions defined by nine pupil centers and four subregions in a monitor defined using calibration points.
Figure 4. Corresponding relations of four subregions defined by nine pupil centers and four subregions in a monitor defined using calibration points.
Sensors 16 00060 g004
Figure 5. Example of correspondence between four pupil centers and four monitor corners when a user is gazing at the four corners of a monitor.
Figure 5. Example of correspondence between four pupil centers and four monitor corners when a user is gazing at the four corners of a monitor.
Sensors 16 00060 g005

2.2. User’s Gaze Tracking Estimation Using a Fuzzy System

2.2.1. Three Features for the Inputs of Fuzzy System, and Fuzzy Membership Function with Rule Table

In this study, a method for estimating a user’s gaze tracking accuracy is proposed using a fuzzy system based on information obtained during the calibration process. As shown in Figure 6, the gaze tracking accuracy of the user is estimated based on the fuzzy algorithm by using three feature values of the user, which can be obtained during the calibration process.
Figure 6. Process of estimating the gaze tracking accuracy of the user by applying a fuzzy algorithm.
Figure 6. Process of estimating the gaze tracking accuracy of the user by applying a fuzzy algorithm.
Sensors 16 00060 g006
Among the eye features of the user that can be obtained during the calibration process, the following three feature values were utilized. In Figure 7, the Euclidean distances are calculated between the reference points that have to be looked at during the calibration, and the positions that the user is actually gazing at. Then, Feature 1 (F1) indicates the mean value of the Euclidean distances. Feature 2 (F2) indicates the standard deviation of the Euclidean distances. Feature 3 (F3) indicates the amount of gaze position movement of the user between the previous and current image frames.
Figure 7. The feature values that can be obtained during the calibration process.
Figure 7. The feature values that can be obtained during the calibration process.
Sensors 16 00060 g007
With respect to the use of the fuzzy algorithm, the design of the membership function is a very important factor. Figure 8 shows the input/output membership function configuration of the feature values. As shown in Figure 8, a linear member function or triangular membership function is most commonly used because the system’s calculation speed is fast and the complexity of the codes can be relatively reduced [24,25,26]. Features 1–3 described above each show different values, and the range of each feature value is different. Furthermore, depending on the user’s calibration result, the ranges of Features 1–3 change irregularly. Therefore, each feature value was normalized with a value of zero to 1, as shown in Figure 8. The fuzzy membership functions can be mainly divided into two types. As shown in Figure 8a, an input membership function having low (L) and high (H) values was designed. In addition, as shown in Figure 8b, an output membership function having low (L), middle (M), and high (H) values was designed.
Furthermore, a fuzzy rule table (Table 2) was designed. For example, if the mean and standard deviation values are small for the Euclidean distance values between the reference and user’s gaze positions, and if the amount of gaze movement of the user is small between image frames, it can be regarded that the error of the user’s gaze position is also small. In other words, if the values of Features 1–3 are L, then the error value of the gaze tracking can be estimated to be L as well. If the values of Features 1–3 are high (H), then the error value of the gaze tracking can be also estimated to be high (H).
Figure 8. Membership functions of calibration-information based gaze accuracy estimation system: (a) input and (b) output membership functions.
Figure 8. Membership functions of calibration-information based gaze accuracy estimation system: (a) input and (b) output membership functions.
Sensors 16 00060 g008
Table 2. Fuzzy rule table.
Table 2. Fuzzy rule table.
Feature 1Feature 2Feature 3Output
LLLL
HL
HLL
HM
HLLM
HH
HLH
HH

2.2.2. Obtaining the Output of Fuzzy System Using Defuzzification Methods

In general, an output value of the fuzzy system can be obtained through the output fuzzy membership function and the fuzzy rule. The input function in Figure 8a has two output values and one input value (Fi). In other words, because there are three input feature values, there are a total of eight output values.
For example, as can be seen in Figure 9, the input value of 0.8 has output values of 0.2(L) and 0.8(H). These two output values are because of Feature 1, but also apply to Features 2 and 3. This means that there are three pairs of output values, {0.2 (L), 0.8 (H)}. Based on these three pairs of output values, eight combinations can be obtained: {0.2(L), 0.2(L), 0.2(L)}, {0.2(L), 0.2(L), 0.8(H)}, {0.2(L), 0.8(H), 0.2(L)} … {0.8(H), 0.8(H), 0.8(H)}. Whenever a single pair of combination values is elicited, one of the values can be determined from (0.2, 0.8) and (L, M, H) through the Min rule, Max rule, and fuzzy rule table [27]. For example, when there is a combination of {0.2(L), 0.8(H), 0.8(H)}, a value of 0.2 can be determined by the Min rule. In addition, in Table 2, because the output value is M when Feature 1 is L and Features 2 and 3 are H, the value of M can also be determined by the fuzzy rule. That is, from the values of {0.2(L), 0.8(H), 0.8(H)}, an inference value of 0.2(M) can be obtained by the Min and fuzzy rules. If the Max rule is used, an inference value of 0.8(M) can be obtained. As mentioned above, because there are a total of eight combinations, the number of inference values is also eight in total.
Figure 9. Example of obtaining an output value when one input value is input into the input membership function.
Figure 9. Example of obtaining an output value when one input value is input into the input membership function.
Sensors 16 00060 g009
In Figure 10a, several output values can be obtained using one inference value. For example, when the inference value is 0.71(M), the output values O2, O3, and O4 can be obtained. From these several output values, using a defuzzification method, one final output value can be determined [28,29]. This output value is used as the accuracy estimation score of the gaze tracking system.
Conventionally, various defuzzification methods exist, and the performances of five methods were compared: First of Maxima (FOM), Last of Maxima (LOM), Middle of Maxima (MOM), Mean of Maxima (MeOM), and Center of Gravity (COG) [28,29]. FOM selects the first value in the output values calculated with the largest value among the inference values obtained. LOM selects the last value in the output values calculated with the largest value among the inference values obtained. MOM selects the median of the first and last values from the output values calculated with the largest value among the inference values obtained [28]. MeOM selects the mean of the output values calculated with the largest value among the inference values obtained. The final output values obtained according to each method in Figure 10a,b are O2 for FOM, O4 for LOM, ((O2 + O4)/2) for MOM, ((O2 + O3 + O4)/3) for MeOM, and O5 for COG. COG is determined through the mass center point of the region expressed with the slashes shown in Figure 10b.
Figure 10. Examples of output value results through various defuzzification methods when an inference value is input: (a) FOM, LOM, MOM, MeOM, and (b) COG.
Figure 10. Examples of output value results through various defuzzification methods when an inference value is input: (a) FOM, LOM, MOM, MeOM, and (b) COG.
Sensors 16 00060 g010

3. Experiment Results and Discussion

Figure 11 shows the experimental environment used in this study. For the experiment, a desktop computer containing a 3.5-GHz Intel® core™ i7-3770K CPU and 8 GB of RAM was used. The monitor resolution was 1280 × 1024. For the camera, a 700-nm long pass filter (Kodak Wratten Filter No. 89B, Rochester, NY, USA [30]) and a zoom lens were mounted on a webcam (Logitech C600, Lausanne, Switzerland [31]) having a universal serial bus (USB) interface. In addition, an 850-nm reference illuminator was used in an 8 × 8 array. The camera was positioned right below the center of the monitor, and the illuminator was also positioned below the camera. The distance between the monitor and user was roughly 75 cm. Our program was implemented using a Microsoft foundation class based C++ program, DirectX 9.0 SDK, and OpenCV in a Microsoft Visual Studio C++ 2010 development environment.
Figure 11. The gaze tracking system and experimental environment used in this study.
Figure 11. The gaze tracking system and experimental environment used in this study.
Sensors 16 00060 g011
The calibration was carried out according to each marker type and display method described in Section 3.1. The gaze position accuracy of the user was measured for each calibration. The experiment was repeated four times for each test subject and a total of seven calibration methods. A total of 15 test subjects were used.

3.1. Various Calibration Marker Types and Display Methods

In this paper, various calibration marker types and display methods are proposed to check the validity of the user-calibration based gaze tracking estimation model. As shown in Figure 1, the calibration marker types are classified into two types: static marker and dynamic marker types.
Among the commonly used calibration markers, Figure 12a shows the static markers of a circle shape and a cross. Figure 12b shows a dynamic marker with a dynamically changing shape, i.e., the color is becoming darker gradually as the shape of the marker decreases from a large circle to a small circle in the actual system. In addition, using each marker, the calibration was performed with different display methods. The marker display methods include a commonly used sequential display method shown in Figure 13a, and a random display method shown in Figure 13b. In addition, they include the method of dynamically guiding to the next display position of the calibration marker, named as guiding display method, shown in Figure 14.
In Figure 13, the red dot is a calibration point that the user has to gaze at, and, in the next step, the calibration finishes with point represented by a white color.
In Figure 14, a dynamic marker is used, and the marker shape changes step by step, as shown in Figure 15. At first, the marker is expressed as shown in the leftmost image of Figure 15, and afterward, the marker changes as shown in the images on the right-hand side. As shown in the second image from the left in Figure 15, the marker is divided into four points and disappears. And, as shown in the third image from the left in Figure 15, at the moment of calibration it blinks as a white dot. Afterward, as shown in the rightmost image of Figure 15, it is changed to an orange dot, and while moving to the next calibration point, it is increased to the marker size shown in the leftmost image of Figure 15. As the marker shape changes in this manner, the calibration is performed at a total of nine positions, as shown in the sequence in Figure 14.
Figure 12. Various calibration marker types: (a) static and (b) dynamic markers.
Figure 12. Various calibration marker types: (a) static and (b) dynamic markers.
Sensors 16 00060 g012
Figure 13. Marker display methods: (a) sequential and (b) random marker displays.
Figure 13. Marker display methods: (a) sequential and (b) random marker displays.
Sensors 16 00060 g013
Figure 14. Guiding display method: (a) an expression guiding to the next marker position of the calibration, and (b) an example of a marker’s movement path.
Figure 14. Guiding display method: (a) an expression guiding to the next marker position of the calibration, and (b) an example of a marker’s movement path.
Sensors 16 00060 g014
Figure 15. Changes to dynamic marker in the guiding display.
Figure 15. Changes to dynamic marker in the guiding display.
Sensors 16 00060 g015

3.2. Calibration Results and Gaze Detection Accuracy

In this section, we show the user calibration results and gaze tracking accuracy. In Figure 16, Figure 17 and Figure 18, the blue and green dots of (a,c) mark the gaze coordinates of both eyes during the user calibration. The red circles represent the regions that have to be looked at. As shown in (a,c) of Figure 16, Figure 17 and Figure 18, when the calibration gaze coordinates are concentrated in regions that have to be looked at during the calibration, the error in the gaze tracking accuracy of the users is small, as shown in (b,d). Based on this, it can be seen that the accuracy levels during the user calibration and gaze tracking are related. At the same time, it is confirmed that the gaze tracking estimation model can be obtained using the proposed three features. The first and second features are respectively the mean and standard deviations of the Euclidean distances between the user’s calculated gaze and the reference positions obtained during the user calibration. The third one is the amount of gaze movement between the previous and current image frames.
Figure 16. Results of a circular marker type expressed sequentially: (a) an inaccurate calibration, (b) an error in the gaze tracking accuracy of 1.223°; (c) an accurate calibration; and (d) an error in the gaze tracking accuracy of 0.407°.
Figure 16. Results of a circular marker type expressed sequentially: (a) an inaccurate calibration, (b) an error in the gaze tracking accuracy of 1.223°; (c) an accurate calibration; and (d) an error in the gaze tracking accuracy of 0.407°.
Sensors 16 00060 g016aSensors 16 00060 g016b

3.3. Estimation Analysis of Fuzzy Algorithm for User Gaze Tracking Accuracy Using Calibration Information

In this study, a method for estimating the user’s gaze tracking accuracy was proposed by applying a fuzzy algorithm to three feature values obtained during the user calibration. From Table 3, the gaze tracing accuracy estimation results can be confirmed according to the fuzzy system’s Min and Max rules and various defuzzification methods. In the results shown in Table 3, it was found that the estimation value of the fuzzy system obtained when the Min rule and COG were used had the highest correlation with the size of the real gaze error. In other words, when the estimation of the fuzzy system was small, the real gaze error was small. In addition, when the estimation of the fuzzy system was large, the real gaze error was large.
Figure 17. Results of a cross-shaped marker type expressed sequentially: (a) an inaccurate calibration, (b) an error in the gaze tracking accuracy of 1.19°; (c) an accurate calibration; and (d) an error in the gaze tracking accuracy of 0.449°.
Figure 17. Results of a cross-shaped marker type expressed sequentially: (a) an inaccurate calibration, (b) an error in the gaze tracking accuracy of 1.19°; (c) an accurate calibration; and (d) an error in the gaze tracking accuracy of 0.449°.
Sensors 16 00060 g017aSensors 16 00060 g017b
Figure 18. Results of a gradation marker type expressed sequentially: (a) an inaccurate calibration, (b) an error in the gaze tracking accuracy of 1.107°; (c) an accurate calibration; and (d) an error in the gaze tracking accuracy of 0.487°.
Figure 18. Results of a gradation marker type expressed sequentially: (a) an inaccurate calibration, (b) an error in the gaze tracking accuracy of 1.107°; (c) an accurate calibration; and (d) an error in the gaze tracking accuracy of 0.487°.
Sensors 16 00060 g018aSensors 16 00060 g018b
Table 3. Estimation results of gaze tracking accuracy according to the marker type and display method (Seq.: Sequential display, Rand.: Random display).
Table 3. Estimation results of gaze tracking accuracy according to the marker type and display method (Seq.: Sequential display, Rand.: Random display).
Display MethodSeq.Rand.MovingSeq.Rand.Seq.Rand.
Marker TypeCrossCrossCircleGradationGradationCircle
Real Gaze Error (°)0.63630.67420.6840.75270.76970.83710.8498
Fuzzy systemMin ruleFOM0.2550.22990.39180.37080.44610.44080.1399
MOM0.2550.27680.40860.43320.27630.32710.1488
LOM0.2550.32370.42540.49570.34220.31430.1576
MeOM0.19480.19910.26220.26710.57370.57960.1259
COG0.37640.41770.46880.48590.30180.74110.3198
Max ruleFOM0.11070.12310.14510.11060.44380.24460.0931
MOM0.53570.52780.50320.52240.41650.45180.4136
LOM0.96070.93240.86130.93410.26920.28540.7341
MeOM0.31220.30320.31240.32010.4640.61090.2228
COG0.50020.50020.49910.50020.50060.34330.4988
To find the correlation between the real gaze error and each method of defuzzification with the Min or Max rule, the correlation, gradient, and R2 values were calculated, as shown in Table 4. The range in correlation values was −1 to 1, indicating a negative or positive correlation among the real data. A correlation value of zero indicates that there is no correlation between two sets of data. As shown in Table 4 and Figure 19, when the Min rule and COG were used, the correlation value was the highest between the real gaze error data and the fuzzy system’s output estimation value.
Most of the two-dimensional data can be expressed through a linear fitted line, which can express the distribution, and can be calculated using the gradient and R2. Here, R2 shows reliability between the data distribution and a linear line. Its value increases as the data are distributed closer to the linear fitted line [32]. As shown in Table 4, when the COG of the Min rule was used, the gradient was closest to 1 and the value of R2 was the largest. Based on these results, it was found that using the COG method of the Min rule is best when a user is estimating a gaze error.
Table 4. The correlations between the real gaze tracking errors and the estimation values for each method of defuzzification using the Min or Max rule.
Table 4. The correlations between the real gaze tracking errors and the estimation values for each method of defuzzification using the Min or Max rule.
MethodCorrelation ValueGradientR2
Fuzzy systemMin ruleFOM0.10930.51770.068
MOM0.17650.80360.1307
LOM0.1580.72690.1464
MeOM0.17560.57750.0776
COG0.51841.57710.2593
Max ruleFOM−0.1841−0.38510.1827
MOM0.14810.33750.0784
LOM0.03930.28430.0078
MeOM0.18720.84160.1558
COG−0.01340.08480.0963
Figure 19. The correlation values between the real gaze errors and each method of defuzzification using the Min or Max rule.
Figure 19. The correlation values between the real gaze errors and each method of defuzzification using the Min or Max rule.
Sensors 16 00060 g019
The following is a statistical analysis of the differences between correlation values according to the correlation value ranking and each method of defuzzification using the Min or Max rule.
As shown in Table 4 and Figure 19, the difference between the COG of the Min rule and MeOM of the Max rule, which ranked 1 and 2 on the basis of the correlation values, respectively, was checked through a t-test [33]. This is a statistical hypothesis test commonly used in statistical analysis. When the t-test was performed using two independent samples, the COG of the Min rule and MeOM of the max rule, the calculated p-value was 0.0347, which was smaller than the 95% (0.05) significance level. That is, because the null-hypothesis that there is no difference between two correlation values is rejected, it indicates that there is a significant difference in the correlation values between the two groups, i.e., the COG of the Min rule and the MeOM of the Max rule. This shows that, to estimate the gaze error of the user, it is appropriate to use the COG of the Min rule, which has the top ranking correlation value among the defuzzification methods. As shown in Figure 20b–i, in all other cases of the ranked correlation values, i.e., the No. 2 and 3 through No. 9 and 10 rankings, the p-value was larger than 0.05, which does not show a statistically significant difference.
Figure 20. A t-test between defuzzification methods based on the correlation value ranking of Figure 19: t-test between ranks (a) 1 and 2, (b) 2 and 3; (c) 3 and 4; (d) 4 and 5; (e) 5 and 6; (f) 6 and 7; (g) 7 and 8; (h) 8 and 9; and (i) 9 and 10.
Figure 20. A t-test between defuzzification methods based on the correlation value ranking of Figure 19: t-test between ranks (a) 1 and 2, (b) 2 and 3; (c) 3 and 4; (d) 4 and 5; (e) 5 and 6; (f) 6 and 7; (g) 7 and 8; (h) 8 and 9; and (i) 9 and 10.
Sensors 16 00060 g020aSensors 16 00060 g020b
If the null-hypothesis between the samples is determined using the p-value through a t-test, the size of the difference between the two groups can be shown using the size of the effect. This can be defined as Cohen’s d [34]. Cohen’s d is considered as small at around 0.2–0.3, medium at around 0.5, and large at 0.8 or higher. For example, in Table 5, in the case of the COG of the Min rule and MeOM of the Max rule, Cohen’s d is 1.2425. Through this, it can be stated that the difference in the correlation values is very large between the COG of the Min rule and MeOM of the Max rule, to the point of having a large effect size. It can be seen from the p-value and Cohen’s d that the difference is large between the COG of the Min rule and MeOM of the Max rule, which have No. 1 and 2 ranked correlation values, respectively. Through this, when estimating the gaze position error of the user, it was found to be most appropriate to use the COG method of the Min rule.
Table 5. Cohen’s d and effect size calculated between each fuzzy method sequentially according to the correlation value rankings.
Table 5. Cohen’s d and effect size calculated between each fuzzy method sequentially according to the correlation value rankings.
Defuzzification Methods with Min or Max Rulep-ValueCohen’s dEffect Size
min_COG vs. max_MeOM0.03471.2425Large
max_MeOM vs. min_MOM0.95280.0301Small
min_MOM vs. min_MeOM0.99540.003Small
min_MeOM vs. min_LOM0.90590.0604Small
min_LOM vs. max_MOM0.94880.0328Small
max_MOM vs. min_FOM0.75130.1616Small
min_FOM vs. max_LOM0.45840.3895Small
max_LOM vs. max_COG0.65450.2324Small
max_COG vs. max_FOM0.3550.4796Medium

4. Conclusions

In this study, a fuzzy-based estimation model was proposed to measure the accuracy of a gaze tracking system based on the user’s calibration information. The accuracy of the gaze tracking system was estimated based on three types of feature values. The first and second features are respectively the mean and standard deviations of the Euclidean distances between the reference and user’s gaze positions during the calibration. The third one is the amount of movement in the user’s gaze position between the previous and current images. Experiments on the accuracy of various gaze tracking methods were conducted using four types of markers and three types of marker display methods during calibration. Through them, the validity of a fuzzy-based estimation system was verified using the feature values and results according to each calibration method. Through the experimental results of this study, the correlation, gradient, and R2 were calculated between the real gaze errors and each defuzzification method using the Min or Max rule. From them, the validity of the fuzzy-based gaze error estimation system was proven. In addition, by calculating a t-test and Cohen’s d between the defuzzification methods using the Min or Max rule, it was shown that the COG method of the Min rule was the most appropriate.
In the future, a follow-up study will be carried out on the estimation of gaze tracking accuracy based on a neuro-fuzzy system. In addition, the convenience of various calibration methods will be measured through user brainwaves, as well as through a subjective evaluation.

Acknowledgments

This research was supported by Basic Science Research Program through the National Research Foundation of Korea (NRF) funded by the Ministry of Education (NRF-2015R1D1A1A01056761), and in part by Business for Developing the Technologies for Foundation and Growth funded Korea Small and Medium Business Administration in 2015 (Grants No. S2320066).

Author Contributions

S.Y. Gwon and K.R. Park designed the overall system for estimating the accuracy of gaze tracking system based on fuzzy method. In addition, they wrote and revised the paper. D. Jung and W. Pan implemented the calibration algorithm, and helped the experiments.

Conflicts of Interest

The authors declare no conflicts of interest.

References

  1. Murphy-Chutorian, E.; Trivedi, M.M. Head pose estimation in computer vision: A survey. IEEE Trans. Pattern Anal. Mach. Intell. 2009, 31, 607–626. [Google Scholar] [CrossRef] [PubMed]
  2. Morimoto, C.H.; Mimica, M.R.M. Eye gaze tracking techniques for interactive applications. Comput. Vis. Image Underst. 2005, 98, 4–24. [Google Scholar] [CrossRef]
  3. Amarnag, S.; Kumaran, R.S.; Gowdy, J.N. Real time eye tracking for human computer interfaces. In Proceedings of IEEE International Conference on Multimedia and Exposition, Baltimore, MO, USA, 6–9 July 2003; pp. 557–560.
  4. Jacob, R.J.K. Eye movement-based human-computer interaction techniques: Toward non-command interfaces. In Advances Human-Computer Interaction; Ablex Publishing Co.: Norwood, NJ, USA, 1993; pp. 151–190. [Google Scholar]
  5. Sibert, L.E.; Jacob, R.J.K. Evaluation of eye gaze interaction. In Proceedings of the SIGCHI Conference on Human Factors in Computing Systems, The Hague, The Netherlands, 1–6 April 2000; pp. 281–288.
  6. Ohno, T. Quick menu selection task with eye mark. Trans. Inf. Process. Soc. Jpn. 1999, 40, 602–612. [Google Scholar]
  7. Cho, D.C.; Kim, W.Y. Long-range gaze tracking system for large movements. IEEE Trans. Biomed. Eng. 2013, 60, 3432–3440. [Google Scholar] [CrossRef] [PubMed]
  8. Model, D.; Eizenman, M. User-calibration-free remote eye-gaze tracking system with extended tracking range. In Proceedings of the 24th Canadian Conference on Electrical and Computer Engineering, Niagara Falls, ON, Canada, 8–11 May 2011; pp. 1268–1271.
  9. Tobii, X2. Available online: http://www.tobii.com (accessed on 2 July 2015).
  10. Zhu, Z.; Ji, Q. Novel eye gaze tracking techniques under natural head movement. IEEE Trans. Biomed. Eng. 2007, 54, 2246–2260. [Google Scholar] [PubMed]
  11. Sigut, J.; Sidha, S.A. Iris center corneal reflection method for gaze tracking using visible light. IEEE Trans. Biomed. Eng. 2011, 58, 411–419. [Google Scholar] [CrossRef] [PubMed]
  12. Colombo, C.; Bimbo, A.D. Interacting through eyes. Robot. Auton. Syst. 1997, 19, 359–368. [Google Scholar] [CrossRef]
  13. Morimoto, C.H.; Koons, D.; Amir, A.; Flickner, M.; Zhai, S. Keeping an eye for HCI. In Proceedings of the XII Brazilian Symposium on Computer Graphics and Image Processing, Campinas, Brazil, 17–20 October 1999; pp. 171–176.
  14. Mimica, M.R.M.; Morimoto, C.H. A computer vision framework for eye gaze tracking. In Proceedings of the XVI Brazilian Symposium on Computer Graphics and Image Processing, São Carlos, Brazil, 12–15 October 2003; pp. 406–412.
  15. Guestrin, E.D.; Eizenman, M. General theory of remote gaze estimation using the pupil center and corneal reflections. IEEE Trans. Biomed. Eng. 2006, 53, 1124–1133. [Google Scholar] [CrossRef] [PubMed]
  16. Zhu, J.; Yang, J. Subpixel eye gaze tracking. In Proceedings of IEEE International Conference on Automatic Face and Gesture Recognition, Washington, DC, USA, 20–21 May 2002; pp. 124–129.
  17. Yoo, D.H.; Chung, M.J. A novel non-intrusive eye gaze estimation using cross-ratio under large head motion. Comput. Vis. Image Underst. 2005, 98, 25–51. [Google Scholar] [CrossRef]
  18. Pfeuffer, K.; Vidal, M.; Turner, J.; Bulling, A.; Gellersen, H. Pursuit calibration: Making gaze calibration less tedious and more flexible. In Proceedings of the 26th Annual ACM Symposium on User Interface Software and Technology, Andrews, UK, 8–11 October 2013; pp. 261–269.
  19. Cho, C.W.; Lee, H.C.; Gwon, S.Y.; Lee, J.M.; Jung, D.; Park, K.R.; Kim, H.C.; Cha, J. Binocular gaze detection method using a fuzzy algorithm based on quality measurements. Opt. Eng. 2014, 53. [Google Scholar] [CrossRef]
  20. Gonzalez, R.C.; Woods, R.E. Digital Image Processing, 2nd ed.; Prentice-Hall: Upper Saddle River, NJ, USA, 2002. [Google Scholar]
  21. Ding, L.; Goshtasby, A. On the canny edge detector. Pattern Recognit. 2001, 34, 721–725. [Google Scholar] [CrossRef]
  22. Kirkpatrick, D.G.; Seidel, R. The ultimate planar convex hull algorithm. SIAM J. Comput. 1986, 15, 287–299. [Google Scholar] [CrossRef]
  23. Lee, H.C.; Lee, W.O.; Cho, C.W.; Gwon, S.Y.; Park, K.R.; Lee, H.; Cha, J. Remote gaze tracking system on a large display. Sensors 2013, 13, 13439–13463. [Google Scholar] [CrossRef] [PubMed]
  24. Bayu, B.S.; Miura, J. Fuzzy-based illumination normalization for face recognition. In Proceedings of IEEE Workshop on Advanced Robotics and Its Social Impacts, Tokyo, Japan, 7–9 November 2013; pp. 131–136.
  25. Barua, A.; Mudunuri, L.S.; Kosheleva, O. Why trapezoidal and triangular membership functions work so well: Towards a theoretical explanation. J. Uncertain. Syst. 2014, 8, 164–168. [Google Scholar]
  26. Zhao, J.; Bose, B.K. Evaluation of membership functions for fuzzy logic controlled induction motor drive. In Proceedings of IEEE 28th Annual Conference of the Industrial Electronics Society, Sevilla, Spain, 5–8 November 2002; pp. 229–234.
  27. Klir, G.J.; Yuan, B. Fuzzy Sets and Fuzzy Logic-Theory and Applications; Prentice-Hall: Upper Saddle River, NJ, USA, 1995. [Google Scholar]
  28. Leekwijck, W.V.; Kerre, E.E. Defuzzification: Criteria and classification. Fuzzy Sets Syst. 1999, 108, 159–178. [Google Scholar] [CrossRef]
  29. Broekhoven, E.V.; Baets, B.D. Fast and accurate center of gravity defuzzification of fuzzy system outputs defined on trapezoidal fuzzy partitions. Fuzzy Sets Syst. 2006, 157, 904–918. [Google Scholar] [CrossRef]
  30. Kodak Professional High-Speed Infrared Film. Available online: http://www.kodak.com/global/en/professional/support/techPubs/f13/f13.pdf (accessed on 2 July 2015).
  31. Webcam C600. Available online: https://support.logitech.com/en_us/product/5869 (accessed on 2 July 2015).
  32. Heo, H.; Lee, W.O.; Shin, K.Y.; Park, K.R. Quantitative Measurement of Eyestrain on 3D Stereoscopic Display Considering the Eye Foveation Model and Edge Information. Sensors 2014, 14, 8577–8604. [Google Scholar] [CrossRef] [PubMed]
  33. Student’s T-test. Available online: http://en.wikipedia.org/wiki/Student′s_t-test (accessed on 2 July 2015).
  34. Cohen, J. A power primer. Psychol. Bull. 1992, 112, 155–159. [Google Scholar] [CrossRef] [PubMed]

Share and Cite

MDPI and ACS Style

Gwon, S.Y.; Jung, D.; Pan, W.; Park, K.R. Estimation of Gaze Detection Accuracy Using the Calibration Information-Based Fuzzy System. Sensors 2016, 16, 60. https://doi.org/10.3390/s16010060

AMA Style

Gwon SY, Jung D, Pan W, Park KR. Estimation of Gaze Detection Accuracy Using the Calibration Information-Based Fuzzy System. Sensors. 2016; 16(1):60. https://doi.org/10.3390/s16010060

Chicago/Turabian Style

Gwon, Su Yeong, Dongwook Jung, Weiyuan Pan, and Kang Ryoung Park. 2016. "Estimation of Gaze Detection Accuracy Using the Calibration Information-Based Fuzzy System" Sensors 16, no. 1: 60. https://doi.org/10.3390/s16010060

APA Style

Gwon, S. Y., Jung, D., Pan, W., & Park, K. R. (2016). Estimation of Gaze Detection Accuracy Using the Calibration Information-Based Fuzzy System. Sensors, 16(1), 60. https://doi.org/10.3390/s16010060

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