QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3793|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置? % n8 g, N2 U$ s6 ~$ l5 L5 c
    - @8 \" m$ i& C9 Y; t6 k

    $ Y; f- j. g& H: F. t, H' T8 y8 I- ?* m0 e# i* K

    & A: {! o6 h! s0 m% h  (1)问题分析
    . U3 r2 t, U9 ]5 A0 ~. P( ?4 j% J) m& K$ d5 |  f% l
    记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算  7 j- b8 M3 C4 c( W2 J( b

    # D: y5 r/ c, Z% m( y% j
    1 i+ e, c) }/ ^/ E3 M" T6 Z7 U( p' b- Z, T
    (2)模型 1 及求解 6 m3 M1 l# I5 m( A* g# I

    ( _, v1 @3 D4 d- E1 M2 C7 [. x 图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )
    / G: a" h8 M1 x: m
    " G( Z) z" R# ^9 |3 R  g对 DME 测量得到的距离,显然有      ( 2 )  t7 q2 y5 l# z- X) M- e
    ; N  z  A4 a! Q. _2 r# w! H* M) ?
    直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解 . U- W/ F, \2 r3 F9 m4 Y

    3 c! ]! r% X& c# _ ( 3 )" y: @! U& u, l. R# ?4 |
    式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:" B' {4 M6 z; ^# e0 m1 A4 g% k' y

    9 N; @  h& w6 b7 d) N3 Q/ ZMODEL:
    9 }/ p& q; ?* _" T0 @3 I  `TITLE 飞机定位模型1;
    3 y, A. D! }9 p) A8 [* BSETS:
    ( e$ T3 l1 x- t' U) E3 m. UVOR/1..3/:x0,y0,cita,sigma;
    $ @. D) Z9 }% }) t7 l( i4 `+ cENDSETS 6 X* H5 C# E2 m
    DATA:
    3 P# t  s1 j1 l' z! t" c: Rx0, y0, cita, sigma = 2 [* W! I( Y& E0 j& H
    746  1393 161.2   0.8 ' v8 a/ D- t/ {! w( ?' B& n- o
    629  375 45.1     0.6
    * X" U7 q5 t7 T' t8 J0 E1571 259 309.0    1.3; " E6 w  d# ^7 ~# T
    x4 y4 d4 sigma4=155,987,864.3,2.0; 1 Z. ~( ]4 q; e# _
    ENDDATA
    2 {4 U) F8 X8 E% H7 Ccalc:
    ) _4 f% G# g9 z/ B7 Z- s& r@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); 2 ?0 S4 A$ X* u6 z
    endcalc 8 Y; K: e' L! @7 }
    min=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4)));
      h1 s% ~# X1 Q- T9 \END
      L. M0 d  C5 C5 i  O上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函
    $ S; x! K; ^- I# \7 p+ W2 y) r4 V9 I数值为 0.4729562,这里的解受π 的取值影响很大。
    0 e4 y' q! h2 O5 T
    % F: d9 b1 l1 z, f/ |! A1 K(3)模型 2 及求解
    8 b& k. E8 Q2 A- ^% H. h5 Q0 Q, e7 }9 F0 ^
    注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:/ d& b) F+ P( D( i' S% z$ F8 [* N

    0 G3 d" _" z1 g$ G  q9 ?2 t) J& Y1 N/ i3 ^" n; L
    ! O3 B6 L  t# y
      也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。
    1 [6 q4 Y3 r  X! a1 E 以 min x 为例,相应的 LINGO 程序为:  
    . V0 i/ A# L1 N7 J) ]  {# }% g& `
    * w5 d; B$ D0 g7 ^: F4 ~MODEL: 9 A* D8 P4 u, h! W* p0 ]
    TITLE 飞机定位模型2;
    1 q( M6 Y; ?& U, lSETS: VOR/1..3/:x0,y0,cita,sigma;
    + L$ ~& ^2 ], pENDSETS
    $ q" Z5 N$ G$ g5 h* p- G" JINIT:
    & F- l8 t. a5 nx=1000; y=900;
    ( O- I8 V* A) VENDINIT . B) h9 O2 n# t
    DATA:
    4 K# e; r, c( i5 P8 d! {  B7 nx0, y0, cita, sigma =
    0 q; o# v1 q% U! w' Q5 Y746  1393 161.2   0.8 5 x$ s* `# L( Z9 Q% F9 q
    629  375 45.1     0.6 $ e5 p! C% R$ T
    1571 259 309.0    1.3; 1 g; s7 M3 b* c% z/ j
    x4 y4 d4 sigma4=155,987,864.3,2.0;
    3 Q; G( K0 x( L+ PENDDATA 3 k  Q0 M$ s/ y% \- P
    calc: ) g* {( p9 _/ i
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); : g. L* H- W5 N2 M* \. [
    endcalc
    3 R  P) Y' N. d9 q# b5 [min=x;   C% O! l* c( E3 I. \) R5 E' D* e% D# s
    @for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma));
    2 P7 f7 D2 b7 ~2 |- U+ T; h6 t5 g@for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma)); + o2 }. y, O6 A! c2 E- R1 ~
    d4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ; % {! _% g/ V( B; j* q
    d4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ; 3 h4 U3 y, \  t# R( ?/ K- q' W" D" n
    END
    1 G4 m1 J" J8 P5 O/ F6 v注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 . 2 `2 I4 W/ m3 Y' ^9 @

    " M, K9 y2 \( [' f9 M  (4)模型 3 及求解8 O7 P5 t3 `: }1 w: f8 \3 C3 l

    5 _: u& s: k. e. i6 H模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量
    . r8 y) `" w7 w/ h0 C/ z2 V误差的标准差。 8 ?$ B  [" L" P3 [5 K- o
      c/ z: g. p% a* `! Z5 i
    在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。
    & L% j: @+ P1 X( T% e: l( ^2 T  J+ O* C: n

    $ A2 @" f! e( r# o
    1 x/ B( _: H, d4 G1 y9 @) y 由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为:
    9 [) d9 U8 w9 [& y' O% {; _+ [+ \# [7 `8 e3 o% R
    MODEL: % n% j% k- c0 a$ z2 P
    TITLE 飞机定位模型3;
    6 l# w5 I5 Z" _3 ?' g2 e' c$ USETS:
    4 E$ f( E4 ]9 K# y6 e' Z  UVOR/1..3/:x0,y0,cita,sigma,alpha; 0 G( Y" ~' ?$ i* W. ?
    ENDSETS
    ! O# |8 A1 n! b4 _8 EINIT:
    6 ~: _4 i6 }- h6 c4 }8 b& U/ Px=1000; y=900;
    5 b( _5 D# g9 ~6 r1 ZENDINIT 6 W  T# @+ {. p* {9 H0 l% J3 ^8 H
    DATA: . K3 X+ V. y  o% {0 e
    x0, y0, cita, sigma =
    + I# V& D& H0 c6 c9 H746  1393 161.2   0.8
    4 ]" Q# Z) S- R9 P/ T629  375 45.1     0.6 6 T" @) j% a5 s2 L
    1571 259 309.0    1.3;
    / t* ~/ u$ A# ?6 Sx4 y4 d4 sigma4=155,987,864.3,2.0; & g" x7 @$ Q) w7 X( a# U4 s
    ENDDATA - Q* Y- o6 b' _; `
    calc: / r5 V+ S; @  Q. a: W! l
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    # }1 M# j7 R  J$ u; i8 Cendcalc ' G4 X% J5 u3 I
    min=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2; 2 \1 l8 \3 C& r4 Z! F
    @for(VOR: @tan(alpha)=(x-x0)/(y-y0) );
    8 Z1 T- l( @* S/ w( O3 DEND2 O4 M0 ]/ `$ ~0 o* w; F
    启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。   L' z" f5 F1 h
    ————————————————
    ) j, n/ h) V4 c( O  t/ W- u5 `版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    - Y  W1 \" L5 G5 v& Z原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044) b* W0 t- V1 G1 u: i( O

    ! x* o4 g% E, D; z  N& f; E7 X$ S6 r9 q5 A# d/ i$ p& b0 O! W

    9 O. q) s7 }) p) r5 R# e
    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-4-15 08:14 , Processed in 0.383613 second(s), 51 queries .

    回顶部