问题描述:飞机在飞行过程中,能够收到地面上各个监控台发来的关于飞机当前位置的 信息,根据这些信息可以比较精确地确定飞机的位置。如图3所示,VOR 是高频多向导航设备的英文缩写,它能够得到飞机与该设备连线的角度信息;DME 是距离测量装 置的英文缩写,它能够得到飞机与该设备的举例信息。图中飞机接收到来自 3 个 VOR 给出的角度和 1 个 DME 给出的距离(括号内是测量误差限),并已知这 4 种设备的 x, y 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置? 6 i" {: a, Q, S! v# U M) t
& A& J$ d6 k0 U( B: f% S8 o4 v; P7 j
. Q/ r5 i2 H: z: k1 n8 ?& {, L$ B8 o1 }9 t" Z7 `5 G2 X
(1)问题分析 & h& Q" _ i2 M
! o9 ^3 M4 l& c
记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为 (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在 之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算 。 : L: D# q( w' @ 9 [) V d/ `& C% L3 ?9 U6 p0 C1 `1 A* c. ` n h; u+ B; Y8 f+ _& @* p' R
(2)模型 1 及求解 $ N9 e! v3 K8 L! a% j! e) k( t% Y2 w6 E8 J, R. |' v/ m+ C
图中角度 是点 和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切 ( 1 ) 9 }1 u% R! D. [+ Y % {. V( t! J) N" i对 DME 测量得到的距离,显然有 ( 2 ) & t! c8 d6 r" F3 c1 d8 A; G3 `3 ^; s2 z) ~6 q5 l
直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解 8 G! O7 o4 A3 h9 G. R2 C% I , Y+ O- _3 v4 p n; @/ r ( 3 ) # T7 c0 \/ J2 o5 k: }式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:* D: J. x% m1 w# `- ]* Z. Q+ }
6 J/ ]4 q6 e* A( C# S2 i' W h/ oMODEL: - S9 e! s, K. {" R) oTITLE 飞机定位模型1; 3 t% V0 L8 D% J# n! f: @SETS: * Z' z& h: \+ z/ _& R
VOR/1..3/:x0,y0,cita,sigma; 8 J y& Y1 i5 Z1 J: T
ENDSETS 5 p# S2 T% `1 }& b8 ]/ t
DATA: 9 [2 Q! ?7 n: I1 m. z% Ix0, y0, cita, sigma = ]( r3 J' U9 [# K
746 1393 161.2 0.8 1 @' j: o. s& {6 e. o5 X/ E
629 375 45.1 0.6 7 c q' v7 I9 i- ]1 Q9 H6 y
1571 259 309.0 1.3; 3 p. \0 Y; I2 A# S
x4 y4 d4 sigma4=155,987,864.3,2.0; ' N* d% F& s7 @' W7 `
ENDDATA # @% t" m2 W# E" p4 w% Z
calc: 4 ~/ L2 O( n' S3 a@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); + t- I3 V; J- }2 E0 Wendcalc * q% U1 S9 A0 r9 }min=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4))); , f+ o( T e& P$ f) O% v
END! S3 r \: A! }
上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909 ,对应的目标函+ |) N, p1 A/ c1 }" e5 _+ L0 }1 X
数值为 0.4729562,这里的解受π 的取值影响很大。 , v5 y: N0 h; s; W; v* z# X0 z; W0 d$ e( k' i
(3)模型 2 及求解0 k! L/ S" {$ D2 o3 A9 O& V% k
) J3 \7 y6 Q' p3 }7 n
注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为 ,测量精度为 ,所以实际的角度应该位于区间 内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式: : J6 Q. k/ r" s* {4 ]2 u: p% |, W$ Z$ K4 m * b& P6 \7 `3 V
. E; V8 @1 [! f7 E 也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x , max x , min y, max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。 " C$ i6 j* z! a5 R 以 min x 为例,相应的 LINGO 程序为: + D `& r2 T" e% `