1. Introduction
With the development of smart cities, navigation and positioning techniques are now more important in daily life. However, it is extremely difficult to improve the accuracy of navigation and position with existing satellite navigation systems, Inertial Navigation Systems (INS), and other navigation systems. The services required by smart cities, such as autonomous vehicle driving and unmanned aerial vehicles, require the support of high-precision navigation and positioning services. The existing navigation and positioning technology mainly improves the accuracy of navigation and positioning by improving the signal quality of satellite navigation systems [
1], enhancing navigation signal strength [
2], map matching [
3], ground station assistance [
4], and so on. These techniques can significantly improve positioning accuracy in sparsely populated areas. In urban environments, it is difficult to substantially improve the positioning accuracy in ill-conditioned wireless environments due to the multipath effect and the high-rise effect of the building. However, it is theoretically feasible to improve positioning accuracy through cooperative locations among multi-user terminals due to the large number of terminals. A simple cooperative positioning method based on a wireless sensor network was proposed by Ziming et al. [
5], where nodes broadcast their position and the user terminal calculates the centroid of the reference point of the received broadcast signal and then takes this as the estimation of the terminal position. A semi-definite programming (SDP) method for collaborative positioning and achieved high robustness in different topological networks was proposed by Monir and Michael [
6]. However, they did not consider the sensor user’s own positioning ambiguity problem. A Second-Order Cone Programming (SOCP) model is proposed by Slavisa et al. [
7], which can sacrifice a certain positioning accuracy in exchange for a faster calculation speed. However, it did not consider the impact of ranging error on the positioning results. The positioning accuracy decreases rapidly when the ranging error is larger. Fabian studied co-location based on measurement selection sequences and proposed a series of methods to solve the ranging error in co-location but also ignored the positioning error of cooperative nodes [
8]. A co-location model approaching the lower limit of positioning error in a non-line-of-sight environment and designed a series of algorithms to solve it [
9]. However, this method cannot obtain the global optimal solution, which leads to an increase in the positioning error of the cooperative nodes. A quasi-linear optimization co-location model is proposed by Jiang et al. [
10]. The model also considers the effect of coordination and non-line-of-sight errors between cooperative nodes; however, the performance improvement of the algorithm is very limited. Positioning based on factor graphs was proposed by Christian and Simon [
11]. It introduced a factor-graph-based positioning algorithm in wireless cellular networks by the base stations and set the base stations as precise nodes, The factor graph was used to obtained the position of mobile nodes. However, it did not consider the effect of the position error and ranging error of base stations and mobile nodes on the cooperative position system. The position error and ranging error are the main limitations of cooperative node localization accuracy. To solve the problem of location ambiguity in distributed cooperative positioning, we propose a cooperative positioning algorithm in this paper under the influence of positioning error and ranging error. The cooperative nodes can measure the distance information and interactive self position information to improve the accuracy of position, which takes into account both the ranging error of cooperative nodes and the fuzzy positioning error of cooperative nodes. We take advantage of factor graph theory to realize the reliability estimation of ranging error and positioning error and integrate the overall least squares theory to achieve a high-accuracy position cooperative position.
In distributed cooperative positioning, because of the large ranging error, the introduction of cooperative positioning creates more positioning errors [
12]. Therefore, the distributed cooperative positioning method is proposed in this paper to achieve positioning through the visual distance of the coordinated nodes. The network topology of distributed cooperative positioning
is set as
where
represents all cooperative nodes in a distributed cooperative positioning network, and
represents a set of range values between cooperative nodes. The total number of cooperative nodes is
K, and the position of cooperative node
k can be expressed as
and
represent the position of the x-axis, y-axis, and z-axis of cooperative node
k. Then, the vector of the position of all cooperative nodes
is represented as
The network topology of distributed cooperative positioning
can be expressed as the product of
K sets of subgraphs of some cooperative nodes due to factor graph theory [
13]. The distributed network topology
of the cooperative node
k is set as
where
represents a set of range values between the cooperative node
k with the other cooperative nodes that have a communication link with cooperative node
k. The range value between cooperative node
k and cooperative node
i can be expressed as
The position of a cooperative node can be obtained by more than three groups of distance equations in a cooperative positioning network [
14]. However, the ranging error of distances between cooperating nodes and the position ambiguity of cooperative nodes affects the accuracy of cooperative positioning [
15]. To address the ranging error between different cooperative nodes, the paper utilized the range difference function instead of the distance function to abate the ranging error. The range difference
between cooperative node
k and any other two cooperative nodes
is expressed as
Combining Equations (
3) and (
4), Equation (
6) can be rewritten as follows:
The belief information is constructed and is transferred between cooperating nodes to obtain the optimal position information of a cooperative node. Belief information is the information describing the mean and standard deviation of the range value between the cooperating nodes and the positioning error of a cooperative node. If cooperative node
i adjacent to cooperative node
k has the highest belief information among all cooperative nodes, the belief information of cooperative node
i is set as the standard belief information for cooperative node
k; then, the index of cooperative node
i is set as
. The belief information is computed by factor graph theory in the next part. The range value between cooperative node
and
k is the standard distance. Then, the distance difference between cooperative node
j and
k and cooperative node
and
k is as follows:
To obtain the position of the cooperative nodes, the aim function can be constructed by multiple sets of Equation (
7), and the form of the aim function can be expressed as
. The
line of matrix
is
; the
line of matrix
is
, and the
line of matrix
is
. The matrix can be defined as
, and the aim function can be rewritten as
The elements of matrix are independent with the same distribution. Therefore, the position of cooperative nodes can be obtained by the least minimum square method. However, any cooperative nodes that have a large position error or ranging error will degrade the performance of all the cooperative nodes, so the factor graphs is adopted to abate the effect of the position error and ranging error.
2. Factor-Graph-Assisted Distributed Coordination Position Algorithm
Due to the positioning information accuracy variation of cooperative nodes, it is difficult to obtain the optimal position by fixed cooperative nodes [
16]. To solve this problem, the factor-graph-assisted element weighting total least squares algorithm is proposed based on parameter estimation theory. The overall optimization position of cooperative nodes is utilized to replace the existing independent optimization of the distributed position cooperative node. First, the cost function of cooperative node
i is constructed as follows:
where
means the norm function,
K represents the total cooperative node,
represents the weight factor of belief information between cooperative node
k and
i,
and
represents the position of cooperative node
k and
i, and
represents the range value between cooperative node
k and
i. The overall positioning optimal cost function
S can be expressed as the sum of cooperative node cost function
.
Factor graph theory has two types of nodes: variable nodes and function nodes. Each edge is connected with a variable node and a function node. In our proposed distributed cooperative position algorithm, the variable node represents the cooperative node, and the function node represents a factor graph local function and achieves nonlinear fusion of belief information in every computation cycle, so there is no link between different variable nodes. The factor graphs method can split a complex multivariate global function into the product of several simple local functions, so the optimal position is obtained by the local function instead of the optimal position of the global function. In product theory of the factor graph, the belief information is transferred between variable nodes and function nodes to obtain the optimal position information of a cooperative node. The structure of distributed cooperative position based on factor graph is shown in
Figure 1.
The belief information passed from the cooperative node to the function node is the product of the belief information of all the other neighbor function nodes arriving at the cooperative node. For example, the belief information based on the transfer from the cooperative node
to the function node
can be described as
where
represents belief information that transfers from function node
to cooperative node
, and
represents belief information that transfers from function node
to cooperative node
. The belief information passed from the function node to the cooperative node is the product of all belief information of the other neighbor cooperative nodes connected to the function node and is then multiplied by a local function of the function node. For example, the belief information passed from function node
to
can be expressed as
where
and
represent belief information that transfers from cooperative nodes
and
to function node
.
represents the local function of the function node. In this paper, the local function is modeled by a signal propagation decay model and obeys a Gaussian distribution. Then, the belief information of cooperative node
can be expressed as the product of all belief information connected with cooperative node
, expressed as
The belief information passed from cooperative node
to
with the shortest path principle is then expressed as
Because the maximum value of the belief information in the factor graph is 1, if the number of cooperative nodes is larger, the actual value of the belief information is different by triangulation and leads to larger calculation errors. The normalized weight factor is adopted in our proposed algorithm to abate calculation error and is expressed as
represents the normalized weight factor of belief information
. The optimal position can be obtained by minimizing cost subfunction
instead of the cost function
S.
Combining Equations (
9) and (
10), the cost function can be rewritten as follows:
where
represents the error of matrix
with zero mean,
represents the
ith line of matrix
,
represents the
ith row vector of
and mutual independence, and the covariance matrix
of
is expressed as
where
and
represent the
ith line of matrix
and matrix
. Optimization can be obtained by minimizing the cost function of matrix
, and the new cost function
is expressed as
To obtain the optimal position of cooperative nodes, Equation (
20) can be rewritten as follows:
where
,
represents the residual matrix and is expressed as
.
represents the
ith row of the residual matrix. The optimal position of cooperative node
i can be expressed as follows by decomposing Equation (
21):
The optimization problem of Equation (
22) is a minimum two-norm problem, so the optimal solution of Equation (
22) is
Therefore, the optimization problem required by Equation (
23) can be expressed as an unconstrained optimization problem. Suppose
; Equation (
23) can be rewritten as
The partial derivative of function
with respect to
is
By expanding Equation (
19), the following standard linear equation can be obtained:
The optimal position of cooperative nodes
can then be computed by the iterated operation in Equation (
26). When
, the position results are stable and
is the global optimal position of the cooperative nodes estimated from the global conditions.
is the judgment threshold and is determined by the error fluctuation.