QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3795|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置? # H" Y2 l2 J6 Y9 t. G/ c+ A

      u4 c6 Q5 Z# V/ I' w+ ?/ I; \. \( F
    ) Z+ Z$ c) q0 A4 V( f  S
    # W% y( T. E& \- J0 ~
      (1)问题分析 ) `& X! y( [/ W+ V# w8 M! j2 ~
    ; f2 X2 R' `' [" P  o
    记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算  
    " D1 G4 T1 h4 c) D$ u6 `  `
    1 Q+ N$ P5 e; I2 t( i
    - d1 Y4 G' x6 y7 {1 i7 s4 x* x
    & }6 |9 f9 K5 I7 K& f$ w(2)模型 1 及求解
    4 K# T1 f# h! N" r& C2 @" X: i; o! `/ S5 l, q+ k! H
    图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )! K' Y; _1 r8 h" M& D

    5 P7 k& P6 W: O- K. J9 R0 {) M; Y对 DME 测量得到的距离,显然有      ( 2 )1 a  |6 ^* D( a

      C9 p  X1 v. S, ^1 w, p1 _直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解 # W3 d* b  r8 F1 J$ f6 w

    $ a# B' v& |3 o ( 3 )& ^+ H5 `# ^8 W, l- K, ^) j. o
    式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:7 l- E: @; D3 ], Q3 S- ~
    9 k1 X/ {# ]! |4 F( k* ^8 ?% u
    MODEL: 6 r  \9 m. \4 |; j8 @
    TITLE 飞机定位模型1; 5 x, b8 q* a- u2 Q9 F/ f9 @2 }
    SETS:
    ! r' k" R( T: j% [! wVOR/1..3/:x0,y0,cita,sigma;
    4 E( Z, C* n8 b4 |ENDSETS
    * n) E1 ?( k) Z/ q- U# P# MDATA: ! B# H( I4 m; N; @0 B: _: @
    x0, y0, cita, sigma =
    , C' f7 \5 |6 q2 s) ?746  1393 161.2   0.8
    - n6 z1 e$ F+ `0 b' n0 w4 t629  375 45.1     0.6 ( C$ U. ]. j. K* {) Z. W, v" G
    1571 259 309.0    1.3; 9 Y, R3 x* u* k+ |, }( \$ n
    x4 y4 d4 sigma4=155,987,864.3,2.0; 0 I3 \5 G' p3 C1 _& ]
    ENDDATA
    5 S' b- P$ a% w9 Wcalc: : f9 l% I" c* W! c$ R" D" q
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    1 S3 @' W" j9 d0 N( H  {; f; t' cendcalc
    & K1 s5 W* h( c5 R/ y( v" Ymin=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4))); 6 q* e7 t+ ?3 r+ x" \5 T" y
    END
    / d1 p; ^2 ^3 I上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函
    ; C9 T, `& m  @& N! k/ j数值为 0.4729562,这里的解受π 的取值影响很大。
    : Y* q0 B  C) V1 |! c4 d" `* Y! n/ D
    (3)模型 2 及求解# O$ Q8 V& j$ h- j7 U. T

    ! t) I1 i. K% x  X8 u/ H$ d4 q注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:
    7 l! ~1 v6 h3 `# P3 D* t4 G2 @$ M, W. e& `

    # j2 n  P0 X" p
    / Q3 u- x7 r$ ]0 L- u1 p  也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。 8 A7 Y* A; R% s$ w& ]) Z
    以 min x 为例,相应的 LINGO 程序为:  
    + j% S' C+ c! `6 ]8 h2 b7 u9 L& ^% t
    MODEL:
    $ J- \, U7 L& X( B) z, K+ u; _1 k+ GTITLE 飞机定位模型2;
    & S! e# Y1 B" tSETS: VOR/1..3/:x0,y0,cita,sigma; 4 G) t* S9 U& ^
    ENDSETS 7 C* `& y% ]4 n% K1 l
    INIT: : K4 |" N2 |7 w2 W
    x=1000; y=900; ' o6 ?/ e7 \( a, ]
    ENDINIT
    3 u/ K# |& ?) c* D1 z& FDATA: 1 j. l- q& x) P7 j& I
    x0, y0, cita, sigma =
    ! n% Q' l: M' ?6 V7 O9 }746  1393 161.2   0.8 ( V# d. r% m/ ^7 M. N- h2 D
    629  375 45.1     0.6
    0 }" [6 }, X1 I/ n1571 259 309.0    1.3;
    1 @6 n% n2 n2 K7 `4 A- Px4 y4 d4 sigma4=155,987,864.3,2.0; $ c* ~) O# O9 N- _/ f+ V
    ENDDATA
    : R  j: J) o4 e; mcalc:
    # B5 r$ ~. d: O! d* Q& E  I@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); ' d4 W, d* v$ a( f9 F" _6 c/ I$ G
    endcalc ) x0 |; ?- e4 b: z4 v
    min=x;
    0 f% ?5 P/ ?0 b+ \+ n; Q8 m@for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma)); 0 [8 X; Q7 K  t
    @for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma));
    # k% B* B0 F  m, Qd4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ;
    2 z9 `- S8 \* u4 jd4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ; 0 Q1 {8 ]. l$ M3 q; _& d& K: T
    END
    - t0 P: m! o6 Q6 f注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 . " `: g: G$ n) Z+ q% E9 a3 W

    9 u: ?4 g7 r3 O: }3 |: ]; G& m  (4)模型 3 及求解; O+ Q' G& k2 c; F( B; F- O

    % ~; C$ X' N, D8 P  u$ L% i模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量
    / X& n. d0 V. l2 e) [5 S8 I误差的标准差。 1 K" A( P7 w$ d& c$ R8 s+ f: r3 Q

    ( ~0 ]7 P. a9 k. F" f在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。 ) `! i/ C2 L. V9 T
    / s4 l, f0 N* T# Z7 c' [

    # O- E( F' G# p7 q4 \
    ; e0 Z7 t. I1 q8 c  g# f1 Z% S! t  T0 Q 由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为:   }" }6 c+ ]! Y- f: ^; C0 V
    4 \% V' D; D, E" a" }
    MODEL: 2 Z; @2 A- D  ^
    TITLE 飞机定位模型3;
    9 l" M* S' Q3 i9 I) v$ B9 W+ c) xSETS:
    6 A# j+ [3 X2 b6 gVOR/1..3/:x0,y0,cita,sigma,alpha; ( e  ]3 v3 g5 Y" l
    ENDSETS . j7 U. T, q+ `5 B9 ^) t
    INIT:
      N. C9 s1 H9 f( `# M# u2 tx=1000; y=900; % ~3 v  ~" d4 Q5 H
    ENDINIT ) T8 b4 C$ X+ j. |0 Z( {+ s( m7 s
    DATA: # C9 f& c% h7 ?" ~7 H- q
    x0, y0, cita, sigma = 4 @- O2 D& u& q- U$ o& N. f7 p
    746  1393 161.2   0.8 ( C% f5 c  C* z) l1 |6 B
    629  375 45.1     0.6 # b/ ?8 W# n5 J" @+ v
    1571 259 309.0    1.3;
    * b1 t1 r% m; l1 c- sx4 y4 d4 sigma4=155,987,864.3,2.0; + g3 J9 Z; Y- O' Q& P. t* R1 B# d
    ENDDATA ( \- i$ m8 V1 J% s0 A  p4 T) q/ w
    calc: 6 U) i1 w" z+ n( `
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); * f. |3 h' r1 ?# B5 U; P4 u
    endcalc
    6 j0 W# Q9 j/ K  A3 f# \: Hmin=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2;
    / j3 `3 T7 U, u8 A) x@for(VOR: @tan(alpha)=(x-x0)/(y-y0) );
      Q% {: E9 `/ A6 o. o( i9 K8 G+ [1 cEND7 l; ^/ a! W, l. p  \! J) ?8 q
    启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。 7 R0 k5 T& Q  }/ {2 w$ r# W3 U& w
    ————————————————
    6 S7 r; f( ?$ i/ ?版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。3 f' l  C- v9 L: o. e( k9 }; Q
    原文链接:https://blog.csdn.net/qq_29831163/java/article/details/893890440 B5 E, k0 X8 P" ]2 c" Q. V

    & ^; p7 m8 P/ k4 f
    % h6 u2 H. S; c: E3 L. m2 s. Q  P8 P& F% ?
    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-17 19:31 , Processed in 0.431209 second(s), 51 queries .

    回顶部