[go: up one dir, main page]
More Web Proxy on the site http://driver.im/
Next Article in Journal
Dimension-Reduced Analog—Digital Mixed Measurement Method of Inductive Proximity Sensor
Previous Article in Journal
Temperature Measurement and Numerical Prediction in Machining Inconel 718
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

GNSS Spoofing Detection and Mitigation Based on Maximum Likelihood Estimation

Department of Electronic Engineering, Tsinghua University, Beijing 100084, China
*
Author to whom correspondence should be addressed.
Sensors 2017, 17(7), 1532; https://doi.org/10.3390/s17071532
Submission received: 19 April 2017 / Revised: 27 June 2017 / Accepted: 28 June 2017 / Published: 30 June 2017
(This article belongs to the Section Remote Sensors)
Figure 1
<p>MLE cost function in a scenario with eight authentic signals and eight spoofing ones.</p> ">
Figure 2
<p>Three different cases when spoofing signals are present. The circles represent the PVT domains in which spoofing signals or authentic signals are present. The highest peak of the MLE cost function at <math display="inline"> <semantics> <msub> <mover accent="true"> <mi mathvariant="bold-italic">ρ</mi> <mo stretchy="false">^</mo> </mover> <mn>1</mn> </msub> </semantics> </math> is superimposed by the signal components in the area emphasized by the dashed lines. (<b>a</b>) <math display="inline"> <semantics> <msub> <mover accent="true"> <mi mathvariant="bold-italic">ρ</mi> <mo stretchy="false">^</mo> </mover> <mn>1</mn> </msub> </semantics> </math> is equal to <math display="inline"> <semantics> <msub> <mi mathvariant="bold-italic">ρ</mi> <mi>s</mi> </msub> </semantics> </math>; (<b>b</b>) <math display="inline"> <semantics> <msub> <mover accent="true"> <mi mathvariant="bold-italic">ρ</mi> <mo stretchy="false">^</mo> </mover> <mn>1</mn> </msub> </semantics> </math> is equal to <math display="inline"> <semantics> <msub> <mi mathvariant="bold-italic">ρ</mi> <mi>a</mi> </msub> </semantics> </math>; (<b>c</b>) <math display="inline"> <semantics> <msub> <mover accent="true"> <mi mathvariant="bold-italic">ρ</mi> <mo stretchy="false">^</mo> </mover> <mn>1</mn> </msub> </semantics> </math> is neither equal to <math display="inline"> <semantics> <msub> <mi mathvariant="bold-italic">ρ</mi> <mi>s</mi> </msub> </semantics> </math> nor to <math display="inline"> <semantics> <msub> <mi mathvariant="bold-italic">ρ</mi> <mi>a</mi> </msub> </semantics> </math>.</p> ">
Figure 3
<p>MLE cost function after estimation-cancellation.</p> ">
Figure 4
<p>Implementation architecture.</p> ">
Figure 5
<p>Detection probabilities versus <math display="inline"> <semantics> <mrow> <mi>C</mi> <mo>/</mo> <msub> <mi>N</mi> <mn>0</mn> </msub> </mrow> </semantics> </math> for different numbers of satellites and a fixed false alarm probability <math display="inline"> <semantics> <mrow> <msub> <mi>P</mi> <mrow> <mi>f</mi> <mi>a</mi> </mrow> </msub> <mo>=</mo> <msup> <mn>10</mn> <mrow> <mo>-</mo> <mn>6</mn> </mrow> </msup> </mrow> </semantics> </math>. <math display="inline"> <semantics> <mrow> <mi>C</mi> <mo>/</mo> <msub> <mi>N</mi> <mn>0</mn> </msub> </mrow> </semantics> </math> of all of the spoofing signals are 50 dB-Hz. ’T’ represents the theoretical results. ’NC’ represents corresponding noncoherent integration results. ’EC’ represents the estimation-cancellation results.</p> ">
Figure 6
<p>ROC curves for different numbers of satellites. <math display="inline"> <semantics> <mrow> <mi>C</mi> <mo>/</mo> <msub> <mi>N</mi> <mn>0</mn> </msub> </mrow> </semantics> </math> of all of the authentic signals are 31 dB-Hz, and those of the spoofing signals are 50 dB-Hz. ’T’ represents the theoretical results. ’NC’ represents corresponding noncoherent integration results. ’EC’ represents the estimation-cancellation results.</p> ">
Figure 7
<p>Spoofing validation probabilities versus <math display="inline"> <semantics> <mrow> <mi>C</mi> <mo>/</mo> <msub> <mi>N</mi> <mn>0</mn> </msub> </mrow> </semantics> </math> for different numbers of satellites and <math display="inline"> <semantics> <mrow> <msub> <mi>P</mi> <mrow> <mi>F</mi> <mi>A</mi> </mrow> </msub> <mo>=</mo> <msup> <mn>10</mn> <mrow> <mo>-</mo> <mn>6</mn> </mrow> </msup> </mrow> </semantics> </math>.</p> ">
Figure 8
<p>Detection probabilities versus code phase difference between spoofing and authentic signals for different numbers of satellites. <math display="inline"> <semantics> <mrow> <mi>C</mi> <mo>/</mo> <msub> <mi>N</mi> <mn>0</mn> </msub> </mrow> </semantics> </math> of authentic and spoofing signals are 45 dB-Hz and 50 dB-Hz, respectively.</p> ">
Figure 9
<p>(<b>a</b>) Ratio metric of signal quality monitoring (SQM) in Scenario 2; (<b>b</b>) SSE of RAIM in Scenario 2; the red dashed line denotes the threshold.</p> ">
Figure 10
<p>(<b>a</b>) Test statistics and threshold in Scenario 2; (<b>b</b>) Detection results in Scenario 2; results larger than 0.5 mean that there are evil signals. The red circles correspond to the results when seven signals are processed together, and the blue points correspond to the results when one signal is processed.</p> ">
Figure 11
<p>(<b>a</b>) <math display="inline"> <semantics> <msub> <mi>r</mi> <mn>2</mn> </msub> </semantics> </math> in Scenario 2; results larger than four indicate that consistent signals are detected in the residual signal and the spoofing attack is validated; (<b>b</b>) Biases of the user clock offsets from the clock offset in Epoch 0: <math display="inline"> <semantics> <mrow> <mi>δ</mi> <msub> <mi>t</mi> <mi>u</mi> </msub> <mo>=</mo> <msub> <mi>t</mi> <mi>u</mi> </msub> <mrow> <mo>(</mo> <mi>t</mi> <mo>)</mo> </mrow> <mo>-</mo> <msub> <mi>t</mi> <mi>u</mi> </msub> <mrow> <mo>(</mo> <mn>0</mn> <mo>)</mo> </mrow> </mrow> </semantics> </math>. The green trace shows the receiver’s unspoofed response; the blue trace shows the receiver’s spoofed response; and the red dots show the recovered results.</p> ">
Figure 12
<p>(<b>a</b>) Ratio metric of SQM in Scenario 2; (<b>b</b>) SSE of RAIM in Scenario 2; the red dashed line denotes the threshold.</p> ">
Figure 13
<p>(<b>a</b>) Test statistics and threshold in Scenario 6; (<b>b</b>) Detection results in Scenario 6; results larger than 0.5 mean that there are evil signals. The red circles correspond to the results when seven signals are processed together, and the blue points correspond to the results when one signal is processed.</p> ">
Figure 14
<p>(<b>a</b>) <math display="inline"> <semantics> <msub> <mi>r</mi> <mn>2</mn> </msub> </semantics> </math> in Scenario 6; results larger than four indicate that consistent signals are detected in the residual signals and the spoofing attack is validated; (<b>b</b>) Biases of user position in the z-coordinate from the position in Epoch 0: <math display="inline"> <semantics> <mrow> <mi>δ</mi> <msub> <mi>z</mi> <mi>u</mi> </msub> <mo>=</mo> <msub> <mi>z</mi> <mi>u</mi> </msub> <mrow> <mo>(</mo> <mi>t</mi> <mo>)</mo> </mrow> <mo>-</mo> <msub> <mi>z</mi> <mi>u</mi> </msub> <mrow> <mo>(</mo> <mn>0</mn> <mo>)</mo> </mrow> </mrow> </semantics> </math>. The green trace shows the receiver’s unspoofed response; the blue trace shows the receiver’s spoofed response; and the red dots show the recovered results.</p> ">
Versions Notes

Abstract

