QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3792|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置? 6 i" {: a, Q, S! v# U  M) t

    & A& J$ d6 k0 U( B: f% S8 o4 v; P7 j

    . Q/ r5 i2 H: z: k1 n8 ?& {, L$ B8 o1 }9 t" Z7 `5 G2 X
      (1)问题分析 & h& Q" _  i2 M
    ! o9 ^3 M4 l& c
    记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算  
    : L: D# q( w' @
    9 [) V  d/ `& C% L3 ?9 U6 p0 C1 `1 A* c. `  n
      h; u+ B; Y8 f+ _& @* p' R
    (2)模型 1 及求解
    $ N9 e! v3 K8 L! a% j! e) k( t% Y2 w6 E8 J, R. |' v/ m+ C
    图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )
    9 }1 u% R! D. [+ Y
    % {. V( t! J) N" i对 DME 测量得到的距离,显然有      ( 2 )
    & t! c8 d6 r" F3 c1 d8 A; G3 `3 ^; s2 z) ~6 q5 l
    直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解
    8 G! O7 o4 A3 h9 G. R2 C% I
    , Y+ O- _3 v4 p  n; @/ r ( 3 )
    # T7 c0 \/ J2 o5 k: }式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:* D: J. x% m1 w# `- ]* Z. Q+ }

    6 J/ ]4 q6 e* A( C# S2 i' W  h/ oMODEL:
    - S9 e! s, K. {" R) oTITLE 飞机定位模型1;
    3 t% V0 L8 D% J# n! f: @SETS: * Z' z& h: \+ z/ _& R
    VOR/1..3/:x0,y0,cita,sigma; 8 J  y& Y1 i5 Z1 J: T
    ENDSETS 5 p# S2 T% `1 }& b8 ]/ t
    DATA:
    9 [2 Q! ?7 n: I1 m. z% Ix0, y0, cita, sigma =   ]( r3 J' U9 [# K
    746  1393 161.2   0.8 1 @' j: o. s& {6 e. o5 X/ E
    629  375 45.1     0.6 7 c  q' v7 I9 i- ]1 Q9 H6 y
    1571 259 309.0    1.3; 3 p. \0 Y; I2 A# S
    x4 y4 d4 sigma4=155,987,864.3,2.0; ' N* d% F& s7 @' W7 `
    ENDDATA # @% t" m2 W# E" p4 w% Z
    calc:
    4 ~/ L2 O( n' S3 a@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    + t- I3 V; J- }2 E0 Wendcalc
    * q% U1 S9 A0 r9 }min=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4))); , f+ o( T  e& P$ f) O% v
    END! S3 r  \: A! }
    上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函+ |) N, p1 A/ c1 }" e5 _+ L0 }1 X
    数值为 0.4729562,这里的解受π 的取值影响很大。
    , v5 y: N0 h; s; W; v* z# X0 z; W0 d$ e( k' i
    (3)模型 2 及求解0 k! L/ S" {$ D2 o3 A9 O& V% k
    ) J3 \7 y6 Q' p3 }7 n
    注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:
    : J6 Q. k/ r" s* {4 ]2 u: p% |, W$ Z$ K4 m
    * b& P6 \7 `3 V

    . E; V8 @1 [! f7 E  也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。
    " C$ i6 j* z! a5 R 以 min x 为例,相应的 LINGO 程序为:  + D  `& r2 T" e% `

    7 l4 p  ~" ^5 [+ C$ TMODEL: & X3 ?) K& U& E  A
    TITLE 飞机定位模型2; ) ~2 X1 ?2 c1 f9 j( w) }
    SETS: VOR/1..3/:x0,y0,cita,sigma;
    ; ~7 k; ^6 G. a7 p' y1 i: }ENDSETS
    5 o1 s% r) _: C: I0 q1 ^INIT:
    # a9 k5 y- ?2 g- k( hx=1000; y=900;
    6 {' r+ D0 a3 h: FENDINIT
    9 C  M5 u% [8 y( s/ Q2 DDATA: 1 ^' H' q+ c+ u0 p
    x0, y0, cita, sigma =
    + W+ |2 c) i; R2 h746  1393 161.2   0.8 : l# f2 A6 C0 _7 h1 E
    629  375 45.1     0.6 + j: H/ V5 s5 R; R
    1571 259 309.0    1.3; # S8 C2 }- f/ G- V
    x4 y4 d4 sigma4=155,987,864.3,2.0; ( {- x  F1 n* C& X# s2 N5 O4 M
    ENDDATA
    7 \4 ~+ @0 \; L+ D# pcalc: 5 o: Z8 @" S( P6 m
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    : C& x4 h4 b/ p9 n3 O  @* Bendcalc
    + g# m( ]( s1 \min=x;
    6 ~9 v: Y5 y' R, ?7 a8 \7 ^6 _@for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma));   [) Y( `4 {! W/ r1 \, ~
    @for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma));
    ' C; B+ t! @6 k6 q# Y" C; Ld4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ; * Q3 k; N6 ]: z; w! \+ R
    d4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ;
    ( l  V& A$ h5 y8 G5 E1 I( nEND
    ; x" k# }/ L) \+ l9 r注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 . 3 d; U+ `- m$ Q0 U! }+ n2 P
    6 Q9 y+ z6 |& w
      (4)模型 3 及求解
    , ~: G8 N' V) I* K* U8 L3 S  h4 u
    模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量0 t; a0 m8 f5 s
    误差的标准差。
      M+ F6 e6 A7 {/ c; R( ?
    4 ~$ @$ H7 @/ ~7 \7 h7 L& m在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。
    % @6 h; ?$ y3 y$ R/ j+ P3 M- p1 J7 T* s# {
    ' H! R5 X7 b6 N% x1 h9 f
    ; l- B; A" p% e2 |+ h
    由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为:
    - o$ H/ l: w3 y9 D* Y; [! c4 X( x  E$ Z7 Q- B4 V
    MODEL:   \" U" ~9 R- K/ N3 ]& A( t3 Z/ {: s) E
    TITLE 飞机定位模型3; 0 }+ o3 A1 |' B
    SETS: & r" p% i# _7 |. g4 P# z
    VOR/1..3/:x0,y0,cita,sigma,alpha;
    3 c/ t0 ]7 r, A0 t" Q  |7 Q; ~ENDSETS
    7 K9 U" I% m7 v& ^" ~+ mINIT: : J- s: q' o. p" B9 d) @
    x=1000; y=900; . X: @. n' a/ D, r, ?4 u- O1 E
    ENDINIT
    , t) [; D  O; c4 SDATA:
    ( l. e# \, _: s# ^9 px0, y0, cita, sigma =
    / b" m9 l5 B* {1 q  J$ x746  1393 161.2   0.8
    $ F( U/ U: \7 E$ L/ Z4 z- p2 Q) r629  375 45.1     0.6
    + ?9 D; {: @; `1571 259 309.0    1.3; $ D. d4 c" {6 X/ n3 _  h
    x4 y4 d4 sigma4=155,987,864.3,2.0; 6 X* @5 M2 R( k# U8 A. f
    ENDDATA
    ; n1 S  x! z# ~* Scalc: ! G, @8 w5 a) `2 L2 r; c: e9 D
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    ( j5 G# V0 Z0 x: m0 t& A% [9 z2 E! K3 Yendcalc
    " O5 J  z8 F) J+ @3 S+ S0 Jmin=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2;
    * F% ?$ l( e. h% }3 M1 c@for(VOR: @tan(alpha)=(x-x0)/(y-y0) );
    + l# R' R* W& X4 Y4 C7 L7 qEND
    3 I: V; [! z1 U6 W 启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。 * b# G& f+ t+ {- E
    ————————————————4 a; S' h, G7 J9 c
    版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    & N/ X' l/ ]: z4 S( n' r' Q% z原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044
    % I. l1 C) x" p. ]9 G! [+ B4 B
    , A% ]+ L& t; E% y' Y7 `1 I; y$ R& F  ^2 K
    8 B6 x+ R8 M. X! v
    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-12 03:04 , Processed in 0.282023 second(s), 51 queries .

    回顶部