1. Introduction
Acquiring accurate and reliable three-dimensional (3D) coordinates for a vehicle is of great interest in monitoring its operation for advanced driver assistance systems and for autonomous navigation of mobile robots. Vehicle coordinates include three distances for position and three angles for posture with respect to a global reference system on Earth surface, that usually employs North-East-Down (NED) local axes [
1].
A common possibility is the use of an Inertial Measurement Unit (IMU), which contain different sensors such as accelerometers, gyroscopes and magnetometers [
2]. For proper operation, these units require calibration once installed on the vehicle and to take into account local magnetic field variations. Knowing the initial position of the vehicle, global 3D coordinates can be obtained with an IMU and odometry, but the estimation of the spatial trajectory tends to deteriorate since the measurements include small deviations that accumulate over time [
3].
To avoid the growth of position uncertainty, a Global Navigation Satellite System (GNSS) receiver that make use of various global satellite constellations (North American GPS, Russian GLONASS, European Galileo and Chinese BeiDou) at once can be employed [
4]. However, absolute GNSS measurements over the Earth’s surface are subject to various types of errors that degrade their accuracy to the order of meters.
GNSS errors can be significantly reduced by incorporating differential corrections provided by a Satellite Based Augmentation Systems (SBAS) or a Continuously Operating Reference Station (CORS) [
5]. In this respect, one of the most effective techniques is Real Time Kinematics (RTK) that performs carrier-phase signal synchronization [
6] by using the RTCM (Radio Technical Commission for Maritime Services) communication protocol. Thus, GNSS receivers can operate in two different modes: RTK-fixed and RTK-float to indicate when they achieve or not centimeter accuracy, respectively.
Besides, multiple GNSS receivers can be installed onboard to enhance vehicle positioning [
5,
7]. In addition, a GNSS compass with two antennas can be employed to obtain heading [
8,
9]. Moreover, by differencing over time the GNSS measurements taken in motion, speed estimations [
10] as well as pitch and heading [
11] can be deduced.
In field robotics, the combination of GPS and IMU sensors has been a popular option to estimate 3D global coordinates accurately [
12]. A different strategy to achieve this objective was to mount the antennas of three high-cost GPS-RTK receivers on the roof of the vehicle [
13].
With modern GNSS receivers, the GNSS-IMU sensor combination [
14] and the synchronization of three low-cost GNSS-RTK devices [
6,
15] or three antennas in a single receiver [
16] have also been employed in automobiles. Moreover, by tightly coupling three GNSS-RTK receivers and an IMU, accuracy can be improved even more [
1,
17,
18].
This paper proposes a reliable sensor system that provides the position and posture of a vehicle by combining the measurements of four identical GNSS-RTK low-cost receivers. In this way, the main contributions are the following:
- The best geometrical configuration for three and four antennas to minimize position and posture uncertainty of a vehicle is deduced. 
- A redundant setup with four antennas is analyzed, so when the precision of one receiver degrades, reliable 3D coordinates can be still calculated in real-time. 
- A decentralized node architecture using the Robot Operating System (ROS) that integrates all the available measurements from the receivers is presented. 
Regarding the first point, although several antenna configurations have been deployed experimentally on cars, no previous work has performed a theoretical analysis to infer the best layout. This has not prevented two recent papers [
6,
16] from employing near-optimal configurations for their tests.
With respect to the second contribution, antenna redundancy was previously intended only to improve positioning precision [
5,
7], but in this paper it also serves to enhance attitude estimations for the vehicle and to tolerate faults on the GNSS receivers.
Regarding the third point, following a low-cost philosophy, it is employed an open-source software of common use in robotics with some already developed nodes in a mini computer instead of programming on specialized boards [
6,
15,
16].
The rest of the paper is organized as follows. Antenna arrangements with three and four GNSS-RTK receivers are discussed in the next Section. Sensor hardware, ROS programming and the optimal calculation of 3D coordinates are described in 
Section 3. Then, experiments on irregular terrain with the robotic platform Argo XTR are presented in 
Section 4, including comparisons with measurements from a high-end IMU. Finally, conclusions, acknowledgements, and references complete the paper.
  2. Spatial Configurations for the Antennas of the GNSS-RTK Receivers
