QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3791|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置? ( t7 i% P  O! F( \, v+ |4 O/ K  U

    , C9 z: O3 P2 t+ [' Q) L9 U8 f) Q6 N3 X9 z: Z
    % l+ y3 m6 n( A1 k
    8 A" J7 F) G1 Z9 f' k/ d
      (1)问题分析
    6 a( w& o8 `" u* \
    $ A+ v* \3 X5 R3 L 记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算    x: {# `' `# K5 D$ g1 Y6 k
    7 ^5 _$ I$ g1 |6 h. \' ?) Z* @/ t$ Q0 c

    - K: O, ^' e" T7 i3 g2 E9 v. y. `3 E1 A" m+ X& {/ q1 @& h
    (2)模型 1 及求解 6 c  D3 H3 H6 F( c7 B7 C* A

      ~8 g9 w( b# l2 ?; H 图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )
    + V7 i- R3 n  L5 Y% W; ~
    ( C8 G, q. z6 y8 r$ t对 DME 测量得到的距离,显然有      ( 2 )
    % a9 z# ~7 P* g- A6 M7 U
      d! r( |" W1 n, c% _& i  u直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解 % f, ^/ z! m) e' O# @
    - i5 j7 f  r- S, A( }* V% _
    ( 3 )
    ; R4 a7 H4 p: B% l: d8 _; ~式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:' E) |$ g  R  y
    # |% Q3 J% ]& I3 j
    MODEL: " S1 c, ]) B( V" Q
    TITLE 飞机定位模型1; ) e* P5 N8 E9 d. f9 [% H8 C
    SETS: 0 t& D, v8 R$ i+ ?
    VOR/1..3/:x0,y0,cita,sigma;
    1 c/ |& l" `' N) J% }% MENDSETS : R7 r( B. m! a
    DATA:
    - a8 d" B  F% w* U! z9 Px0, y0, cita, sigma =
    1 L3 H! ^* s2 f7 C746  1393 161.2   0.8
    & O" j  ^  [) K  E; F% W6 Z629  375 45.1     0.6
    . P. q# m- j) X1571 259 309.0    1.3;
    * w/ X! O/ M' C2 H- C/ @( px4 y4 d4 sigma4=155,987,864.3,2.0;
    3 I; D# \+ x% I# Q' J6 B0 n5 M: EENDDATA 5 `2 Z) D) y, \$ k/ {0 V1 d
    calc:
    8 W. r0 \* B1 @7 r0 n+ I  @# K@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    " i3 T6 ]" G* Cendcalc # A; a9 W' R6 @0 \) D2 d
    min=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4)));
    * q; Q2 x' ?+ nEND1 v1 m$ ~( d: `. Z9 u
    上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函, D/ p5 T* n; K  X
    数值为 0.4729562,这里的解受π 的取值影响很大。 0 a. c- }2 Y/ t, c

    5 T5 b9 C  \6 c% k(3)模型 2 及求解
    ) ?: m1 y4 i0 C# }+ l2 T- a* P
    注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:
    & [( G2 {+ ~( O6 B$ r* r
    ! q( D& A3 n- G1 o; N0 l% |. c- U. {! x3 E( e( P. o; Y- }, C
    ( x: T" Y  u5 R% c5 \; N( V
      也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。
    5 W; d% X7 j2 E  V/ M7 l3 \6 v 以 min x 为例,相应的 LINGO 程序为:  
      p" F2 ]% I: v0 p! J$ f1 P) R
    & J+ y  T8 {; Q1 k6 PMODEL:
    - q+ v( ^/ K* X! e; YTITLE 飞机定位模型2; ' ?1 U  o5 o5 i7 {3 J- m: E
    SETS: VOR/1..3/:x0,y0,cita,sigma; 4 t# T$ N7 x: f  O. R* ]; J
    ENDSETS
    . S5 a4 i( h( ^# Q) H7 lINIT:
    4 x# L2 m' ?+ Nx=1000; y=900;
    % ^% E- {) A! OENDINIT
    6 {" `! T8 S1 i' k$ X: ]DATA:   U$ @- K# P( J* G) @4 D( j" p
    x0, y0, cita, sigma = $ c& B$ s7 s; L. p% ]2 d3 Y
    746  1393 161.2   0.8 : s& b/ y/ ~" [' V4 }" F& u
    629  375 45.1     0.6
    % [& R+ o. r4 M& I" G1571 259 309.0    1.3;
    & B& r9 G- ~/ ?! Q+ Yx4 y4 d4 sigma4=155,987,864.3,2.0;
    % `+ H! P( M' S' W0 i5 K+ dENDDATA
    ( `3 K/ m9 V  H6 a3 rcalc: / a& b# e3 j" K5 v
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    $ C; x8 R; p/ i  Fendcalc & d# M& }! a( \+ C& u$ q
    min=x;
    & S4 `( C8 w" C' M; Y/ R7 Z@for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma));
    $ M# E) C2 s- ~$ H( [; G5 m@for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma)); " ?7 d2 S+ b8 t) j( F( s% N3 ^
    d4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ;
    ' F$ n* ?* r. ~! Bd4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ;   X. H( @2 `) a4 }8 J2 L
    END
    0 B9 r" X1 v- J5 r注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 .
    0 ]- I3 \7 F! N6 K8 |2 R& o' k/ n
      (4)模型 3 及求解
    7 x( ~$ Z) a2 \2 ~
    * O, z7 m3 ?/ e$ K模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量
    0 l$ z& o& H1 Y$ ~  ]误差的标准差。
      ~- f3 \/ d5 k  a6 z$ r2 w7 B0 z+ h* Z8 d# s5 U; u4 G
    在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。 . S# s8 d  @7 s# a  f* I
    / k) e5 y! e0 i
    , q2 C8 z1 r; b3 [
    $ D# Y8 h8 n0 ]' @$ {9 g
    由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为:
    * Q/ x. e$ S/ P
    5 J0 b1 l* |" s1 P8 N6 s) ^% J5 @MODEL: " l. _/ r. C. x% ^! P& u
    TITLE 飞机定位模型3;
    " M2 k# z. n3 v' T3 S" iSETS: : ^! |5 n' B7 b: e2 |
    VOR/1..3/:x0,y0,cita,sigma,alpha;
    ' i+ A5 v, g; u) X. x$ f8 QENDSETS + [9 y) ?, Q  B3 q
    INIT:
    : g" S' I/ W( R. Z5 Q" [2 Ex=1000; y=900; 6 @: d9 s' q! T
    ENDINIT * _  k. B. j/ E
    DATA:
    4 J" E) j0 [: P; z* n: Bx0, y0, cita, sigma = 0 z; ]  a: V( F& l/ {
    746  1393 161.2   0.8 + c/ C  n4 ^: {9 {: F
    629  375 45.1     0.6
    % x. E* N0 C/ m6 R1571 259 309.0    1.3;
    8 d; ^$ v% N/ Rx4 y4 d4 sigma4=155,987,864.3,2.0; ' u3 i0 U* m, K9 _' z/ q
    ENDDATA
    5 D8 n6 p+ z, h) qcalc: ) f0 O: L# `8 M* B/ R
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    , X: h1 j6 N" l; N+ {" [' z) kendcalc ! s" E* f0 U+ q
    min=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2;
    % z  m! E8 H9 r5 b6 N@for(VOR: @tan(alpha)=(x-x0)/(y-y0) ); % b' i2 i. j) G! n4 j
    END
    ! Z) a" x' g" l1 W' v; c5 i3 M 启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。 8 j6 E# e6 J4 H
    ————————————————+ \3 p1 h$ K7 U3 |
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    5 H: ^8 s4 C' o1 M6 b原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044
    1 U2 B; U0 ^% _& }
    4 @4 B' s: e8 ?4 r. O* O7 y* Q& d/ m; T: s$ Q
    3 Y- u9 i* V: G* R# |  I) O0 H
    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-12 01:37 , Processed in 0.541428 second(s), 50 queries .

    回顶部