QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3796|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置? ( C/ J5 W" A4 e2 D5 O

    $ O- K8 r1 i. S: }; ~* f: I
    ) x* H/ S) W. \; {# ]% Z1 x* @6 ~: h' @' Y9 {) m9 ~5 M; R

    # H: W! r! B# a, P% Z  V$ R  (1)问题分析
    ' P% Q3 d; {# ]# q# M
    ' u- x% ]( m7 i5 D, |8 N 记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算  
    ( l7 y! ~$ O, z& [1 L
    ( {# i5 @# m6 F% K" b2 _$ [7 y2 y' d) w0 R4 A- N1 U

    8 x8 e8 g' |5 t9 t/ b% z(2)模型 1 及求解 & @& o/ b3 h0 v2 w
    ( G# Z" F, U5 a& I
    图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )
    ' b6 e; R# o( p4 V7 S2 K  \$ s) b8 B
    对 DME 测量得到的距离,显然有      ( 2 )+ F: [! e9 n; j2 Z

    % r( t& z$ U/ l1 @0 Q0 M% _$ y直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解 , l  C1 K$ E0 B9 \0 Z: x3 Q/ }
    9 y) |9 ~1 ~  w! B
    ( 3 )3 u6 ], C' w) f7 M" C+ K) b
    式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:! L" p4 Q+ A1 T1 O

    9 K1 e  T+ }, P' YMODEL:
    ; ~% ]5 H* M3 Z( x1 `TITLE 飞机定位模型1; ) D* F; j) f; r+ O
    SETS:
    ! u& |- Q* O& B; Q- I9 j" {' S1 E: LVOR/1..3/:x0,y0,cita,sigma; 5 `' }, t& X- \0 _& ~! W
    ENDSETS
    % x- z4 x' P' h! JDATA: 3 ]6 m8 X+ m/ n/ G8 t# K# Z; r
    x0, y0, cita, sigma =
    / l% |, c7 W5 m$ G6 ]) M; S746  1393 161.2   0.8
    8 s! e3 I, u: R7 f3 u. T) _629  375 45.1     0.6 + @& B8 O" b( V) L2 p
    1571 259 309.0    1.3;
    6 F" E4 I4 X. N% g: j& Ax4 y4 d4 sigma4=155,987,864.3,2.0; 1 a4 v9 J% V, C5 F" X$ P
    ENDDATA / S1 |8 H4 g% c5 J
    calc: . Y& J0 }1 v, o
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); ; C* E( s- x8 v2 |6 l9 Z
    endcalc 8 H+ U( J# U. O. S9 h, l$ U
    min=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4))); 7 s, ?' |$ ^* I: F. b! k
    END* x% S/ _; g$ L
    上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函# @: r% [  h: U
    数值为 0.4729562,这里的解受π 的取值影响很大。 - P0 h% _1 z1 d! F
    # q4 m0 ?9 [% A
    (3)模型 2 及求解
    4 F8 }7 A/ [$ b- I0 N# m' l
    6 g5 e3 o- n: E" W注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:0 A, j! Q4 @: T# o9 I' U. j

    " D% i9 L  p8 K0 Z" v% p% t# p6 [) u. W+ b
    ) S% p6 q$ k& t- J# @) h' h* W5 ^
      也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。
    + ^2 a4 j3 V; a# ^- X4 Q' b; d+ D 以 min x 为例,相应的 LINGO 程序为:  
    % Z7 j$ C5 P" A: f7 B7 m. c
    - g, H$ i+ D) Y1 c9 BMODEL:
    # A' n2 J; E6 z" ]0 wTITLE 飞机定位模型2;
    9 v" ?$ f3 w+ Q- h3 hSETS: VOR/1..3/:x0,y0,cita,sigma;
    ' q* i0 g& S/ j) p0 WENDSETS
    " S7 `2 l+ n: M6 i, O# g% ~  E% p8 o* XINIT: / g0 O6 R6 B$ |5 e# U7 Q( d
    x=1000; y=900;
    / _; {1 ^% A* ?: f4 Q7 [5 rENDINIT & p- J# ]1 A( H/ e- k- V7 ^
    DATA: & q) _, U- ]2 }4 Z, y! z! b
    x0, y0, cita, sigma = 1 {/ ^% t! l( i. a' d
    746  1393 161.2   0.8
    # ?* c0 P5 U$ U  a629  375 45.1     0.6 - Y3 W, _4 |4 F+ b- b, S
    1571 259 309.0    1.3;
    8 C+ c2 F$ f' v. q( kx4 y4 d4 sigma4=155,987,864.3,2.0; . t# Y5 w) `8 _4 M3 E9 u, K
    ENDDATA
    - U0 A: [1 y) K% u; }; J, k- Y5 vcalc: ! B' N; s3 g0 r; \6 L
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    , x; Z/ V! ^% t0 vendcalc " U1 C7 J+ g9 q0 N: j$ P5 ~  }
    min=x; + r# _1 Q% r* S, ]* b
    @for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma)); % l" M  B& _& g5 y8 J
    @for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma));
    1 t. K- d2 D3 Z  ?d4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ; : K" n8 |- Q- S
    d4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ; 9 |# L7 W* E1 Q& Z4 s7 l
    END
    & b- A8 h0 `# C! `注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 . 7 `/ ~3 c& V# ^" _7 v' N7 d

    " C2 W$ E2 A2 C3 @% f8 k  (4)模型 3 及求解  r5 T0 j) ^0 `9 C1 R# T

    / m! ^3 L. f3 \9 d6 J" w6 s" a# b, g# N模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量
    / ~" s# l4 O2 E+ r  l误差的标准差。 0 b5 r% ?0 u  L9 B; A/ X& E6 e
    ' Q+ ~) ~) s0 E/ _
    在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。 : q  m  T% G) G2 l$ `, m3 t

    # u& r7 N, t: A* |* u3 Y" ^" ]/ Z; o/ f% i$ H5 q2 q& v1 m+ a" N
    " f' F' N/ z3 E
    由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为:
    - _+ U6 Y1 P. W- |* y; M
    + u6 h6 L9 G: F: l8 BMODEL: 0 n1 @% u' I5 f+ i$ T, u
    TITLE 飞机定位模型3; # S- d8 C! `4 N+ `* W' C
    SETS:
    0 F% h3 f& y6 AVOR/1..3/:x0,y0,cita,sigma,alpha; ( p! [5 m  p: ]3 X" l& K0 l
    ENDSETS
    " Y- |; x  o4 ~0 f  f4 ^2 }INIT: $ Y( A8 a' s& h
    x=1000; y=900; $ b* s6 A! ~  E" e! d# ^
    ENDINIT 7 Z8 X6 V% n9 u) a
    DATA:
    % R) M/ c" a+ c& Dx0, y0, cita, sigma =
    ' ?9 s( n( q0 H5 X/ @  y746  1393 161.2   0.8
    " {& n7 E: V( u# m, \, [0 q629  375 45.1     0.6
    & \) ^' O; V" {/ G1 T$ z1571 259 309.0    1.3; 7 `2 X; X+ ^8 D9 [8 u$ A% @# k/ F
    x4 y4 d4 sigma4=155,987,864.3,2.0;
    2 Z- t+ l3 S# q  B/ {ENDDATA
    . {' s4 |9 p5 Lcalc: 6 D, c8 V1 l; ~% o
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    ! c& w! L7 j$ o& J2 tendcalc
    % w" j: c" C" Q- D, ^/ \min=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2; % ]' [# g2 R7 R; P( ?0 d3 ^) V; k
    @for(VOR: @tan(alpha)=(x-x0)/(y-y0) );
    4 z6 h( u) _0 w1 N) k1 s/ |END8 s" q- h; i2 J* L* C1 ^
    启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。
    1 [" I' ]$ [! U- [# e' J# |& u————————————————* z+ v% j6 k4 t* O
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    3 F9 u: j; X! W7 M; B原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044* b5 F7 {4 T: V4 E9 O4 N; ^
    ( B0 ]" x: W4 c3 t% b

    $ C8 k3 H, l5 P; s5 a8 o  X0 g* H) i- S* F3 H( R/ H9 {
    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-18 11:20 , Processed in 0.438553 second(s), 51 queries .

    回顶部