Let 
 be the actual position of an antenna with respect to a global NED coordinate system:
      where 
 is the measurement produced by the receiver 
 at instant 
t and 
 is its associated error. The 
 coordinates correspond to north, east, and down displacements, respectively. The covariance matrix for 
 is given by:   
      
      where 
, 
 and 
 are the variances, whereas 
, 
 and 
 are the covariances.
For this analysis, it is considered that:
- The mean errors of the receivers along time are null, i.e., . 
- The errors of different receivers are independent, i.e.,  for . 
- All the receivers share the same covariance matrix, i.e., . 
  2.1. Three Receivers Optimal Configuration
To obtain the optimal configuration for the triangle formed by three GNSS-RTK antennas, its associated position and posture uncertainty should be minimized. In this case, it is also assumed that:
- The distances  and  of the second and third antenna with respect to the first antenna, respectively, are constant values determined without uncertainty. 
- The angle  between the directions given by  and  is also known certainly on the plane that contains the three antennas. 
The centroid of the triangle formed by the antennas:
        can be estimated from the measurements of the receivers as:
The covariance matrix for 
 is calculated as:   
        
        where the position uncertainty of the geometric center of the triangle is reduced by three with respect to each vertex.
Regarding the posture in space of the triangle, the direction cosines of the lines between two antennas are given by the unitary vectors:  
        
        where the corresponding covariance matrices are: 
Thus, the spatial uncertainty of the direction cosines can be reduced by separating the antennas as much as possible. But  and  are inherently limited by the available space on the roof of the vehicle. Furthermore, to balance posture uncertainty in both directions, these distances should be selected equal: , so that  and .
The direction cosine of the normal vector 
 to the plane defined by the three antennas is given by the unitary vector from the cross product of 
 and 
: 
        as long as the three antennas are not aligned to avoid 
, where 
 will be indeterminate.
By using Taylor series expansion [
19], 
 can be approximated by:
        where 
J is the time-dependent Jacobian matrix:
The error 
 can be minimized regardless of vehicle posture by choosing 
. In this case, the covariance matrix for 
 can be approximated by:
Finally, the rotation matrix is obtained from the direction cosines as . Roll, pitch and yaw angles can be deduced from R and represent rotations with respect to ,  and  axis, respectively.
To summarize, the best configuration to minimize position and posture uncertainty with three GNSS-RTK antennas is to form a right-angled triangle with two identical sides of the maximum possible length 
d (see 
Figure 1).
  2.2. Four Receivers Optimal Layout
The optimum for four receivers would consist of placing the fourth antenna orthogonal to the plane defined by the remaining three at a distance 
d of the first antenna, where its centroid:
        does not coincide with the geometric center of the underlying cube (see 
Figure 2).
Assuming perfect placement of the fourth receiver with respect to the triangle:
        which can be calculated directly from measurements as:
        and can be merged with the estimation (
14) to decrease posture uncertainty even more. Furthermore, this reduction can also be applied to 
 (
7) and 
 (
9) with their corresponding normal vectors formed by their respective ortogonal planes: 
 and 
, respectively.
  2.3. Four Receivers Redundant Configuration
In this paper, an additional fourth receiver is added to the optimal three-receivers configuration to form a square of side 
d on a planar surface (see 
Figure 3). This is a redundant arrangement that is easier to mount on the roof of an automobile (see 
Figure 4) than the optimal one of 
Figure 2. The local coordinate system has its origin in 
 with axes 
, 
 and 
 as defined by (
7), (
9) and (
13), respectively.
In 
Figure 4, the longitudinal and transverse axes of the car coincide with 
 and 
, respectively. The vertical axis 
 is not displayed but it would be pointing downwards. This figure also shows the position of a radio antenna, denoted by the letter R, to receive RTK corrections from a CORS.
The proposed redundancy is useful in two different ways. Firstly, position and posture uncertainty can be reduced further than with three receivers. Secondly, if the precision of one of the receivers deteriorates, the rest of receivers can still provide a reliable position and posture estimation for the vehicle.
Regarding the first advantage, when all the measurements are available, its centroid 
 (
18) can be estimated as:  
        
        whose covariance matrix is divided by four, instead of by three (
5). Furthermore, the direction cosines 
 and 
 can be estimated by using one side of the square and its opposite:
        that represents half uncertainty of (
10) and (
11). This reduction directly benefits to the covariance matrix 
 (
17) of the direction cosine 
:
        where 
