QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3838|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置? / [8 [) [8 r. H4 k9 m/ `1 w

    0 c9 J. \6 S* u6 Q+ _
    , }+ q1 N- ]4 S9 ^  a+ H" I
    " R' W( Q" p. t6 Q/ [# {2 Y+ h3 }1 @. K6 }4 {- h  a
      (1)问题分析 ' W0 D( ^" A" s+ b7 E

    ; f6 q* ^7 |5 G2 ]3 A: X9 m# m; C5 { 记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算  
    0 l5 T2 `1 n8 N' |) V7 _8 H) R4 _0 \
    " n# x: W- b" x- E' B7 q* S1 M$ x6 \
    6 w2 h. z& f; E( J$ _5 F
    ! U- m4 z) y9 n(2)模型 1 及求解
    6 }* o  l/ k5 L& L
    . S. B+ m/ n, P$ ^+ a( J- Z 图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )0 B! [) O& T" G# n+ w' R2 f. W$ c

    # s6 e& y+ G% }& _6 k' {8 G" K' i对 DME 测量得到的距离,显然有      ( 2 )
    " M/ ?' A1 D# p( [, Z$ b
    9 c/ e' E% T" j) g直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解
    ; P  Q! ]" G! _
    ' l" u& X- m% S9 Y ( 3 )/ R. G" w! N! ]) b1 Z
    式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:& Z  R4 D. |5 Q8 U* V
    3 j+ G0 y3 X5 @& {' ?1 q1 C
    MODEL:
    1 |# _4 I! j( X% X7 z$ r4 NTITLE 飞机定位模型1;
    * i. A, y7 \9 YSETS: 4 ?2 R2 z3 ~- [5 Z+ p' a' n1 |. k
    VOR/1..3/:x0,y0,cita,sigma; - F6 N1 s3 |2 Y0 r* p
    ENDSETS / U0 _- N' T+ A. V( {$ H) I( Y
    DATA:
    0 S7 Q% F4 |3 i+ X' zx0, y0, cita, sigma = - p2 g! o: K6 ^
    746  1393 161.2   0.8 . E' _; M& }- ]- @) d7 [
    629  375 45.1     0.6
    , e% a; N. W& E! z1571 259 309.0    1.3; % w( I/ b, g7 S; l: D
    x4 y4 d4 sigma4=155,987,864.3,2.0; / S5 I: U% H! u4 m; a9 c
    ENDDATA
    & S0 e1 \5 @2 @, a' q( y  C, qcalc:
    # k# j1 P: ^0 ~@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    ( |# k. P  K  [1 u: e' K$ oendcalc & w0 W( ^( e5 H: }+ H& I9 ]) d8 V
    min=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4)));
    / S% h$ @, Y# B! N( ~( o* lEND* o7 J7 I  Z. y* i
    上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函
    2 q! d, V: b  n数值为 0.4729562,这里的解受π 的取值影响很大。
    9 ^( }4 P0 s; Y6 n) ?3 s' q
    8 K! V, q* [& f/ _! z. X6 y! K(3)模型 2 及求解2 Q0 C! ~6 c, a6 W; y$ B. A

    1 J8 Q1 Y. K- y5 S4 U, e' M注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:7 Z* j! f% ~' I& a- I% L' @
    ' G' i; H" b; D8 y$ R

    , U! v# }" T& H9 J# ~
    1 I( j8 V5 m9 V2 F  也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。 3 U) J! J  [0 A8 {6 Y; u6 ?
    以 min x 为例,相应的 LINGO 程序为:  4 \4 J) ^5 r" L4 g
    , k  i; `( w, c7 |# m) a' m. `
    MODEL: # B7 }2 Y4 i) G# H! l. {: F) r
    TITLE 飞机定位模型2;
    8 R# m& e6 t7 _$ MSETS: VOR/1..3/:x0,y0,cita,sigma;
    # y( Y. m, p$ nENDSETS
    % P  O8 v; W. \INIT: ' ^, ^$ g. }# I9 @; z1 Z  k
    x=1000; y=900; 8 S! c  {0 ^, S' c! c# d8 D, E1 H6 Y
    ENDINIT 3 p  f: u, V# @" G
    DATA: * ?/ A  I& }: m* i( I& G5 [
    x0, y0, cita, sigma =
    : X& e# I& G1 o2 ~$ f$ n, T% c+ s746  1393 161.2   0.8
    8 {$ ~2 [" s1 f: V* {629  375 45.1     0.6 , r. |8 N- X* S/ M2 K6 U/ T
    1571 259 309.0    1.3;
    / s0 H$ l; E/ z5 j0 [x4 y4 d4 sigma4=155,987,864.3,2.0;
    . R! u4 c' a; ^ENDDATA 3 ^+ O6 ]# H) T5 @
    calc:
    ' _+ y- o' ]0 W7 y7 w+ V@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    & K% K  c9 C. d: m) J. rendcalc ' g3 l+ A" K/ \; y! E+ D- `
    min=x;
    6 {3 {; L% T& \@for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma)); 0 a8 Y# i, v# X" V4 Z
    @for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma));
    0 _0 P/ F. C! u$ j5 |d4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ;
    % B- V7 [3 k4 ]! r" r+ Yd4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ; 5 ], ^) g( l9 L8 {- `3 v
    END ! d* @' T& \8 i# o
    注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 .
    1 ]$ e. r7 p" d6 D" T4 J+ a6 {: p6 l
      (4)模型 3 及求解+ ?" E' c9 G! x( R  B: t2 ~0 M
    - i0 j' Q( X9 u- }( b2 |
    模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量1 M& q) o; B0 k9 e
    误差的标准差。 + w* W& m) y8 L$ ~

    1 Y3 S* c# G8 t1 K5 G8 ^2 l在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。
    1 y* z5 z0 V3 _- l( Q
    " k- k! Y2 E- }' N
    8 U: A1 x( L; J) k( @" y$ K& M1 c& d9 q0 w
    由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为:
    1 e2 z$ J( e" X8 C; ~2 k7 i# |# G8 l8 A6 L- i5 [6 c
    MODEL:
    ( x% ^# P, N4 h/ hTITLE 飞机定位模型3;
    5 H9 j5 v; V) @4 q; w9 ASETS:
    ! @5 ?) J5 h& X4 H0 a. VVOR/1..3/:x0,y0,cita,sigma,alpha;
    & Z- ^& ?: c% }* FENDSETS $ |. ^! H7 `, @+ B
    INIT: 2 \# T" h# z  X4 J2 G5 d
    x=1000; y=900; & m: {: }$ P/ n- f4 c5 D
    ENDINIT
    + t% L! a9 O2 l& W. f  K+ f# GDATA: : m$ q% t% H" E+ W  y8 x7 [
    x0, y0, cita, sigma =
    2 o2 E- J/ b: h5 K8 s& h746  1393 161.2   0.8
    8 M/ z2 B# U9 X8 s* U- l! _# z5 A% V$ i629  375 45.1     0.6
    3 J7 l/ f! @1 _1 u, l  z: @1571 259 309.0    1.3; : r" T* q3 {( H/ B
    x4 y4 d4 sigma4=155,987,864.3,2.0;
    , Y, F( G* {  MENDDATA % Z, N' T& s' _( ^# ]( y6 T3 e# c6 W
    calc: 7 C, [* h- s7 T1 |; S
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); 9 B1 B# d2 G& B& Y
    endcalc
    ' D" b% T: E+ }2 a8 ]) ^. O) Emin=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2; 6 d! z( s4 c. E; o! l7 G0 y2 ^
    @for(VOR: @tan(alpha)=(x-x0)/(y-y0) ); " R  `) D1 A4 x7 ~$ S5 @# e
    END
    " d" n5 k1 M, p8 E, _ 启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。 ' u+ ?. d* h6 _" M( G& O- @4 @
    ————————————————
    , \$ q6 B0 R- Q版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    ; q# l& h0 h& f! A& \0 H( p原文链接:https://blog.csdn.net/qq_29831163/java/article/details/893890445 \, q$ T" s/ @- G: `$ e2 x
    ; I) p" m- d4 p. \! k  h& [
    6 H8 k( }% Z3 [$ R& R7 n3 ]6 q

    6 f9 B2 I, ^8 r6 [: s
    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-13 08:16 , Processed in 0.503226 second(s), 51 queries .

    回顶部