数学建模社区-数学中国
标题:
飞行机的精确定位问题
[打印本页]
作者:
浅夏110
时间:
2020-6-17 09:25
标题:
飞行机的精确定位问题
问题描述:飞机在飞行过程中,能够收到地面上各个监控台发来的关于飞机当前位置的 信息,根据这些信息可以比较精确地确定飞机的位置。如图3所示,VOR 是高频多向导航设备的英文缩写,它能够得到飞机与该设备连线的角度信息;DME 是距离测量装 置的英文缩写,它能够得到飞机与该设备的举例信息。图中飞机接收到来自 3 个 VOR 给出的角度和 1 个 DME 给出的距离(括号内是测量误差限),并已知这 4 种设备的 x, y 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置?
. l {5 Q, T) ^' p3 H
0 ~' t0 E6 F4 Z" Y+ D
) ^% }# _* ^& a$ L
' n3 ?9 G- Y ^$ d
; D+ x! P2 T7 W2 }( U8 z' P9 O6 I
(1)问题分析
% g2 s. P% I0 w% b: H# n
1 O7 y5 u8 \* Z. H# R z0 x+ a
记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为
(以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为
(从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在 之间),角度的误差限为
;DME 测量得到的距离为
(单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为
,则问题就是在表 9 的已知数据下计算
。
( j, G8 _! B" @3 C$ J
( p( ^3 ?# y' k/ }' X2 i
& y" \& W- z' I4 x( w1 ]+ r
' A# A$ C: l6 k) I/ I# F: }8 I
(2)模型 1 及求解
& U S% O0 B/ G8 ^; V1 b2 c [. Q
5 f% C8 [2 C3 Y# g1 m0 j
图中角度
是点
和点
的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度
的正切
( 1 )
( A, Q8 P S. Z! H: I9 k d- q
. L ], w! {2 K6 [# X5 m
对 DME 测量得到的距离,显然有
( 2 )
( y, \0 }0 I5 i9 ^0 A. @
. ]( t' B" ^) ~; ^ W
直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解
l% q% S: e. ]; }. ?7 a7 o
/ P2 t! L1 Z# b: b
( 3 )
4 Y! {. T W9 w: ]
式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:
$ e8 h+ z$ ^5 v& g M
7 E2 k/ m) P+ L2 e) J
MODEL:
" U0 g! h- m/ B6 b+ n% v
TITLE 飞机定位模型1;
* a3 H) I# U' t% {, S
SETS:
2 Y) h7 B+ F5 j
VOR/1..3/:x0,y0,cita,sigma;
0 w5 W; ~8 ^5 ?# J8 H+ `/ ?; E A" O
ENDSETS
2 U; K' a- X5 K: L
DATA:
/ p, K0 ` C* n9 ~
x0, y0, cita, sigma =
0 g. S1 F# Y7 t
746 1393 161.2 0.8
" L5 o- e) d+ s4 I, P* H; q& I
629 375 45.1 0.6
) O3 [& ^! P4 c" Y5 L l: y2 W1 Q
1571 259 309.0 1.3;
- ?" k/ b) o! a0 K3 y+ s
x4 y4 d4 sigma4=155,987,864.3,2.0;
! D4 _5 a* }, g7 ?0 v6 R
ENDDATA
% m. f5 }" V$ j$ X7 G+ C" b# F
calc:
! e7 [# w: l( v! I
@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
$ `* |& G% v% X; o+ U2 q3 t
endcalc
: ?' p8 ]- y9 l
min=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4)));
; s0 V: m6 J, F) r
END
8 l. s2 v" j0 H; i% C# g
上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909 ,对应的目标函
3 \' _/ b- ]1 t* t5 z4 K
数值为 0.4729562,这里的解受π 的取值影响很大。
9 e% j( w( A+ @
4 F% F- O# E9 W; k3 {! q
(3)模型 2 及求解
% k' `- W# }( W7 a
' x" Q# ]8 }6 E! e5 ~; n) b5 w
注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为
,测量精度为
,所以实际的角度应该位于区间
内。对其它设备也可以类似理解。由于
很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:
5 H2 B: e7 ?2 x8 y( h
1 V' s, `6 L8 C( j5 @. c
5 z& c" B( n& G. _, S# f6 u
" ^3 f8 F% U3 ? Z" l
也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x , max x , min y, max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。
5 Z0 h/ i# M+ j. Y F
以 min x 为例,相应的 LINGO 程序为:
8 M8 q {2 k# a
6 I) u0 u5 N- F+ W3 I! C' D
MODEL:
: B7 L" b* X( q: ?9 D
TITLE 飞机定位模型2;
- O6 l$ B! G r: i3 V# B$ H
SETS: VOR/1..3/:x0,y0,cita,sigma;
1 |) w) w" U% h) H2 Y
ENDSETS
x! N+ n. i+ |3 E$ B8 Y
INIT:
7 Y l3 \1 O& U& k J3 T
x=1000; y=900;
( k% K( M% i+ f& Y+ m4 T b' M
ENDINIT
& h( k1 ]/ S% Y( `8 ]1 s6 Z
DATA:
& Z* L1 r: q, ~4 V
x0, y0, cita, sigma =
3 i }( B; P/ J% x
746 1393 161.2 0.8
' e% Z8 E0 d5 J% X
629 375 45.1 0.6
) J5 j8 F( x9 t x. p( h
1571 259 309.0 1.3;
4 p2 W- S- Y" S8 [ i: [& G1 X( m4 s
x4 y4 d4 sigma4=155,987,864.3,2.0;
$ q: H) v, w( f3 e3 U" N- K
ENDDATA
: W$ u8 F' K2 F% B! G
calc:
( z* X1 s9 s9 X5 T0 c$ ?7 Z1 \: B" I
@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
9 Z( J' p; @$ O3 c4 X* O* J8 @1 q
endcalc
) A1 ? B) k9 _6 j' P1 M: r
min=x;
2 x$ C) Z$ W3 l" Y+ J1 T# d
@for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma));
( d# r/ R2 J2 N1 k2 h4 ]
@for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma));
' a) n- H2 v1 q5 w: ]$ Q
d4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ;
* x) W2 ?) {6 \4 G8 }- {
d4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ;
* r# S7 @% @, l- i$ d
END
- J0 b7 c6 Q/ h. `1 D' r
注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为
.
# P q4 r( H$ N y
" _" m. G9 o+ q1 b, p
(4)模型 3 及求解
' h* f/ H6 R6 E& m: [7 w
$ `; u% O6 I8 I4 i# ]6 E
模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度
可以认为是测量
3 g" \- ^4 S( ~2 B8 e$ [. W& H1 A
误差的标准差。
: I0 `: l5 h! d( h; Z; F( l; E
* R( y9 W6 K$ {) |6 I2 A3 M
在这种理解下,用各自的误差限
对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。
. L; ^2 X; J4 q6 F
. K* b+ G) \9 I
& ~/ m9 ~& y m
0 T6 O; k6 U2 K' d; [
由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为:
7 _$ w3 M# D& d' \& A
7 n1 O2 d8 R' E' p
MODEL:
/ W- A n+ O; e6 C1 o" R
TITLE 飞机定位模型3;
' @- Y$ C* u. k; X3 |/ r) ^
SETS:
1 ~7 ]8 j0 K) @) B0 C7 ]5 u
VOR/1..3/:x0,y0,cita,sigma,alpha;
+ o/ P K* Q2 z/ k' E
ENDSETS
4 k8 A" G7 o, I- b$ G, r
INIT:
& S5 P1 j5 g" Z0 t4 h, D k' V
x=1000; y=900;
. {. H( V. b1 K' R3 b
ENDINIT
, k/ l$ g, k/ a7 h, V2 ^0 ` e
DATA:
5 \7 W0 p; m5 d0 M/ h4 `- y; q7 U
x0, y0, cita, sigma =
: u4 }3 o& |+ j$ { X- e
746 1393 161.2 0.8
' F2 L8 |4 w6 D; H# O/ ?& T
629 375 45.1 0.6
4 s5 k4 B, H$ O1 g1 I% v0 V" q" n
1571 259 309.0 1.3;
+ O$ C8 x) ]/ s$ I3 u3 X
x4 y4 d4 sigma4=155,987,864.3,2.0;
+ F$ F7 U/ r( Z; w" ?% ?9 k
ENDDATA
; V9 \) |4 i6 U- _
calc:
- S# ]- z6 w; q" K
@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
* Y! o6 |( O2 S! b
endcalc
0 Q, i* o3 |' `; ^. {. @2 w$ F- e
min=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2;
4 ?2 B; d- A2 T% C; Z( A
@for(VOR: @tan(alpha)=(x-x0)/(y-y0) );
" {! Q+ b% {( N
END
% j/ R* e5 w) s+ e
启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度
的误差。对角度而言,分母
很少,所以相对误差比绝对误差大,这是可以理解的。
4 g, |/ y4 I' J6 W7 h: O
————————————————
+ u: y; ^: ^1 S: o
版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
4 ~- | s6 \# I% g3 `, d; ]) d3 X- v
原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044
* O# a/ y4 u# G4 x1 n
' Y1 m0 ]* m8 U. Y+ `; U
- }6 \& g. y# `1 Q- s
. y' U) n& q9 l
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5