.
The second advantage comes from the fact that with a three-antenna configuration, there is no possibility to obtain the complete set of six coordinates for the vehicle when one of the receivers fails. However, the proposed sensor system can keep working with the remaining three receivers. In this case, to obtain the center of the square, instead of the triangle centroid (
4), only two measurements from opposite vertices can be employed:
		
	  which implies that 
, i.e., twice position uncertainty with respect to four available measurements (
22).
  3. Sensor System
In addition to the four low-cost GNSS receivers and their corresponding antennas, the sensor system includes a mini computer to obtain the 3D position and posture of the vehicle (see 
Figure 5).
The chosen GNSS-RTK receiver is the SparkFun GPS-RTK2 (
https://www.sparkfun.com/products/15136, accessed on 28 July 2021) board, which is based on the compact ZED-F9P module from U-blox. The receiver does not only provide geodetic coordinates (longitude, latitude and height), but also ECEF (Cartesian coordinates with respect to Earth center) and NED coordinates with respect to a nearby CORS to obtain centimeter accuracy with an output rate of 8 
.
Each receiver is connected to a multi-band antenna ANN-MB-00 (
https://www.sparkfun.com/products/15192, accessed on 28 July 2021) from U-blox. To avoid multi-path problems, the magnetic base of each antenna is mounted on a steel ground plate.
The computer communicates with each receiver through different Universal Serial Bus (USB) ports. The Internet connection of the computer is used to get differential correction data via the standard protocol NTRIP (Networked Transport of RTCM via Internet Protocol) through the Andalusian public positioning network [
21].
  ROS Programming
The developed ROS software consists of a number of independent nodes, each of which communicates with others using topics under a publish/subscribe messaging model (see 
Figure 6).
The 
ntrip_ros (
https://github.com/ros-agriculture/ntrip_ros, accessed on 28 July 2021) node connects to a nearby CORS to get RTCM streams through internet and to publish them into the topic 
RTCM. Each receiver 
i has associated a driver node (
https://github.com/KumarRobotics/ublox, accessed on 28 July 2021) named 
gnss_i that is subscribed to this topic to receive differential corrections via callbacks. These nodes publish NED coordinates on its own topic 
NED_i along with a time stamp and three accuracy estimates (each one 
).
Then, the reliable_estimator node receives all the messages from the four NED_i topics and computes the six 3D coordinates with three or four synchronized measurements. Finally, it publishes the current pose into the 3D_POSE topic, making this data available for any navigation node on the ROS system.
All the receivers weight the same to produce vehicular position and attitude in real-time. When the accuracy of one receiver degrades, it is completely discarded from computations.
For calculating the global position of the centroid 
 of the square (
21), (28) or (29) are employed depending on the number of valid GNSS-RTK measurements. For posture computation, the closed-form method by Horn [
22] is applied with a scale factor of 1. Instead of quaternions, an orthonormal rotation matrix 
R [
23] is obtained that minimizes the following cost function:
        where 
 and 
 are the relative positions of the antenna 
i and the centroid of the square with respect to the local reference system, respectively. This represents a least squares problem that can be solved with three or four valid measurements. Lastly, the roll, pitch and yaw angles with respect to the global NED axes are extracted from the resulting rotation matrix [
17].
  4. Experiments with the Rover Argo XTR
The rover Argo XTR is a battery-powered unmanned land vehicle that allows extreme mobility with a low center of gravity and amphibious capability (see 
Figure 7). It features skid-steer traction with eight low-pressure 24-inch tires, a top speed of 16 km h
−1 and zero turning radius. The robotic rover can be controlled via a follow-me system with a 2D laser scanner or via remote teleoperation with a joystick and a line-of-sight wireless link.
The proposed sensor has been mounted on the rear deck of the vehicle. The four antennas are tied to the side rails forming a square of 
 on the side (see 
Figure 7). For comparison purposes, a fifth antenna has been installed at the center of the square together with the high-end AHRS400CC-100 MEMS IMU from Crossbow with an output rate of 60 
 [
24].
The Málaga broadcast station located    away is employed to get differential corrections RTCM 3.1 through 4G internet connection and it is considered the global NED reference system in the following experiments.
  4.1. Calibration Test
This test was carried out by recording the RTK-fixed measurements of the five GNSS receivers during three hours with the rover stopped on an almost horizontal parking lot. This experiment serves to characterize the covariance matriz 
C for the positioning errors. To this end, the mean NED coordinates are calculated for each receiver and the difference of each measurement with respect to its mean value is considered as an error. Then, by using (
2):
        where it can be observed almost null covariances and a standard deviation in the 
z coordinate (
) much greater than in the 
x (
) and in the 
y (
) coordinates.
Moreover, the relative location of each antenna 
 can also be accurately estimated with the computed mean values (see 
Table 1). It can be observed small positioning errors on the square with the fifth antenna centered and 166 
 below the rest of antennas. 
Table 1 also includes the local position of the centroids of the square 
 for (
30) when using four or three receivers.
  4.2. Reliability Test
This test was performed with the vehicle stopped in the countryside as shown in 
Figure 7. One by one, each GNSS antenna was partially blocked with a metallic cover during one minute approximately to test sensor reliability.
Figure 8 shows the estimation of NED coordinates when using all (
21), the first and the fourth (28) or the second and the third (29) receivers. Similarly, 
Figure 9 displays the estimation of the three angular coordinates with all the combinations of three and four receivers. In both figures, it can be clearly observed significant estimation changes when an antenna was temporarily blocked.
 The mean accuracy provided by each receiver is shown in 
Figure 10 (up), where it can be observed successive antenna covering, in this order: 3, 1, 4 and 2. Apart from checking the RTK-fixed mode, these values can be employed as a fail indicator for each receiver. However, there is a time period between 325 
 to 350 
 when the indicator for the first receiver does not detect any error but position and posture estimations were inaccurate.
An additional accuracy indicator is the error in calculating the perimeter of the square from measurements with respect to the data of 
Table 1 ( 
 ). As it is shown in 
Figure 10 (down), precision degradation can be better detected by using this complementary indicator. Thus, by comparing individually the distances of each vertex with respect to the rest, outlier measurements can be identified adequately when present.
Furthermore, in 
Figure 8 and 
Figure 9, it can be observed that the estimations that do not include the failing measurement maintain high accuracy. For example, when the precision of the first receiver degrades in the interval between 290 
 to 350 
, good position and posture estimations are provided by the second and third receivers, and by the second, third and fourth receivers, respectively. Therefore, overall accuracy for the sensor system can be maintained by properly detecting a single failure and excluding it from computations.
  4.3. Dynamic Test
Several experiments were performed by teleoperating the robotic rover on rough countryside. 
Figure 11 presents an aerial view of one of them using geodetic coordinates for the grid. The beginning and the end of the path, that almost coincide, are marked with a green square and a red circle, respectively. In total, the vehicle travelled 644 
 at a mean speed of 
  −1.
Figure 12 shows the three NED coordinates obtained by the proposed sensor system and by the fifth receiver at the center of the square formed by the antennas. There are no appreciable differences between both estimations, with the exception of the step of 
  in the down coordinate (see 
Table 1). Altogether, the rover went up and, then, under  12 
.
 Figure 13 displays the rover posture obtained by the GNSS setup and by the onboard IMU. It can be observed high peaks in the pitch (above 15°) and the roll (above 25°) angles, as well as several complete turns in the yaw angle during the test. Both estimations are very similar, which confirms the good performance of the proposed sensor system.
   5. Conclusions
A low-cost sensor system composed of four GNSS-RTK receivers connected to a mini computer has been presented in the paper. The placement of three antennas on a vehicle have been analyzed to reduce the uncertainty associated to position and posture estimations with respect to a global reference system. The redundant fourth receiver allows to improve estimations even more and to maintain accuracy when the precision of one of the receivers deteriorates.
Static calibration and reliability tests have been performed with the sensor system mounted on the ground rover Argo XTR. Dynamic experiments on countryside show that this new sensor, in addition to produce reliable positioning, can effectively substitute a high performance IMU to obtain accurate vehicular roll, pitch and yaw angles in real-time.
Future work includes characterizing the achieved pose precision with the robotic rover as well as developing ROS nodes for integrating the proposed sensor system with an IMU for GNSS-denied environments.