QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3837|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置?
      D! W  n! b! N8 l5 V) T* t9 I" g1 a, }+ O- Z4 j( B/ H
    1 K% o& T1 O8 Y% R* R9 x
    ; T6 a5 b6 O+ r4 s9 f

    9 b+ |' a7 r) _" `  y/ w9 b* ]  (1)问题分析 1 Z$ z  f! c3 _" N8 x- H
      k( O0 e: A( I7 R, s
    记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算  
    2 U, W1 _" n3 n9 ~+ y) H3 }. j
    % H: A2 C' B9 k& F1 J. Y
    " S/ {+ H, }; C( T, J$ ~8 Z9 W) r* E  i
    (2)模型 1 及求解
    - A3 f" E' g2 V! k% q' e( V
    - B. Y/ d" l5 w7 F# Z6 k( d 图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )# }4 L9 p! L% n  k( N6 a
    ; W0 o, B$ e& x% t
    对 DME 测量得到的距离,显然有      ( 2 )/ c0 X2 {' p/ q  y

    7 x  D8 J' {1 j. v3 U( B直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解 6 w) P) F0 I: |# J; X
    6 `$ O- u: n7 h( [2 ~5 V
    ( 3 )
    3 y4 ?0 p( f& @$ M! D& W式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:- q  j) ?5 m' X# v7 ]# n. U
    0 ]* u7 J6 G1 E# t7 u
    MODEL: , A/ d1 x9 i' ]3 ]3 q) e0 E" e: k( j
    TITLE 飞机定位模型1;
    * @9 k& u. }; E7 u7 }: u4 kSETS: 4 P- }7 b1 }' o) c9 u7 S
    VOR/1..3/:x0,y0,cita,sigma; * n# w/ {5 P/ i
    ENDSETS
    2 T0 r8 P6 ]# N! MDATA:
    / ?. y+ d1 y% I/ s. G/ Z9 e2 v* fx0, y0, cita, sigma = 1 Z+ C$ x& N# A& Q7 f# n& a
    746  1393 161.2   0.8 9 @& N5 G! l0 t, S
    629  375 45.1     0.6 5 ]9 U! y6 v5 A+ S' `4 @  `
    1571 259 309.0    1.3; ( T( Q( I5 T" u: d
    x4 y4 d4 sigma4=155,987,864.3,2.0; & _6 y( @' G: }
    ENDDATA 8 {  W* U  y# R* D
    calc:
    7 V% [, _5 o/ }' o6 H  w  ~; f( a@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); " {; H: C" w" F# E" i" Q3 U6 \
    endcalc 1 D" p, [: m9 \! s/ [
    min=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4))); + ], x0 W( T  T0 l; F0 s
    END" A- z5 q( |! z5 x0 K# `  ]) n, G9 B
    上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函1 N: L6 W& P% j' o  f8 O5 S
    数值为 0.4729562,这里的解受π 的取值影响很大。
    ) \2 Z  ?/ J1 C" y+ e9 o4 T4 B7 S) w1 L: v  f5 J
    (3)模型 2 及求解! v6 J- s; x. T3 y( i
    3 f5 ?- T0 `- @8 m; _% @
    注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:
    0 K, I3 I- t; S6 c$ I
    - `; o# v4 F! i, P) Z/ P
    9 j6 x# S# C* J. S7 G$ W: j5 c' q+ M
    & v( j, `3 I& I) j5 \, k  也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。
    & \+ c$ b, k1 z3 @$ x2 w 以 min x 为例,相应的 LINGO 程序为:  ! K/ V* y4 M) j5 D: n" \$ ?

    " k; K- z" j/ k5 ]3 xMODEL: 5 q7 Q8 v/ _5 A1 U
    TITLE 飞机定位模型2; 4 V+ I8 v0 K5 R
    SETS: VOR/1..3/:x0,y0,cita,sigma; ! I1 ?, A- P; s8 t
    ENDSETS
    0 V2 m2 [" N$ M: r) ?INIT:
    7 U& s* ?( V5 r3 Lx=1000; y=900; ) [, C! w3 A3 k) f, c$ q
    ENDINIT
    ; a0 E' l( Y/ o# @# rDATA: " Q+ V$ Z8 i: F3 U# N. R
    x0, y0, cita, sigma = ' a6 V- k8 g7 |" V* K7 K
    746  1393 161.2   0.8 , Q* }0 l" m3 O9 P5 {3 M3 m" a
    629  375 45.1     0.6
    7 u% _4 @# W5 @# h) s1571 259 309.0    1.3;
    3 w/ f% b$ M/ O0 v0 ^6 ex4 y4 d4 sigma4=155,987,864.3,2.0;
    & V; p+ z& v1 y4 [$ ~+ LENDDATA
    * k  O) p# U$ K# M9 |calc: 7 L, a" @1 ~' V8 Q/ w& K
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    . Y! p$ \' Q  B- }endcalc
    9 w& E! O# d' C6 ?7 j& y0 H5 Vmin=x;
    / d+ d3 [! Y8 Q& E1 q. D9 k@for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma));   ]5 C5 d3 u9 X& f
    @for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma));
    & c% B0 P1 L2 Hd4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ; ( ]4 b( R8 x- P
    d4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ; , v2 D- V6 Y9 r
    END
    + d! Z& v( S' S+ W5 j9 ?注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 .
    ( H( V8 F/ \3 d- ]! r+ A) g" D" _7 O6 w+ R  J
      (4)模型 3 及求解
    4 _5 f  {& Y( H2 o- Q& m1 j3 j1 S' G8 }0 ?; ]
    模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量' Y) |/ }% _) h1 O& ~
    误差的标准差。
    0 U4 m) H6 V0 c) y: T: e- {+ S" ~0 f6 {2 u/ s  c7 j3 A/ T
    在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。 2 n. B. [8 x( y1 R' g2 t

    & V7 j2 m2 l+ e' i8 V* ~# ^& F
    $ `8 C9 d" p' g% @# x- Q) M( o4 _+ T+ U  [; ^8 }
    由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为:
    ! ~) Q  V5 Q+ l- h- e1 K
    . z# I* s( F# L2 l" tMODEL:
    ! H/ x4 i# W7 gTITLE 飞机定位模型3;
    3 I( Y' J( k/ z+ V% HSETS: & `, U. Y: E/ H0 `; `1 J: {
    VOR/1..3/:x0,y0,cita,sigma,alpha;
    1 [3 a: o; y0 w8 {# y+ \  h4 VENDSETS
    ' E4 t( z: ^! [, m8 `1 B6 BINIT:
    , `) u* N4 d8 \, l* v+ @x=1000; y=900; 2 T  z& x9 n4 M  Z' V2 N& c
    ENDINIT
    2 [2 J/ w4 J, t$ A  v/ X- kDATA:
    & @' n/ I. H! Q4 y6 s& zx0, y0, cita, sigma = + m; E* {; r) Q0 {' B0 p2 e* p8 k
    746  1393 161.2   0.8
      _8 @! T( S1 a6 y/ H* o5 [4 s629  375 45.1     0.6
    2 b) o6 x5 W! C$ L3 r1571 259 309.0    1.3; # ~: x. ~. d7 m& d
    x4 y4 d4 sigma4=155,987,864.3,2.0;
    3 l  S/ n+ d1 b% o( x9 \& {9 k8 b/ kENDDATA
    ! U! a! a5 N3 W' r% C9 X1 Pcalc: % \+ U, Q' [1 S: A0 r6 j, q8 x. l2 t% z
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); # T4 j. X" Q" p2 [
    endcalc
    5 q+ F0 u; g" U9 ]) p$ d: K4 T" mmin=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2; + ?3 v( W  t7 w* `9 p/ e
    @for(VOR: @tan(alpha)=(x-x0)/(y-y0) ); 6 j4 P& u/ H+ i. m- L
    END
    & R; O. M& V+ ]- B" M 启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。
    % [5 U/ n  E6 b————————————————( I  D+ `/ Q9 `! p( R* d1 m5 d
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    # u& d4 t* `3 V# d原文链接:https://blog.csdn.net/qq_29831163/java/article/details/893890448 X/ W; d4 E2 Z& @$ h+ _! s
    - ?& c/ H* u& Z" D: [$ [7 @

    * H( I  r+ Z! `- h7 a4 L
    $ L$ Y* ], C& 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-6-12 09:23 , Processed in 0.424309 second(s), 55 queries .

    回顶部