:
Spoofing attacks are threatening the global navigation satellite system (GNSS). The maximum likelihood estimation (MLE)-based positioning technique is a direct positioning method originally developed for multipath rejection and weak signal processing. We find this method also has a potential ability for GNSS anti-spoofing since a spoofing attack that misleads the positioning and timing result will cause distortion to the MLE cost function. Based on the method, an estimation-cancellation approach is presented to detect spoofing attacks and recover the navigation solution. A statistic is derived for spoofing detection with the principle of the generalized likelihood ratio test (GLRT). Then, the MLE cost function is decomposed to further validate whether the navigation solution obtained by MLE-based positioning is formed by consistent signals. Both formulae and simulations are provided to evaluate the anti-spoofing performance. Experiments with recordings in real GNSS spoofing scenarios are also performed to validate the practicability of the approach. Results show that the method works even when the code phase differences between the spoofing and authentic signals are much less than one code chip, which can improve the availability of GNSS service greatly under spoofing attacks.

1. Introduction

The security of global navigation satellite system (GNSS) has caught more and more public attention because of the ever-increasing reliance on GNSS in our lives. GNSS receivers are vulnerable to jamming and spoofing attacks because the power of received GNSS signals is very low and the details of civilian signals are open to the public [1,2].
Spoofing signals can lead to wrong position, velocity and time (PVT) results. A victim receiver may output results preassigned by a spoofer so that the motion of the vehicle equipped with the receiver will be misled [3].
Many spoofing tests have been carried out over the last few years. The first GNSS spoofing experiment was presented by Warner and Johnston using a GS720 satellite simulator [4]. In the experiment, a spoofer was mounted on a truck, and the counterfeit signals were effective when the distance between the spoofer and the victim receiver did not exceed 30 feet. A portable Global Positioning System (GPS) civilian spoofer was developed by researchers at the University of Texas at Austin [3]. Spoofing threat was assessed with the device, and a successful spoofing experiment was carried out on a super yacht [5]. The researchers also did a successful spoofing test on phasor measurement units (PMU), which are employed in time synchronization of the power system [6]. It is obvious that the GNSS spoofing attack is not far from reality. Hence, efficient spoofing countermeasures need to be developed.
Many anti-spoofing techniques have been developed because of the importance of GNSS security. Some of them require additional hardware or changes to the interface specification. Techniques based on multiple antennas, absolute power measurements and inertial navigation system (INS) perform spoofing detection with measurements from additional sensors [7,8,9]. Cross-correlation techniques detect spoofing attack by performing cross-correlation of encrypted signals between secure and defended receivers [10]. Cryptographic methods, such as spread spectrum security code (SSSC) [11] and navigation message authentication (NMA) [12], attempt to prevent spoofing attacks by signal encryption or designing new GNSS signals, which are difficult to simulate. However, these methods are, to some extent, vulnerable to the replay attacks, in which the spoofer estimates, manipulates and replays the cryptographically-secured GNSS signals in real time [13,14].
The above-mentioned countermeasures require additional hardware, which increases the expense. Hence, their applications are limited. Other countermeasures are applied in single antenna receivers by detecting the abnormality and inconsistency of measurements. For example, signal quality monitoring (SQM) techniques detect the distortion of correlation results in the tracking stage [15]. Receiver autonomous integrity monitoring (RAIM) checks the consistency between pseudorange measurements of different satellites [16]. It fails when all channels are taken over by spoofing signals [17]. Moving antenna techniques detect and identify spoofing signals with the correlation between measurements of pairwise signals. It is desirable to be implemented in a moving single antenna handset [18,19,20]. The multiple tracking technique tracks all of the signals that are over the threshold in the acquisition stage and attempts to distinguish the authentic measurements from spoofing ones and recover the navigation solution [21]. It only works when the code phase difference between the authentic and spoofing signals is more than one code chip [22].
Most of the spoofing countermeasures mentioned above process signals separately, which limits their performance since the associated information between different signals is ignored. The maximum likelihood estimation (MLE)-based positioning technique is a direct positioning method originally developed for multipath rejection and weak signal processing [23]. In this paper, a jointly performed estimation-cancellation approach is proposed for spoofing detection and navigation solution recovery based on the technique. Firstly, a composite signal is reconstructed based on the estimated PVT parameters and subtracted from the original signal. Then, a test statistic is calculated with the residual signal to indicate whether there are evil signals such as spoofing and multipath signals. If evil signals are detected, a validation procedure is performed by inspecting the consistency of the signals to determine whether the evil signals are spoofing ones or not. Unlike the RAIM technique, the proposed method can detect spoofing attacks when all of the channels of the victim receivers are taken over by the spoofing signals, and it can even work when the code phase differences between the authentic and spoofing signals are much less than one code chip.
The outline of the paper is as follows. In Section 2, the GNSS baseband signal model is introduced. In Section 3, the maximum likelihood estimation for the GNSS PVT solution is reviewed. It is the foundation of the proposed method in the paper. In Section 4, an estimation-cancellation algorithm based on MLE is described, and a statistic for evil signal detection is derived based on GLRT. Furthermore, a metric is proposed for spoofing validation. The theoretical performance of the spoofing countermeasure is also derived in this section. In Section 5, both numerical and simulation results are presented to investigate the factors that affect the performance of the proposed method. In Section 6, the countermeasure is evaluated with the Texas Spoofing Test Battery (TEXBAT), which consists of recorded data in different real spoofing scenarios and has been widely used for GNSS anti-spoofing tests in the world. Finally, we conclude our work in Section 7.

2. Signal Model

The received GNSS signal can be transformed into a complex baseband signal. When no spoofing signals are present, the baseband signal can be expressed as follows [23,24]:
x n = i = 1 M a i D i ( n T s - τ i ) c i ( n T s - τ i ) e j ( 2 π f i n T s + θ i ) + w ( n T s ) , n = 0 , 1 , , K - 1 .
Here,
  • F s = 1 / T s is the sampling frequency;
  • M stands for the number of in-view satellites;
  • K stands for the number of samples;
  • a i is the amplitude of the i-th satellite signal;
  • D i ( t ) is the navigation data of the i-th signal at time t;
  • c i ( t ) is the pseudorandom code of the i-th signal at time t;
  • τ i is the propagation delay of the i-th signal;
  • f i is the Doppler frequency offset of the i-th signal;
  • θ i is the carrier phase of the i-th signal;
  • w ( t ) is complex zero-mean additive white Gaussian noise (AWGN) with variance σ 2 .
Choosing K samples as observation data, Equation (1) can be rewritten as [23]:
x = G ( τ , f ) a + w .
Here,
  • x = [ x 1 , x 2 , , x K ] T C K × 1 is the measurement vector;
  • G ( τ , f ) can be expressed as [ g 1 , , g M ] , being g i = [ g 1 , i , , g K , i ] T , and g k , i = D i ( k T s - τ i ) c i ( k T s - τ i ) e j 2 π f d i k T s , k = 1 , 2 , , K , i = 1 , 2 , , M ;
  • τ = [ τ 1 , τ 2 , , τ M ] , f = [ f 1 , f 2 , , f M ] . During the observation period, τ and f can be regarded as constants under static or low dynamic condition;
  • a = [ a 1 e j θ 1 , a 2 e j θ 2 , , a M e j θ M ] T C M × 1 represents complex amplitudes of the received signals;
  • w = [ w ( T s ) , w ( 2 T s ) , , w ( K T s ) ] T C K × 1 is the AWGN vector, and each element has a variance σ 2 during the observation period.

3. Review on MLE-Based Positioning

Unlike a conventional GNSS receiver, which extracts measurements in several parallel tracking channels independently, the GNSS MLE-based positioning technique provides a way of jointly processing the signals of all in-view satellites. Taking advantage of the gain from the merging of signals, the method is robust against multipath and signal fading conditions [23]. In this section, we will review the MLE-based positioning, which is the foundation of the proposed method in the paper.

3.1. Maximum Likelihood Estimation

The probability density function (pdf) of the measurement vector x can be expressed as Equation (3) since the noise vector w is zero-mean AWGN with variance σ 2 .
p ( x ; τ , f , a , σ 2 ) = 1 ( 2 π σ 2 ) K 2 e x p [ - | | x - Ga | | 2 2 σ 2 ] .
Denote { τ , f } as r . The maximum likelihood (ML) estimates of the unknown parameters are given by [25]:
r ^ = a r g max r { x H G ( r ) [ G ( r ) H G ( r ) ] - 1 G ( r ) H x }
a ^ = [ G ( r ^ ) H G ( r ^ ) ] - 1 G ( r ^ ) H x .
σ ^ 2 = 1 K [ x - G ( r ^ ) a ^ ] H [ x - G ( r ^ ) a ^ ] .
J ( r ; x ) = x H G ( r ) [ G ( r ) H G ( r ) ] - 1 G ( r ) H x
We call J the cost function of MLE in the rest of the paper. The ML estimates of the parameters can be obtained by maximizing the cost function.

