QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3835|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置?
    ; Q" [* z- R" ^+ {, |
    1 S* }: }* z! X
    ; C0 I8 x7 z. s8 @$ \4 M  p5 G
    ' A! ~+ j! m" z& o& \2 v. o0 ~2 Z2 D7 `
      (1)问题分析
    / ]0 o1 Q# s+ A7 @8 b/ t7 ^0 G  D0 v; G/ ]/ ^
    记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算  1 G& a' d) ~2 t0 F( a7 h2 Y- j
    4 {3 S$ d( O5 q2 b' V  d( Q% O

    * ~( ?$ r% g. x% N/ T7 h  n* ?2 C  w  l- N4 D4 w5 C
    (2)模型 1 及求解 & a2 P0 w# L# H  t; {
    % ]8 e& t" {0 u: a8 {
    图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )5 @2 X! O; }" ?' C3 j& L1 W, ^
      g: ?2 V1 Y& h) H4 @$ M# K/ L
    对 DME 测量得到的距离,显然有      ( 2 )+ b$ p, K9 _" f3 f5 B

    ' g$ d: E! I6 w直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解 : U8 }6 ~9 t4 R$ f" U$ s( l( l. l
    1 R/ g" s" }3 A, D4 g# \2 I  J
    ( 3 )
    1 f$ V5 s1 {1 L  v式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:
    5 J9 o2 K! Q4 A+ L+ ~3 I( F+ Y
    ( M5 j: N/ `! q+ Y$ EMODEL: 6 Q7 F( G/ n5 T( x
    TITLE 飞机定位模型1; 8 M9 V. w9 n) A6 I7 b
    SETS: * s. V$ I% H' s9 @
    VOR/1..3/:x0,y0,cita,sigma; * g7 Q  K2 U, M, _* c  f
    ENDSETS 7 `6 T8 L8 G( A; a+ C' D7 |
    DATA:
    4 T! P% |6 p6 Jx0, y0, cita, sigma = ) O/ ?9 \3 D! w% }# c1 q- P
    746  1393 161.2   0.8
    1 L) g" B. I2 g* _. H629  375 45.1     0.6 1 I  o" ]( T7 U- L
    1571 259 309.0    1.3;
    ; E0 b! H* w1 s$ g: ]( Y# R" @x4 y4 d4 sigma4=155,987,864.3,2.0; & g) L  c/ g2 P, I' D7 P' {+ Y1 l1 x
    ENDDATA
    " e0 f! L9 u# z9 ycalc:
    9 \3 i* z1 F2 f6 p, v0 B( S@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); 7 m/ E4 ?  X8 Q
    endcalc
    $ g  \. c$ A9 T0 Ymin=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4))); 7 V# P$ J% v- F+ v
    END
    6 _  C/ {  {& m3 Q6 t; q, W( m上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函
    . s9 u3 y3 f- W  ~. f数值为 0.4729562,这里的解受π 的取值影响很大。
    " u. U! Q0 }5 z
    8 Q3 s/ o3 _$ n" s(3)模型 2 及求解8 g$ b8 a2 j' L' L/ y: ^
    8 v/ Y. A3 d) ^/ s
    注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:
    , o7 U& m4 m* X
    7 k, l) c' ^- ~9 M' i. L% w' r4 i: S! b2 O9 t* |, z3 ~( u! o

    % ~( G9 A& n% I3 t  也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。
      [1 Y5 N1 G  ]" z6 E. n7 H% _ 以 min x 为例,相应的 LINGO 程序为:  & U: T2 y( R# x; [* u
    5 B2 W4 U$ o% q
    MODEL: ; m/ Y( f+ [. Q2 @9 b: \' k: M4 U% j
    TITLE 飞机定位模型2; 6 E/ k. h% d8 A; g
    SETS: VOR/1..3/:x0,y0,cita,sigma;
    0 s* h" O; k' j! @" wENDSETS # i* j# i9 r9 e4 i3 t2 c1 T
    INIT: 6 B2 x5 I9 L* L2 O0 L7 U
    x=1000; y=900; * Y# C6 k* `/ `1 V
    ENDINIT
    " U* Y5 ~* p# B% _DATA:
    ) ~' z* O* T1 `) s2 m0 v$ ?3 ox0, y0, cita, sigma = 8 |, i+ f. O* j
    746  1393 161.2   0.8
    1 _$ P/ s; q. X7 ]8 h/ J629  375 45.1     0.6 : M8 p/ l9 G5 h, f+ I1 ?
    1571 259 309.0    1.3;
    6 C$ @( v7 Q; k& ^7 \! j4 Hx4 y4 d4 sigma4=155,987,864.3,2.0; ! ~3 `4 W) O5 Z; v, l3 i0 j
    ENDDATA
    # K$ j: G' l3 J. i- d# x6 @calc: # X# B& R! @7 w* x$ Z3 k
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); & D2 }* c1 Z7 [$ D: G+ V; F
    endcalc ! z( ^' `1 e7 Q& v: g
    min=x; 4 b/ N% P3 D# z  O7 P0 B! w
    @for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma));
    ; A5 q( G: ]7 P; \@for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma)); 4 y2 n0 o* ~/ P' ?( v# \
    d4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ;
    0 V* o3 l( t  ?5 e: md4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ; 4 }0 x& k9 q* @* y. v
    END
    / v. b3 [6 \) l" e% x* k注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 .
    4 Y/ w# X# L: n/ f  x, o4 A- y) f, X+ p3 e  Y
      (4)模型 3 及求解1 e- `# T& O2 f

    + G) C0 F# X8 g1 G) Y1 Q- w  I0 O1 Z模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量
    9 N5 T. ^9 N9 @' x误差的标准差。 % ^3 Q) u  A6 O- d5 F8 x6 l
    ( q: y/ H/ R: }( l  p! g
    在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。
    ) \. q, P  K* S! ]# ~7 A( e" `$ B+ F- V0 ~

    7 p' I% d4 m/ e+ z& J
    # Z8 A2 ]( C' n4 s 由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为: , X" _. e7 d# k: B$ s4 o) }) L
    % r1 L) a' |0 s
    MODEL:   I5 D; P7 T+ L8 _! e& X" }
    TITLE 飞机定位模型3;
    # D, _4 Z$ K3 aSETS: ) W) e3 s$ A% e) X! Z, J+ {
    VOR/1..3/:x0,y0,cita,sigma,alpha; 0 ~9 b- W' K2 X2 p$ o
    ENDSETS 1 }: g3 R+ y9 S9 b# V/ n
    INIT:
    8 w  u4 i- r- i3 O7 W; t: ]4 S' C, Ux=1000; y=900; : f1 G- k+ t7 w" _) j, l
    ENDINIT ) C) p2 P! c" S# C3 j/ P  O8 |
    DATA: ' M+ _! `7 j# m$ ]2 G7 y9 w' r, n% X
    x0, y0, cita, sigma =   Z# S; P$ \/ M
    746  1393 161.2   0.8 3 B$ o. @! S' O- d, W& Q4 [
    629  375 45.1     0.6 % G( W2 c# Y3 J. g  l" \6 g
    1571 259 309.0    1.3;
    % @1 z! T/ `/ s0 b4 I- xx4 y4 d4 sigma4=155,987,864.3,2.0;
    0 J/ Y4 z2 A7 X6 y& QENDDATA
    + G* ~1 }( |+ L+ c4 |0 B9 N+ I  bcalc: 1 r2 c2 M+ N. g  H" T
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); ' Z( G2 ^1 H, G3 T0 K/ ]
    endcalc 5 |: ~0 v) U9 l  e* E  E
    min=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2;
    ' B) N" o4 Q6 B1 B, }. d9 v! a' g@for(VOR: @tan(alpha)=(x-x0)/(y-y0) ); . V7 g9 a3 S, F- Q  |! V! G
    END
    3 F+ c' [' C. D 启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。
    2 G" h6 w, d% O6 T————————————————- [# Z. N9 F" ^. j. w: ^
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。  X3 E, R5 [' o- T8 j, R
    原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044
    : D. k5 A2 r# I$ `/ N( X4 R4 s: Z% f( {3 P/ k. C

    $ ^; m8 S$ k7 J! G; ?  P" |  x: C2 I; A3 J% Q3 d' a
    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 08:20 , Processed in 1.324255 second(s), 50 queries .

    回顶部