- 在线时间
- 791 小时
- 最后登录
- 2022-11-28
- 注册时间
- 2017-6-12
- 听众数
- 15
- 收听数
- 0
- 能力
- 120 分
- 体力
- 36086 点
- 威望
- 11 点
- 阅读权限
- 255
- 积分
- 13766
- 相册
- 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置?
9 F4 u8 d' P- S& n8 `# H. B$ C3 C- Q9 I; T
![]()
( T. L1 n4 K) d8 ^! Q
2 T# a# q# \/ C3 Z" |
1 o8 o' ?5 J5 {" g, L/ L (1)问题分析
5 A: P9 m- [: S% b- @9 N' G. y, n' {, \& q8 E! L7 M
记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为 (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在 之间),角度的误差限为 ;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算 。& B8 S' q/ A6 {% X' `
% B) t+ q& H5 e% u+ X6 O2 o& }( J
0 y# z' f ~: ? z# P+ E9 O" @
(2)模型 1 及求解
h. q/ K; r# X" I5 c8 B( I
9 i( Z4 ~$ \% h. z; y K 图中角度 是点 和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切 ( 1 )2 q3 i# P- _% N, U; g/ E! b
& {7 w; k" |" u1 S& v4 x
对 DME 测量得到的距离,显然有 ( 2 )- W+ k% J* m0 X+ M/ S# A# h7 O
+ d' ^ y( J) \; f8 C直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解 3 c% [1 A, w; n2 b' n o1 {2 [1 d& d
3 ^# \# \% c: s5 U( y' e" n ( 3 ) N/ E6 |$ r1 y7 s6 J& g+ y
式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下: S& I' O7 u$ k7 s! [7 I. ~
+ P2 z4 Q& c: m2 n, l- K' D9 N
MODEL:
3 q" ?9 p g6 \TITLE 飞机定位模型1; . m- r R7 }7 Y3 \1 O5 T: ~" b
SETS:
- v0 P' {$ ^/ |9 ~VOR/1..3/:x0,y0,cita,sigma; 2 \" _+ p! w7 R9 J1 ^% C
ENDSETS ( s, N) b- t% ^! ^+ G
DATA:
4 b3 `: i, m$ Q L( [7 ?x0, y0, cita, sigma =
& O0 e6 @ x Q8 M! E; y2 ~+ d746 1393 161.2 0.8
/ F. Q8 q/ n% S629 375 45.1 0.6
0 N1 [+ o% m4 Q" G4 n+ E E% s1571 259 309.0 1.3;
4 \6 V Y9 t! i# v: ux4 y4 d4 sigma4=155,987,864.3,2.0; % O% |; U( i- b# ]5 ^+ v
ENDDATA
' J. _" H! ]8 U8 Y; ecalc: : Q5 w5 Z" n; o5 K! l: A( Z6 Q
@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
. U/ ^7 v) ~; x/ p; Dendcalc
# @9 p4 n$ h+ h- Smin=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4)));
/ Z, n5 i0 L; Y3 o9 |9 K" REND
0 B- ?( w/ M& v$ V上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909 ,对应的目标函
8 K! Y4 a+ T; f5 m0 w+ h* j数值为 0.4729562,这里的解受π 的取值影响很大。 ' U. `8 D: w/ l0 R9 n
' w' C. G0 g, n9 v
(3)模型 2 及求解/ O* g/ A o7 ^5 a" H" _# E
' M9 w" C: z; V3 f a注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为 ,测量精度为 ,所以实际的角度应该位于区间 内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:
3 M% z% K' J( A* ?$ k3 [3 w \
d/ m5 f8 ^8 `/ P( k' x![]()
5 M* u- d/ `3 P2 u2 w m9 Q: x8 d7 @: I$ Z7 `2 r7 a
也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x , max x , min y, max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。
5 ?. z1 P% E) I( E; C+ \# o( g. k 以 min x 为例,相应的 LINGO 程序为: ; }' D2 u8 q7 `
% h8 r& b) q; R, x& ^
MODEL: # f, k0 h6 N) q9 t2 m
TITLE 飞机定位模型2;
1 t" p5 [/ _% D0 l7 \4 dSETS: VOR/1..3/:x0,y0,cita,sigma; 3 P L _ ?9 Z( P7 \% r+ f; F
ENDSETS " W8 Z" T" r5 b$ ~. f- { o
INIT: 0 K1 |& a& z4 ^ o2 U D6 d
x=1000; y=900; ( h1 u4 }/ C, R) m: Q4 J5 i9 r
ENDINIT
2 H) Q* L2 s# O9 T5 UDATA:
. F$ p3 B9 a. }2 {$ Yx0, y0, cita, sigma = 6 ]; Q t, q) q1 \( V @6 I* m
746 1393 161.2 0.8
4 V, m9 U+ Q O! Z8 u629 375 45.1 0.6
) I2 O5 @% k% ^+ f% V a [1571 259 309.0 1.3; 8 Q; }% m5 J' h/ L# X
x4 y4 d4 sigma4=155,987,864.3,2.0;
8 y" n, Z. ?5 @) T* t) M7 ?ENDDATA + I- j/ }# t9 g6 I' Y
calc: % m8 p" ^/ U$ A9 G# Z- ^) F; ?, {
@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
1 Z; R/ ~& N7 H8 ^/ V# R$ Xendcalc
/ u, X" t0 |- N5 Z- H, b' emin=x; 8 ~9 K6 N) b# K( d
@for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma)); 7 J: U r' x3 m. _% H
@for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma)); , O3 _$ ~. ]" t0 b
d4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ;
- G3 ?% r) V- M j1 m5 kd4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ;
! b' H$ H$ x B2 @) M) m7 iEND
* W% L/ @7 E6 R$ c! Y1 N注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 . |* U3 K7 ]5 a) d' E3 P
% X/ `, x7 u& c7 c6 X (4)模型 3 及求解& a- N8 m- j' t$ [3 q a
8 {) O* G$ L% S模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量6 j, p! J% s* ?& O& R
误差的标准差。 + K2 i4 |8 X- G1 e- i
7 b- R7 c5 O2 ^+ Y: F7 a
在这种理解下,用各自的误差限 对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。 6 t0 _8 R& u- p5 a
6 ~: [) L+ J# Y* X- Z5 m' K! J) ?
$ K$ [" g( b0 D) W8 W: I% b1 E5 q+ w
: E# [( i3 K. m8 l8 e& F5 n- A
由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为: 2 S+ n* m/ _: U5 e/ ?; a
0 q7 c* L- a v( y
MODEL:
9 w, k% C" j8 J0 h- {TITLE 飞机定位模型3;
2 x* ^+ K0 e, X$ eSETS: 4 i/ I; Y: [7 t# F) `
VOR/1..3/:x0,y0,cita,sigma,alpha; 1 A# o, o2 n2 g, |+ G
ENDSETS
3 E' Z9 @! X: h( ^" U" yINIT:
; ~0 x6 ^& ]$ V/ k6 ~7 {x=1000; y=900;
6 C( G+ {- |% Y; r2 E% EENDINIT $ h; G* h. [! J4 {/ }
DATA:
" t$ Y* ~& T/ ^6 f& b9 Kx0, y0, cita, sigma =
9 }8 S) Y5 F1 y- U( |746 1393 161.2 0.8
( f+ t, }8 w _9 m X/ g629 375 45.1 0.6 - c9 {- Y, R7 c; k& c- z
1571 259 309.0 1.3; . W7 n8 F5 ?0 ] J
x4 y4 d4 sigma4=155,987,864.3,2.0;
+ F u: t0 x n# F% hENDDATA
6 X$ J* z" l6 L" G) @calc: $ ^5 R( y- S, ]3 Z. f/ b& b; \) m
@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); - p( Z1 Z6 R2 e% e
endcalc
4 e: h. @! s' ^0 [, L" }min=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2;
4 j* m2 v- u9 p. F9 H$ S X3 t@for(VOR: @tan(alpha)=(x-x0)/(y-y0) );
: K& N8 v w" S6 T, F# ZEND
! {7 {) }; m- |6 Z6 p 启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母 很少,所以相对误差比绝对误差大,这是可以理解的。 2 o F) F! ?1 E6 Q0 y6 @3 }8 Q
————————————————4 p9 W% N+ u5 j3 y) i# D
版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
2 a j6 c! b. I+ [( j+ G7 y原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044
. X! E. `+ [, K% H% D3 b+ b/ b6 m# R) q/ b# Z$ x0 v
7 z' I$ n; i- A! N/ p. v9 v' {
6 U4 Q0 D# h7 s* U/ r, _
|
zan
|