3.2. Position Estimation

The MLE cost function is determined by the synchronization parameters τ and f . These parameters can be calculated with the user PVT parameters. The elements in τ and f are given by [26]:
τ i = 1 c u ( i ) - u + t u - t ( i ) + e ( i ) ,
f i = - f T c [ ( v ( i ) - v ) 1 ( i ) + t ˙ u - t ˙ ( i ) ] .
Here,
  • c is the speed of light;
  • u ( i ) is the coordinates of the i-th satellite in Earth-centered earth-fixed (ECEF) coordinate system;
  • u = [ x u , y u , z u ] T is the coordinates of the user in ECEF coordinate system;
  • t u is the offset of the user clock from system time;
  • t ( i ) is the offset of the i-th satellite clock from system time;
  • e ( i ) denotes ionospheric and tropospheric delays and errors induced by relativistic effects; these errors can be eliminated by models or differential techniques;
  • f T is the frequency of the transmitted satellite signals;
  • v ( i ) is the velocity of the i-th satellite in ECEF coordinate system;
  • v = [ x v , y v , z v ] T is the velocity of the user in ECEF coordinate system;
  • 1 ( i ) is the unit vector pointing along the line of sight from the user to the i-th satellite and can be expressed as Equation (10);
  • t ˙ u is the drift rate of the user clock relative to system time;
  • t ˙ ( i ) is the drift rate of the i-th satellite clock relative to system time.
1 ( i ) = - u ( i ) - u u ( i ) - u .
It can be seen that τ and f are determined by the user PVT parameters ρ = [ u , t u , v , t ˙ u ] . When at least four satellites are in view, ρ can also be resolved by τ and f . Hence, the ML estimates of the user PVT parameters can be obtained by maximizing J based on the invariance principle of MLE [23].

4. MLE-Based GNSS Anti-Spoofing Method

Since the MLE cost function is directly connected with the PVT parameters, spoofing signals that mislead the PVT results will cause distortion to the MLE cost function. Hence, the MLE-based positioning technique has a potential ability for spoofing detection. In this section, based on the technique, an estimation-cancellation algorithm is proposed, and a test statistic is derived for the detection of evil signals. Then, a validation method is proposed based on the decomposition of MLE cost function to determine whether the evil signals are spoofing ones or not. Finally, the overall implementation architecture is provided at the end of the section.

4.1. Model of Spoofing Signal

When there is a spoofing attack, the baseband signal can be expressed as:
x = G ( ρ a ) a a + G ( ρ s ) a s + w ,
where ρ a and a a are the PVT and amplitude parameters of the authentic signals and ρ s and a s are the corresponding parameters of the spoofing ones. Since a spoofer aims to mislead the PVT results of the victim receiver, ρ s is different from ρ a . Consequently, the authentic and spoofing signals will form different peaks in the cost function.
In order to view the MLE cost function under a spoofing attack intuitively, it is assumed that only x u and y u are unknown, and the search space is limited to [ x u , y u ] . The two-dimensional cost function J with eight authentic signals and eight spoofing ones is shown in Figure 1. The center of the search space corresponds to ρ a or [ δ x u , δ y u ] = [ 0 , 0 ] . The position offset induced by the spoofing signals is [ δ x u , δ y u ] = [ 0 , 600 ] m, and the other parameters in ρ a and ρ s are the same. The C / N 0 of each authentic signal is 45 dB-Hz, and the power of a spoofing signal is 0.8 dB higher than that of the corresponding authentic one. It can be seen that when [ δ x u , δ y u ] = [ 0 , 600 ] m, the cost function is maximized, and when [ δ x u , δ y u ] = [ 0 , 0 ] , another peak, which is slightly lower than the maximum value of the cost function, can be found. If the MLE-based positioning is employed, since the power of the spoofing signals is higher than that of the authentic ones, the peak at ρ s will be the highest, and the ML estimate of ρ will be equal to ρ s . That is to say, when the conventional MLE-based positioning method is used, the spoofing attack can still mislead the PVT result.

4.2. Estimation-Cancellation Approach

