QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3843|回复: 0
打印 上一主题 下一主题

[建模教程] 飞行机的精确定位问题

[复制链接]
字体大小: 正常 放大
浅夏110 实名认证       

542

主题

15

听众

1万

积分

  • TA的每日心情
    开心
    2020-11-14 17:15
  • 签到天数: 74 天

    [LV.6]常住居民II

    邮箱绑定达人

    群组2019美赛冲刺课程

    群组站长地区赛培训

    群组2019考研数学 桃子老师

    群组2018教师培训(呼伦贝

    群组2019考研数学 站长系列

    跳转到指定楼层
    1#
    发表于 2020-6-17 09:25 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta |邮箱已经成功绑定
    问题描述:飞机在飞行过程中,能够收到地面上各个监控台发来的关于飞机当前位置的 信息,根据这些信息可以比较精确地确定飞机的位置。如图3所示,VOR 是高频多向导航设备的英文缩写,它能够得到飞机与该设备连线的角度信息;DME 是距离测量装 置的英文缩写,它能够得到飞机与该设备的举例信息。图中飞机接收到来自 3 个 VOR 给出的角度和 1 个 DME 给出的距离(括号内是测量误差限),并已知这 4 种设备的  x, y 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置? " S7 z) T5 y& ]/ G  U9 v% D

    7 i! X; I2 \, }# f7 [& _' d4 W9 I- W: D0 [

    " s. p  B* T( s4 X1 s3 [
    , f% D; }' S* L8 [: e# S% d$ Q) Q& i  (1)问题分析
    1 s0 O0 d" ]2 z
    * Z' G; f+ v! O  c& s 记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算  4 n  I6 o" K8 X4 Y) u& z! d; D

    2 ~" g5 S1 _2 H, d' k2 V8 O0 Y: a3 T  e- |: G# Y$ A( V0 A$ V
    6 m" \& m$ e8 r  G, w
    (2)模型 1 及求解 4 z, l1 C; i9 I7 a" y

    9 q; {; U) c, |# T1 n0 O. Y 图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )0 U2 V( A- o5 o8 L5 Y# L
    ; N" p+ F, N+ E4 c
    对 DME 测量得到的距离,显然有      ( 2 )7 m3 ?# w5 t. k# E2 |5 C
    . n" ^' v7 a: y4 M
    直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解
    & D# T$ p1 F( c: e
    - E4 X& H: D5 [8 g8 q( n  o ( 3 )' C6 O/ Z' a5 K; g
    式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:
    ' {6 n2 ]6 z6 W9 _" J* Z) G* h0 \# L* h, S/ I% ~
    MODEL:
    * W# i+ U' W; [TITLE 飞机定位模型1; 7 o; S! E: y. q( P
    SETS:
    9 L- |, ]8 v, P) x& @$ @VOR/1..3/:x0,y0,cita,sigma;
    8 M! P2 M9 U$ i8 sENDSETS
    8 d$ g4 |; X- W+ H% A1 j& j$ UDATA:
    5 ?* e. e; H7 T% Cx0, y0, cita, sigma = 5 U$ e" G3 c- P& c5 e) L/ s
    746  1393 161.2   0.8 ( T+ f( H' E, ^+ f
    629  375 45.1     0.6
    2 m4 J5 X' m# p2 N, }: U- P' F1571 259 309.0    1.3; 3 X; {+ J# d& L! K7 {! `2 [: G4 C
    x4 y4 d4 sigma4=155,987,864.3,2.0;
    , t) B' O& T: u3 ~% e8 E6 XENDDATA 1 N! q5 U" o1 \, [, p
    calc: # o. ^7 c. q4 J$ w. R
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
      a4 J% ], v1 M. N! T& Rendcalc
    / Y+ t- r6 J, C3 ]# Imin=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4)));
    ' K6 h/ `# p/ e  u) c" r% NEND
    + C2 [9 `0 K# G- M) j上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函
    0 ]! P5 n9 N( `6 g% a. N8 t8 m+ Y6 b0 \6 P数值为 0.4729562,这里的解受π 的取值影响很大。 - \* z- u4 n( `  v
    & D; j- `, e/ x5 t$ r
    (3)模型 2 及求解! Z  c" F$ H" ^: s9 e

    ) {3 C" \, c1 _注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:  V: [* f% r! f2 `7 ~
    # u1 @9 Z% F: h% m( `$ H  S; t
    1 i0 y  I$ C( y/ H/ G
    3 C; ~# _" `* Y$ p
      也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。 + S9 P# G) a& q# \9 P0 ~5 N7 [
    以 min x 为例,相应的 LINGO 程序为:  $ h7 O2 e2 W: t8 b
    ( L1 V3 X/ e* d# n$ k* I  x
    MODEL:
    ) q1 t% p, V9 K/ y7 P( h  M& STITLE 飞机定位模型2;
    9 T1 I$ C# b$ j( s6 c) Z: \0 G" KSETS: VOR/1..3/:x0,y0,cita,sigma; . G& b$ J8 ^. Q3 e9 W! G
    ENDSETS
    " H" o& j; W# w2 t5 @! ?6 W: qINIT:
    5 y+ g4 g' f0 T, y1 F. Jx=1000; y=900;
    + N0 i4 D6 {2 _- v! d% |ENDINIT 3 M; _( p' i% n& j+ P9 A
    DATA: ; j1 b6 S# o8 D/ o% ^
    x0, y0, cita, sigma = 3 Z% N, ?8 X# T" H$ b* O6 h1 e* Q  v
    746  1393 161.2   0.8
    - A2 Y) }  e) ^6 i9 f629  375 45.1     0.6 7 s& ~" X6 r- `2 G0 z
    1571 259 309.0    1.3;
    6 F; K1 D" Z; w# I4 @: Xx4 y4 d4 sigma4=155,987,864.3,2.0;
    % E6 y6 G& }, S- \( @7 d- JENDDATA
    & z# p2 t/ q" a- `' P/ m: z: bcalc: , B) Y1 e' C' b" }
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); + o) i3 G: T6 T' I( E3 N- {
    endcalc
    9 m6 Z9 Z! g; ymin=x;
      U( o' V9 R4 S8 R@for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma));
    ) h0 p  p) g/ o+ r' @@for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma)); $ l1 g; ?. j. _+ [9 A
    d4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ;
    8 u! @: g: Y; S. T1 Yd4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ; ( W3 `6 O7 r& d! ?* C
    END ' m' X) F& T8 N  V* D
    注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 . 0 e  U* M: G8 y6 r9 u' K

    7 O/ U' t0 e' f' ~1 T' [0 T  (4)模型 3 及求解; \! U  ~1 t1 N6 q; F2 L1 q
    8 ?( R+ d4 Z* C6 P: w! Q+ J" D2 o
    模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量
    + G7 O& V* R8 G- s$ O2 z" v误差的标准差。
    0 u3 k' `- |  u
    ( |! k7 N$ s2 k+ S4 S在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。
    , o  G& x! l: j* t% X* B7 y
    5 x' N/ e0 _4 X/ G- y6 V' m
    ! H: a) K+ c4 d* |& O  Y& {+ ?9 D+ o
    由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为:
    2 c& z( f- `- t/ V
    4 N& r4 H/ B* N: d& ]1 x! {! C  kMODEL:
    - e4 U; k0 e' t- q6 B4 S6 mTITLE 飞机定位模型3;   k# }% K9 I% J& {; v& W( Q# q
    SETS:
    8 A) G/ X2 q7 K5 sVOR/1..3/:x0,y0,cita,sigma,alpha;
    - A1 g* h, ]* M/ I$ KENDSETS " |1 b, H9 S  C+ n' l
    INIT: 3 a" [) d) _! W( L' f
    x=1000; y=900; 5 e& Q) I/ q0 X& s( p; ^8 y  e! O
    ENDINIT
    5 F/ o* ]0 A- n1 B$ CDATA: ( P  J5 r7 ^6 \7 Q/ [! B
    x0, y0, cita, sigma =
    - J; p8 {: n& h  {- Y4 s/ s/ H3 M! K# h746  1393 161.2   0.8 , V! q3 g3 X; S
    629  375 45.1     0.6
    " a: ?- k& @* f8 E9 T1571 259 309.0    1.3; + h, U3 M  i6 N* O" ]! y9 U
    x4 y4 d4 sigma4=155,987,864.3,2.0;
    9 M+ O: @: L" t; ?) M2 QENDDATA 0 d9 {' v- a+ {. p
    calc: " v% b; R  Z) G8 H4 Q- e
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); 3 T( i* V5 P6 Q" o2 }1 `1 p4 G7 d
    endcalc
    * R9 g; }' `! }6 hmin=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2; 8 l( t4 V' M' _7 O4 ~
    @for(VOR: @tan(alpha)=(x-x0)/(y-y0) ); 9 z$ `4 h5 |% M; C* N
    END1 z, j! Y" ]$ r
    启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。 2 k* J; ~" \, z5 f# A2 {6 J
    ————————————————
    % ]9 E' @1 b) O9 h; V版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    & m0 G' s* D9 C& |$ Y- z: D8 V原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044
    * Y9 f' P& E1 R$ O/ D2 T9 \. \2 a( ~# u. W* Q8 J

    , B! I& k/ G- x4 \  x' n" t% o0 H4 N2 K
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-6-13 16:10 , Processed in 0.413974 second(s), 50 queries .

    回顶部