QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3797|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置?
    + T* [/ }; j/ D# Q6 [) L: g& P8 @) D
    ' N7 W/ P8 G9 ^7 [9 [  C. y* L5 z9 _( X5 F% ^& R% s

    $ A' G' Z7 P/ S0 v  b% x% y* v% V- I3 n
    , j7 V6 b* w; y8 N( b, ]0 ~  y  (1)问题分析
    7 j( o9 P2 [* A- R$ W- X) [
    + Z, H! E1 K6 p# `) N, X 记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算  ) _* h, b1 y# m) |8 g9 \* _
    & r; ^" ^+ O5 M

    ' G& D$ ^1 ~( K' b9 K
    * s+ k0 C, h% q4 c9 v& s(2)模型 1 及求解 & T% I4 M: }$ ~( F3 ~5 _6 C
    2 Z" B, S4 r' E5 g5 l/ `; A; C
    图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )6 U- R1 E  l) i1 K

    3 |. n, }! E& z对 DME 测量得到的距离,显然有      ( 2 )
    3 _! d/ u( R7 S; d. v
    $ Z  T$ h% d6 C) a直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解
    1 K# @4 x0 B0 H* `# I0 r
    : h( P1 S$ F1 `; L, U* y& U! ^ ( 3 )( p. j8 H2 _6 f4 v8 H* l; e
    式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:
    0 @4 ^/ B+ E# X; |$ G5 W  V* {4 i6 C, c3 J- N
    MODEL:
    6 z/ V: X7 I0 X0 ?' r! g' L0 W3 P8 fTITLE 飞机定位模型1; - g) }) [* P% G9 q5 t9 i; l
    SETS:
    6 n! p+ Z' E. h- X$ f, h2 V7 ]VOR/1..3/:x0,y0,cita,sigma;
    & u0 G# d% {/ {% h, G9 D* EENDSETS
    ) V- M& d% ~) wDATA:
    * ]4 g) h- V7 M  v, q) }x0, y0, cita, sigma = ! n1 J8 b; I$ C  d2 b
    746  1393 161.2   0.8
    ' n$ {" O1 a' z) ]- K( P' e# ?0 W629  375 45.1     0.6
    / {1 X' A) G! u. ^( Z- W( Z& w1571 259 309.0    1.3;
    7 W% N, w+ s, _3 @( s* B, @2 gx4 y4 d4 sigma4=155,987,864.3,2.0;
    $ N/ u: N/ @0 V; }ENDDATA 4 }$ W6 d# n7 j$ v5 E
    calc:   {; {8 D) {1 R( ]" B1 q/ k1 Z
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    ( W  @0 ~: [  s& a/ a* Tendcalc 7 l+ l; ]! i( q% M9 Y
    min=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4))); - a! \3 n3 Q4 ?$ a
    END
    / H6 s2 q0 e2 E% I4 b+ E6 i% Y上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函3 b& T2 f5 m- R, b8 n
    数值为 0.4729562,这里的解受π 的取值影响很大。 " k0 c% {* \: |3 r/ w9 K
    ( {% }% C3 l% B, @5 s  ?
    (3)模型 2 及求解+ C2 W% D+ U) z) w
    / v# ?" F3 H& K/ V+ @4 `% Y
    注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:
    0 D8 |6 |" t* H+ x5 N. ?' U% w! R/ r' g2 h. u

    : g; ], i( c2 E7 I1 u
    , j0 d2 U& T' M8 e8 p( C  也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。
    ! E* H& L" B5 P, ]" c 以 min x 为例,相应的 LINGO 程序为:  
    6 @! ?+ f) k  {. w+ ~0 O. F& y/ Q, E
    MODEL:
    / O) z! p2 U* r% ZTITLE 飞机定位模型2; 0 w1 }' }! h1 ~8 D% h7 o
    SETS: VOR/1..3/:x0,y0,cita,sigma;
    6 Y$ A0 a# M% j- W) o/ ZENDSETS ( N4 B0 j7 d& w/ Z5 H) s
    INIT: ( Y; Z1 v0 A% M% n
    x=1000; y=900; 2 C; \' n4 C/ P: e  J
    ENDINIT
    $ u) T, H3 k8 ?: t/ z3 YDATA:
    1 `, c) e+ Z- X% U/ X( gx0, y0, cita, sigma = 8 Y% E% N8 a3 a
    746  1393 161.2   0.8 $ U" D& C- F* T
    629  375 45.1     0.6 8 j% d1 @% O  Q& f# H, ^& h
    1571 259 309.0    1.3;
    / `7 s& G/ t( G4 o5 \' P+ U3 w/ mx4 y4 d4 sigma4=155,987,864.3,2.0;
    " D' N" J% J- UENDDATA $ T# U9 q4 n, R$ \: E% K( C/ b
    calc:
    % O$ [3 t& f* Y@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    6 z. ^2 ?! N# ~4 a5 s, Q: b. Y& uendcalc
    8 T" i' b0 @0 u; [- b5 N  Ymin=x;
    * n/ l( p% f; `! A" h% x@for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma));   M/ l  @0 S  \1 P2 {  B
    @for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma)); / \" F' T: r* R4 j. n( x0 }
    d4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ;
    $ Y0 j" _0 F$ q3 x8 Id4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ;
    0 H' D6 f9 y) A8 j6 q4 R3 [END
    4 Q! I! @  E9 e8 _, s, a注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 .
      e6 }5 M; ^6 p# T
    & l. l/ L9 m: s$ o  (4)模型 3 及求解1 G) N  z; X! \; W
    + L4 p% l8 J7 N* s. T
    模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量& J6 g, X4 m, L$ Z" T7 D
    误差的标准差。 6 H2 `+ T* [1 z% m. T& F, u5 |
    + q; y; e3 ~: n
    在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。 ' `5 u4 ?* {/ B5 J) G
    + [  P: t: r8 y8 k, T

    9 v. y7 B. p# A6 H; k1 B5 z3 m
    5 I; L! R* _+ {/ a8 L- d 由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为: # a! B* b) F: U1 f, U# C
    $ {- E! e: }. T3 j$ O2 Y
    MODEL:   U! |9 P1 h3 N, V5 b& V: j- e7 u
    TITLE 飞机定位模型3;
    , C8 S2 y7 W- F8 QSETS:
    8 }( q. I7 r5 }. @( H" CVOR/1..3/:x0,y0,cita,sigma,alpha; ' W6 t4 a, s' F* G4 u6 v- n1 d
    ENDSETS / n* d( w" n: j( L
    INIT: ( Y( R( Y. u, W$ I1 T0 X+ X
    x=1000; y=900; 8 w$ P+ p7 d  }; X( x: J
    ENDINIT
    * O9 H4 c9 ]5 h: s* NDATA:
    . G/ o) r6 g) _9 r5 L# K, M% ?x0, y0, cita, sigma = # J: B, I: M. |# Y4 r" w& H+ B! u
    746  1393 161.2   0.8
    " Z, I6 J5 K7 N2 Y) B! I629  375 45.1     0.6 3 P! |5 d$ a; l$ X+ T
    1571 259 309.0    1.3;
    ' b% B0 i" t! w8 Q% u/ z/ Fx4 y4 d4 sigma4=155,987,864.3,2.0; 4 g6 B. r% E& B* f% ~( |
    ENDDATA
    ! G& B4 V$ a* h" \6 lcalc:
    8 b& b# F) V8 k@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); 1 _$ b* Z! V9 U
    endcalc , ^% C, |% X9 k; b) \
    min=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2;
      I( E$ I& T- q@for(VOR: @tan(alpha)=(x-x0)/(y-y0) ); & Q* U  C( O$ {4 h
    END/ n. B/ u" M1 u3 q( U
    启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。
    , z) `7 g% S' H) y8 m————————————————" T( [  X5 q" `9 u5 v
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。; L/ R- x/ y: R
    原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044! u2 b% O% `5 A7 k
    ' }( b5 `8 Y6 Y5 C3 b) o1 @7 @2 ]6 }

    * t0 N) a: z4 v1 Z+ J! ]+ A- F& \
    $ V( `$ f* i. X( W, S; V
    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-21 04:35 , Processed in 0.415368 second(s), 51 queries .

    回顶部