After obtaining the ML estimate of ρ , which is denoted as ρ ^ 1 , the composite signal can be reconstructed as follows:
x ^ = G ( ρ ^ 1 ) a ^ 1 = G ( ρ ^ 1 ) [ G ( ρ ^ 1 ) H G ( ρ ^ 1 ) ] - 1 G ( ρ ^ 1 ) H x
Then, we subtract the reconstructed signal from the original signal. The residual signal plus noise is given by:
y = x - x ^
When there is no spoofing signal, ρ ^ 1 is equal to ρ a , and x ^ is the estimation of the sum of the authentic signals. Thus, y mainly consists of noise. When spoofing signals are present, y will consist of residual signals and noise because ρ s is different from ρ a . Based on the above analysis, y can be expressed as follows:
H 0 : y = w H 1 : y = G ( ρ s ) a s + G ( ρ a ) a a - G ( ρ ^ 1 ) a ^ 1 + w
where H 0 denotes that spoofing signals are absent and H 1 denotes that spoofing signals are present. A spoofing attack can be detected by detecting signal components in y , and we call it the estimation-cancellation approach.
The alternative hypothesis H 1 consists of three cases, which are illustrated in Figure 2. Figure 2 is an abstract expression of the PVT domain. Spoofing and authentic signal components form peaks at different positions of the domain. Figure 1 shows that the spoofing and authentic signal components are distributed around ρ s and ρ a , and the corresponding PVT domains are represented with circles centered at ρ s and ρ a in Figure 2, respectively. The highest peak of the MLE cost function at ρ ^ 1 is superimposed by the signal components in the area emphasized by dashed lines.
Figure 2a represents the first case. The total power of the spoofing signals is higher than that of the authentic ones. Therefore, the MLE cost function is maximized at ρ s and the residual signal y mainly consists of authentic signals and noise. The spoofing scenario shown in Figure 1 is a good illustration for this case. It should be noted that when the designated falsified PVT parameter ρ s is close to ρ a , parts of authentic signals will also contribute to the peak, which corresponds to the overlapped part of the circles in Figure 2a.
Figure 2b represents the second case, which is opposite the first case. It happens when the total power of the spoofing signals is lower than that of the authentic ones. Consequently, the MLE cost function is maximized at ρ a , and the residual signal y mainly consists of spoofing signals and noise. In this case, the authentic PVT results can be obtained with the MLE-based positioning method directly.
In particular, when ρ s is far away from ρ a , the two circles representing spoofing and authentic signal components will be separate in Figure 2a,b.
Figure 2c represents the third case. ρ ^ 1 is different from both ρ s and ρ a . Thus, the residual signal consists of residual authentic signals, spoofing signals and noise.
We will discuss the three cases respectively in the rest of the subsection. As for the first case, we will first consider the limiting case in which the two circles in Figure 2a are separate. All of the authentic signals will be reserved in y , and the hypothesis test in Equation (14) can be rewritten as follows:
H 0 : y = w H 1 : y = G ( ρ a ) a a + w
Then, we perform the MLE-based positioning again with y . The ML estimates of τ a , f a , a a and σ 2 under H 1 can be obtained with Equations (4)–(6) by replacing x with y , and they are denoted as τ ^ 2 , f ^ 2 , a ^ 2 and σ ^ 2 2 , respectively. The only unknown parameter under H 0 is the variance of noise, which is denoted as σ 0 2 , and its ML estimate is given by:
σ 0 ^ 2 = 1 K y H y
Then, with the ML estimates mentioned above, the generalized likelihood ratio test (GLRT) statistic can be derived as:
L G ( y ) = max τ , f , a , σ 2 p 1 ( y ; τ , f , a , σ 2 ) max σ 2 p 0 ( y ; σ 2 ) = ( σ ^ 0 2 σ ^ 2 2 ) K 2 = y H y [ y - G ( ρ ^ 2 ) a ^ 2 ] H [ y - G ( ρ ^ 2 ) a ^ 2 ] K 2
where p 0 ( y ; σ 2 ) and p 1 ( y ; τ , f , a , σ 2 ) denote the likelihood functions under H 0 and H 1 , respectively. ρ ^ 2 is the ML estimate of the PVT result corresponding to the residual signal y . Using the monotonicity of the function f ( x ) = a ( 1 - 1 / x c ) , x , a , c > 0 , we have:
T ( y ) = 2 K [ 1 - 1 L G ( y ) 2 K ] = 2 y H y - [ y - G ( ρ ^ 2 ) a ^ 2 ] H [ y - G ( ρ ^ 2 ) a ^ 2 ] y H y / K = a ^ 2 H G ( ρ ^ 2 ) H G ( ρ ^ 2 ) a ^ 2 σ ^ 0 2 / 2 = y H G ( ρ ^ 2 ) [ G ( ρ ^ 2 ) H G ( ρ ^ 2 ) ] - 1 G ( ρ ^ 2 ) H y σ ^ 0 2 / 2 = max ρ 2 J ( ρ 2 ; y ) σ ^ 0 2 / 2 > γ
The cost function J ( ρ 2 ; y ) after estimation-cancellation is shown in Figure 3. All of the simulation parameters are the same as those in Figure 1. It can be seen that when [ δ x u , δ y u ] = [ 0 , 0 ] , the cost function is maximized. Figure 3 shows that ρ a can be obtained by maximizing J ( ρ 2 ; y ) in the first case.
T ( y ) follows F and non-central F distributions under H 0 and H 1 , respectively [25]. Since the estimation are performed with a large number of samples considering the sampling frequency and processing time, the ML estimate σ ^ 0 2 is very close to its true value σ 2 . Therefore, T ( y ) follows central χ 2 distribution under H 0 and non-central χ 2 distribution under H 1 .
T ( y ) χ 2 M 2 , u n d e r H 0 χ 2 M 2 ( λ ) , u n d e r H 1
The non-central parameter is given by [25]:
λ = a H G ( ρ 2 ) H G ( ρ 2 ) a σ 2 / 2
Thus, the false alarm and detection probabilities are given by [27]:
P f a ( γ , M ) = exp { - γ 2 } i = 0 M - 1 1 i ! ( γ 2 ) i
P d ( γ , M ) = Q M ( λ , γ )
where γ is the threshold which can be determined by P f a . Q M ( a , b ) is the generalized Marcum Q-function [28].
Further, by using the properties of cross-correlation of different satellites’ pseudorange codes, we have [29]:
G ( ρ ^ 2 ) H G ( ρ ^ 2 ) K I M × M
Substituting Equation (23) to Equations (18) and (20), we have:
T ( y ) = y H G ( ρ ^ 2 ) [ G ( ρ ^ 2 ) H G ( ρ ^ 2 ) ] - 1 G ( ρ ^ 2 ) H y σ ^ 0 2 / 2 1 K y H G ( ρ ^ 2 ) G ( ρ ^ 2 ) H y σ ^ 0 2 / 2 = 2 K σ ^ 0 2 i = 1 M | | g i ( ρ ^ 2 ) H y | | 2
λ K i = 1 M a i 2 σ 2 / 2 = 2 K T s i = 1 M ( C / N 0 ) i
where ( C / N 0 ) i denotes the carrier to noise ratio of the i-th satellite in Hz. The equations show that the test statistic T ( y ) can be viewed as the noncoherent sum of different signals’ integration results.
The above analysis is based on the assumption that ρ s and ρ a are separate, and all of the authentic signals are reserved in the residual signal. However, when the peaks of the MLE cost function formed by spoofing and authentic signals are close, parts of the authentic signals will be subtracted in the cancellation procedure. Consequently, the signal components in Equation (15) under H 1 will be fewer. Thus, the detection performance, which is given by Equation (22), can be viewed as the upper bound. The detection performance will improve when the distance between ρ s and ρ a increases, and it will approach the upper bound after the peaks formed by the spoofing and authentic signals are separated completely.
The detection performance of the second case is very similar to that of the first one. It can also be evaluated with Equations (21), (22) and (25). Different from the first case, the ( C / N 0 ) i in Equation (25) represents the carrier to noise ratio of the i-th spoofing signal.
As for the third case, as long as spoofing signals are present and mislead the PVT results of a receiver (i.e., ρ s ρ a ), y will include residual signal components. Therefore, the test statistic T ( y ) will exceed the threshold and can also be used for spoofing detection in this case. However, the method may fail to detect the spoofing attacks when ρ s is very close to ρ a . Therefore, it is not fit for the applications that require high-precision PVT results. It should be noted that there is no exact expression for the detection performance of the third case. Nevertheless, since most of the spoofing and authentic signals that are superimposed in the PVT domain are eliminated, Equation (22) can still be viewed as the upper bound of the detection performance.

4.3. Spoofing Validation and Recovery of Navigation Solution

It should be noted that when there are severe multipath signals, T ( y ) can also exceed the threshold. However, the multipath signals are hardly consistent with each other since they are generated by different reflectors around a receiver. Different from the multipath signals, the spoofing ones may have the collaboration since they are generated sophisticatedly by a spoofer. Based on the difference, the following discrimination method is presented to reduce the false alarms induced by multipath signals and to validate the navigation solution.
After evil signals are detected, we calculate the following statistics.
T 1 i ( x ) = 2 K σ ^ 0 2 | | g i ( ρ ^ 1 ) H x | | 2 , i = 1 , 2 , , M T 2 i ( y ) = 2 K σ ^ 0 2 | | g i ( ρ ^ 2 ) H y | | 2 , i = 1 , 2 , , M
Then, count the statistics T 1 i ( x ) and T 2 i ( y ) that are over a threshold γ , respectively. Since the expressions of T 1 i ( x ) and T 2 i ( y ) are the same as the noncoherent integration result of a single satellite, γ can be given by [26]:
γ = - 2 l n ( P f a )
Denote the numbers of T 1 i ( x ) and T 2 i ( y ) that are over γ as r 1 and r 2 , respectively. If r 1 and r 2 are larger than four simultaneously, two groups of consistent signals are found in x , and the detected evil signals can be determined as consistent spoofing signals. The tenet of the method is similar to RAIM, which is based on the self-consistency of pseudorange measurements. In RAIM, the consistency can be determined when more than four measurements are used [26], and in the proposed validation method, signals can be judged as self-consistent only if the peak of the MLE cost function is superimposed by more than four signals.
It should be noted that if the multipath signals form consistent measurements, they cannot be distinguished from the spoofing signals. However, in this case, the multipath signals are very similar to the spoofing ones and may mislead the PVT results in the same way as the spoofing ones. Consequently, they can also be categorized as spoofing signals. The spoofing validation probability can be expressed as:
P V = P V 1 · P V 2 P V k = p ( r k > 4 ) , k = 1 , 2
where p ( E ) denotes the probability of event E.
Particularly, when all of the signals’ C / N 0 are the same, P V k has the following simplified form:
P V k = n = 5 M M n P d k n ( 1 - P d k ) M - n = 1 - B ( 4 ; M , P d k )
where B ( k ; N , p ) denotes the cumulative binomial distribution function and P d k denotes the detection probability of the single signal in the k-th MLE positioning module, which can be calculated with Equations (22) and (25) by setting M to one.
In order to see when a spoofing detection or a spoofing validation can be performed successfully, we further classify the cases in Figure 2 into nine different scenarios based on the numbers of spoofing and authentic signals in x and y . Since a peak of the MLE cost function is formed by consistent signals, spoofing signals with inconsistent measurements will not contribute to the peak at ρ s , and their effects will be eliminated by the MLE-based method directly. Therefore, only consistent spoofing signals are considered. The classifications are given in Table 1. spf and auth denote the numbers of the spoofing and authentic signals, respectively.
Case 1 consists of Scenarios 1, 2 and 3. In these scenarios, consistent spoofing signals are more than four, and the total power of them is higher than that of the authentic ones. Therefore, ρ ^ 1 equals ρ s , and only authentic signals are reserved in y .
In Scenario 1, ρ s and ρ a are separate. Therefore, the number of authentic signals is more than four in y , and both r 1 and r 2 are larger than four. Consequently, both spoofing detection and validation are successful.
In Scenario 2, ρ s and ρ a are close. Therefore, parts of the authentic signals are eliminated in the cancellation procedure, and the residual authentic signals are fewer than four. Consequently, r 2 is no more than four, and the spoofing validation fails. However, when the PVT bias induced by the spoofing signals becomes larger (i.e., ρ s is farther from ρ a ), the peaks of the MLE cost function formed by the spoofing and authentic signals will separate, and this scenario will turn into Scenario 1.
In Scenario 3, the number of the authentic signals is fewer than four due to the blockage in different traffic conditions. Consequently, r 2 is no more than four, and the spoofing validation also fails.
Case 2 consists of Scenarios 4, 5 and 6. In these scenarios, authentic signals are more than four, and the total power of them is higher than that of the spoofing ones. Therefore, ρ ^ 1 equals ρ a , and only spoofing signals are reserved in y .
Scenarios 4, 5 and 6 are symmetric to Scenarios 1, 2 and 3, respectively. The detection and validation results are the same as those in Case 1.
Case 3 consists of Scenarios 7, 8 and 9. In these scenarios, the peak at ρ ^ 1 is formed by parts of spoofing signals and parts of authentic ones. Since at most four authentic and spoofing signals can be superimposed in the search domain, r 1 is no more than four, and the spoofing validation fails.
Even though only Scenarios 1 and 4 can be validated successfully. The validation is very meaningful since these two scenarios include the intermediate and sophisticated spoofing attacks mentioned in [3], which are very covert since they mislead the PVT results while maintaining the tracking state of a GNSS receiver.
In such spoofing attacks, the spoofer can extract the ephemeris and estimate the position and motion of a victim receiver in real time, based on which spoofing signals, which are consistent with the observed constellation, can be generated.
At the initial stage of the spoofing attacks, spoofing signals try to align their code phases to those of the corresponding authentic ones; consequently, ρ s ρ a . Then, the spoofing signals increase their powers and take control of the delay lock loops of the victim receiver. Finally, they drag the code phases away from the true values, and ρ s will not be approximately equal to ρ a any longer.
When the code phases of the spoofing and authentic signals are perfectly aligned, the proposed method cannot detect the attack. However, since the aim of a spoofing attack is to mislead the PVT results, the bias between ρ s and ρ a will not maintain as zero, and it will increase gradually. Afterwards, the spoofing attack can be detected, and the navigation solution can be recovered.
The spoofing detection, validation and navigation recovery of such spoofing attacks in real tests will be provided in Section 6.

