Rotation Matrix-Based Factor Graph Cooperative Localization Algorithm

Information

  • Patent Application
  • 20210373855
  • Publication Number
    20210373855
  • Date Filed
    April 21, 2021
    3 years ago
  • Date Published
    December 02, 2021
    3 years ago
Abstract
The present disclosure designs a rotation matrix-based factor graph cooperative localization algorithm. Firstly, the reasons of sudden increase in an error in an operation process of a conventional factor graph cooperative localization algorithm are analyzed; secondly, a rotation matrix is designed, and the size of a rotation angle is determined; then, a rotation matrix-based cooperative localization algorithm factor graph model is constructed, and a specific algorithm flow is designed; and finally, filtering fusion estimation is performed on position status information of a slave boat. Therefore, coordinate values of master and slave boats can be transformed within a factor graph in real time without changing the measurement accuracy of an inertial device in a system to cause the coordinates of the master and slave boats that participate in the calculation of the factor graph to be inconsistent, thereby solving the problem of sudden increase in a localization error of the conventional factor graph cooperative localization algorithm, and improving the robustness of the cooperative localization system.
Description
TECHNICAL FIELD

The present disclosure relates to a cooperative localization technology for an autonomous underwater vehicle (AUV), in particularly, based on a factor graph and a sum product algorithm, coordinate values of master and slave boats are transformed in real time inside a factor graph by means of introducing a rotation matrix, so that coordinates of the master and slave boats that participate in the calculation of the factor graph are inconsistent. When this method is used to perform cooperative localization on an AUV, the problem that a localization error suddenly increases when coordinates of the master and slave boats in a certain direction tend to be the same during cooperative localization with a conventional factor graph method is solved. This method can effectively reduce a cooperative localization error and improve the robustness of a cooperative localization system.


BACKGROUND

As a booster for humans to explore the ocean, underwater vehicles have experienced a process from birth to development to application. An autonomous underwater vehicle (AUV), as a leader that integrates various cutting-edge technologies in the world today, represents the development direction of underwater vehicles. However, the boundedness of a single AUV working platform in a process of further development and utilization of marine resources is becoming more and more significant. Therefore, the capacity of a multi-AUV cooperative system composed of N sets of AUVs will be far greater than N times that of one AUV by means of sharing data and information of other AUVs. Therefore, in recent years, the research on improving the navigation performance of a single AUV through the cooperation between a plurality of AUVs has attracted people's attention and gradually become a hot spot in the field of AUV navigation. As long as a plurality of AUVs can be directly or indirectly observed relatively, such as measuring a distance or azimuth between them and other AUVs, the navigation statuses of other AUVs can be used to improve their own navigation accuracy. In this way, a cooperative navigation system is formed among the plurality of AUVs. By means of sharing information, the multi-AUV cooperative navigation system can obtain advantages that a single AUV navigation system cannot have: 1) partial AUVs with high-performance navigation equipment share their navigation information through communication to achieve the sharing of their high-performance navigation information in the entire AUV group, so that the overall navigation accuracy of the AUV group is improved; 2) in the multi-AUV cooperative navigation system, as long as partial AUVs have the localization capability with bounded errors, each AUV in the system can have the localization capability with bounded errors by means of cooperative navigation; and 3) the multi-AUV cooperative navigation system has higher fault tolerance and stability.


The cooperative localization algorithm is essentially the problem of filtering. Since a distance observation equation of an underwater cooperative localization system is non-linear, status estimate for the cooperative localization system needs to be implemented with a non-linear filtering algorithm. During use of a factor graph to design the cooperative localization algorithm, the disadvantages of low localization accuracy and large amount of computation of a traditional cooperative localization algorithm under a Gaussian noise condition can be effectively avoided. When the noise in the cooperative localization system is Gaussian noise, a sum product algorithm is used to update information in the factor graph. The factor graph sum product algorithm transforms complex operations into several simple operations. The algorithm does not involve Jacobian matrix operations, thereby reducing the complexity of computation. The factor graph does not need to linearize the distance observation equation, which avoids errors caused by linearization, reduces the cooperative localization error, and improves the localization capability of the cooperative localization system.


However, when an expectation and a variance of a system status variable are used as reliability information of the system for cooperative localization, a problem of sudden increase in the cooperative localization error due to the close or same coordinates of a master boat and a slave boat in a certain direction is prone to occur.


In view of the above existing problems, the present disclosure designs a rotation matrix-based cooperative localization algorithm. The present disclosure uses a factor graph for data fusion, introduces a rotation matrix factor node between an absolute position variable node and a relative position variable node of a status variable, and realizes real-time transformation of coordinate values of the master boat and the slave boat within the factor graph through this node, so that the coordinates of the master and slave boats participating in the calculation of the factor graph are always inconsistent, thereby solving the above problems, and greatly improving the robustness of the cooperative localization algorithm.


SUMMARY

The present disclosure is directed to design a rotation matrix-based cooperative localization algorithm. A rotation matrix factor node is added into a factor graph model without changing the accuracy of an inertial device to transform coordinate values of master and slave boats within a factor graph in real time, thereby improving the robustness of a system.


The objective of the present disclosure can be realized through the following steps:


step 1: constructing a rotation matrix-based cooperative localization algorithm factor graph model; and


step 2: establishing a rotation matrix-based cooperative localization algorithm, and filtering and updating position status information of a system.


In step 1, an actual working environment of an underwater vehicle is a three-dimensional space, but in consideration that actual depth information can be accurately measured by a pressure sensor in real time, which does not play a role of accumulating a localization error of the vehicle, the cooperative localization is further simplified to a problem under a two-dimensional space. The factor graph is a bipartite model used for expressing a joint probability distribution of a random variable. It includes two types of nodes: one type is a factor node, which refers to a local function in factorization, and the other type is a variable node, which refers to a variable in a global multivariate function. As shown in FIG. 1, the circle in the figure represents the variable node, and the rectangle represents the factor node. In the factor graph, the variable node to the factor node or the factor node to the variable node interact through information. Based on this, a cooperative localization model can be decomposed into two one-dimensional problems. The two one-dimensional problems are respectively expressed by two main node groups in an x coordinate group and a y coordinate group in the factor graph.


Meanwhile, reasons of a sudden increase in an error occurring when a conventional factor graph cooperative localization algorithm taking an expectation and a variance of a status variable as reliability information filters and updates a position status of a system are analyzed, and then a rotation matrix is designed.


Specifically, it is as follows:


(1) Analysis of Error Reasons


In a cooperative localization algorithm factor graph mode as shown in FIG. 1, an updating process of the factor node En is as follows.


The factor node En is used to combine a coordinate system of an x group with a coordinate system of a Y group. According to the Pythagorean theorem, the constraint between the variable nodes Δxn and Δyn can be described as:






d
n
2
=Δx
n
2
+Δy
n
2.


A probability density function transmitted from the factor node En to the variable node Δyn can be expressed as:







N
(


Δy
n

,

±



d
n
2

-


(

Δ


x
n
-


)

2




,





(

Δ


x
n
-


)

2



σ

x
n
-

2


+


d
n
2



σ

d
n

2





d
n
2

-


(

Δ


x
n
-


)

2




)

,




where Δxnrepresents an x coordinate difference between a master boat and a slave boat in the previous iteration process; and


σxn2 represents a corresponding variance.


A probability density function transmitted from the factor node En to the variable node Δxn can be expressed as:







N
(



Δ


X
n

,


±



d
n
2

-


(

Δ


y
n
-


)

2




,





(

Δ


y
n
-


)

2



σ

y
n
-

2


+


d
n
2



σ

d
n

2





d
n
2

-


(

Δ


y
n
-


)

2




)

,




where Δynrepresents an x coordinate difference between a master boat and a slave boat in the previous iteration process; and


σyn2 represents a corresponding variance.


According to the probability density function transmitted from the factor node to the variable node Δyn, an expectation E(Δyn) of Δyn can be further expressed as:








E


(

Δ


y
n


)


=

±



d
n
2

-


(

Δ


x
n
-


)

2





,




A function f(x)=√{square root over (dn2−x2)} is set, which is subjected to first-order Taylor expansion to obtain:











f


(
x
)







d
n
2

-

x
0
2



+



x
0




d
n
2

-

x
0
2






(

x
-

x
0


)




,












then:











f


(


x
0

+

x
~


)


-

f


(

x
0

)








d
n
2

-

x
0
2



+



x
0




d
n
2

-

x
0
2






x
~






-



d
n
2

-

x
0
2




=



x
0




d
n
2

-

x
0
2







x
~

.


















Due to dn2=Δxn2+Δyn2, when y axis coordinates of the master boat and the slave boat tend to be the same, Δyn2→0, then dn2−Δxn2→0, Δxn/√{square root over (dn2−Δxn2)}θ∞, and according to the above formulas, a slight error of Δxn at this time will cause a great error of E(Δyn). This result further leads to the phenomenon that the cooperative localization error suddenly increases when the y axis coordinates of the master boat and the slave boat are close or the same in an actual operation process of the factor graph cooperative localization algorithm taking the expectation and the variance of the status variable as the reliability information.


When the x axis coordinates of the master boat and the slave boat tend to be the same or close, the same as the above, it will cause a greater error of E(Δxn), leading to an increase in the localization error.


(2) Design of a Rotation Matrix


