QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3794|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置? . a2 l7 i: U) y# ?2 M" V
    ) f# m/ W' R& c% N% y

    2 A; s& n7 |' Z. {: J+ M: u. n  g$ X# ^
    - C+ T) p6 b$ k- w
    9 Q3 r% G' K" r0 k  a9 u  (1)问题分析 3 l( A# j# D) X. {

    . g8 Q# ?% K5 ~% e8 | 记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算  3 G4 g' \; J0 B7 q

    ' J3 w2 F) t2 J: t
    4 G8 R+ K7 w. `# [7 }4 J( k* w6 B( @; w
    (2)模型 1 及求解 % A. l0 X' u# v: l) s  W* f& G" H

    & `$ X! i+ z* u# ^1 U+ N& s 图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )
    ; P& d0 [* t- C/ [! R
    ( i. M2 Q+ u% ]对 DME 测量得到的距离,显然有      ( 2 ), C: @# V4 j; t7 D& [

    ( [/ i- |* `2 h4 V/ P9 v" U; p直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解 ' w: f1 H2 @& m& {  k

    3 Q( s, f9 p4 k0 s ( 3 ); h" ?- {; G9 L+ p! A2 Z
    式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:4 B; k/ k' |7 {8 ]

    0 m2 A4 D, C' q7 l; P4 p; N  G1 EMODEL: ' V  o/ u% E3 m& R4 Q
    TITLE 飞机定位模型1; 5 ], G$ `" N2 Z; F$ z
    SETS:
    * f( W) R, E, E7 ?! jVOR/1..3/:x0,y0,cita,sigma;
    1 {" ]6 A$ b8 z  y8 U5 gENDSETS
    3 ~+ l) e/ d' s/ RDATA: # l, j" R: p9 O' s4 j: \7 j
    x0, y0, cita, sigma =
    , ?3 L  y3 v  S/ Y& h746  1393 161.2   0.8
    8 ]" F4 H2 i, G0 ~" {629  375 45.1     0.6
    # y4 h3 r" u1 c6 L6 d$ p) C2 i1571 259 309.0    1.3; , `) v9 ]7 U3 Z: t: U9 B* `
    x4 y4 d4 sigma4=155,987,864.3,2.0;
      H4 T7 s! M; s) Q1 sENDDATA
    ! p% J  I- ^/ N; D, g( U2 I8 e' Ocalc: $ i! F8 G- Q# g
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);   j0 W2 r) i3 ^. w3 W  R/ t
    endcalc + q& g1 v) n& ?
    min=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4))); * t- w, Z# j0 l  u+ h
    END
    $ ~3 Y8 p, v/ C' L, S' t上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函0 g$ y  p+ l7 m9 {1 p: m
    数值为 0.4729562,这里的解受π 的取值影响很大。 1 Z2 N* k1 M; B

    0 ?/ b; q4 Y, H! X, U(3)模型 2 及求解
    % n/ w. k& W+ ]# e- A5 W6 e" d8 p( [6 R$ X. d3 J" G- {* F
    注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:
    8 E& c! o& B) }8 _( n5 l# w5 z4 b' F9 F& `& [4 a) ^

    / m. y9 a2 K  j7 V7 {5 z$ F! W
    0 X! Z0 m# U6 z7 ~1 p- y2 J; \7 T  也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。 7 u. a7 Z0 i( l0 E3 s- R
    以 min x 为例,相应的 LINGO 程序为:  
    * o; W2 H! R) Q: E; h6 L3 c' @# x1 u, Y3 L
    MODEL:
    ' k3 Y( {# q9 g- lTITLE 飞机定位模型2;
    . I7 w* C! }' ]$ S: rSETS: VOR/1..3/:x0,y0,cita,sigma;
    7 T) E5 H% v6 ~) a; q* A  [ENDSETS
    + ?3 U' U$ q1 a% aINIT:
    2 W# \! k& ~: c0 C' Y( A8 tx=1000; y=900;
    # B, m; w$ K* S& a; {' O. hENDINIT " S1 d5 z, ]; m3 e' J, n2 F
    DATA: 9 W3 A# d/ X1 [8 j  O
    x0, y0, cita, sigma =
    ! Q1 R- F7 C3 w6 X  d746  1393 161.2   0.8 ' H" L' J% n2 J
    629  375 45.1     0.6 : }! f* b: Q# O& G( ]  k( _
    1571 259 309.0    1.3; + n, b5 s- K1 \1 V
    x4 y4 d4 sigma4=155,987,864.3,2.0; 2 o5 R7 b& [. V) u4 _
    ENDDATA
    ) M( F% A+ n! C* J- C1 bcalc: # a3 P4 j" y7 W
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    / U1 y: k/ q/ I" K: Z2 iendcalc 4 r- c: r7 k7 `7 N+ U( c/ g9 I
    min=x;
    # r8 g* v$ w7 J7 ^0 o@for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma)); & i5 i( [5 u2 n7 e* r( _
    @for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma));
    ) K" D& x6 b- G! `8 k: \. o$ _' Ed4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ; 5 n& M+ J( V7 e" f7 {
    d4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ;
    9 ]* _4 }2 Q& E7 R7 S3 ~6 T0 Z/ W4 QEND
    ; x6 R; v  k$ m4 R注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 .
    + Y- x( E! S1 L5 C/ s* L+ j0 [; a$ B# T+ ~
      (4)模型 3 及求解. |* Q1 j+ m: u! m6 E
    7 \# T. x, e& U+ U. D
    模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量
    : Y" k8 j! G, E9 X误差的标准差。
    7 Y) p" ~* Z8 O! \4 D+ o
    3 E3 ?5 B5 n8 b在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。 7 e( q/ ?: _# G- J7 U% D: Y5 D

    : Q, G. G! Z8 A; m' c/ H7 ]! d7 z; D! @0 A! ?7 s+ F+ s
    # H/ a2 i4 L. K8 V: N4 o, a( o6 w
    由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为:
    9 m% a2 x2 u# u- m. ~
    2 R' \& M( O, p9 q1 [4 PMODEL: ( u+ D% `  l3 b0 B' D
    TITLE 飞机定位模型3;
    - h/ U% F: q4 J4 r2 b9 X) {' ^SETS:
    ' S* h7 L' ^  ^3 cVOR/1..3/:x0,y0,cita,sigma,alpha;
    ; c  }! Z6 z" b$ ]# PENDSETS : B) \$ a9 ?) G* m2 d+ J# i
    INIT:
    ! r/ d1 ]( H! S; g, tx=1000; y=900; 6 g) b) N6 Z+ s+ E1 y$ N
    ENDINIT
    ' {% c( l# [( C) m& X; ^0 m. UDATA:
      ~, l0 Q( o6 l" F5 Xx0, y0, cita, sigma =
    ( x" ^; O; ~/ W9 ?# ]. S; e746  1393 161.2   0.8
    ( O* q1 P7 _4 ~* U629  375 45.1     0.6
    6 ^1 W  B# h+ z; I1571 259 309.0    1.3;
    8 ]5 a( G  k4 h1 G0 Ax4 y4 d4 sigma4=155,987,864.3,2.0;
    % W$ |  l8 A$ A, uENDDATA % e  R1 I; X0 H- @6 y) X9 k
    calc: % @* j* T3 |5 Z. }
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    # \9 N1 ^3 V+ Y1 L% d7 pendcalc
    ' q  V/ ]' e) qmin=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2;
    & D5 ?1 S) h# w7 S" R" O, f; j9 O@for(VOR: @tan(alpha)=(x-x0)/(y-y0) ); 9 Q0 C) l) t+ s9 n9 h+ x
    END9 P  r, q3 b& }! f( ]$ K0 F" L
    启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。 6 m0 q+ `& o' M) J9 `) e: Q- ~
    ————————————————  l6 }4 u3 C3 v, s; M. K
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。5 {' s' R/ E, ]1 P. L* L4 C0 J) h
    原文链接:https://blog.csdn.net/qq_29831163/java/article/details/893890440 `# `! P# S3 I. u7 @! l; o7 r( [

    9 F: {# [) E" c. ~7 a9 C0 _, @0 w3 {9 R

    3 W* ^2 J( W9 {9 K9 E4 q4 X0 s+ H
    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 16:47 , Processed in 0.418829 second(s), 51 queries .

    回顶部