4.4. Implementation Architecture

The implementation architecture of the proposed method is shown in Figure 4. An anti-spoofing module can be embedded into a conventional receiver. It consists of two MLE position modules, one signal reconstruction module and one spoofing validation module. The first MLE position module is used to obtain the refined PVT result ρ ^ 1 and the corresponding amplitude estimation a ^ 1 . After that, the reconstructed signal x ^ is subtracted from the original baseband signal x , and the residual signal y is obtained. Then, y is input to the second MLE position module. When the test statistic is over the threshold, evil signals are detected. Then, x , y , ρ ^ 1 and ρ ^ 2 are input to the spoofing validation module. If both r 1 and r 2 are larger than four, two groups of consistent signals are detected. Thus, the evil signals in x are validated to be spoofing ones, and one of ρ ^ 1 and ρ ^ 2 corresponds to the authentic navigation solution.

5. Simulation Results

In the previous section, the MLE-based anti-spoofing countermeasure is presented, and the theoretical performance is derived. In this section, theoretical and simulation detection probabilities and the receiver operating characteristic (ROC) curves are provided to validate the analytical results. Spoofing validation probabilities are also evaluated.
GPS L1 C/A signals are employed in the simulations. The common simulation parameters are given as follows. The coherent integration time is 1 ms; the signals are sampled at a rate of 5 MHz; and the false alarm probability is set to 10 - 6 .
In Figure 5, detection probabilities for different numbers of satellites and a fixed false alarm probability are compared. For simplicity and clarity, all of the C / N 0 of the authentic signals are equal, and those of the spoofing signals are set to 50 dB-Hz. The code phase differences between authentic, and spoofing signals for different PRNs are all set to 600 m. Thus, the correlation peaks of authentic and spoofing signals are separate. Theoretical results are shown with different types of lines (’T’). Estimation-cancellation results are shown with black markers (’EC’). Corresponding noncoherent integration results of M satellites are also provided for comparison, shown with blue markers (’NC’). Figure 5 demonstrates that the noncoherent integration results are almost the same as the theoretical results, but the estimation-cancellation results are slightly lower than the theoretical curves due to the small power loss of the authentic signals in the cancellation procedure. It also shows that the detection performance is better when more signals are processed simultaneously.
Figure 6 shows the ROC curves for different numbers of satellites. All of the C / N 0 of the authentic signals are set to 31 dB-Hz, and the C / N 0 of the spoofing signals and the code phase differences are the same as those in Figure 5. Similar to Figure 5, the noncoherent integration results match the theoretical results well, and the detection probabilities of the estimation-cancellation algorithm are slightly lower than the theoretical results. Figure 5 and Figure 6 demonstrate that the detection performance can be evaluated with Equations (21) and (22) when the code phases of spoofing and authentic signals are separate.
Figure 7 shows the spoofing validation probabilities for different numbers of satellites. The simulation parameters are the same as those in Figure 5. Since the C / N 0 of the spoofing signals are very high, P V 1 = 1 and P V = P V 2 . Results show that the probability of spoofing validation is higher when more signals are processed.
Then, we consider the situation when the peaks of the MLE cost function formed by spoofing and authentic signals are overlapped. Figure 8 shows the detection probabilities versus code phase difference between spoofing and authentic signals for different numbers of satellites when C / N 0 = 45 dB-Hz. The detection probability is zero when the code phases of the spoofing and authentic signals are aligned, and it increases as the code phase difference increases. When only one signal is processed, the detection probability is one only when the code phase difference is larger than 250 m, and when 12 signals are processed simultaneously, the detection probability is one as long as the code phase difference is larger than 60 m. Figure 8 demonstrates that not only more numbers of satellites, but also larger code phase differences can improve the detection performance. This improvement comes from the integration of multiple signals. The ROC curves determined by Equations (21) and (22) can be viewed as the upper bound of the detection performance. This bound can be nearly reached when the correlation peaks of spoofing and authentic signals are separated completely.

6. Performance Evaluation with TEXBAT

The Texas Spoofing Test Battery (TEXBAT) is a set of digital recordings of GPS L1 C/A spoofing tests. It is provided by the Radio Navigation Laboratory (RNL) at the University of Texas at Austin for evaluating civil GPS spoofing countermeasures [30].
The TEXBAT consists of eight data recordings representing different types of GNSS spoofing attacks at the time of writing. In the paper, Datasets 2 to 7 (ds2 to ds7) are employed to evaluate the proposed anti-spoofing method. They represent “static overpowered time push”, “static matched-power time push”, “static matched-power position push”, “dynamic overpowered time push”, “dynamic matched-power time push” and “seamless static matched-power time push”, respectively. The lengths of ds2 to ds6 are 400 s, and the length of ds7 is 465 s.
Ds1 is a “static switch” spoofing attack, which removes all of the authentic signals when spoofing signals appear. It cannot be detected by the MLE-based method since authentic and spoofing signals do not exist simultaneously. ds8 represents a security code estimation and replay (SCER) attack, which is identical to ds7, except that the spoofer guesses and generates the navigation data bits in real time. Since our method does not employ the security codes to detect a spoofing attack, ds8 is also not considered in the paper.
The Doppler measurements from a conventional receiver are employed in the experiment; therefore, the velocity does not need to be searched, and the search space is { x , y , z , t u } . The center of the search space is set to the user position and clock offset results obtained from the conventional receiver. The search range of each dimension and the search step length of the two MLE position modules in Figure 4 are given in Table 2. Shorter search step improves the accuracy of the recovered PVT results. However, it also leads to a higher computational burden. Consequently, a trade-off needs to be made in practical applications.
Table 3 shows the spoofing detection and validation performance in Scenarios 2 to 7 of TEXBAT. M denotes the number of the processed signals. Here, the detection performance is measured by the spoofing detection percentage ( S D P i ), which is defined as the ratio between the data length of successful detections when i signals are processed ( L i ) and the data length under spoofing attack ( L S ). The validation performance is measured by the spoofing validation percentage ( S V P ), which is defined as the ratio between the data length of successful validations ( L V ) and L S . The improvement of multi-signal processing is also given in Table 3, which is defined as I m p = S D P M - S D P 1 .
The anti-spoofing module is called every second. Therefore, 400 T ( y ) are calculated in each dataset of ds2 to ds6, and 465 T ( y ) are calculated in ds7. L S is about 290 in each dataset of ds2 to ds6 and 315 in ds7.
Table 3 demonstrates that in all of the scenarios, spoofing attacks can be detected. The detection performance is better when more signals are processed in each scenario. Table 3 also shows that the spoofing detection percentages are lower in ds4 and ds6, which mislead the positioning results of the victim receiver. The reason is that the code phase differences induced by the spoofing signals are smaller in these two scenarios. In addition, two groups of consistent signals are found in all of the scenarios. Thus, the detected evil signals can be judged as spoofing ones.
In particular, in order to view the performance of the proposed method intuitively, detailed spoofing detection, validation and recovered PVT results of ds2 (Static Over-Powered Time Push) and ds6 (Dynamic Matched-Power Position Push) are provided. Detection results of SQM and RAIM of the two scenarios are also provided for comparison. These two scenarios are chosen because they include different motion states of victim receivers and different power levels of spoofing signals. In addition, the spoofing attacks in the two scenarios falsify the positioning and timing results, respectively.

6.1. Scenario 2 of TEXBAT

Detection results of SQM and RAIM in Scenario 2 are shown in Figure 9. Figure 9a shows the ratio metric, which is one of the most widely-used metrics in the SQM technique. It is defined as ( I E + I L ) / ( 2 I P ) , where I E , I L and I P are the early, late and prompt taps on the in-phase component, respectively [15]. Here, the correlator spacing is set to 0.25 code chip; therefore, the ratio metrics should be about 0.75 when the spoofing signal is absent. It can be seen that the ratio metrics in Scenario 2 are constant throughout the experiment and fail to detect the spoofing attack. This is because the power of the spoofing signal is much higher, and no obvious disruptions occur in the drag-off process.
Figure 9b shows the sum of the squares of the range residual error (SSE), which is a statistic in RAIM technology. It is employed to evaluate the consistency of the pseudorange measurements of different signals when more than four satellites are observed at the same time [16]. When the measurements are inconsistent, the range residual error will be large, and the SSE will be over a pre-assigned threshold, implying that the PVT results are unreliable [16]. Figure 9b shows that the SSEs are all beneath the threshold and fail to detect the spoofing attack. This is because that all of the tracking channels are taken over by the spoofing signals, and the code phases of these signals are manipulated sophisticatedly to generate consistent pseudorange measurements.
Figure 10a shows the test statistics T ( y ) in Scenario 2. They are smaller than the threshold in the first 110 s when no spoofing signals are present. At about 110 s, spoofing signals are added, and the statistics are over the threshold because the code phases of the spoofing signals are not perfectly aligned with those of the authentic ones. The statistics increase when the code phase differences between authentic and spoofing signals are larger, indicating that the spoofing signals are more likely to be detected, which is consistent with the results in Figure 8. They stop increasing after the correlation peaks of the authentic and spoofing signals are completely separate (after about 210 s).
Figure 10b shows the detection results of Scenario 2. Results larger than 0.5 mean that evil signals are detected. The red circles correspond to the results when seven signals are processed together, and the blue points correspond to the results when only one signal is processed. Figure 10b shows that the detection performance is better when more signals are processed simultaneously.
Figure 11a shows r 2 in Scenario 2. r 1 is omitted since it is larger than four throughout the experiment. r 2 is larger than four after 150 s, indicating that consistent signals are detected in the residual signal y . Thus, the evil signals can be judged as spoofing ones, and one of ρ ^ 1 and ρ ^ 2 corresponds to the authentic result. Here, since the total power of the spoofing signals is higher, the spoofing signals will be constructed and canceled in the estimation-cancellation procedure. Consequently, ρ ^ 2 corresponds to the authentic PVT results.
Figure 11b shows the biases of the user clock offsets in Scenario 2. The spoofed, unspoofed and recovered PVT results are indicated by blue, green and red traces, respectively. The recovered results are only shown when r 2 is larger than four. Since the spoofing signals only falsify the timing results, only the biases of the user clock offsets are shown. Figure 11b shows that the red trace (recovered result) is close to the green trace (unspoofed response) after the time error induced by spoofing signals is more than 0.2 μ s (about 1/5 C/A code chip length), which demonstrates that the proposed method can recover the navigation solution even when the code phase differences between the spoofing and authentic signals are much smaller than one code chip.

6.2. Scenario 6 of TEXBAT

Detection results of SQM and RAIM in Scenario 6 are shown in Figure 12. Different from Scenario 2, the ratio metrics and SSEs occasionally exceed the threshold. The abnormalities before 110 s are probably caused by the dynamics of the receiver. There are abnormalities between 150 and 250 s since the spoofing signals try to mislead the code phases and cause disruptions in the tracking loops of the receiver. After drag-off, both the metrics are normal again, but the receiver is completely spoofed and can only output falsified PVT results. Figure 12 demonstrates that the SQM and RAIM techniques cannot deal with the spoofing attack in Scenario 6.
Figure 13a shows the test statistics in Scenario 6. They are smaller than the threshold in the first 110 s when no spoofing signals are present. From 110 s to 150 s, spoofing signals are added, but their code phases are aligned with those of the authentic ones, and their powers are only slightly higher than those of the authentic ones. Consequently, the spoofing and authentic signals will be canceled simultaneously, and the signal component in the residual signal y is very weak. Hence, the test statistics do not increase obviously. After 150 s, the test statistics increase because the code phase differences between the authentic and spoofing signals increase. Similar to Figure 10a, the statistics stop increasing after the peaks of the authentic and spoofing signals are completely separated.
Figure 13b shows the detection results of Scenario 6. It can be seen that when only one signal is processed, the detection probability in a dynamic receiver is much lower than that in a static receiver due to the motion of the receiver and the changing environment. However, the detection performance is still very good when all of the signals are processed together, since it takes advantage of the diversity gain of multiple signals.
Figure 14a shows r 2 in Scenario 6. It is larger than four after 180 s, indicating successful spoofing validations.
Figure 14b shows the biases of user position results in Scenario 6. Since the spoofing signals in this scenario only falsify the position results in the z-coordinate, only the biases in this dimension are shown. Figure 14b shows that the recovered position results are also very close to the receiver’s unspoofed response.

7. Conclusions

In this paper, we develop an estimation-cancellation approach for GNSS spoofing detection and navigation solution recovery based on the MLE-based positioning technique. The proposed method distinguishes the spoofing signals from the authentic ones based on the fact that the spoofing and authentic signals form peaks at different positions of the MLE cost function. After canceling the composite signal constructed with the ML estimates of the PVT parameters, another peak can still be detected in the MLE cost function of the residual signal if evil signals such as spoofing signals are present. In order to analyze the theoretical performance and set the threshold appropriately, a test statistic is derived based on the GLRT. Furthermore, once evil signals are detected, spoofing validation can be performed by decomposing the cost function and inspecting the consistency of the signals. We also present theoretical and simulation results to investigate the anti-spoofing performance. Finally, we evaluate the proposed countermeasure with the TEXBAT GPS spoofing datasets. Results show that the method can detect and recover navigation solution even when the code phase differences between authentic and spoofing signal are much less than one code chip, which greatly improves the availability of GNSS service under spoofing attacks.

Acknowledgments

This work was supported by the National Natural Science Foundation of China (Grant No. 61571255).

Author Contributions

Fei Wang proposed the anti-spoofing method and wrote the paper. Hong Li supervised and supported the study and revised the paper. Fei Wang, Hong Li and Mingquan Lu discussed the study and read the paper.

Conflicts of Interest

The authors declare no conflict of interest.

Abbreviations

The following abbreviations are used in this manuscript:
GNSSGlobal navigation satellite system
MLEMaximum likelihood estimation
GLRTGeneralized likelihood ratio test
PVTPosition, velocity, and time
GPSGlobal Positioning System
PMUPhasor measurement units
INSInertial navigation system
SSSCSpread spectrum security code
NMANavigation message authentication
SQMSignal quality monitoring
RAIMReceiver autonomous integrity monitoring
TEXBATTexas Spoofing Test Battery
AWGNAdditive white Gaussian noise
ECEFEarth-centered Earth-fixed
ROCReceiver operating characteristic
SCERSecurity code estimation and replay

