1. Introduction
The Global Navigation Satellite System (GNSS) has, since its introduction in 1978, revolutionized several industries, such as aviation, transportation and agriculture, with a continued increase in the number of GNSS-enabled devices for the foreseeable future. Most of these devices make use of the positioning capabilities provided by GNSS and show that there is a strong and dynamic market for precise positioning capabilities [
1].
A single-frequency GNSS receiver can estimate its position with an accuracy of less than 10 m. To improve these results, high-quality dual-frequency GNSS receivers can attain position solutions with an error below 1 or 2 m [
2]. These receivers are usually very expensive, on the order of thousands of euros, although newer low-cost receivers have recently appeared on the market [
3].
While these receivers can be enough for many applications, others require an accuracy down to the decimeter or centimeter level [
3,
4]. To solve this problem, a GNSS receiver can employ differential methods such as Differential GNSS (DGNSS) and Real-Time Kinematics (RTK), which, for absolute positioning, make use of a static reference receiver, a base station, with a known position. DGNSS positioning, in its more usual form, is based on comparing the pseudorange obtained by the reference station to a given satellite with the expected pseudorange given the same satellite and the previously surveyed reference station position. Given the spatial correlation of the GNSS signals, the pseudorange error of the reference station to a given satellite will be similar to that of another receiver nearby, and as such a correction factor can be obtained and applied to the received pseudoranges of the rover receiver. In RTK, the process is similar, but instead of using only pseudoranges, the positioning is based on the measurement of both the pseudorange and carrier phase of the received signals. A reference station with a known position creates a set of carrier phase measurements that can then be transmitted to a rover receiver, which in turn will create a Double Difference solution and solve the the integer ambiguity problem of the carrier phase observable, allowing for much more precise results than those possible with simply pseudoranges [
2]. It should be noted, however, that this only applies to RTK usage for absolute positioning. In the case of relative positioning using RTK, as with attitude estimation, the position estimate of the base station is unnecessary; however, that application is outside of the scope of the present paper.
The problem this paper intends to tackle is how to obtain a precise estimate for the position of a base station, a so-called auto-survey, which then can be used to obtain the necessary corrections for a differential positioning system. This problem is part of the “Survey Phase” illustrated in
Figure 1 and
Figure 2 and a critical part of the entire differential positioning system. Current research trends in the GNSS precise static positioning area are focused on the application of Precise Point Positioning (PPP) [
5,
6,
7] for the problem of static receiver positioning. If a base station already exists, both RTK [
3,
8,
9] and DGPS [
10] can also be used for determining the position of a new base station. However, these methods require external communications, usually in the form of internet access or radio links as well as at least one already existing base station, making them unsuitable for remote applications and/or for deployment in developing countries. In an attempt to solve this problem, this paper aims to characterize position estimation methods that require no external connectivity and can be used in low-cost setups, with regards to both the precision and time of convergence of the position solution. While high-end receivers can output not only pseudorange and carrier phases but also Doppler and signal-to-noise ratios, for example, the research presented in this paper was restricted to those observables that are guaranteed to be present in low-end receivers. For the position estimation, four positioning methods were chosen: Least Squares (LS), Weighted Least Squares (WLS), Extended Kalman Filter (EKF) and Unscented Kalman Filter (UKF). The first two are based on the Least Squares method of data fitting and attempt to obtain the best position solution possible for a set of observations in a given instant, with no regards for previous observations. The other two methods are based on the theory of the Kalman Filter and provide a way to incorporate previous measurements in the current position estimate, as well as including extra information regarding the receiver’s dynamics. Besides these methods, a code-smoothing algorithm, the Hatch Filter, was also implemented in order to use carrier phase measurements to improve the pseudorange measurements. Finally, a position threshold filter based on the standard deviation of the estimates was implemented.
The novelty of this paper is that it not only attempts to fill the gap of a complete comparison between these methods using modern low-cost receivers, it also intends to demonstrate the viability of these methods for DGNSS/RTK base station auto-survey using only the measurements available with low-cost single-frequency receivers capable of raw data output By characterizing and benchmarking the time and precision obtained using short-term surveys for the base station position in a completely autonomous fashion, it aims to provide information regarding the trade-off between the survey time and precision of the position estimate, as well as analyzing its impact on the positioning accuracy of a rover receiver. The low-cost, fully-autonomous approach has applicability in several areas where the required position estimate precision is greater than what is obtainable with a single, low-cost receiver but cannot justify the added expense of a high-performance receiver, as well as temporary applications that, by their nature, require a quick survey period for the base station. Such applications can, for example, include the following:
Non-professional or associative sporting events, such as orienteering or nautical sports;
Forestry applications that do not necessitate permanent base stations for monitoring and registry activities;
Use of drones in temporary or remote activities such as power line monitoring or the monitoring of forest or crop areas;
Agricultural applications for more precise crop dusting and monitoring using airplanes and helicopters, where the the expense of a full precision-agriculture suite of machinery is prohibitive for the owners;
Other temporary activities that are performed in correction-denied areas that do not require centimetric precision.
While PPP provides better precision for the problem of single-receiver positioning, it also requires access to external data that must be obtained either a priori or during the survey; in comparison, our methodology is totally autonomous, and this paper aims to show it is a viable alternative. In addition, the proposed approach allows the usage of very low-cost processors for the positioning algorithm, since the pseudorange-only approach is computationally much simpler due to not having to solve the integer ambiguity problem, as well as including computationally simple smoothing and filtering methods. As a result, the proposed methodology leads the way to lower entry costs for precise position estimation in remote areas with no connectivity or where the required communication systems are expensive. It is worthy of note that, while this paper worked only with GPS measurements, its methodology can be easily applied to other GNSS systems, which should improve the position estimate accuracy [
11,
12].
2. Materials and Methods
2.1. GPS Observables
In this paper, the only GPS observables used are the pseudorange and carrier phase as given by a GPS receiver capable of raw data output.
2.1.1. Pseudorange
For a satellite–receiver pair, let
be the true range from the receiver to the
i-th satellite. This range can be calculated from the transit time of the GPS signal; however, both receiver and satellite present some errors in their clocks,
and
, respectively, which means that the transit time calculation yields a range different from the true range. Other errors, such as the tropospheric and ionospheric delays,
and
, respectively, and multipath errors,
, also add to this difference. This new distance is called the pseudorange and is given by [
13]
where all terms are in units of meters and
corresponds to other unmodeled errors. The true range
can be given by [
2]:
where
are the receiver coordinates, and
are the
i-th satellite coordinates.
2.1.2. Carrier Phase
Another observable is the phase of the GPS carrier signal, which can be measured with a resolution on the order of millimeters but is ambiguous by an integer number of cycles, also called integer ambiguity,
. By multiplying the carrier phase by the wavelength of the GPS signal and adding the same errors as the pseudorange model, the full model of the carrier phase observable, in units of meters, can be written as [
13]
where
is the carrier phase observable in meters, the modeled errors are equal to those in Equation (
1), and
denotes the unmodeled errors in the carrier phase.
2.2. Position Determination
2.2.1. Least Squares
Combining the pseudorange model of Equation (
1) with Equation (
2) and assuming the modeled errors have been removed from the pseudorange measurement, the pseudorange model can be rewritten as [
2]
which is an equation with four unknowns: the receiver coordinates in an ECEF frame,
, and the receiver clock offset,
. In order to solve this equation, at least four independent measurements are required, after linearizing the equations.
Since Equation (
4) is non-linear, Taylor’s series expansion can be applied to the satellite–receiver range, with the linearization being conducted around an initial receiver position estimate
[
14]. By applying this linearization to Equation (
4), it yields [
14]
where
is the satellite–receiver distance for the initial position estimate. Since the problem requires at least four measurements, the previous equation can be rewritten in matrix form
or, in a more compact notation,
Finally, the Least Squares solution of this equation is
2.2.2. Weighted Least Squares
The Least Squares solution of Equation (
8) is taken with the assumption that the errors of the pseudorange measurements from all satellites have the same variance, which might not correspond to reality. To solve this, a weighting matrix, corresponding to the inverse of the measurement error covariance matrix, can be applied to the Least Squares solution [
15].
While there are several possible formulations for the measurement error covariance, in this paper, the approach used in [
16] is adopted. Let
be the weighting matrix. Assuming uncorrelated measurements with a standard deviation given by
where
is the broadcasted user range accuracy for satellite
i and
is the satellite elevation angle, the weighting matrix can be constructed as a diagonal matrix with elements
Using this matrix, the Weighted Least Squares solution can be written as [
15]:
2.3. Extended Kalman Filter
The Extended Kalman Filter (EKF) is another possible method to obtain a position estimate. This method works in discrete time, , and for each iteration k of the filter, there are two steps:
Prediction, where the state vector is estimated using the observations from the previous iteration;
Filtering, where is estimated using the state vector estimate of the prediction step and the current observations.
For the EKF, two different models are required: A dynamics model, which describes the receiver dynamics, and an observations model, which describes the relationship between the receiver state vector and the observations.
2.3.1. Dynamics Model
There are several possible models for the receiver dynamics. In this paper, the P model for the EKF was implemented, as the reference receiver whose position is to be estimated is in a static, fixed position. In this model, the state vector
, state transition matrix
, and the noise covariance matrix
are given by [
17]
where
and
are associated with the Allan variance parameters. In the case of a low-cost temperature-compensated crystal oscillator, those parameters are approximated by [
17]
The noise covariance matrix of the discrete-time dynamics model,
, can be obtained from Equations (
13) and (
14):
with the clock variances multiplied by
to convert the clock errors to units of meters.
2.3.2. Observations Model
In the EKF, the non-linear navigation equations are linearized in order to construct the observations model. The observations equation is given by
where
is the measured pseudorange vector with
observations,
the observation noise and
is the navigation equation vector composed of
n instances of Equation (
4). The navigation equations can be linearized by obtaining the Jacobian matrix of
, which yields the observation matrix,
. For the case of
n observations, this matrix yields
where
is the satellite–receiver range, taken at the estimated position, given by Equation (
2)
The last parameter of the observations model is the observation noise covariance matrix,
. In this paper, since the measurements are considered uncorrelated, the noise covariance matrix is reduced to a diagonal matrix, given by
2.4. Unscented Kalman Filter
The Unscented Kalman Filter (UKF) is another implementation of the Kalman Filter for non-linear systems. However, instead of linearizing the non-linear system around a point, it computes the statistics of the state random variables, using a function called the Unscented Transform (UT), in order to approximate the state distribution of the non-linear function [
18]. As such, the only difference between the EKF and UKF liess in its observations model, keeping the entire dynamics model from the EKF.
Let be a non-linear function, where is a vector of Gaussian random variables with an expected value; i.e., mean, and covariance matrix . The UT of this function consists in taking a set of samples from the random variable , applying the non-linear function to this set of points, and then obtaining a new set of statistics for the transformed random variable, which will also be Gaussian.
The points used in the UT are called sigma points and together form the sigma vector,
. For a given iteration
k, these points are given by [
18]
where
n is the size of
,
is the scale factor of the sampling,
designates the
i-th line of
and
can be obtained by the Cholesky decomposition of
. The resulting sigma vector is then a matrix of
, where each line is a set of sigma points for a given element of
. The scaling factor
is used to adjust the spacing between sample points and their weight in the statistics of the transformation and can be either positive or negative. For the symmetrical sampling case [
18],
After the sampling, the sigma points are propagated through
and then the statistics of the resulting vector can be obtained by means of a weighted average [
18], from which the mean and covariance matrix can be determined using
where the weight values
are given by
2.5. Hatch Filter
While the pseudorange measurements are unambiguous but imprecise, the carrier phase measurement is very precise but ambiguous. One method to apply carrier phase measurements without explicitly solving the integer ambiguity problem is to use those measurements to smooth the pseudorange measurements—so-called Carrier-Smoothed Code (CSC) techniques. One of these techniques is the Hatch Filter.
The time-differencing of the carrier phase measurement, in its error-free model, is given by [
19]
where, by means of differencing, the integer ambiguity is cancelled out. Then, the weighting factors
for the Hatch Filter are given by
The weighting factor must be initialized in its first iteration, which can be accomplished by using the pseudorange measurement in this iteration, corresponding to making
. Finally, the Hatch Filter equation is
where
is the averaging constant and defines the averaging interval for the filter. The averaging constant is usually set as 0.01 or 0.02 for smoothing intervals of 100 or 50 s respectively, for measurements at the rate of 1 Hz. It should be noted that, since this filter uses the time-differencing of the carrier phase measurements, it must be reset whenever a cycle slip occurs to account for changes in the integer ambiguity.
3. Results
3.1. Experimental Setup
For this paper, two different 24 h surveys were used. The first survey used GPS data from the International GNSS Service (IGS), captured using a geodetic-grade receiver in ESA’s Malargüe Satellite Tracking Station, in Argentina [
20,
21]. The second survey was conducted at the GNSS Laboratory of Instituto de Telecomunicações, in Lisbon. Data collection for this survey was performed using two different types of receivers: two u-blox 6T receivers from u-blox (Thalwil, Switzerland) with NovAtel GPSAntenna Model 521 antennas from Novatel Inc. (Calgary, Canada) and an Ashtech ProFlex 500 receiver with an AT1675-7M antenna, both from Ashtec, now Magellan (San Dimas, California, U.S.A.). These receivers were connected to a laptop computer which provided both serial communication handling and internet protocol (IP) communication. The resulting surveys were saved in RINEX 3.02 format. The two u-blox receivers were also used for a DGPS test based on the initial results of this paper. In this setup, the antenna designated RF2 worked as base station, while the antenna RF6 worked as a rover (the naming scheme of the antennas is specific for the IT GNSS Laboratory and has no correlation with GNSS marker names). The data collection was performed in clear meteorological conditions to avoid signal degradation and to provide a good performance baseline. It should be noted that these conditions correspond to the expected real-world conditions for the expected uses of this methodology, so there is a good expectation of obtaining comparable results.
For all the positioning methods, the ionospheric and clock modeling used is as defined in [
22], and the tropospheric modeling follows that in [
23].
3.2. Hatch Filter Averaging Constant Determination
To obtain the Hatch Filter averaging constant that best fits the four different methods, four values were tested: 0.005, 0.01, 0.015, and 0.02. The results are presented in
Table 1. It was observed that a higher value improves the LS and WLS mean error, at the cost of a slightly decreased precision, but only at the decimeter level. For the EKF and UKF, a lower value for the constant yielded better results in all metrics, but in the order of millimeters. A middle-ground value of
was then chosen for the rest of the simulations in order to quantify the impact of the Hatch Filter in the positioning methods.
3.3. Base Station Antenna Position Determination
Using the previous positioning methods, the position of antenna RF2, from here on also designated as the base station, was measured for the entire survey. The obtained results are presented in
Table 2.
From these results, it is clear that both EKF and UKF present a much more precise and accurate position solution, with an error below the meter level. The Hatch Filter also results in a lower spread for the LS and WLS results but produces a slightly higher mean error, while for the EKF and UKF, the effect is opposite.
3.4. Convergence over Time of the Position Solution
Another important metric is the time necessary for the position solution to converge to below a given error threshold. As such, the mean error over time was computed and is presented in
Figure 3 and
Figure 4.
From here, it is clear that the Hatch Filter does not produce significant changes to either of the mean error dynamics. Furthermore, while the EKF and UKF show a higher initial error, that error falls to values below those of the LS and WLS in only a few hours. From here, a clear trend of more accurate results for the EKF and UKF can be seen, with a lead for the UKF. It should be noted that there is an increase in the mean error after approximately 13 h of the survey; most likely, that is the result of constellation changes, as can be seen from
Figure 5, where there is a jump in the GDOP parameter to much higher values.
3.5. Position Estimate Filtering Using a Threshold
To improve the mean position estimate, a threshold filter based on the standard deviation,
, of the position solutions was used, with two different thresholds:
and
. This filter works by taking the mean and standard deviation of the position estimates during the first hour and then uses those parameters to filter outliers in the data set, continuously updating the mean and standard deviation after the first hour. The results are presented in
Figure 6,
Figure 7,
Figure 8 and
Figure 9.
From these results, it is seen that for the 2 threshold, the EKF and UKF present a lower mean error but allow greater variation in the position solutions; meanwhile, for the LS and WLS, this greater variation allows an increase in the estimate error. For the 1 threshold, the results show significantly smaller variations for all methods but an increase in the mean error.
3.6. Final Proposed Positioning Method
In order to obtain a final positioning method, the combination from the previous results that yielded the best overall performance was chosen. For the LS and WLS, this corresponds to the case without threshold filtering and with a Hatch Filter with
; In the case of the EKF and UKF, it is the case with a 2
threshold and a Hatch Filter with
. The error metrics in these conditions are presented in
Table 3 and the mean error for the whole survey is given in
Figure 10.
While using a Hatch Filter for the LS and WLS increases the mean error slightly, it also reduces the noise in the position estimates significantly, allowing for much more precise, even if slightly less accurate, position estimates; for this reason, it was opted to be included in the final proposed method.
3.7. Performance Comparison with Existing Auto-Survey Methods
In order to benchmark the results of the proposed methods, they were compared against known auto-surveying methods. To this end, the survey-in mode of the u-blox 6T receivers was used, as well as the static EKF positioning method of RTKLIB [
24] using the ProFlex 500 as a receiver. These surveys were done in the same conditions and for the same time, and the results are presented in
Figure 11.
Comparing these results with the results presented in
Figure 3 and
Figure 4, it can be seen that the EKF and UKF methods proposed provide a significantly better estimate than the survey-in mode, and, although worse, within 25 cm, after roughly 4 h, of the results obtained with the ProFlex 500 receiver, which is a much higher quality receiver than the u-blox 6T used in the survey.
3.8. DGPS Test
As a final test of the proposed methods, a DGPS test using a Double Difference DGPS setup as defined in [
2] was performed. The choice of DGPS for the test of the proposed methods, instead of RTK, stems from the fact that, in the present paper, only pseudorange-based positioning was performed, which makes DGPS the most suitable method to benchmark the results of the present research. This test used the u-blox 6T receiver connected to an RF2 antenna from the previous tests as a base station, and another, identical receiver–antenna pair as a rover, with the antenna designated as RF6. This test took the mean position estimate of the base station since the start of the survey at 4 h intervals, using both EKF and UKF to estimate the base station position, and used that estimate to determine the rover receiver during a 4 h survey. The resulting mean error is presented in
Table 4, with the rover position error during the survey presented in
Figure 12 and
Figure 13.
4. Discussion
To characterize the performance of several methods for the auto-survey procedure of a GNSS base station, the LS, WLS, EKF, and UKF methods were tested using data from a 24 h survey. To enhance the results of these methods, both a carrier-smoothed code method, the Hatch Filter, and a threshold filter were also analyzed.
The analysis of these results shows a very clear benefit of the EKF and UKF compared to the LS and WLS, with the UKF showing slightly better results than the EKF. From these results, the LS and WLS do not appear to be viable auto-survey methods; hence, the EKF and UKF should be used for this purpose. In addition, while the UKF shows a slightly better result than the EKF, it also has higher computational complexity due to the sampling of the sigma points and their propagation through the non-linear function.
Comparisons with existing auto-survey methods show that the EKF and UKF provide significantly better results when compared to the survey-in algorithm of the u-blox 6T receiver but show a worse estimate than that of the ProFlex 500 receiver; this is to be expected, since the u-blox 6T receiver used is an low-cost, single-frequency receiver when compared to the geodetic grade, dual-frequency ProFlex 500. It should be noted, however. that the EKF and UKF mean position estimate is still very close to that of the much more expensive ProFlex 500 receiver, with both having decimeter-level accuracy.
When applied to a DGPS setup, the good performance of the EKF and UKF methods for auto-survey can be seen, with the test showing estimates with error of about 1 m or less for the rover position for all auto-surveys using the UKF and slightly worse results for the EKF. These results are promising, and further research could improve them, allowing for even greater precision.
Another important conclusion is that there is a precision threshold at roughly the 4 h mark, with only marginal improvements for longer surveys. This result is important for the stated applications of the presented methods, as it can be used, together with the estimate precision data, to help the intended audience of this paper guide planning and logistics for said activities to better account for the auto-survey procedure without requiring an arbitrarily long survey time.
These results show that low-cost GPS base stations are achievable with inexpensive receivers and small survey windows, without requiring extensive surveys, high-end survey equipment, or other external inputs and still provide meter-level or below accuracy for rovers. This opens the possibility of creating very low-cost GPS base stations for differential positioning methods without requiring external augmentations, paving the way for the use of precise GPS position estimation in activities that cannot justify the added cost of high-precision receivers and in remote and GNSS-underserved areas at a fraction of the cost of a commercial high-end receiver.