- 在线时间
- 791 小时
- 最后登录
- 2022-11-28
- 注册时间
- 2017-6-12
- 听众数
- 15
- 收听数
- 0
- 能力
- 120 分
- 体力
- 36058 点
- 威望
- 11 点
- 阅读权限
- 255
- 积分
- 13758
- 相册
- 0
- 日志
- 0
- 记录
- 1
- 帖子
- 616
- 主题
- 542
- 精华
- 10
- 分享
- 0
- 好友
- 225
TA的每日心情 | 开心 2020-11-14 17:15 |
---|
签到天数: 74 天 [LV.6]常住居民II
 群组: 2019美赛冲刺课程 群组: 站长地区赛培训 群组: 2019考研数学 桃子老师 群组: 2018教师培训(呼伦贝 群组: 2019考研数学 站长系列 |
问题描述:飞机在飞行过程中,能够收到地面上各个监控台发来的关于飞机当前位置的 信息,根据这些信息可以比较精确地确定飞机的位置。如图3所示,VOR 是高频多向导航设备的英文缩写,它能够得到飞机与该设备连线的角度信息;DME 是距离测量装 置的英文缩写,它能够得到飞机与该设备的举例信息。图中飞机接收到来自 3 个 VOR 给出的角度和 1 个 DME 给出的距离(括号内是测量误差限),并已知这 4 种设备的 x, y 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置? $ x" K3 |) v9 Y; |1 k0 R# p; `6 ^! d4 A
; _: c" ^* h+ b0 _' V# U
% `3 J3 e& s; j
, E# z, n/ N& p8 N' T
" Z4 R7 |" m( f0 L M (1)问题分析
, c- m9 e7 t' R; G0 T) P& @# D" H1 m6 U) r$ D
记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为 (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在 之间),角度的误差限为 ;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算 。
& x V0 O/ p! J3 Z, O/ P2 h
, N0 k- G8 i8 e; Q5 N( [9 F: R' E
8 m7 e# o4 @! r4 z! \
(2)模型 1 及求解 & x% _7 ^$ o5 Z6 l$ ~
% d/ l, k) U5 a' ~' { 图中角度 是点 和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切 ( 1 )2 n8 {% V7 p0 u, E0 ~
1 E8 F# E I' |; {% g
对 DME 测量得到的距离,显然有 ( 2 )
8 i7 f% D2 f" s9 F% f. v, v I% Z6 x: q, A
直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解
/ f4 F0 E1 |" E& U7 ?& X% ]8 R# B" e1 T* G- m" j6 [- Z3 i" W& j7 u
( 3 )
4 i9 c: b- o# E# r式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:
5 ~1 R0 C; _5 s* e5 H8 m! @" w7 E- A% r0 b
MODEL:
4 f0 K9 F( h) v' P+ w: b: cTITLE 飞机定位模型1;
( u8 a7 e& [/ c4 `( D# m- E, [SETS:
3 e+ m& {: h- H. l5 t5 P1 a/ SVOR/1..3/:x0,y0,cita,sigma;
- d1 P& w4 ^* W6 d4 z* ~ENDSETS D# d7 b" t- g2 \
DATA: * O* I* N7 [ [. Z
x0, y0, cita, sigma = % }9 u5 _! X0 n) n3 ~. k+ O
746 1393 161.2 0.8 ) f" E, x( V" s9 t1 J: N
629 375 45.1 0.6 * E8 ~- T- |9 T. ]+ Z# V
1571 259 309.0 1.3;
# P2 j! M7 h9 a N& X, Ax4 y4 d4 sigma4=155,987,864.3,2.0; $ M& D( Q& d1 B9 K( [- w$ S& J( L
ENDDATA , e& B4 v& L, F* j6 N
calc:
& @# E. B# N; @! x7 H* [@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
4 h7 E1 S' i) Q a& Mendcalc ! Z& y: Z) ^9 J4 i \' V7 }1 I+ N
min=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4)));
* G; a l Q' K# m* [END! u) C( g+ V. [/ q- \* s' {# ~& \
上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909 ,对应的目标函" y: l4 U7 _5 d2 l
数值为 0.4729562,这里的解受π 的取值影响很大。 ( A/ |' w9 p) P: B4 n
) u8 @0 l2 G* `/ R) ~! \( l+ ?# H6 z0 V
(3)模型 2 及求解
# q& q# d% ?4 b \$ Z
( s% u( z0 ^! R! Y, G注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为 ,测量精度为 ,所以实际的角度应该位于区间 内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:
, {( ~! M* b1 f& b9 O
% P5 z* d$ G! i3 }0 k![]()
1 n( }4 _5 }. |9 V* n
% H2 I. `0 A- s t" u+ N 也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x , max x , min y, max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。 , s3 o2 Y) e3 V( U, E2 v
以 min x 为例,相应的 LINGO 程序为:
: l- _8 }# h h" ?" v
1 A9 l7 j2 u$ q! x% ]0 \MODEL: - Y, T1 L- r5 z! _. @! b4 _
TITLE 飞机定位模型2;
% O/ n. O7 s! r ?0 x7 ]/ n( ]SETS: VOR/1..3/:x0,y0,cita,sigma; . C1 y* R* b" w5 K& e
ENDSETS 6 t& h4 \ B1 |# ~* k8 x
INIT:
, P: Q5 s X; Xx=1000; y=900;
4 u3 M* p1 X0 k" EENDINIT 5 s: w" Y' m9 i9 {
DATA: 3 s+ ?, J# N. i4 x/ m3 E; c
x0, y0, cita, sigma = 3 L! ]" a' R" |, h" R# U" ^; j% u
746 1393 161.2 0.8
. F. g0 w3 L0 A% J629 375 45.1 0.6
2 z7 d' z5 A) p7 k1571 259 309.0 1.3; 3 _; R- G- V8 C
x4 y4 d4 sigma4=155,987,864.3,2.0; 7 I I( @) l& R! y
ENDDATA ' [% ?& K# Z( q f4 I/ D* W
calc:
( Y& P, a% e3 B3 H9 z E* ]@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); 5 t/ H* t* H( c; F1 L/ M3 S9 q* F/ a `* A
endcalc
% }( O1 Q; q8 V5 r5 H( amin=x;
: M& E! e- \" |% |@for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma)); " Z/ b) c4 P4 r: ?4 a' D5 k4 R% m
@for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma));
, ]; Q/ R* C4 Z( qd4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ; 7 N$ A7 a: H1 O8 _
d4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ;
' Z6 {& S/ h0 R2 i- P* CEND 4 Q' f2 S- O, u6 c3 Y6 C% q
注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 .
6 I. U! b# B; t4 v; n; @
' ^9 f5 M+ ~% h d6 y& h7 o (4)模型 3 及求解
& r3 w2 J. H* W# b1 C; y5 P% J8 m) @) H
模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量( `6 ?0 _' r i. Z2 I
误差的标准差。 * ?& y6 @4 H4 H/ j. }
* Q, E9 I( I' @6 C4 I# S
在这种理解下,用各自的误差限 对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。
2 h$ F& ?; v: k" H2 N! M% T- Q+ i
) |0 Z5 C# D7 L3 L! G8 _![]()
$ e# C& ~ f# r6 B1 c: U! s. D6 ]4 T8 f" X
由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为:
* U( E6 C7 }3 a3 V1 H2 D) {8 Q+ M, S( i2 Q. i% H$ v3 y8 G# ]
MODEL:
' |! ~) a4 {3 z3 M y6 e2 D. S& A) H' aTITLE 飞机定位模型3;
7 @1 T0 v" U, V8 m" Y: oSETS:
+ ?$ J0 W9 ?2 j' eVOR/1..3/:x0,y0,cita,sigma,alpha;
: K/ X1 R4 {# [$ ^& nENDSETS # F/ l) b* w- V0 Y. [
INIT: # E& B1 Q# a7 x S
x=1000; y=900; : C: u0 ]/ @2 A. k6 r6 J' }
ENDINIT ' n# Q: D: A; C/ V& R
DATA:
; r1 k. }( ^8 t, {x0, y0, cita, sigma = 4 F2 }% C$ x7 ~. |5 J' k
746 1393 161.2 0.8
4 P# ^7 G" `1 I. r' b629 375 45.1 0.6 4 n/ a1 g5 k( m3 h% `5 T4 K9 S$ g, b
1571 259 309.0 1.3;
' M" A' V: o& t9 i" o) A4 fx4 y4 d4 sigma4=155,987,864.3,2.0;
( G' t% ^9 q- [ENDDATA
; l6 R7 ]1 ]& U0 d+ qcalc: + s J) [( y6 }
@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
+ \: {( s) a9 Q }endcalc
, M! G A7 T5 \! p+ a$ s. _. f- K1 Bmin=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2;
( d' t. G, b& s@for(VOR: @tan(alpha)=(x-x0)/(y-y0) );
3 i$ ~$ G; ^; t, Q. O8 A- l+ xEND
6 D$ m( y' w( U2 B0 C- d" j6 z 启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母 很少,所以相对误差比绝对误差大,这是可以理解的。
9 J9 I2 d. \/ \! j4 M( o————————————————) v! v7 z, E7 T J9 M8 { v! S7 A. o& `
版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。0 B! m/ v' @& }* v
原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044
) m7 [8 S+ k3 i- |
- C8 q% w) p1 k/ r+ {
' D# n- G; l! T5 ~% ]' x3 a$ G# K2 D" o1 H) U- l
|
zan
|