CN112365743A - Method and device for correcting flight path positioning data offset of aircraft - Google Patents

Method and device for correcting flight path positioning data offset of aircraft Download PDF

Info

Publication number
CN112365743A
CN112365743A CN202011084881.1A CN202011084881A CN112365743A CN 112365743 A CN112365743 A CN 112365743A CN 202011084881 A CN202011084881 A CN 202011084881A CN 112365743 A CN112365743 A CN 112365743A
Authority
CN
China
Prior art keywords
real
information
current
point
time
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN202011084881.1A
Other languages
Chinese (zh)
Other versions
CN112365743B (en
Inventor
王毅
王国强
刘宝树
罗晓艳
陈通
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Second Research Institute of CAAC
Original Assignee
Second Research Institute of CAAC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Second Research Institute of CAAC filed Critical Second Research Institute of CAAC
Priority to CN202011084881.1A priority Critical patent/CN112365743B/en
Publication of CN112365743A publication Critical patent/CN112365743A/en
Application granted granted Critical
Publication of CN112365743B publication Critical patent/CN112365743B/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G08SIGNALLING
    • G08GTRAFFIC CONTROL SYSTEMS
    • G08G5/00Traffic control systems for aircraft, e.g. air-traffic control [ATC]
    • G08G5/0073Surveillance aids

Landscapes

  • Engineering & Computer Science (AREA)
  • Aviation & Aerospace Engineering (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Traffic Control Systems (AREA)

Abstract

The invention provides a method and a device for correcting aircraft track positioning data offset, wherein the method comprises the steps of emptying historical cache information before correcting the current track positioning data offset of an aircraft; receiving real-time measuring point information of an aircraft sent by a distributed positioning system; determining current parabola and real-time deflection angle information used as a filter cover according to the real-time measuring point information and the current cache information; calculating and generating real-time filtering point information corresponding to the real-time measuring point according to the real-time measuring point information, the current parabola and the real-time deflection angle information; updating current cache information according to the real-time measuring point information, the real-time filtering point information and the real-time deflection angle information; and obtaining the corrected flight path of the current flight path of the aircraft according to all the filtering point information of the current flight path. The invention realizes accurate positioning and high stability, and the track is more in line with the motion rule.

Description

Method and device for correcting flight path positioning data offset of aircraft
Technical Field
The invention relates to the technical field of aircraft positioning, in particular to a method and a device for correcting an aircraft track positioning data offset.
Background
In airport route guidance project application, a software system is required to control runway edge lights and conduct route light guidance on aircrafts. In the guiding process, the aircraft is required to travel according to the optimized path calculated by the software, the road surface light around the relevant path is lightened, and the aircraft travels according to the light indication. And calculating the real-time position data of the aircraft by the distributed positioning system and sending the real-time position data to the application software end so as to draw the flight path information of the aircraft. And the software controls and extinguishes the lamplight along the path of the history track which has been walked in real time through the track information which has been walked by the airplane and keeps the lamplight along the non-driving path. When the aircraft leaves the preset optimized path from the fork temporarily for some reason, the lights on the road surface along which the original optimized path which is not completely traveled is completely extinguished, the optimized path is recalculated according to the real-time position of the aircraft, and the lights on the road surface along which the new path is located are lightened.
Because of the positioning accuracy, there will be great error in the positioning data, so in the route has the guide process, because the error leads to the positioning data drift, will cause the following two aspect's problem above all:
when the aircraft is still at the starting point of the taxiway, the software end receives the positioning data, and can mistakenly find that the aircraft moves forwards and mistakenly control the light behind the advancing direction to be extinguished;
when the aircraft is guided to travel to a certain fork and temporarily changes the direction and deviates from the preset optimized path, the software end can mistakenly continue to keep the light of the path which is not completed for the aircraft to go on according to the preset optimized path after receiving the positioning data, the deviation is not slowly found until the aircraft goes out for a certain distance, and then a route planning suggestion is given again, the light of the previous path is extinguished, and the light for re-planning the path is lightened.
Generally speaking, it is because of the drift of the positioning data, there will be no synchronous coincidence between the light control and the aircraft operation state, and the response speed of the real-time path re-planning will be delayed greatly compared with the change of the aircraft operation plan.
The existing method for solving the problem of positioning data drift and correcting the flight path offset mainly comprises the following three aspects:
and the positioning accuracy of the positioning algorithm is improved. The disadvantages are as follows: in the aspect of hardware, communication equipment, computing equipment and storage equipment with more quantity, higher precision and stronger performance need to be replaced or added, and the cost is high; in the aspect of software, the improvement difficulty of the positioning algorithm is high, the improvement space is small, and the improvement effect is not obvious.
And carrying out path matching through the inherent path information of the road surface. The disadvantages are as follows: data which needs to be subjected to detailed data modeling, transmission or storage on the road surface can become complex in type and structure, and data throughput and calculation overhead can be increased sharply; when the aircraft moves to an area outside the modeling road network due to an unexpected reason, correct matching and positioning cannot be carried out.
And correcting the measured positioning data with errors on the software algorithm level. The method is a mainstream solution mode adopted by considering the factors of development cost, development difficulty, resource consumption, convenience in use and maintenance and the like at present. However, the existing correction methods are all to analyze the motion law of the statistical historical trajectory, including but not limited to position, velocity, acceleration, distribution law, etc., and find the correct position of the current aircraft by a prediction or fitting method. Such a design has the following disadvantages:
(1) the corrected paths of some correction methods are continuous and smooth, can well reflect the advancing trend, but are far away from the actual measurement data, and cannot reflect the real position information.
(2) Some correction methods keep higher precision after correction, can well reflect real position information, but have poor path continuity (for example, zigzag) and can not be matched with a performed pavement;
the above methods cannot well filter out the situation that the trajectory self-intersection caused by the drift of the positioning data and the soft distribution are formed, and the trajectory reciprocates in the globoid distribution, which does not conform to the physical motion law of the large-scale aircraft.
Disclosure of Invention
In view of the above, the present invention provides a method and an apparatus for correcting an aircraft track positioning data offset, so as to achieve accurate positioning and high stability, and the track better conforms to the motion law.
In one aspect, the present invention provides a method for correcting an aircraft track positioning data offset, including:
clearing historical cache information before correcting the current track positioning data offset of the aircraft;
receiving real-time measuring point information of an aircraft sent by a distributed positioning system;
determining current parabola and real-time deflection angle information used as a filter cover according to the real-time measuring point information and the current cache information; the current cache information includes: the cache queue comprises last measurement point cache information, last filtering point cache information, last deflection angle cache information and cache queues of all filtering point information between an initial filtering point and a last filtering point of the current flight path; the last deflection angle cache information is an included angle formed between a unit vector in the positive direction of the x axis and a connecting line from the focus of the current parabola to the vertex of the current parabola along the anticlockwise direction;
calculating and generating real-time filtering point information corresponding to the real-time measuring point according to the real-time measuring point information, the current parabola and the real-time deflection angle information;
updating current cache information according to the real-time measuring point information, the real-time filtering point information and the real-time deflection angle information;
and obtaining the corrected flight path of the current flight path of the aircraft according to all the filtering point information of the current flight path.
Further, determining the real-time deflection angle information according to the real-time measurement point information and the current cache information includes:
determining a common point of a line segment formed by connecting the cache information of the previous filtering point to the information of the real-time measuring point and the boundary of the current parabola;
and forming an included angle between vectors by the unit vector in the positive axial direction and a common point connecting line from the focus of the current parabola to the boundary of the current parabola along the counterclockwise direction to serve as real-time deflection angle cache information.
Further, determining a current parabola for use as a filter mantle based on the real-time measurement point information and current cache information comprises:
and determining the size of the current parabola according to the length of a connecting line between the cache information of the previous measuring point and the real-time measuring point information.
Further, the step of calculating and generating real-time filtering point information corresponding to the real-time measuring point according to the real-time measuring point information, the current parabola and the real-time deflection angle information comprises:
calculating an included angle between a first deflection angle information and a real-time deflection angle information, calculating a distance between a common point of a current parabola boundary and a focus of the current parabola, if the common point exists, determining real-time filtering point information on a line segment formed by the focus of the current parabola and the real-time measuring point information, wherein the real-time filtering point information meets the condition that the distance between a last filtering point information and the common point is equal to the distance between the real-time filtering point information and the real-time measuring point, and if the common point does not exist, the real-time filtering point information is the last filtering point information.
Further, the step of calculating and generating real-time filtering point information corresponding to the real-time measuring point according to the real-time measuring point information, the current parabola and the real-time deflection angle information further comprises the following steps:
and correcting the real-time filtering point information according to the cache queue so as to update the current cache information according to the corrected real-time filtering point information and obtain the corrected flight path of the current flight path of the aircraft.
The invention also provides a device for correcting the flight path positioning data offset of the aircraft, which comprises:
the preprocessing unit is used for emptying historical cache information before the correction operation of the current track positioning data offset of the aircraft is carried out;
the receiving unit is used for receiving the real-time measuring point information of the aircraft sent by the distributed positioning system;
the filtering unit is used for determining the current parabola and the real-time deflection angle information which are used as the filtering cover according to the real-time measuring point information and the current cache information; calculating and generating real-time filtering point information corresponding to the real-time measuring point according to the real-time measuring point information, the current parabola and the real-time deflection angle information; the current cache information includes: the cache queue comprises last measurement point cache information, last filtering point cache information, last deflection angle cache information and cache queues of all filtering point information between an initial filtering point and a last filtering point of the current flight path; the last deflection angle cache information is an included angle formed between a unit vector in the positive direction of the axis and a connecting line from the focus of the current parabola to the vertex of the current parabola along the anticlockwise direction;
the updating unit is used for updating the current cache information according to the real-time measuring point information, the real-time filtering point information and the real-time deflection angle information;
and the track correction unit is used for obtaining the corrected track of the current track of the aircraft according to all the filtering point information of the current track.
Further, the filtration unit is specifically configured to: determining a common point of a line segment formed by connecting the cache information of the previous filtering point to the information of the real-time measuring point and the boundary of the current parabola; and forming an included angle between vectors by the unit vector in the positive axial direction and a common point connecting line from the focus of the current parabola to the boundary of the current parabola along the counterclockwise direction to serve as real-time deflection angle cache information.
Further, the filter unit is specifically further configured to: and determining the size of the current parabola according to the length of a connecting line between the cache information of the previous measuring point and the real-time measuring point information.
Further, the filter unit is specifically further configured to: calculating an included angle between a first deflection angle information and a real-time deflection angle information, calculating a distance between a common point of a current parabola boundary and a focus of the current parabola, if the common point exists, determining real-time filtering point information on a line segment formed by the focus of the current parabola and the real-time measuring point information, wherein the real-time filtering point information meets the condition that the distance between a last filtering point information and the common point is equal to the distance between the real-time filtering point information and the real-time measuring point, and if the common point does not exist, the real-time filtering point information is the last filtering point information.
Further, the device for correcting the aircraft track positioning data offset further includes:
the filtering point information correcting unit is used for: and correcting the real-time filtering point information according to the cache queue, so that the updating unit updates the current cache information according to the corrected real-time filtering point information and the flight path correcting unit obtains the corrected aircraft of the current flight path of the aircraft according to the corrected real-time filtering point information.
According to the method and the device for correcting the flight path positioning data deviation of the aircraft, the position is corrected to the near small-range space field, the situation that the measured data is not excessively deviated is guaranteed, a continuous and smooth advancing track is formed, the positioning is accurate, the stability is high, and the track is more in line with the motion rule.
Drawings
In order to more clearly illustrate the technical solutions of the embodiments of the present invention, the drawings needed to be used in the embodiments will be briefly described below, and it is obvious that the drawings in the following description are only some embodiments of the present invention, and it is obvious for those skilled in the art to obtain other drawings based on these drawings without creative efforts.
FIG. 1 is a flow chart of a method for correcting an aircraft track location data offset according to an exemplary first embodiment of the present invention.
Fig. 2 is a frame overview of a method for correcting an aircraft track location data offset according to an exemplary second embodiment of the invention.
FIG. 3 is a data flow diagram of a method for correcting an aircraft track location data offset according to an exemplary third embodiment of the present invention.
FIG. 4 is a flowchart of a method for correcting an aircraft track location data offset according to an exemplary fourth embodiment of the invention.
Fig. 5 is a spatial relationship between relevant points in the Shell structure.
FIG. 6 is an example of a simple filter trace generation process.
FIG. 7 is a diagram illustrating a modification of a history filter point to a latest filter point.
FIG. 8 is a screenshot of a modification procedure for a historical filter point to a latest filter point.
Fig. 9 is a screenshot of the convergence effect procedure on the path of the long distance round-trip trajectory.
Fig. 10 is a screenshot of the filter effect procedure for drift in a quiescent state.
Fig. 11 is a screenshot of the filter effect procedure for drift in the straight state.
Fig. 12 is a screenshot of a filter effect routine for drift in a stationary launch condition.
Fig. 13 is a screenshot of a filtering effect procedure for a drift in a deceleration stop state.
Fig. 14 is a screenshot of the filter effect procedure for drift in the steered state.
Fig. 15 is a block diagram of an apparatus for correcting an aircraft track positioning data offset according to an exemplary fifth embodiment of the present invention.
Detailed Description
Embodiments of the present invention will be described in detail below with reference to the accompanying drawings.
It should be noted that, in the case of no conflict, the features in the following embodiments and examples may be combined with each other; moreover, all other embodiments that can be derived by one of ordinary skill in the art from the embodiments disclosed herein without making any creative effort fall within the scope of the present disclosure.
It is noted that various aspects of the embodiments are described below within the scope of the appended claims. It should be apparent that the aspects described herein may be embodied in a wide variety of forms and that any specific structure and/or function described herein is merely illustrative. Based on the disclosure, one skilled in the art should appreciate that one aspect described herein may be implemented independently of any other aspects and that two or more of these aspects may be combined in various ways. For example, an apparatus may be implemented and/or a method practiced using any number of the aspects set forth herein. Additionally, such an apparatus may be implemented and/or such a method may be practiced using other structure and/or functionality in addition to one or more of the aspects set forth herein.
The idea of the correction method for the aircraft track positioning data offset is as follows: with a spatial hysteresis design, the unpredictability of the measurement points due to the upcoming front is counteracted. Colloquially, by analogy, are: now there are two people, a and B, starting at the same starting point and going along a definite path from the starting point to the destination. The path A represents a track drawn by a measuring point given by a positioning algorithm, and the path A stops from the starting point to the end point for the determined path in a manner of 'left neglect, right neglect, front neglect and back neglect', and alternates with the path B until the end point after the path A goes further. What B needs to walk is a point-drawn track given by the correction algorithm, and B can step forward according to the position of A, so that the walking path of B is ensured to be a determined path as much as possible, and the walking path continuously and stably walks forward to the terminal point, and the situations of 'left neglect, right neglect, front neglect and back neglect' can not occur. The current practice of B is:
firstly, A walks first, B always keeps a one-step difference with A, and they are all positioned at the same starting point at the beginning;
b always keeps a proper distance from A according to the speed of A, the faster the speed of A, the farther B is away from A, and on the contrary, the closer B is to A;
if the A suddenly stops right ahead of the B or backs towards the B direction, the B station is not moved in situ until the A continuously moves right ahead and exceeds a certain distance, and then the B keeps up with the B;
if A changes direction suddenly and is no longer in the front of B, B will first adjust the advancing direction to the direction opposite to A,
and determining the distance to be followed up or kept in place according to the distance between the A and the B.
The following embodiments of the method for correcting the flight path positioning data offset of the aircraft are implemented by formalizing the game thought into a mathematical method and performing an algorithm.
As shown in fig. 1, a method for correcting an aircraft track positioning data offset includes:
step 101, emptying historical cache information before correcting the current track positioning data offset of the aircraft;
102, receiving real-time measuring point information of an aircraft, which is sent by a distributed positioning system;
103, determining current parabola and real-time deflection angle information used as a filter cover according to the real-time measuring point information and the current cache information; the current cache information includes: the cache queue comprises last measurement point cache information, last filtering point cache information, last deflection angle cache information and cache queues of all filtering point information between an initial filtering point and a last filtering point of the current flight path; the last deflection angle cache information is an included angle formed between a unit vector in the positive direction of the x axis and a connecting line from the focus of the current parabola to the vertex of the current parabola along the anticlockwise direction;
104, calculating and generating real-time filtering point information corresponding to the real-time measuring point according to the real-time measuring point information, the current parabola and the real-time deflection angle information;
105, updating current cache information according to the real-time measuring point information, the real-time filtering point information and the real-time deflection angle information;
and 106, obtaining the corrected flight path of the current flight path of the aircraft according to all the filtering point information of the current flight path.
The position of the embodiment is corrected to the near small-range space field, so that the continuous and smooth advancing track is formed without excessively deviating from the measured data, the positioning is accurate, the stability is high, and the track is more in line with the motion rule.
Specifically, as shown in fig. 2, the schematic frame diagram of the method for correcting the aircraft track positioning data offset includes the following steps:
firstly, a filtering algorithm module comprises two functions of initialization and calculation, and a cache mechanism is arranged in the module;
before the filtering track is generated by using the filtering algorithm module, an initialization function is required to be called to clear the cache;
thirdly, the filtering algorithm module receives a latest measuring point as an input;
invoking a calculation function through input data and cache data to generate a latest filtering point and update the cache data;
the filtering algorithm module returns a latest measuring point as output;
and sixthly, returning to the step III, receiving the next latest measuring point by the filtering algorithm module, or ending.
Further, as shown in fig. 3, the data flow frame diagram (corresponding to the detailed outline frame diagram) of the method for correcting the aircraft track positioning data offset includes the following steps:
the filtering algorithm module comprises two functions: the initialization function and the geometric computation function comprise four buffer variables: a cache queue of a recent measurement point cache, a recent filtering point cache, a recent deflection angle cache and a recent history filtering point;
before the filtering track is generated by using the filtering algorithm module, the cache is emptied by calling the initialization function only once so as to clear temporary data remained in a cache variable in the calculation process of generating the previous complete filtering track;
the filtering algorithm module integrally waits for receiving a latest measuring point as input, the data of the latest measuring point is an instant calculation result from the distributed positioning system, and the point is added into the current original track;
inputting the latest measuring point and all cache data into a geometric calculation function, calculating to generate the latest filtering point, respectively updating the latest measuring point cache and the latest filtering point cache by using the latest measuring point and the latest filtering point, updating the latest deflection angle cache by using the latest deflection angle, and adding the latest filtering point into a ring cache queue of the latest generated history filtering point (if the queue is full, covering the position stored by the earliest filtering point);
the filtering algorithm module returns a latest filtering point as output and adds the latest filtering point into the current filtering track;
and returning to the step III, and waiting for receiving the next latest measuring point by the filtering algorithm module or ending.
To explain in more detail the implementation idea of the method for correcting the aircraft track positioning data offset, the basic variables and the basic function definitions are now described:
p is a trace point for specifying the position of a moving target on the earth surface at a certain moment, P (x, y) is a P data format representation form, and is a two-dimensional rectangular coordinate of a local geodetic reference system converted from longitude and latitude coordinates, and x and y are respectively a horizontal coordinate and a vertical coordinate under a rectangular coordinate system.
② L is a trace, denoted L ═ P0,P1,...,Pi-1,Pi},P0Referred to as the starting point, PiCalled the latest point; f and S are track points with a data format of P; LF ═ F0,F1,...,Fi-1,FiIs called the current original trajectory, FiCalled nearest measurement point, Fi+1Called the latest measurement point; LS ═ S0,S1,...,Si-1,SiIs called the current filtering track, SiCalled nearest filter point, Si+1Called the latest filter point; add is a method for adding new track points in a track in sequence, and a calling mode LFi+1) Add (S) or LSi+1)。
If the line segment formed by connecting the P point with the focus of the parabola does not have a common point with the parabola, the P is positioned in the parabola; the parabola and its inner region are referred to herein as the Shell (filter sock); the parabolic focus is a certain filtering point S, called the focus of the Shell; vertex Z of the parabola is called the vertex of Shell; the symmetrical midline of the parabola is called the midline of the Shell; throwingThe object line itself is called the boundary of the Shell; a point on the Shell boundary is called C; unit vector of positive x-axis direction
Figure BDA0002720004380000081
In the counterclockwise direction and vector
Figure BDA0002720004380000082
The angle between them is called the angle of deflection of the Shell.
The Shell (s, f, alpha) is a data format representation form of the filter mantle Shell; wherein s represents the focus of the Shell, f represents the distance of the line segment SZ in the Shell, and alpha represents the deflection angle of the Shell; the position, the size and the direction of the Shell are respectively and uniquely determined by s, f and alpha; the minimum allowed value of f is set to Min _ f and the maximum allowed value is set to Max _ f.
For trace LS ═ S0,S1,...,Si-1,Si},ShelliIs the nearest filter point SiIs a focal point, point ZiIs a vertex, FiSiIs a line segment on the middle line (if F)i≠Si) For calculating the latest filtering point Si+1The Shell of (1); unit vector of positive x-axis direction
Figure BDA0002720004380000083
In the counterclockwise direction and vector
Figure BDA0002720004380000084
Angle alpha therebetweeniReferred to as the most recent deflection angle.
⑥ShelliS focus ofiTo the latest measuring point Fi+1Connected line segment and ShelliThe common point of the boundary is called Ci(if a common point exists); focal point SiAnd vertex ZiFormed vector
Figure BDA0002720004380000085
And a focus SiAnd point CiFormed vector
Figure BDA0002720004380000086
The angle between them, smaller than the straight angle, is called thetai(if C isiPresence); unit vector of positive x-axis direction
Figure BDA0002720004380000087
In the counterclockwise direction and vector
Figure BDA0002720004380000091
Angle alpha therebetweeni+1Called the latest deflection angle (if C)iPresent).
Seventhliter is an example of a filtering algorithm module; init is an initialization function, and is called only once before the module is used to generate a complete filtering track, and the calling mode is as follows: init (); the generation is a calculation function, and is called once every time a measurement point is received to Generate a filter point, and the calling method is as follows: si+1=fliter.Generate(Fi+1)。
⑧F*Is used in the fliter for storing the most recent measurement point FiThe cache variable of (2); s*Is used in the fliter for storing the nearest filtered point SiThe cache variable of (2); alpha is alpha*Is used in fliter for storing the most recent deflection angle alphaiThe cache variable of (2); the RN is a circular cache queue in the fliter and used for storing the history filtering points generated recently in the LS; when the length of LS is less than N, RN equals LS, otherwise RN equals Si-N+1,Si-N+2,...,Si-1,SiN is the maximum allowed length of the queue.
AddElement is a method for adding elements in RN, and the calling mode is RNi+1) I.e. the order of the elements Si+1Is added to SiThen; clear is a method for clearing all elements in RN, and the calling mode is rn.clear (); IsEmpty () is a method for judging whether the RN is an empty list or not, and is called in a mode RN; size is a method for judging RN length, and a calling mode is RN. Middle Get is a method for obtaining a certain track point in RN and a calling mode
Si=RN.Get(RN.Size()-1)。
GeoF in R is the core function in fliter to implement Generate, called the geometric computation functionNumber, satisfying the relation Si+1=GeoF(Fi+1,F*,S**RN) for calculating the latest filtering point; create is an internal function of GeoF, is used for generating Shell and satisfies the relation Shelli=Create(Fi+1,F*,S**) (ii) a Update is an internal function of GeoF for calculating or updating the latest deflection angle satisfying the relation αi+1=UpdateS(α*,S*,Fi+1or Si+1) (ii) a GetRaw is an internal function of GeoF, is used for preliminarily calculating the latest filtering point and satisfies the relation Si+1=GetRaw(Shelli,Fi+1i+1) (ii) a Attach is an internal function of GeoF and is used for correcting the latest filtering point to obtain the latest filtering point as a final result, and the latest filtering point meets the relation Si+1=Attach(Si+1,RN)。
Figure BDA0002720004380000092
Distance is a tool function used for calculating the Distance between two points and is called in a manner of | P1P2|=Distance(P1,P2) In which P is1、P2Is any two track points, | P1P2L is a distance value of two points, the preset minimum value of the distance is Min _ d, the preset maximum value of the distance is Max _ d, and the preset value can be used in a Create function; atan is a tool function used to calculate the unit vector in the positive x-direction
Figure BDA0002720004380000093
In the counterclockwise direction to vector
Figure BDA0002720004380000094
Angle therebetween
Figure BDA0002720004380000095
The calling mode is
Figure BDA0002720004380000096
Bettween is a tool function, and calculates the nearest deflection angle alphaiAnd the latest deflection angleαi+1Included angle theta less than straight angleiSatisfies the relation ofi=Bettween(αii+1) (ii) a Linear is a tool function, and the calling mode y is Linear (X)1,X2X) when X1≤x≤X2When y is more than or equal to 0 and less than or equal to 1, X and y are in a linear relationship, X1X, y is 0, X > X2When y is 1; CosP is a tool function, and calling mode l is CosP (Shell)i.f,θi) Wherein thetaiIs ShelliFocal point SiAnd vertex ZiFormed vector
Figure BDA0002720004380000101
And a focus SiAnd ShelliPoint C on the boundaryiFormed vector
Figure BDA0002720004380000102
The angle between l is the line segment SiCiThe distance value of (2).
Specifically, as shown in fig. 4, a computation flow diagram of a method for correcting an aircraft track positioning data offset (mainly, a computation part in a data flow diagram is made into a flow and a form) includes the following steps:
s1: fliter is an example of a filtering algorithm module, calling an initialization function fliter*、S*、α*RN, which is an internal attribute associated with the specific instance fliter, sets the receiving point sequence number i to-1.
Figure BDA0002720004380000103
And setting the global receiving point sequence index number i to be-1.
S2: receiving a latest measuring point Fi+1And added to the end of the original trajectory LF: add (F) in LFi+1)。
S3: the step is a process of generating a latest filtering point for the calculation of a geometric computation function and updating cache data:
Si+1=GeoF(Fi+1,F*,S**RN), the function GeoF implementation process is detailed later.
The implementation of the GeoF function in step S3 is the main content of the specific implementation, and the sub-step S33 (generating Shell) is discussed with emphasis oniCorrelation), S34 (calculate S)i+1Correlation), S35 (correction S)i+1Related) to the implementation of the process.
S31: judging whether the ring buffer queue RN of the history filtering point is an empty queue: isoempty (); if the cool is true, go to step S32, otherwise go to step S33.
S32: at this time, no filtering point is generated in the LS, a first filtering point needs to be generated, and the first filtering point is set to be a first measuring point: si+1=Fi+1(i.e., S)0=F0) (ii) a Setting the latest deflection angle alphai+1═ infinity (i.e., α)0═ infinity), meaning that the first Shell has not been generated.
The function GeoF is implemented as follows:
calculating the bol (RN. IsEmpty ()), judging whether the bol is true, and if not, turning to the step (c);
secondly, directly taking the latest filtering point as the latest measuring point: si+1=Fi+1And initializing the latest deflection angle alphai+1Changing to the step ninthly;
computing Shelli=Create(Fi+1,F*,S**) For creating a preliminary calculation Si+1Time dependent filter mantle Shelli
Fourthly, calculating alphai+1=Update(α*,S*,Fi+1) For calculating the latest deflection angle αi+1
Calculating Si+1=GetRaw(Shelli,Fi+1i+1) For preliminary calculation of the latest filtering point Si+1Wherein the filter mantle Shell created in the step (c) is utilizedi
Sixthly, calculate Si+1=Attach(Si+1RN) for preliminary counting in the correction step (c)Calculated latest filtering point Si+1A value of (d);
seventh judgment S*≠Si+1If the result is not true, turning to the step ninthly;
b calculating alphai+1=Update(α*,S*,Si+1) For adjusting the latest deflection angle alpha calculated in step (iv)i+1A value of (d);
ninthly, updating the value of the cache variable: f*=Fi+1、S*=Si+1、α*=αi+1Caching the latest measuring point, the latest filtering point and the latest deflection angle obtained by the calculation respectively to form the latest measuring point, the latest filtering point and the latest deflection angle parameter which are depended by calling the GeoF calculation for the next time;
r is the latest filtering point Si+1Adding to the RN circular buffer queue: AddElement (S)i+1);;
Figure BDA0002720004380000111
Return to the latest filtering point Si+1
S33: call Shelli=Create(Fi+1,F*,S**) Generating a calculation Si+1Dependent filter housing Shelli(S0As the first filtering point, it is computationally derived without passing through a filter housing), where S*Is ShelliFocus of (Shell)i.s=S*),α*Is ShelliDeflection angle (Shell)i.α=α*) Value of line segment | Fi+1F*The size of |, determines the ShelliSize of (Shell)iF); call alphai+1=Update(α*,S*,Fi+1) To calculate the unit vector of the positive direction of the x-axis
Figure BDA0002720004380000112
In the counterclockwise direction to line segment Fi+1S*Angle alpha ofi+1When line segment Fi+1S*Is absent (i.e. F)i+1=S*Of (i) alphai+1Is set to a*
Wherein the implementation process of the Create function in step S33 is as follows:
creating ShelliExample (c): shelliInitially setting Shell () for new Shell ()iFocal point Shelli.s=S*Initialization setting ShelliAngle of deflection Shelli.α=α*
② calculating the latest measuring point Fi+1To the nearest measurement point F*The distance of (c): i Fi+1F*|=Distance(Fi+1,F*) Calculating the distance value in the interval [ Min _ f, Max _ f]Relative ratio coefficient of (1): phi ═ Linear (Min _ d, Max _ d, | F)i+1F*|);
Third, the Shell generated in the first step of calculationiMagnitude-dependent f-value: shelli.f=Min_f+(Max_f-Min_f)*φ;
Fourthly, the latest filtering point S of the calculation is returnedi+1Dependent filter housing Shelli
Wherein the implementation of the tool function Linear is as follows,
firstly, judging that X is less than or equal to X1If yes, returning to 0;
② judge that X is more than or equal to X2If yes, returning to 1;
③ return a proportionality coefficient between (0, 1): (X-X)1)/(X2-X1)。
Note: shelliThe value of f determines the size of the filter housing, which is set to [ Min _ f, Max _ f]Between the ranges, and with the value | Fi+1F*I is related in size, i.e. the latest measuring point F in the original trajectoryi+1Closest measurement point F to the original trajectory*Distance between | Fi+1F*The larger the | is, the larger the absolute value of the drift error can be considered, and the required filter housing ShelliThe larger the design.
S34: calling Si+1=GetRaw(Shelli,Fi+1i+1) Preliminary calculation of the bestNew filter point Si+1Here first the Shell is calculatediAngle of deflection alphaii=Shelliα) and α)i+1Angle theta therebetweeni=Bettween(αii+1) Recalculating ShelliS focus ofiAnd Fi+1Line segment formed with ShelliCommon point of boundary CiDistance from focal point | SiCi|=CosPi(Shellii) If C is presentiIf present, then in line segment SiFi+1To find a point Si+1So that SiCi|=|Si+1Fi+1I, otherwise (C)iIn absence of Fi+1Dotted on ShelliBoundary or interior) Si+1Take the value of Si
The tool function CosP is realized as follows, and is related to a parameter (rho)ii) Parabolic polar equation:
|SiCi|=ρi=CosP(Shelli.f,θi)=2*Shelli.f/(1+cosθi)=2*SiZi|/(1+cosθi)。
note: when alpha isi< 0 is present when i is 0, alphaiIn the case of ═ infinity, the Shell that has been generated is explained0Is that the deflection angle has not been set yet, but α has been generated in step S331Is the next filter mantle Shell1Angle of deflection (alpha)1Does not change its value after step S35), the Shell is put into service at this time0Angle of deflection alpha0Preset to alpha1I.e. alpha0And alpha1Included angle theta0And (0) keeping the two filter covers from turning. When | SiFi+1|<=|SiCiWhen l, Fi+1Is positioned on the filter housingiOn the inside or boundary, when F is noti+1Whether or not to react with SiCoincident, latest measurement point Si+1Are all set to be equal to SiAnd (4) overlapping.
Process description of GetRaw function As shown in the example of FIG. 6, ShelliIs a line segment Si-1SiThe straight line is the symmetric central axis (if SiIs not modified by the Attach function, then FiPossibly on the medial axis) with a vertex ziAt a deflection angle of
Figure BDA0002720004380000131
In the counterclockwise direction to
Figure BDA0002720004380000132
Angle alpha ofi,θiIs composed of
Figure BDA0002720004380000133
In the counterclockwise direction to
Figure BDA0002720004380000134
Angle of (D) Fi+1Is ShelliOne point outside, calculate | SiFi+1|、|SiCiAfter | preliminarily calculating the line segment SiFi+1Upper is calculated Si+1Satisfy | SiCi|=|Si+ 1Fi+1|。
The geometry of the Shell will be constructed as a filter shroud because it exhibits symmetry with respect to the direction of motion of the aircraft and is easy to calculate. ShelliThe direction of (1) is a vector formed by two filtering points of the nearest moving object
Figure BDA0002720004380000135
Should theoretically be symmetrical, but not symmetrical in the front-to-back direction, i.e. Fi+1Relative to SiThe positional relationship of (A) can be represented by a vector
Figure BDA0002720004380000136
A description is given.
Figure BDA0002720004380000137
And
Figure BDA0002720004380000138
angle of (theta)iAnd the nearest measurement point FiAnd Fi+1Distance d ofi=|FiFi+1Two parameters that are of paramount importance to how the filter housing Shell is designed. ThetaiThe degree to which the currently moving object needs to be steered at the next moment (real-time direction change), diThe extent to which the currently moving object needs to be displaced at the next moment (real-time velocity) is illustrated. The method comprises the following steps: thetaiIn addition to reflecting true steering, error-induced directional offset is also reflected, especially at low speeds, which can cause the target to change direction frequently and even back up, so the design of Shell needs to prevent abrupt steering due to error as much as possible. The principle is therefore thetaiThe larger the value, the more it needs to be suppressed, so that the filtered trajectory is more continuously smooth. And when the shape of the Shell is designed as a parabolic region, when theta isiThe larger the value, SiFi+1The intersection C of the straight line and the Shell boundaryiTo the focus SiThe greater the distance of Fi+1Fall on ShelliThe higher the probability of the inside, the more effectively F that is severely diverted due to the errori+1Effectively filtering out. Therefore, θiThis index determines the ShelliThe design of the geometrical shape of (2). The method comprises the following steps: diIn addition to the true speed, the error-induced position offset, diThe larger the value is, the larger the amount of positional deviation due to the error becomes. If all the shells areiSet to a fixed small size, the yaw angle is merely changed following the movement of the target, and the size is not changed with the real-time speed. When the target speed is faster, di=|FiFi+1The greater the value of | is, the less the velocity will not decrease due to the inertia of the target movement, so the d of the subsequent measurementi+1=|Fi+1Fi+2The value of | will also be larger. Because of the ShelliF is small, so the distance F is obtained after GetRaw function calculationi+1Very close Si+1. Because of di+1Is larger, so | Si+1Fi+2The value of | will also be roughly greater, then Fi+2Fall in Si+1Shell in focusi+1The probability of insides is low. At the sudden turning of the target due to the error, so that thetai+1In the case of a relatively large size, F is required to be reducedi+2Successfully filtered out (i.e. S)i+2And Si+1Overlap) is less likely, even if F cannot be adjustedi+2Filtration, also requiring suppression from Si+1To Fi+2Distance of directional displacement (selected from S)i+1Near, far from Fi+2The far point is taken as Si+2) However, such an effect of suppressing is also weak. If all the shells areiSet to a fixed large size, thus the distance S will be setiSufficiently far Fi+1Is also enclosed in the ShelliInternally, will lead to Si+1Is superposed on Si,Si+1F of true measurement of distancei+1The deviation is too far away so that the filtering effect does not fit the actual measurement. Thus, in summary, with diVariation of (3), ShelliThe value of f should be reasonably scaled up or down in positive correlation, so that diThis index determines the ShelliThe size of the device is designed.
S35: calling Si+1=Attach(Si+1RN), correcting the latest filtering point S by using the local trace RN constituted by the history filtering points generated most recentlyi+1The value of (c): when S isi+1And removing S in RNiA point S other thanjSatisfies SjIs leaving S in RNi+1Nearest track point, and | Si+1SjIf | is less than the minimum allowed value Min _ f of Shell.f, Si+1Value is SjOtherwise, when there is S in RNiTwo points S adjacent to each otherj、Sj+1Line segment S of the compositionjSj+1So that SjSj+1Is leaving S in RNi+1Nearest line segment and passes through Si+1As SjSj+1The vertical foot S of the straight lineIs located on line segment SjSj+1Within, and | Si+1S|<|Si+1SiI, and I Si+1SIf | is less than the minimum allowed value Min _ f of Shell.f, Si+1Value is SOtherwiseSi+1The value of (a) is not changed, i.e. no position correction is required; if S isi+1Not in contact with S*In case of coincidence, call αi+1=Update(α*,S*,Si+1) To update the unit vector in the positive direction of the x-axis
Figure BDA0002720004380000141
In the counterclockwise direction to the line segment Si+1S*Angle alpha ofi+1
We demonstrate completely how the function GeoF works without considering the effect of the Attach function modification, i.e. the function GeoF omits step S35. FIG. 6 is a diagram illustrating an example of a simple filtering trace generation process:
obtaining an initial measurement point F0,S0Direct value of F0
② obtaining F1According to S0Determining Shell0According to S0F1Calculate Shell0And Shell1The deflection angles (the deflection angles are matched) according to | F1F0I determining Shell0According to S0F1Calculate C0(C0Is located on Shell0The vertex) to calculate S1
Obtaining F2According to S1Determining Shell1Known as Shell1Has been calculated, according to S1F2Calculate Shell2According to | F2F1I determining Shell1According to S1F2Calculate C1Thereby calculating S2
Obtaining F3According to S2Determining Shell2Known as Shell2Has been calculated, according to S2F3Calculate Shell3According to | F3F2I determining Shell2According to S2F3Calculate C2Thereby calculating S3
Fifthly, F is obtained4According to S3Determining Shell3Known as Shell3Has been calculated, according to S3F4Calculate Shell4According to | F4F3I determining Shell3According to S3F4Calculate C3Thereby calculating S4
Obtaining F5According to S4Determining Shell4Known as Shell4Has been calculated, according to S4F5Calculate Shell5According to | F5F4I determining Shell4In this case because of F5In Shell4Inside, so that S does not exist4F5And Shell4Intersection C of the boundaries4So that S5And S4Overlapping;
obtaining the end point F6According to S5Determining Shell5Known as Shell5Has been calculated, according to S5F6Calculate Shell6According to | F | (no longer used)6F5I determining Shell5According to S5F6Calculate C5Thereby calculating S6
So that the broken line LF is equal to F0F1F2F3F4F5F6Is converted into a broken line LS ═ S through an algorithm0S1S2S3S4S5S6(wherein S4、S5Overlap, so | S4S50). It can be seen that the direction change between adjacent line segments of the original trajectory LF is severe and the trajectories intersect themselves; the direction change between adjacent line segments of the filtering track LS is relatively smooth, such as ≈ Fk-1FkFk+1≤∠Sk-1SkSk+1(when k is 1,2,3) and self-intersection is released.
The implementation process of the Update function in step S33 and step S35 is as follows:
given a trace point p, it can be the latest measurement point Fi+1Or the latest filtering point Si+1
② judgment of S*P and α*Whether more than or equal to 0 is simultaneously established, if so, the latest deflection angle is kept as a cache alpha*Value of the most recent deflection angle of (1): alpha is alphai+1=α*Transferring to the step IV;
③ passing through the track point p and buffer S*The latest deflection angle alpha is calculated from the relative position of the nearest filtering point in (b)i+1=Atan(S*,p);
Fourthly, the latest deflection angle alpha is returnedi+1
Note: latest measurement point Fi+1Or the latest filtering point Si+1Relative to the nearest filter point S*In the case of no movement (coincidence), the latest deflection angle αi+1The nearest deflection angle alpha to be stored before*And the filter housing does not turn. However, there is a precondition that the deflection angle has been successfully set recently, i.e., α*Not ≠ - ∞. If the latest deflection angle is not set in case of coincidence, then α in the else statement block is called1=Atan(S*,S*) Set at 0.
The implementation procedure of the GetRaw function in step S34 is as follows:
firstly, from the filter mantle ShelliTo obtain the nearest deflection angle alphai=Shelli.α;
② judgment of alphaiIf < 0, if yes, initializing included angle thetaiIf the value is 0, the step IV is carried out;
calculating the nearest deflection angle alphaiAnd the latest deflection angle alphai+1The included angle between: thetai=Bettween(αii+1);
Fourthly, from the filter mantle ShelliTo obtain the nearest filtering point Si=Shelli.s;
Fifthly, calculating the nearest filtration point SiTo the latest measuring point Fi+1The distance of (c):|SiFi+1|=Distance(Si,Fi+1);
sixthly, calculating the nearest filtering point Si(focus) on the filter mantle and the vertex of the filter mantle form an included angle theta relative to the focusiPoint C ofiThe distance between: i SiCi|=CosP(Shelli.f,θi);
Judgment of | SiFi+1|≤|SiCiIf |, if true, the latest filtering point Si+1And the nearest filtering point SiSuperposing: si+1=SiTurning to step ninthly;
calculating distance ratio coefficient lambda ═ S [ [ lambda ] ]iCi|/|SiFi+1L, calculation is located on line segment SiFi+1Last filter point above: si+1=λ*Si+(1-λ)*Fi+1
Ninthly, returning to the latest filtering point Si+1
Wherein the implementation process of the Attach function in step S35 is as follows:
judging whether RN.Size () > 0 is true, if not, turning to step ninthly;
acquiring the nearest trace point S in the ring cache queue RNiGet (rn. size () -1), calculate the distance to the latest filter point Si+1Distance | S ofiSi+1|=Distance(Si,Si+1);
Calculating every point in RN to Si+1Finding out the point min _ p with the minimum distance and the minimum distance value min _ d;
fourthly, judging that Min _ d is less than Min _ f and Min _ d is less than | SiSi+1If the l is simultaneously established, wherein Min _ f is the allowed minimum filter cover f value, and if not, the step is executed to the step (c);
the latest filtration point Si+1The assignment is min _ p: si+1Min _ p, go to step ninj;
sixthly, calculating the line segment formed by every two adjacent points in the RN to the Si+1Find the two end points min _ pA and min _ pB of the line segment with the smallest distance, and find the most distantSmall distance values min _ l and Si+1A proportionality coefficient min _ λ of the position of the foot on the line segment with respect to the entire line segment;
seventhly, judging Min _ l < Min _ f and Min _ l < | SiSi+1If the | is simultaneously established, if not, turning to the step ninthly;
according to the proportional coefficient obtained in the step (c), calculating the latest filtering point of the latest filtering point on the line segment min _ pA min _ pB by using min _ lambda: si+1=(1-min_λ)*min_pA+min_λ*min_pB;
Ninthly, returning to the latest filtering point Si+1
Note: substituting the parameter S of the function in three casesi+1Conditional screening of the Attach function, i.e. S, can be circumventedi+1Is not modified, but remains as it is, here called the "escape Attach function": firstly, when the RN has no track point or only one track point, the S is generated0、S1The Attach function can be escaped; when Si+1The value of (D) and the last trace point S in RNiThe Attach function can be escaped when the overlapping is carried out; ③ Dang | SiSi+1| < S >i+1Set of all points (S) contained in the polyline formed by RNiExcept for dots) "separated by Si+1The distance to the nearest point, and the distance value from the point is less than Min _ f, the Attach function can be escaped.
Description of the procedure of the Attach function as shown in the example of fig. 7, two different modifications S are shown separatelyi+1Value of S 'before correction'i+1Denotes Si+1. A is the case: when calculating S'i+1Distance RN-SiMiddle closest point SuIts distance value | SuS′i+1| satisfy | SuS′i+1|<|SiS′i+1I and I SuS′i+1If Min _ f is | < S'i+1Is corrected to SuSo that S after correctioni+1=Su(ii) a The Situation of B is: is S'i+1And RN-SiUnder the condition that the position relation of the left half graph is not satisfied, a line segment S is founduSu+1Is satisfied with S'i+1To SuSu+1The vertical foot S of the straight lineOn line segment SuSu+1Inner (two points at the boundary are not included), and SuSu+1Is a distance S 'in a broken line composed of RN'i+1Nearest line segment and distance value | SS′i+1| satisfy | SS′i+1|<|SiS′i+1I and I SS′i+1If Min _ f is | < S'i+1Is corrected to SSo that S after correctioni+1=S
The reason why the subfunction Attach is designed is that the latest filtering point S preliminarily generated by the subfunction GetRaw in the function GeoFi+1If step S35 is skipped and added directly to LS, the trajectory formed when the moving object traverses a certain path will have such a feature: in the LS, a plurality of sub-tracks running approximately parallel to the path and not related to each other are formed in the portion passing through the path, and the dispersion width sometimes exceeds the path width, resulting in the overall drift of the track. Because the function GetRaw only reacts with Shelli、Fi+1、αi+1Correlation; shelliOnly with Fi+1、F*(Fi)、S*(Si)、α*i) Correlation; alpha is alphai+1And also with alpha*i)、S*(Si)、Fi+1And (4) correlating. So Si+1And Si、αi、Fi、Fi+1These four parameters are directly related. Wherein the nearest measuring point FiLatest measuring point Fi+1Is independent data, nearest filtering point SiMost recently the deflection angle alphaiIs iteratively calculated based on historical trajectories. The more first occurring or generated historical track points (e.g., S)0、F1) For calculating the latest filtering point Si+1The smaller the impact of (c) is, because in an iterative process, historical data impact weights will diminish rapidly, and recent and up-to-date data impacts will be very large. Therefore, the GeoF function not including step S35 is considered to have no ability to track the history data, and to be on the same routeGenerate the path of the path (ls)1) Then, a return sub-track (denoted as ls) is generated2) Usually ls1And ls2There is a longer sub-track connecting the two, so ls1Containing pairs of track points ls2That is, the long history data, vs. ls2The generation of each filtering point in the filter has little influence, and is considered to be ls1And ls2Are almost irrelevant. In this case, therefore, it is ensured that LS generated by GeoF is smooth, but the sub-trajectories passing through the same road segment will be shifted as a whole. As shown in fig. 9, in the case that the original trajectory LF has multiple round trips in the same link, there is a wider (about 10m) offset width (the surrounding mark is identified by a white thick line in the figure); when the filtering trajectory LS (the label "Without S35") generated by the function GeoF not including the step S35 is used, if the same link has multiple round trips, the offset width is also wide, and is equivalent to the width of the LF on the same link; in the case where multiple round trips occur in the same link (the recent round trip data is stored in RN), the filtered trajectory LS generated by the GeoF function including step S35 (identified as "Include S35") has only a narrow (less than 3m) offset width between sub-trajectories, and all sub-trajectories going to and from the same link are highly overlapped. The strip-shaped area where the white bounding area is located in the case including step S35 is almost located in the middle of the strip-shaped area corresponding to LF, and the distribution of the latter is usually a certain symmetric probability distribution about the center line of the link, so that the function Attach can converge the sub-trajectories reciprocating on the same link into the area where the link is located with high probability, and reduce the situation that a certain segment of LS drifts out of the link boundary.
The actual program run screenshot in which the Attach function works is shown in fig. 8, which shows a scenario involving the collection object illustrated by the two schematic diagrams of fig. 5 and 7. In location A and location B, the trace points are corrected to correspond to location A and location B in FIG. 7, respectively. The small dots marked with numbers in the figure represent track points and positions thereof, and after a complete filtering track (a track record called from a database in advance) is generated by using the numbers with the upper row connected by vertical connecting lines to represent the track points and the positions thereof, the track points overlapped at the corresponding positions of the dots areNumber of the cells. The adjacent trace points are connected by line segments to form the complete LS (because each dot may be a plurality of overlapped trace points, a certain line segment forming the broken line LS may be the result of multiple overlapped line segments). ShelliIs a dark color area with a parabola as a boundary, and the corresponding track point of a small circle with a star-shaped edge circle is ShelliS focus ofiSince here Fi+1Is located on ShelliExternal, so SiFi+1Cross ShelliIs bounded by CiUsing function GetRaw to preliminarily calculate the latest filtering point S before correctioni'+1. In the configuration A, a certain historical filtering point corresponding to the circle center position of the circular area is a modified point S found by the Attach functioni+1,S′i+1At the boundary of the circular region, vector
Figure BDA0002720004380000191
That is, the correction amount, the moving distance is the radius of the circle and is S 'in RN'i+1The nearest trace point, notably the one existing closer in the graph, is the historical trace point earlier or S later than the point in RN i+1In-line with the aboveThe later track points do not participate in the calculation of the track filtering algorithm; in situ B, the center of the capsule-shaped region is the line segment connecting two adjacent points in RN, which is S 'in RN'i+1The nearest line segment and the vertical foot between the line segments are the corrected points S found by the Attach functioni+1It is most likely not co-located with any historical track point, S'i+1A vector at the boundary of the capsule-shaped region and orthogonal to the line segment
Figure BDA0002720004380000192
I.e. the correction amount.
Wherein in the Update function in step S35, the calling condition is S calculated by the Attach functioni+1Not with the nearest filtering point S*Coincidence, i.e. S*≠Si+1. The logic so designed is that if after the Attach function calculation there is S*And Si+1Coincidence, then as a parameter inputS before Attachi+1Has already reacted with S*(i.e. the last trace point S in RNi) Coincidently, having been previously analyzed, Si+1Is the escape Attach function. So in the process of GetRaw function, Fi+1Is located on ShelliThe latest deflection angle alpha calculated at that time, inside or on the boundaryi+1Is directed to Fi+1More specifically, if the Update function is called in step S35 without setting the conditional filtering, then α appears after the call is forcedi+1In the case of 0, the next filter housing Shelli+1In relation to ShelliThe direction of (2) can change suddenly, which is not in accordance with the movement rule and affects the filtering effect.
S36: at this time, the latest filtering point Si+1It has been calculated that the cache data needs to be updated here: f*=Fi+1(original value is F)i),S*=Si+1(original value is S)i),α*=αi+1(original value is alpha)i) Adding Si+1To the ring buffer queue of the most recently generated history filtering point: AddElement (S)i+1)。
S4: outputting a latest filtering point Si+1And added to the end of the filter trace LS: add (S) to LSi+1) At this time, the sequence number i may be set to be self-increasing (i + +), and the process returns to step S2 (if there are measurement points of a certain trajectory that need to be received), otherwise, the algorithm is ended, and a complete filtering trajectory LS is generated.
The embodiment has the advantages that firstly, the requirement on data complexity is low, only the spatial position information of the measuring points based on time sequence is needed, the time stamp of each measuring point is not needed to calculate the motion rule based on the time difference, and the path matching for improving the precision is not needed to be carried out depending on the road information; secondly, the computing resource consumption is low, the result is obtained by computing simple space geometric relationship, the latest filtering point is rapidly computed after the latest measuring point is input, the motion trend is predicted without statistical analysis such as fitting on historical data, and the computing overhead is greatly reduced; and thirdly, the positioning is accurate, the stability is high, the track is more consistent with the motion rule, the positions are corrected to the near small-range space field, the situation that the measured data are not excessively deviated, a continuous and smooth advancing track is formed, the situations of self-intersection, front-back reciprocating, left-right zigzag swing and the like do not occur, and the motion trend which is consistent with the physical inertia characteristics, such as stable rest, uniform acceleration and deceleration, smooth turning and the like can be reflected.
In this embodiment, when the positioning accuracy error of the positioning data is 5m to 10m, the following effects can be achieved under the parameter settings of Min _ f being 5, Max _ f being 100, Min _ d being 30, Max _ d being 150, and N being 1000:
as shown in fig. 10, when the moving object is actually stationary, the received positioning data from the red marked measurement points appears to be distributed in a lump, the distribution range is in a planar space with a span of about 8m, and random drift with an amplitude of about 1m to 3m appears between the points, forming a self-intersecting trajectory (upper half graph); the filtering algorithm maps the point set of the globoid distribution to a single filtering point marked by blue, the position of the point is a certain point in the globoid distribution space, and the filtering point keeps moving along with the drift of the measuring point in the space, so as to accord with the static actual situation (the lower half picture).
As shown in fig. 11, in the case of a moving object actually moving straight, the received positioning data given by the red marked measuring point drifts along the left and right direction of the straight line and reciprocates back and forth to form a zigzag track (upper half graph) with a local self-intersecting small lump with a size of about 4 m; the filtering algorithm corrects the drawn track of the measuring points to a smooth track (lower half picture) which is formed by a filtering point marked by blue and continuously advances forwards without reciprocating.
As shown in fig. 12, in the process from actual rest to acceleration of the moving object, the received positioning data given by the red marked measuring points appear to be distributed like a lump when starting to gradually accelerate, and a trajectory (upper half diagram) with a self-intersecting head part of a small lump with a size of about 6m and then winding is formed; the filtering algorithm corrects the locus drawn by the measuring points to a smooth locus (lower half picture) which is formed by filtering points marked by blue and gradually accelerates and continuously advances forwards.
As shown in fig. 13, in the process of decelerating the moving object to be stationary from practice, the received positioning data given by the red marked measuring points appears in a lump distribution when gradually decelerating to be stationary, so as to form a track (upper half graph) with a zigzag travel and a self-intersected small lump with a size of about 5m at the tail; the filtering algorithm corrects the locus drawn by the measuring points to a smooth locus (lower half picture) which is formed by filtering points marked by blue and gradually decelerates and continuously advances forwards.
As shown in fig. 14, in the case of a real speed-change turning, the received positioning data from the red marked measurement points shows the distribution of the lumps in the turning processes of "turning after deceleration" and "turning after acceleration", the distribution range is in a plane space with a span of about 12m, and the random drift with an amplitude of 1 m-2 m occurs between the internal points of the lumps, so as to form a self-intersecting trajectory (upper half graph) during the zigzag travel and turning; the filtering algorithm corrects the track drawn by the measuring points to a smooth track (lower half picture) which is formed by filtering points marked by blue and continuously advances forwards, is gradually decelerated, turns at the break and gradually accelerated, and does not reciprocate in the process.
As shown in fig. 15, a structure diagram of an apparatus for correcting an aircraft track positioning data offset according to a fifth exemplary embodiment of the present invention includes:
the preprocessing unit 1501 is configured to empty the history cache information before performing the operation of correcting the current track positioning data offset of the aircraft;
a receiving unit 1502, configured to receive real-time measurement point information of an aircraft sent by a distributed positioning system;
the filtering unit 1503 is used for determining the current parabola and the real-time deflection angle information which are used as the filter cover according to the real-time measuring point information and the current cache information; calculating and generating real-time filtering point information corresponding to the real-time measuring point according to the real-time measuring point information, the current parabola and the real-time deflection angle information; the current cache information includes: the cache queue comprises last measurement point cache information, last filtering point cache information, last deflection angle cache information and cache queues of all filtering point information between an initial filtering point and a last filtering point of the current flight path; the last deflection angle cache information is an included angle formed between a unit vector in the positive direction of the axis and a connecting line from the focus of the current parabola to the vertex of the current parabola along the anticlockwise direction;
an updating unit 1504, configured to update current cache information according to the real-time measurement point information, the real-time filtering point information, and the real-time deflection angle information;
the track correction unit 1505 is used for obtaining a corrected track of the current track of the aircraft according to all the filtering point information of the current track.
Preferably: the filtering unit 1503 is specifically configured to: determining a common point of a line segment formed by connecting the cache information of the previous filtering point to the information of the real-time measuring point and the boundary of the current parabola; and forming an included angle between vectors by the unit vector in the positive axial direction and a common point connecting line from the focus of the current parabola to the boundary of the current parabola along the counterclockwise direction to serve as real-time deflection angle cache information.
Preferably: the filtering unit 1503 is specifically further configured to: and determining the size of the current parabola according to the length of a connecting line between the cache information of the previous measuring point and the real-time measuring point information.
Preferably: the filtering unit 1503 is specifically further configured to: calculating an included angle between a first deflection angle information and a real-time deflection angle information, calculating a distance between a common point of a current parabola boundary and a focus of the current parabola, if the common point exists, determining real-time filtering point information on a line segment formed by the focus of the current parabola and the real-time measuring point information, wherein the real-time filtering point information meets the condition that the distance between a last filtering point information and the common point is equal to the distance between the real-time filtering point information and the real-time measuring point, and if the common point does not exist, the real-time filtering point information is the last filtering point information.
Preferably: the device for correcting the aircraft track positioning data offset further comprises a filtering point information correcting unit 1506, which is used for: correcting the real-time filtering point information according to the cache queue, so that the updating unit updates the current cache information according to the corrected real-time filtering point information and the track correcting unit obtains the corrected track of the current track of the aircraft according to the corrected real-time filtering point information
The corrected path is continuous and smooth, the conditions of sudden change of the running direction and the displacement degree can not occur, and the continuous advancing trend of the aircraft can be well reflected; each point in the corrected path has no large deviation with the corresponding actual measurement data, the error is controlled in a small range, and the error is matched with the road surface in space as much as possible; the corrected path is to filter out the self-intersection of the track caused by the drift of the positioning data error, eliminate the conglomeration distribution, height folding and other conditions of the track in a smaller space range, prevent the reciprocating motion along the advancing direction of the road surface, and enable the form of the track to accord with the physical law of the motion of the aircraft, such as the motion characteristics of large-inertia objects, such as continuous advancing, slow acceleration and deceleration, large turning amplitude, incapability of easily changing the direction and the like. The dependence of the correction device on input data is simple enough, only a measuring point sequence generated according to the time sequence and coming to positioning data needs to be input, and reasonable corrected positioning points are calculated through analysis of the space geometric relationship of the points without depending on an additional data set, so that the increase of use, maintenance and calculation difficulty is avoided.
The above description is only for the specific embodiment of the present invention, but the scope of the present invention is not limited thereto, and any changes or substitutions that can be easily conceived by those skilled in the art within the technical scope of the present invention are included in the scope of the present invention. Therefore, the protection scope of the present invention shall be subject to the protection scope of the claims.