References

  1. Cavaleri, A.; Motella, B.; Pini, M.; Fantino, M. Detection of spoofed GPS signals at code and carrier tracking level. In Proceedings of the 2010 5th ESA Workshop on Satellite Navigation Technologies and European Workshop on GNSS Signals and Signal Processing (NAVITEC), Noordwijk, The Netherlands, 8–10 December 2010; pp. 1–6. [Google Scholar]
  2. Wen, H.; Huang, P.Y.; Dyer, J.; Archinal, A.; Fagan, J. Countermeasures for GPS signal spoofing. In Proceedings of the 18th International Technical Meeting of the Satellite Division of The Institute of Navigation (ION GNSS 2005), Long Beach, CA, USA, 13–16 September 2005; pp. 13–16. [Google Scholar]
  3. Humphreys, T.E.; Ledvina, B.M.; Psiaki, M.L.; O’Hanlon, B.; Kintner, P.M. Assessing the spoofing threat: Development of a portable GPS civilian spoofer. In Proceedings of the ION GNSS International Technical Meeting of the Satellite Division, Savannah, GA, USA, 16–19 September 2008. [Google Scholar]
  4. Warner, J.S.; Johnston, R.G. A simple demonstration that the global positioning system (GPS) is vulnerable to spoofing. J. Secur. Adm. 2002, 25, 19–27. [Google Scholar]
  5. Bhatti, J.; Humphreys, T.E. Hostile control of ships via false GPS signals: Demonstration and detection. Navigation 2017, 64, 51–66. [Google Scholar] [CrossRef]
  6. Shepard, D.P.; Humphreys, T.E.; Fansler, A.A. Evaluation of the vulnerability of phasor measurement units to GPS spoofing attacks. Int. J. Crit. Infrastruct. Prot. 2012, 5, 146–153. [Google Scholar] [CrossRef]
  7. Montgomery, P.Y.; Humphreys, T.E.; Ledvina, B.M. A multi-antenna defense: Receiver-autonomous GPS spoofing detection. Inside GNSS 2009, 4, 40–46. [Google Scholar]
  8. Jafarnia-Jahromi, A.; Broumandan, A.; Nielsen, J.; Lachapelle, G. GPS spoofer countermeasure effectiveness based on signal strength, noise power, and C/N0 measurements. Int. J. Satell. Commun. Netw. 2012, 30, 181–191. [Google Scholar] [CrossRef]
  9. Tanil, C.; Khanafseh, S.; Joerger, M.; Pervan, B. Kalman filter-based INS monitor to detect GNSS spoofers capable of tracking aircraft position. In Proceedings of the IEEE/ION PLANS Meeting, Savannah, GA, USA, 11–14 April 2016; pp. 1027–1034. [Google Scholar]
  10. Psiaki, M.L.; O’Hanlon, B.W.; Bhatti, J.; Shepard, D.P.; Humphreys, T.E. GPS spoofing detection via dual-receiver correlation of military signals. IEEE Trans. Aerosp. Electron. Syst. 2013, 49, 2250–2267. [Google Scholar] [CrossRef]
  11. Scott, L. Anti-spoofing and authenticated signal architectures for civil navigation systems. In Proceedings of the 16th International Technical Meeting of the Satellite Division of The Institute of Navigation (ION GPS/GNSS 2003), Portland, OR, USA, 9–12 September 2003; pp. 1542–1552. [Google Scholar]
  12. Kerns, A.J.; Wesson, K.D.; Humphreys, T.E. A blueprint for civil GPS navigation message authentication. In Proceedings of the IEEE/ION PLANS Meeting, Monterey, CA, USA, 5–8 May 2014; pp. 262–269. [Google Scholar]
  13. Humphreys, T.E. Detection strategy for cryptographic GNSS anti-spoofing. IEEE Trans. Aerosp. Electron. Syst. 2013, 49, 1073–1090. [Google Scholar] [CrossRef]
  14. Wesson, K.D.; Shepard, D.P.; Humphreys, T.E. Straight talk on anti-spoofing. GPS World 2012, 23, 32–39. [Google Scholar]
  15. Manfredini, E.G.; Dovis, F.; Motella, B. Validation of a signal quality monitoring technique over a set of spoofed scenarios. In Proceedings of the 7th ESA workshop on satellite navigation technologies and European workshop on GNSS signals and signal processing 2014 (NAVITEC 2014), Noordwijk, The Netherlands, 3–5 December 2014. [Google Scholar]
  16. Juang, J. Analysis of global navigation satellite system position deviation under spoofing. IET Radar Sonar Navig. 2009, 3, 1–7. [Google Scholar] [CrossRef]
  17. Xie, G. Principles of GPS and Receiver Design; Publishing House of Electronics Industry: Beijing, China, 2009. [Google Scholar]
  18. Broumandan, A.; Jafarnia-Jahromi, A.; Dehghanian, V.; Nielsen, J.; Lachapelle, G. GNSS spoofing detection in handheld receivers based on signal spatial correlation. In Proceedings of the Position Location and Navigation Symposium (PLANS), Myrtle Beach, SC, USA, 23–26 April 2012; pp. 479–487. [Google Scholar]
  19. Psiaki, M.L.; Powell, S.P.; O’Hanlon, B.W. GNSS spoofing detection using high-frequency antenna motion and carrier-phase data. In Proceedings of the 26th International Technical Meeting of the Satellite Division of the Institute of Navigation (ION GNSS+ 2013), Nashville, TN, USA, 16–20 September 2013; pp. 2949–2991. [Google Scholar]
  20. Nielsen, J.; Broumandan, A.; Lachapelle, G. GNSS Spoofing Detection for Single Antenna Handheld Receivers. Navig. J. Inst. Navig. 2011, 58, 335–344. [Google Scholar] [CrossRef]
  21. Broumandan, A.; Jafarnia-Jahromi, A.; Lachapelle, G. Spoofing detection, classification and cancellation (SDCC) receiver architecture for a moving GNSS receiver. GPS Solut. 2014, 19, 475–487. [Google Scholar] [CrossRef]
  22. Psiaki, M.L.; Humphreys, T.E. GNSS spoofing and detection. Proc. IEEE 2016, 104, 1258–1270. [Google Scholar] [CrossRef]
  23. Closas, P.; Fernndez-Prades, C.; Fernndez-Rubio, J. Maximum likelihood estimation of position in GNSS. IEEE Signal Process. Lett. 2007, 14, 359–362. [Google Scholar] [CrossRef]
  24. Parkinson, B.W. Global Positioning System: Theory and Applications; AIAA: Reston, VA, USA, 1996. [Google Scholar]
  25. Kay, S.M. Fundamentals of Statistical Signal Processing: Detection Theory; Prentice Hall: Upper Saddle River, NJ, USA, 1998. [Google Scholar]
  26. Kaplan, E.D. Understanding GPS: Principles and Applications; Artech House: Norwood, MA, USA, 1996. [Google Scholar]
  27. Borio, D.; Akos, D. Noncoherent integrations for GNSS detection: Analysis and comparisons. IEEE Trans. Aerosp. Electron. Syst. 2009, 45, 360–375. [Google Scholar] [CrossRef]
  28. Simon, M.K. Probability Distributions Involving Gaussian Random Variables: A Handbook for Engineers and Scientists; Springer Science & Business Media: Berlin, Germany, 2007. [Google Scholar]
  29. Gao, G.X.; Enge, P. How many GNSS satellites are too many? IEEE Trans. Aerosp. Electron. Syst. 2012, 48, 2865–2874. [Google Scholar] [CrossRef]
  30. Humphreys, T.E.; Bhatti, J.A.; Shepard, D.P.; Wesson, K.D. The Texas spoofing test battery: Toward a standard for evaluating GPS signal authentication techniques. In Proceedings of the 25th International Technical Meeting of The Satellite Division of the Institute of Navigation (ION GNSS+ 2012), Nashville, TN, USA, 17–21 September 2012; pp. 3569–3583. [Google Scholar]
Figure 1. MLE cost function in a scenario with eight authentic signals and eight spoofing ones.
Figure 1. MLE cost function in a scenario with eight authentic signals and eight spoofing ones.
Sensors 17 01532 g001
Figure 2. Three different cases when spoofing signals are present. The circles represent the PVT domains in which spoofing signals or authentic signals are present. The highest peak of the MLE cost function at ρ ^ 1 is superimposed by the signal components in the area emphasized by the dashed lines. (a) ρ ^ 1 is equal to ρ s ; (b) ρ ^ 1 is equal to ρ a ; (c) ρ ^ 1 is neither equal to ρ s nor to ρ a .
Figure 2. Three different cases when spoofing signals are present. The circles represent the PVT domains in which spoofing signals or authentic signals are present. The highest peak of the MLE cost function at ρ ^ 1 is superimposed by the signal components in the area emphasized by the dashed lines. (a) ρ ^ 1 is equal to ρ s ; (b) ρ ^ 1 is equal to ρ a ; (c) ρ ^ 1 is neither equal to ρ s nor to ρ a .
Sensors 17 01532 g002
Figure 3. MLE cost function after estimation-cancellation.
Figure 3. MLE cost function after estimation-cancellation.
Sensors 17 01532 g003
Figure 4. Implementation architecture.
Figure 4. Implementation architecture.
Sensors 17 01532 g004
Figure 5. Detection probabilities versus C / N 0 for different numbers of satellites and a fixed false alarm probability P f a = 10 - 6 . C / N 0 of all of the spoofing signals are 50 dB-Hz. ’T’ represents the theoretical results. ’NC’ represents corresponding noncoherent integration results. ’EC’ represents the estimation-cancellation results.
Figure 5. Detection probabilities versus C / N 0 for different numbers of satellites and a fixed false alarm probability P f a = 10 - 6 . C / N 0 of all of the spoofing signals are 50 dB-Hz. ’T’ represents the theoretical results. ’NC’ represents corresponding noncoherent integration results. ’EC’ represents the estimation-cancellation results.
Sensors 17 01532 g005
Figure 6. ROC curves for different numbers of satellites. C / N 0 of all of the authentic signals are 31 dB-Hz, and those of the spoofing signals are 50 dB-Hz. ’T’ represents the theoretical results. ’NC’ represents corresponding noncoherent integration results. ’EC’ represents the estimation-cancellation results.
Figure 6. ROC curves for different numbers of satellites. C / N 0 of all of the authentic signals are 31 dB-Hz, and those of the spoofing signals are 50 dB-Hz. ’T’ represents the theoretical results. ’NC’ represents corresponding noncoherent integration results. ’EC’ represents the estimation-cancellation results.
Sensors 17 01532 g006
Figure 7. Spoofing validation probabilities versus C / N 0 for different numbers of satellites and P F A = 10 - 6 .
Figure 7. Spoofing validation probabilities versus C / N 0 for different numbers of satellites and P F A = 10 - 6 .
Sensors 17 01532 g007
Figure 8. Detection probabilities versus code phase difference between spoofing and authentic signals for different numbers of satellites. C / N 0 of authentic and spoofing signals are 45 dB-Hz and 50 dB-Hz, respectively.
Figure 8. Detection probabilities versus code phase difference between spoofing and authentic signals for different numbers of satellites. C / N 0 of authentic and spoofing signals are 45 dB-Hz and 50 dB-Hz, respectively.
Sensors 17 01532 g008
Figure 9. (a) Ratio metric of signal quality monitoring (SQM) in Scenario 2; (b) SSE of RAIM in Scenario 2; the red dashed line denotes the threshold.
Figure 9. (a) Ratio metric of signal quality monitoring (SQM) in Scenario 2; (b) SSE of RAIM in Scenario 2; the red dashed line denotes the threshold.
Sensors 17 01532 g009
Figure 10. (a) Test statistics and threshold in Scenario 2; (b) Detection results in Scenario 2; results larger than 0.5 mean that there are evil signals. The red circles correspond to the results when seven signals are processed together, and the blue points correspond to the results when one signal is processed.
Figure 10. (a) Test statistics and threshold in Scenario 2; (b) Detection results in Scenario 2; results larger than 0.5 mean that there are evil signals. The red circles correspond to the results when seven signals are processed together, and the blue points correspond to the results when one signal is processed.
Sensors 17 01532 g010
Figure 11. (a) r 2 in Scenario 2; results larger than four indicate that consistent signals are detected in the residual signal and the spoofing attack is validated; (b) Biases of the user clock offsets from the clock offset in Epoch 0: δ t u = t u ( t ) - t u ( 0 ) . The green trace shows the receiver’s unspoofed response; the blue trace shows the receiver’s spoofed response; and the red dots show the recovered results.
Figure 11. (a) r 2 in Scenario 2; results larger than four indicate that consistent signals are detected in the residual signal and the spoofing attack is validated; (b) Biases of the user clock offsets from the clock offset in Epoch 0: δ t u = t u ( t ) - t u ( 0 ) . The green trace shows the receiver’s unspoofed response; the blue trace shows the receiver’s spoofed response; and the red dots show the recovered results.
Sensors 17 01532 g011
Figure 12. (a) Ratio metric of SQM in Scenario 2; (b) SSE of RAIM in Scenario 2; the red dashed line denotes the threshold.
Figure 12. (a) Ratio metric of SQM in Scenario 2; (b) SSE of RAIM in Scenario 2; the red dashed line denotes the threshold.
Sensors 17 01532 g012
Figure 13. (a) Test statistics and threshold in Scenario 6; (b) Detection results in Scenario 6; results larger than 0.5 mean that there are evil signals. The red circles correspond to the results when seven signals are processed together, and the blue points correspond to the results when one signal is processed.
Figure 13. (a) Test statistics and threshold in Scenario 6; (b) Detection results in Scenario 6; results larger than 0.5 mean that there are evil signals. The red circles correspond to the results when seven signals are processed together, and the blue points correspond to the results when one signal is processed.
Sensors 17 01532 g013
Figure 14. (a) r 2 in Scenario 6; results larger than four indicate that consistent signals are detected in the residual signals and the spoofing attack is validated; (b) Biases of user position in the z-coordinate from the position in Epoch 0: δ z u = z u ( t ) - z u ( 0 ) . The green trace shows the receiver’s unspoofed response; the blue trace shows the receiver’s spoofed response; and the red dots show the recovered results.
Figure 14. (a) r 2 in Scenario 6; results larger than four indicate that consistent signals are detected in the residual signals and the spoofing attack is validated; (b) Biases of user position in the z-coordinate from the position in Epoch 0: δ z u = z u ( t ) - z u ( 0 ) . The green trace shows the receiver’s unspoofed response; the blue trace shows the receiver’s spoofed response; and the red dots show the recovered results.
Sensors 17 01532 g014
Table 1. Detailed classification based on the numbers of spoofing and authentic signals in x and y .
Table 1. Detailed classification based on the numbers of spoofing and authentic signals in x and y .
No.Casex ρ ^ 1 y ρ ^ 2 rDetectionValidation
spfauthspfauth r 1 r 2
1Case 1>4>4= ρ s =0>4= ρ a >4>4
2>4>4= ρ s =0≤4 n d 1>4≤4×
3>4≤4= ρ s =0≤4 n d >4≤4×
4Case 2>4>4= ρ a >4=0= ρ s >4>4
5>4>4= ρ a ≤4=0 n d >4≤4×
6≤4>4= ρ a ≤4=0 n d >4≤4×
7Case 3>4≤4 ρ s ≠0≤4 n d ≤4 n d ×
8≤4>4 ρ a ≤4≠0 n d ≤4 n d ×
9≤4≤4 n d ≤4≤4 n d ≤4≤4 2×
1 n d means “cannot be determined”; 2 when the total number of signals is 4, no signal component will be reserved in y , and the detection will fail.
Table 2. Search range and step of the MLE-based positioning modules.
Table 2. Search range and step of the MLE-based positioning modules.
NumRange (m)Step (m)
1−50 ∼ 502
2−750 ∼ 75050
Table 3. Spoofing detection and validation performance in different spoofing scenarios of TEXBAT.
Table 3. Spoofing detection and validation performance in different spoofing scenarios of TEXBAT.
M SDP 1 (%) SDP M (%) Imp (%) SVP (%)
ds2779.797.317.682.5
ds3677.384.97.677.3
ds4864.978.713.861.2
ds5669.493.524.149.0
ds6646.481.835.471.5
ds7774.782.07.372.2

Share and Cite

MDPI and ACS Style

Wang, F.; Li, H.; Lu, M. GNSS Spoofing Detection and Mitigation Based on Maximum Likelihood Estimation. Sensors 2017, 17, 1532. https://doi.org/10.3390/s17071532

AMA Style

Wang F, Li H, Lu M. GNSS Spoofing Detection and Mitigation Based on Maximum Likelihood Estimation. Sensors. 2017; 17(7):1532. https://doi.org/10.3390/s17071532

Chicago/Turabian Style

Wang, Fei, Hong Li, and Mingquan Lu. 2017. "GNSS Spoofing Detection and Mitigation Based on Maximum Likelihood Estimation" Sensors 17, no. 7: 1532. https://doi.org/10.3390/s17071532

APA Style

Wang, F., Li, H., & Lu, M. (2017). GNSS Spoofing Detection and Mitigation Based on Maximum Likelihood Estimation. Sensors, 17(7), 1532. https://doi.org/10.3390/s17071532

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