The error is caused by the same x axis coordinates or y axis coordinates of the master and slave boats, so that the present disclosure would construct a rotation matrix to transform coordinate values of the master and slave boats within the factor graph in real time and to cause the coordinates of the master and slave boats that participate in the calculation of the factor graph to be inconsistent, thereby solving the problem of sudden increase in the localization error.


A form of the introduced rotation matrix is as follows:






C
=


[




cos





θ




sin





θ







-
sin






θ




cos





θ




]

.





A determination method for a θ value is as follows:


supposing that the coordinate of a certain master boat is (xm,ym) and the coordinate of a slave boat is (xs,ys), the coordinates are transformed into (x′m,y′m) and (x′s,y′s) via a transformation matrix C, and a transformation process is as follows:







[




x
m







y
m





]

=




[




cos





θ




sin





θ







-
sin






θ




cos





θ




]



[




x
m






y
m




]






[




x
s







y
s





]

=



[




cos





θ




sin





θ







-
sin






θ




cos





θ




]



[




x
s






y
s




]


.






When the estimated coordinate of the slave boat has an error, the following formula is obtained:







[





x
s


+


x


~








y
s


+


y


~





]

=


[




cos





θ




sin





θ







-
sin






θ




cos





θ




]



[





x
s

+

x
~








y
s

+

y
~





]






where {tilde over (x)} represents an error of the slave boat at the x axis of the original coordinate system;


{tilde over (y)} represents an error of the slave boat at the y axis of the original coordinate system;


{tilde over (x)}′ represents an error of the slave boat at the x axis after the transformation matrix; and


{tilde over (y)}′ represents an error of the slave boat at they axis after the transformation matrix.


It can be further obtained that:






{







x


~

=



x
~


cos





θ

+


y
~


sin





θ










y
~



=



-

x
~



sin





θ

+


y
~


cos





θ






.





It can be obtained in combination with the first-order Taylor expansion formula f(x) in (1) that:






{






Δ


x
~


=


±



y
m


-

y
s






d
n
2

-


(


y
m


-

y
s



)

2








y


~









Δ


y
~


=


±



x
m


-

x
s






d
n
2

-


(


x
m


-

x
s



)

2








x


~






.





In order to avoid the phenomenon of increase in the error, the following formula needs to be met:






{







d
n
2

-


(


y
m


-

y
s



)

2



0








d
n
2

-


(


x
m


-

x
s



)

2



0




.





By means of a constraint relation of the formula dn2=Δxn2+Δyn2, the above formula is further simplified into:








{






x
m


-

x
s




0








y
m


-

y
s




0









According to the above formula, conditional expressions that θ should meet are as follows:







θ


θ
1


,


θ
1

=

arctan


(



y
s

-

y
m




x
s

-

x
m



)










θ


θ
2


,


θ
2

=


arctan


(



x
s

-

x
m




y
s

-

y
m



)


.






In consideration of an actual situation, obviously θ1≠θ2, and θ can be selected as:





θ=(θ12)/2.


At this time, θ always meets the above conditions.


In step 2, according to the rotation matrix obtained by analysis and design in step 1, a rotation matrix-based factor graph cooperative localization algorithm is designed, specifically as follows:

    • a rotation matrix factor node Ti and a transformed coordinate variable node xi are added based on a conventional factor graph cooperative localization algorithm. A probability density function transmitted from the factor node Ti to the variable node xi can be expressed as:





N(xi, x cosθ+y sinθ, σx2 cos2 θ+σy2 sin2 θ)


where σx2 represents a variance transmitted from the variable node x to the factor node Ti; and


σy2 represents a variance transmitted from the variable node y to the factor node Ti.


A probability density function transmitted from the factor node Ti to the variable node yi can be expressed as:





N(yi, −x sinθ+y cosθ, σy2 cos2 θ+σx2 sin2θ).





BRIEF DESCRIPTION OF FIGURES


FIG. 1 is a constructed rotation matrix-based cooperative localization algorithm factor graph model.



FIG. 2 is a movement path diagram of a master boat and a slave boat in a simulation experiment.



FIG. 3 is a graph showing a localization error in a simulation experiment.





DETAILED DESCRIPTION

The present disclosure is described in detail below in combination with specific embodiments.


The present disclosure designs a rotation matrix-based factor graph cooperative localization algorithm. Coordinate values of a master boat and a slave boat can be transformed within a factor graph in real time by means of introducing a rotation matrix to cause the coordinates of the master boat and the slave boat that participate in the calculation of the factor graph to be inconsistent, thereby avoiding the phenomenon of sudden increase in a cooperative localization error caused by the fact that the coordinates of the master and slave boats in a certain direction are close or the same in an operation process of the master and slave boats, improving the capability of a cooperative localization system and enhancing the robustness of the system. The objective of the present disclosure can be realized through the following steps:


1. a rotation matrix-based cooperative localization algorithm factor graph model is constructed;


2. a rotation matrix-based factor graph cooperative localization algorithm is established; and


3. filtering fusion estimation is performed on a position status of the system by means of a transmitted probability density function.


In order to verify the effectiveness of the present disclosure, software is used to simulate the rotation matrix-based factor graph cooperative localization algorithm.


As shown in FIG. 1, the constructed rotation matrix-based cooperative localization algorithm factor graph model is illustrated. In the drawing, ({circumflex over (x)}kk) represents one-step forecasting of the position status; (x,y) represents a position status after the filtering fusion estimation; represents a position status processed by the rotation matrix represented by the factor node Ti; (Δx,Δy) represents relative position information between the master and slave boats; {circumflex over (d)}i represents measurement information between the master and slave boats; and di represents di=√{square root over (Δx2+Δy2)}.



FIG. 2 illustrates movement simulation of the master and slave boats. Simulation conditions: the master boat 1: initial position (xm1,ym1)=(−200 m, −400 m), speed 2 m/s, and heading 90°; the master boat 2: initial position (xm2,ym2)=(1800 m, −400 m), speed 2 m/s, and heading 90°; the slave boat: initial position (0 m, 0 m), speed 2 m/s, and heading 30°. During simulation, speed noise σv2=(0.5 m/s)2, acceleration noise σα2=(0.01 m/s2)2, gyroscope measurement noise σϕ2=(1°)2 and hydroacoustic range observation noise σd12d22=(2 m)2 of the slave boat are all irrelevant additive noise. A filtering algorithm is used to estimate and update position information, and a cycle for each filtering estimation is 1 s. Moreover, the extended Kalman filter (EKF) algorithm, the unscented Kalman filter (UKF) algorithm and the conventional factor graph cooperative localization (FGAS) algorithm are compared with the rotation matrix-based factor graph cooperative localization (RMFGAS) algorithm designed by the present disclosure.


It can be seen from FIG. 3 that when the system is operated to about 400 s, the localization error of the FGAS algorithm suddenly increases. According to the simulation conditions, elapsed time t when the y axis coordinates of the master boat and the slave boat are the same, can be calculated as:






t
=



Δ


y
0



Δ


v
y



=



0
-

(


-
4


0

0

)



2
-

2
×

sin


(

3


0
°


)





=

4

0

0

s







where Δy0 represents an initial distance between the master boat and the slave boat in a y axis direction; and


Δvy represents a speed difference between the master boat and the slave boat in the y axis direction.


It can be seen that a common factor graph cooperative localization algorithm has the phenomenon of sudden increase in the localization error when the coordinates of the master and slave boats in a certain direction are close or the same. However, the rotation matrix-based factor graph cooperative localization algorithm provided by the present disclosure can always maintain a smaller cooperative error. At the same time, it can be seen that the overall cooperative performance of the RMFGAS algorithm is better than that of the EKF and the UKF. In addition, it should be noted that the localization errors of the RMFGAS algorithm, the EKF algorithm, and the UKF algorithm all increase first and then decrease. This is caused by changes in the observability of the system, and this problem cannot be solved by algorithms.


The above experiments verify the effectiveness of the rotation matrix-based factor graph cooperative localization algorithm of the present disclosure, the coordinate values of the master and slave boats can be transformed within the factor graph in real time without reducing the measurement accuracy of an inertial element in the cooperative system to cause the coordinates of the master and slave boats that participate in the calculation of the factor graph to be inconsistent, thereby solving the problem of sudden increase in the localization error of the conventional factor graph cooperative localization algorithm, which is caused when the coordinates of the master and slave boats in a certain direction are close or the same, and improving the robustness of the cooperative localization system.

Claims
  • 1. A method, comprising the following steps: step 1: constructing a rotation matrix-based cooperative localization algorithm factor graph model; andstep 2: establishing a rotation matrix-based cooperative localization algorithm, and filtering and updating position status information of a system.
  • 2. The method according to claim 1, wherein in the step 1, rotation matrix factor nodes are added into a factor graph algorithm flow with the following concept: distance information of master and slave boats enter the factor graph algorithm flow by means of a node Fi; a priori estimate of a position of the slave boat enters the factor graph algorithm flow by means of nodes A and B; then a position of the slave boat is rotated to change by means of a node Ti; absolute position information of the master and slave boats are transformed into relative position information by means of nodes Ci and Di; and finally, the position information of the master and slave boats are fused by means of a node Ei.
  • 3. The method according to claim 1, wherein in the step 2, a rotation matrix is constructed and a rotation angle is designed; a form of the rotation matrix is as follows:
Priority Claims (1)
Number Date Country Kind
2020115525991 Dec 2020 CN national