Claims (10)

1. A method for correcting an aircraft track positioning data offset, comprising:
clearing historical cache information before correcting the current track positioning data offset of the aircraft;
receiving real-time measuring point information of an aircraft sent by a distributed positioning system;
determining current parabola and real-time deflection angle information used as a filter cover according to the real-time measuring point information and the current cache information; the current cache information includes: the cache queue comprises last measurement point cache information, last filtering point cache information, last deflection angle cache information and cache queues of all filtering point information between an initial filtering point and a last filtering point of the current flight path; the last deflection angle cache information is an included angle formed between a unit vector in the positive direction of the x axis and a connecting line from the focus of the current parabola to the vertex of the current parabola along the anticlockwise direction;
calculating and generating real-time filtering point information corresponding to the real-time measuring point according to the real-time measuring point information, the current parabola and the real-time deflection angle information;
updating current cache information according to the real-time measuring point information, the real-time filtering point information and the real-time deflection angle information;
and obtaining the corrected flight path of the current flight path of the aircraft according to all the filtering point information of the current flight path.
2. The method of correcting for aircraft track positioning data drift of claim 1, wherein: determining real-time deflection angle information according to the real-time measuring point information and the current cache information comprises:
determining a common point of a line segment formed by connecting the cache information of the previous filtering point to the information of the real-time measuring point and the boundary of the current parabola;
and forming an included angle between vectors by the unit vector in the positive axial direction and a common point connecting line from the focus of the current parabola to the boundary of the current parabola along the counterclockwise direction to serve as real-time deflection angle cache information.
3. The method of correcting for aircraft track positioning data drift of claim 2, wherein: determining a current parabola for use as a filter sock from the real-time measurement point information and the current cache information comprises:
and determining the size of the current parabola according to the length of a connecting line between the cache information of the previous measuring point and the real-time measuring point information.
4. A method of correcting for aircraft track positioning data drift as defined in claim 3, wherein: the step of calculating and generating real-time filtering point information corresponding to the real-time measuring point according to the real-time measuring point information, the current parabola and the real-time deflection angle information comprises the following steps:
calculating an included angle between a first deflection angle information and a real-time deflection angle information, calculating a distance between a common point of a current parabola boundary and a focus of the current parabola, if the common point exists, determining real-time filtering point information on a line segment formed by the focus of the current parabola and the real-time measuring point information, wherein the real-time filtering point information meets the condition that the distance between a last filtering point information and the common point is equal to the distance between the real-time filtering point information and the real-time measuring point, and if the common point does not exist, the real-time filtering point information is the last filtering point information.
5. Method for the correction of an aircraft track positioning data offset according to any of claims 1 to 4, characterized in that: the step of calculating and generating real-time filtering point information corresponding to the real-time measuring point according to the real-time measuring point information, the current parabola and the real-time deflection angle information further comprises the following steps:
and correcting the real-time filtering point information according to the cache queue so as to update the current cache information according to the corrected real-time filtering point information and obtain the corrected flight path of the current flight path of the aircraft.
6. An apparatus for correcting an aircraft track positioning data offset, comprising:
the preprocessing unit is used for emptying historical cache information before the correction operation of the current track positioning data offset of the aircraft is carried out;
the receiving unit is used for receiving the real-time measuring point information of the aircraft sent by the distributed positioning system;
the filtering unit is used for determining the current parabola and the real-time deflection angle information which are used as the filtering cover according to the real-time measuring point information and the current cache information; calculating and generating real-time filtering point information corresponding to the real-time measuring point according to the real-time measuring point information, the current parabola and the real-time deflection angle information; the current cache information includes: the cache queue comprises last measurement point cache information, last filtering point cache information, last deflection angle cache information and cache queues of all filtering point information between an initial filtering point and a last filtering point of the current flight path; the last deflection angle cache information is an included angle formed between a unit vector in the positive direction of the axis and a connecting line from the focus of the current parabola to the vertex of the current parabola along the anticlockwise direction;
the updating unit is used for updating the current cache information according to the real-time measuring point information, the real-time filtering point information and the real-time deflection angle information;
and the track correction unit is used for obtaining the corrected track of the current track of the aircraft according to all the filtering point information of the current track.
7. The apparatus for correcting for aircraft track positioning data drift of claim 6, wherein: the filter unit is specifically configured to: determining a common point of a line segment formed by connecting the cache information of the previous filtering point to the information of the real-time measuring point and the boundary of the current parabola; and forming an included angle between vectors by the unit vector in the positive axial direction and a common point connecting line from the focus of the current parabola to the boundary of the current parabola along the counterclockwise direction to serve as real-time deflection angle cache information.
8. The apparatus for correcting for aircraft track positioning data drift of claim 7, wherein: the filter unit is specifically further configured to: and determining the size of the current parabola according to the length of a connecting line between the cache information of the previous measuring point and the real-time measuring point information.
9. The apparatus for correcting for aircraft track positioning data drift of claim 8, wherein: the filter unit is specifically further configured to: calculating an included angle between a first deflection angle information and a real-time deflection angle information, calculating a distance between a common point of a current parabola boundary and a focus of the current parabola, if the common point exists, determining real-time filtering point information on a line segment formed by the focus of the current parabola and the real-time measuring point information, wherein the real-time filtering point information meets the condition that the distance between a last filtering point information and the common point is equal to the distance between the real-time filtering point information and the real-time measuring point, and if the common point does not exist, the real-time filtering point information is the last filtering point information.
10. An aircraft track positioning data offset correction device according to any one of claims 6-9, characterized in that: further comprising:
the filtering point information correcting unit is used for: and correcting the real-time filtering point information according to the cache queue, so that the updating unit updates the current cache information according to the corrected real-time filtering point information and the track correcting unit obtains the corrected track of the current track of the aircraft according to the corrected real-time filtering point information.
CN202011084881.1A 2020-10-12 2020-10-12 Method and device for correcting flight path positioning data offset of aircraft Active CN112365743B (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN202011084881.1A CN112365743B (en) 2020-10-12 2020-10-12 Method and device for correcting flight path positioning data offset of aircraft

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN202011084881.1A CN112365743B (en) 2020-10-12 2020-10-12 Method and device for correcting flight path positioning data offset of aircraft

Publications (2)

Publication Number Publication Date
CN112365743A true CN112365743A (en) 2021-02-12
CN112365743B CN112365743B (en) 2021-11-09

Family

ID=74507622

Family Applications (1)

Application Number Title Priority Date Filing Date
CN202011084881.1A Active CN112365743B (en) 2020-10-12 2020-10-12 Method and device for correcting flight path positioning data offset of aircraft

Country Status (1)

Country Link
CN (1) CN112365743B (en)

Cited By (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113641685A (en) * 2021-10-18 2021-11-12 中国民用航空总局第二研究所 Data processing system for guiding aircraft
CN114001976A (en) * 2021-10-19 2022-02-01 杭州飞步科技有限公司 Method, device and equipment for determining control error and storage medium
CN114627687A (en) * 2022-01-19 2022-06-14 南京航空航天大学 Helicopter ground proximity warning method for predicting escape trajectory based on neural network

Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6345217B1 (en) * 2000-03-31 2002-02-05 Rapistan Systems Advertising Corp. Automated guided vehicle (AGV) with bipolar magnet sensing
CN1656357A (en) * 2002-03-28 2005-08-17 松下电器产业株式会社 Relative position information correction device, relative position information correction method, relative position information correction program, shape vector generation device, shape vector generat
CN103425377A (en) * 2012-05-21 2013-12-04 汉王科技股份有限公司 Coordinate correction method and device and electromagnetic touch-control device
CN107924630A (en) * 2015-08-05 2018-04-17 株式会社电装 Position detecting device, method for detecting position and position detecting system
CN109459772A (en) * 2018-11-28 2019-03-12 江苏理工学院 A kind of position of aircraft signal fused filtering method
CN109725804A (en) * 2018-12-21 2019-05-07 歌尔科技有限公司 Track recognizing method, projection device and storage medium based on projection
CN110494345A (en) * 2017-04-07 2019-11-22 歌乐株式会社 Parking aid
CN111210668A (en) * 2019-12-30 2020-05-29 四川函钛科技有限公司 Landing stage flight trajectory offset correction method based on time sequence QAR parameter
CN111602029A (en) * 2018-01-16 2020-08-28 爱知制钢株式会社 Vehicle position management system and vehicle position management method

Patent Citations (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6345217B1 (en) * 2000-03-31 2002-02-05 Rapistan Systems Advertising Corp. Automated guided vehicle (AGV) with bipolar magnet sensing
CN1656357A (en) * 2002-03-28 2005-08-17 松下电器产业株式会社 Relative position information correction device, relative position information correction method, relative position information correction program, shape vector generation device, shape vector generat
CN103425377A (en) * 2012-05-21 2013-12-04 汉王科技股份有限公司 Coordinate correction method and device and electromagnetic touch-control device
CN107924630A (en) * 2015-08-05 2018-04-17 株式会社电装 Position detecting device, method for detecting position and position detecting system
CN110494345A (en) * 2017-04-07 2019-11-22 歌乐株式会社 Parking aid
CN111602029A (en) * 2018-01-16 2020-08-28 爱知制钢株式会社 Vehicle position management system and vehicle position management method
CN109459772A (en) * 2018-11-28 2019-03-12 江苏理工学院 A kind of position of aircraft signal fused filtering method
CN109725804A (en) * 2018-12-21 2019-05-07 歌尔科技有限公司 Track recognizing method, projection device and storage medium based on projection
CN111210668A (en) * 2019-12-30 2020-05-29 四川函钛科技有限公司 Landing stage flight trajectory offset correction method based on time sequence QAR parameter

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
ADOLF MATHIAS: "ADS-B Error Estimation and Correction in the PHOENIX Tracker", 《2008 TYRRHENIAN INTERNATIONAL WORKSHOP ON DIGITAL COMMUNICATIONS - ENHANCED SURVEILLANCE OF AIRCRAFT AND VEHICLES》 *
张兆宁 等: "自由飞行下基于航空器定位误差", 《安全与环境学报》 *
李小龙: "SCARA机器人标定及轨迹规划", 《中国优秀硕士学位论文全文数据库信息科技辑》 *

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113641685A (en) * 2021-10-18 2021-11-12 中国民用航空总局第二研究所 Data processing system for guiding aircraft
CN113641685B (en) * 2021-10-18 2022-04-08 中国民用航空总局第二研究所 Data processing system for guiding aircraft
CN114001976A (en) * 2021-10-19 2022-02-01 杭州飞步科技有限公司 Method, device and equipment for determining control error and storage medium
CN114001976B (en) * 2021-10-19 2024-03-12 杭州飞步科技有限公司 Method, device, equipment and storage medium for determining control error
CN114627687A (en) * 2022-01-19 2022-06-14 南京航空航天大学 Helicopter ground proximity warning method for predicting escape trajectory based on neural network
CN114627687B (en) * 2022-01-19 2023-04-07 南京航空航天大学 Helicopter ground proximity warning method for predicting escape trajectory based on neural network

Also Published As

Publication number Publication date
CN112365743B (en) 2021-11-09

Similar Documents

Publication Publication Date Title
CN112365743B (en) Method and device for correcting flight path positioning data offset of aircraft
US10347139B2 (en) Autonomous nap-of-the-earth (ANOE) flight path planning for manned and unmanned rotorcraft
US11136027B2 (en) Vehicle control device
US6529821B2 (en) Route planner with area avoidance capability
US20180032077A1 (en) Method for guiding and controlling drone using information for controlling camera of drone
KR20180100194A (en) Method for recognizing path deviation, terminal and storage medium
US20130325222A1 (en) Automatic recovery method for an unmanned aerial vehicle
CN111665508B (en) Helicopter-mounted terrain following and avoiding visual navigation system and navigation method
EP4130668A1 (en) Method for determining lane line recognition abnormal event, and lane line recognition apparatus and system
CN105844969B (en) Method for improving the flight trajectory of an aircraft as a function of meteorological conditions
JP2020076745A (en) Method and device for positioning image and map data base
CN116740667B (en) Intersection surface data generation method and device, electronic equipment and storage medium
CN112034479A (en) Positioning method and system applied to intelligent inspection unmanned aerial vehicle under coal mine
CN107289945A (en) A kind of Navigation of Pilotless Aircraft method
CN110032214A (en) Quick Standoff method for tracking target based on vector field
US11373328B2 (en) Method, device and storage medium for positioning object
US9410807B2 (en) Method for determining an offset lateral trajectory for an aircraft
CN114910079A (en) Navigation path planning method and device, electronic equipment and readable storage medium
WO2018157309A1 (en) Air route correction method and device and unmanned aerial vehicle
JP2021062653A (en) Trajectory generation device, trajectory generation method, and trajectory generation program
CN110068832A (en) A kind of high-precision locating method of laser navigation AGV
JP6713781B2 (en) Passive positioning system and multi-sensor system
CN115016546B (en) Unmanned aerial vehicle three-dimensional path planning method and device, electronic equipment and storage medium
CN112622924A (en) Driving planning method and device and vehicle
CN112214037B (en) Unmanned aerial vehicle remote sensing networking flight path planning method based on field station

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant