QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3834|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置?
    9 x6 u/ d* o( j+ ]" W8 [) a* q9 {" E% N& d, p* r, X+ Y! A/ Q+ Y

    + R* r. H' x$ M* e, x3 i' ~) o9 E4 T* f, I0 W; \. r
    * B* S3 A+ X) \% B* l4 c
      (1)问题分析 : s* u8 `; X) S  \* Z9 S
    / |4 _/ ]( ^( ?& O% x
    记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算  & C! G) G% W- x% S$ ?

    ' H! R, D9 W+ Z
    4 [* H! l0 _9 c- A* n# \6 Z" w
    ; \+ x8 k2 k. s8 G(2)模型 1 及求解
    2 S. N9 B- d5 q7 g, m; q+ G+ D, G, v+ W8 b8 v! P- O) \' E
    图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )2 ~2 c1 T4 u2 L" F4 J5 O# W: d3 ~1 {

    9 E1 [! `9 Y( S* W对 DME 测量得到的距离,显然有      ( 2 )/ D, c1 G, x& o# M  @

    % B5 g; {9 V+ ]( p4 C+ T( f& O' U5 O直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解 + k9 `; M7 ^/ Q- ~: s+ N

    . K5 i' d* q" c% k, | ( 3 )1 i: l2 ^, p+ q, G) P4 c, l: y
    式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:6 H4 y  q& G% h: K

    ! l& x+ G. T4 f* I5 FMODEL:
    6 J4 h6 m. N0 S# i6 u& b- U- jTITLE 飞机定位模型1;
    2 M! @$ y3 }1 W" ]% BSETS:
    6 k0 j' e2 J- l2 i; O9 uVOR/1..3/:x0,y0,cita,sigma; 4 Q& U( F4 l& V+ x+ n
    ENDSETS
    4 Q! U" O* G5 e: Z, eDATA:
    . S4 q6 H- s" M5 Tx0, y0, cita, sigma = . u/ `) j/ T+ Q
    746  1393 161.2   0.8 7 Q$ [. ?; l; _* u
    629  375 45.1     0.6 / K, U" U, g2 ]
    1571 259 309.0    1.3; ( R4 K6 H" U. v
    x4 y4 d4 sigma4=155,987,864.3,2.0;
    ' r" P& I" K2 \1 \0 B/ xENDDATA
    ! c) X/ o6 i, @" k& Ycalc:
    1 f  V" K, }9 K' l@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
      {% W" X  r; [* |endcalc
    - \, I0 s7 N4 P* X- amin=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4))); ; m6 P; G, F' u$ T
    END' c; s3 y* b3 V" H# n# c
    上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函
    # X1 G, `, p1 j' K7 K5 m4 ~数值为 0.4729562,这里的解受π 的取值影响很大。
    ( v: E  h& j9 l' N, i4 f
    , N& i6 ]0 q( o  [$ |(3)模型 2 及求解2 o2 R3 ~$ Z5 z8 v5 |: A2 @
    , W9 B- }/ F9 }. Y7 j- M
    注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:
    : k4 N% a3 A- T5 D5 J
    8 X+ z, P. g# ^/ z% c
      {/ T; [  Z, K5 p
    & J! M2 ~$ v$ O0 S/ X5 T  也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。 1 ~- i: h) l6 u' }
    以 min x 为例,相应的 LINGO 程序为:  
    0 w/ d# _- ^0 B( C7 F; C; l5 ^1 i
    0 M* d7 |2 ]& B( t2 ?$ nMODEL:
    : H" `/ F) E( x" dTITLE 飞机定位模型2; / U0 I* {9 U3 X/ w& Z
    SETS: VOR/1..3/:x0,y0,cita,sigma; . S9 F6 y! T2 m" c
    ENDSETS ( S& [& _) e5 b$ ]5 G
    INIT:
    . z8 K& W. D, p. B0 Xx=1000; y=900; 2 [& m% z* j( X# t& F: U
    ENDINIT
    6 j8 r4 q! T& P/ N  }DATA:
    5 T3 \) Z: P$ L0 E, ^/ R! lx0, y0, cita, sigma =
    . x" o6 A6 F2 K' y; X746  1393 161.2   0.8 ) |! [* x2 B3 e1 D; G  n' n# F3 I
    629  375 45.1     0.6 8 u/ p$ m# F' v/ E; z9 M, C' E
    1571 259 309.0    1.3;
    ' F5 p; i: N- p$ [, c0 X* [( Z& M1 ^x4 y4 d4 sigma4=155,987,864.3,2.0;
    6 `! X( A/ I/ I8 mENDDATA , _+ V" e! Y/ v6 u7 U
    calc: 5 f) T+ c- Q3 K) I3 u
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); 7 A- [5 P' t) V  t9 w9 n, h7 y4 L
    endcalc , u: V: x' a- O/ a* k) F
    min=x; 1 a  D% N* Q- Y2 Q, o/ q
    @for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma));
    ! C: V/ t( U7 Z3 ^4 V4 P- h$ M@for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma));
    & l" Y+ J1 ?9 Yd4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ; 9 h% S+ b% C' ?  t* c1 J5 A1 ^
    d4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ; 6 S* G) F; {( T$ v6 M& G! u6 k
    END ) D& k4 z/ T+ G" W* `
    注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 .
    2 O6 g; h  u) ]& p6 f$ A4 v- m; G3 y5 M
      (4)模型 3 及求解" v; Q  |& [8 e0 \2 ]

    7 j5 m+ Y+ n, ^! a模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量" h' n3 {2 R3 [. p; B) v, H6 C+ m
    误差的标准差。 2 E3 N2 N( K0 s$ B  l
    ' n" N* ^+ o+ M7 A1 i& P- p
    在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。
    8 |1 f0 O$ z# C1 g; k$ n; r" ]/ `3 W$ G
    ! Y; @$ f* |6 {( ~! S
    : Y# {. `" L: V( Q. t: `) O: C& F/ Z6 c8 R  J  |( L& ?) ]+ I
    由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为: 0 A3 b7 V6 g- _7 ^( B7 R

    9 U# t% G, f) CMODEL:
    ' U! A; q# n) E; T+ p9 x, wTITLE 飞机定位模型3;
    & B# B2 g5 T  w1 v5 }: v  N2 i* o3 uSETS: 5 [# ?+ S* h& s& f1 z2 H% }
    VOR/1..3/:x0,y0,cita,sigma,alpha; , P! \6 K' w3 `& d- ]
    ENDSETS 7 L5 D4 O+ \4 S+ X
    INIT:
    ) y; E2 Z& C" Y# q$ xx=1000; y=900; $ J0 y! |) W8 t  W* z
    ENDINIT
    2 U4 }& Z3 g9 H3 g+ [DATA:
    , L; f0 \9 J9 c# y1 M' lx0, y0, cita, sigma =
    7 A: ?( |3 U4 Z: N746  1393 161.2   0.8
    $ Z& q, n& t( I629  375 45.1     0.6
      P5 \+ C, p  N! l& u) f$ W  t1571 259 309.0    1.3;
    6 d9 i" i; D& P% Ox4 y4 d4 sigma4=155,987,864.3,2.0; 4 J$ I: @0 ?# _" k7 e! F* w. \
    ENDDATA
    3 T* G: X* l8 \  o# n0 v3 tcalc: 9 U: R% @" ^% L( [9 D5 g
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); ! S: \% Q9 S$ q% q
    endcalc / ~* o$ N8 p( b* z0 T7 D
    min=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2;
      G5 u. O# s( E* A5 H@for(VOR: @tan(alpha)=(x-x0)/(y-y0) ); . C1 c& |) n1 J) k% X' ^
    END+ j# u- X8 q. V7 r' e
    启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。 8 B* V0 x4 @! D; Q6 l' M" D3 J! X
    ————————————————4 k- f/ U5 v4 u& r
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    3 \3 [2 `& C9 q2 N" A% Z原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044  W3 A8 _0 J9 G3 i" j* V; I. t

    " J. c# k7 _) I4 x. ?$ \- y; @
    1 H% z: j; C* V& K* n! Z  `; I7 I3 s2 }. ~* _
    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-11 04:06 , Processed in 0.366801 second(s), 50 queries .

    回顶部