QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3848|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置?
    * L# @5 i, D+ ^4 M- ]6 r0 R% w
    4 `/ S. p4 O, W( e2 l# V2 F( y; s! p& C3 J# R+ ]) z+ L% B: X7 T

    2 _& m4 C+ e; x' e4 A$ ~+ e- b  L# K; |0 P4 @* c
      (1)问题分析 ' }, e8 H* b% V) N- J$ }2 c

    ' b) {' x2 L& @ 记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算  / l7 L( D) r8 z: C; `% c

    ( d% _1 ^: D3 r" k, P+ C# |
    ; J! N0 c2 O# f1 u/ X5 h8 q' L: H; L
    % z. P- _# V# Q9 h; B6 W(2)模型 1 及求解 9 C9 t0 s- \& J2 b
    ! s8 R4 D, R0 D6 }, e) o5 M, @
    图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )
    : h) @+ C1 B, ^- n. n7 G! b5 z( J9 F& C3 ]
    对 DME 测量得到的距离,显然有      ( 2 )
    # S. {' Y1 V' _5 l( M) n: ?" m
    ( ^' \3 O! R* N0 m直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解 * K8 Y8 t) B& Z$ I
    : P0 v$ H5 W/ V8 G0 n
    ( 3 )6 u7 X3 ]. R* d/ u
    式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:
    : f* Q# r. |8 t7 a
    " x0 Y; R* _9 c5 O( r! @MODEL: : C3 `( l, M3 t9 z0 o$ |
    TITLE 飞机定位模型1; 3 }: b: l" ]: l! \% y  c+ I
    SETS:
    ! \) k6 ?. T. U7 C5 Z+ O7 l+ {VOR/1..3/:x0,y0,cita,sigma;
    ; f+ P. m' `( A/ \. D: V2 rENDSETS , V" [' [* F8 m' Z( p
    DATA: 0 `, P8 H+ n' S9 j) J
    x0, y0, cita, sigma = 8 v# Y) F3 ^$ J1 }
    746  1393 161.2   0.8
    ! Q& o! Z" V0 B$ ~+ U5 j' E629  375 45.1     0.6 $ f; h' a7 |, d- t  F6 }6 Q/ m8 h
    1571 259 309.0    1.3;
    2 L. V! P5 E/ A# r. g: Fx4 y4 d4 sigma4=155,987,864.3,2.0; 0 h/ m5 T  H; W: H9 B
    ENDDATA
    / L* W/ M  T- d  {1 Ucalc: / H8 F1 S) E; N0 e6 W4 d9 k
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);   c! h: y2 I6 X' l
    endcalc
    / _1 Z" M6 S( @$ hmin=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4)));
    * p* ]$ h; O; ]4 e4 x& Q7 ZEND
    % _! T$ M* _3 g$ w上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函1 k* }) U8 l& ~
    数值为 0.4729562,这里的解受π 的取值影响很大。
    . \; a7 S2 {% C( N
    1 R9 S/ c8 p9 ^4 a, p" d1 ^2 o) F(3)模型 2 及求解
    6 @- O0 \. r6 f+ l5 t4 W3 Y0 ^% X; g. f" ]; y
    注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:  G/ f6 R4 o5 c6 S9 G2 b2 `

    1 L4 P$ P$ B; m$ m
    4 F! Y( ~3 x8 q1 t: c2 W: k: h! B: O1 ?  v8 Z
      也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。
    9 q  i, @0 C1 G( ~6 E2 g8 G( v 以 min x 为例,相应的 LINGO 程序为:  : e% X$ `' g4 P" t& @8 B
    1 t- ^; s* z! o/ e
    MODEL:
    2 K- w- `" [% o/ J- bTITLE 飞机定位模型2;
    ( _! w7 ~* v) a4 [2 T# qSETS: VOR/1..3/:x0,y0,cita,sigma; . T7 E6 m. E* U1 y9 a
    ENDSETS
    * E% R1 V0 k( y) GINIT: ; f/ h$ }7 R# ^4 D( w6 A, x7 k
    x=1000; y=900;
    # N) \; n; l" i+ W# G- X# WENDINIT 3 p- ^4 T# q' [
    DATA: 6 Q8 k1 \$ |" J: ?1 j
    x0, y0, cita, sigma = # e7 P% w2 R4 j4 M8 D
    746  1393 161.2   0.8
    ' d* e9 T$ ^3 N( H629  375 45.1     0.6   T& v* }. y! I( B/ r, ]& k
    1571 259 309.0    1.3; " c2 b7 l& s0 u- n
    x4 y4 d4 sigma4=155,987,864.3,2.0; ' y& G* P+ N# t/ f! F/ D
    ENDDATA - F* W3 r% H0 r8 O( D
    calc:
      Z  g: m" r2 P' ?@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    1 g7 `9 y1 L/ e5 R1 j  D) `endcalc 7 f+ @$ D* r; U1 Z9 w- R
    min=x;
    5 S% d( t$ ?. a& w# S% ^, D@for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma));
    & Z* y+ l: t! c) `@for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma));
    ! x/ ~$ {) N2 Nd4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ;
    0 ]* O* ?) E" ^. I1 qd4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ;
    & Z5 Q' N" C$ `8 kEND
    6 Q( F2 X! h* s& `3 B0 e* W# ]7 s4 m注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 . : r' w! D+ o+ ~# j4 w
    5 S1 `2 t" Z( d1 M) c% f
      (4)模型 3 及求解- ^' Z& M" c- v) ~& z5 K9 Z9 o4 D

    * L  O  _" p& `8 w6 ?模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量
    4 F* z, X  ^" v  S* r误差的标准差。 4 S" g) Y! O5 a0 Q7 s; W+ q

    " z: d& D0 w0 z: G在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。 - V% {+ \& u2 P6 M; G% n
    # v1 i/ j4 \# ^3 g/ M

    ! O; O  B; i( f# q% r
    * ~, l$ `7 {$ L+ v) Z6 k  n" k2 _ 由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为: 7 v. C* J. v6 c1 G* z; a

    - N9 x- A. n/ zMODEL:
    ( L' ]) K1 U) P7 F, r1 _; y0 U9 g0 ~& [TITLE 飞机定位模型3; ( c6 J, y( n# E7 I3 S8 j9 F2 H
    SETS:
    & S) Q2 N+ G2 J' v& }3 _/ eVOR/1..3/:x0,y0,cita,sigma,alpha; # F3 }: c0 Y- E$ r
    ENDSETS & X; P0 s2 O7 n2 E( ]. V0 J6 w
    INIT:
      U" V/ E) a& u+ o" ?6 ^x=1000; y=900;
      z2 g7 S/ w. j3 B9 Y2 t7 l2 sENDINIT
    % E# i# f5 w+ RDATA:
    0 g9 e# M8 |) Q+ ?x0, y0, cita, sigma = 9 k8 e: f* b' @1 q! n" Q) V" O
    746  1393 161.2   0.8 5 D9 P5 n) Z" I. V
    629  375 45.1     0.6 - P/ l8 B" M# u! S" x8 o2 d5 Z# g, ^1 O
    1571 259 309.0    1.3; ' S4 T/ _) l; ~  r2 N1 W3 |/ l
    x4 y4 d4 sigma4=155,987,864.3,2.0;
    3 ]9 l9 {4 ]' u$ k7 {) ZENDDATA
    * z7 \' p( M2 T2 {* ]calc:
    , Z+ g" h) D; Q* n' I' n@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); 6 V% A& w" @5 |) A, W! K. q3 d
    endcalc 9 R' x! g; m' P2 p  k
    min=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2; 0 l8 x5 J8 X! ~+ t+ a; |/ S
    @for(VOR: @tan(alpha)=(x-x0)/(y-y0) );
      Q& L% Y8 P5 i) u. QEND
    ) [6 {2 c# t( W. i( ^" m 启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。
    * Q* X" V7 G! h/ R0 _6 o8 q" w————————————————
    " U: S, h$ Q% l版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    3 z, m; B+ D) F: n5 [原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044  F- H; Y# u; _- t3 y  t% h
    7 Y) j8 c7 l2 `5 w0 V% L
    ; W: t0 i) r: i6 U2 |8 ^; v0 ^

    2 j" {  R, b* @
    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-16 11:11 , Processed in 0.562444 second(s), 51 queries .

    回顶部