QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3716|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置? ) b$ H" D& L; h" y8 f2 c2 A

    % a+ C; |' c8 E$ E& K; J+ T) [
    7 y7 z; f- |. G( S- v6 f* \5 N9 g( P

    3 k% `+ h6 @- C/ c  (1)问题分析 # w8 K" y8 |- C: ?
    + e9 E' Y; G, o5 V6 n, H
    记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算  
    " ]$ b% q1 W3 X; y! N8 n% [
    $ F) D6 e5 i2 {! }5 S$ A- `4 q! S9 k3 F

    / V* J% a& E: ]8 a8 k; Q(2)模型 1 及求解 ' @: Z0 v3 m2 x; d7 b$ j% g5 `
    / [6 e" R' l& ?. ?# j3 O8 b
    图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )" Z9 s7 f/ i6 x# ?9 P* ~

    8 D) f- X( W3 d! q# ~5 u$ {对 DME 测量得到的距离,显然有      ( 2 )
    ; g5 `3 _& @) @8 M
    ; F# e  V- F  t直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解 ' C# t# B2 }; x: x: O( ^3 [

    5 \; r& G  `# g* f5 V ( 3 )
    ; q. X' |) D8 \式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:4 z2 k( s0 c) O9 X

    9 k4 J/ v. D* y$ ]- i6 o" m1 l" D$ t5 TMODEL:
    + S& m) G; R( {$ [' x8 ]& DTITLE 飞机定位模型1; : y9 \1 ~; |2 S# p( n
    SETS:
    + b0 {1 c: b* J9 k1 ~2 v* q9 eVOR/1..3/:x0,y0,cita,sigma; 0 ?( @* l( K- e0 u1 k3 l
    ENDSETS
    ) h3 o' K% ~9 f# g6 ^- GDATA: & H9 M' j1 C2 u) K+ R# _: Y
    x0, y0, cita, sigma =
    ! j) m+ V( u9 P* c) S746  1393 161.2   0.8
    / I% k! m. g/ H3 L629  375 45.1     0.6 ) r7 I9 L# C; F3 L2 `
    1571 259 309.0    1.3;   I- z# M: A' ~8 j) V
    x4 y4 d4 sigma4=155,987,864.3,2.0;
      c( `. [$ h' IENDDATA
    $ s/ _- z2 v# m7 N' Z; qcalc:
    7 r! U6 U- W5 i8 i@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    4 U+ U- A) }% H# V' ]endcalc
    / m+ \4 G5 p. X& _# ?/ lmin=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4)));
      V) R' _2 n/ ^8 _END
    - _$ o8 X; Z* o. F上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函
    . v$ ]' j: U4 Z! ~# ^" B8 U数值为 0.4729562,这里的解受π 的取值影响很大。 * k/ ~$ p. ^) U) G! R9 u: @
    6 j4 K+ p3 P. g4 j: N% W
    (3)模型 2 及求解+ _6 x. _& G, c( F9 v
    # V* k, ~, \0 K. _& R/ f
    注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:2 u1 s1 U8 P8 s7 j
    6 i2 u+ G0 Y' B$ ]1 o
    & c1 m. g2 u! V" m7 j$ {; ]9 w

    . J0 k% l+ o4 Z" Q, B3 D  也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。 ! _- ^( b' N+ q$ {! E" q) N
    以 min x 为例,相应的 LINGO 程序为:  . V$ g( v" w! ^
    * J$ Y& F8 D+ B- D- h
    MODEL:
    ( K* Z  \- `5 b! [TITLE 飞机定位模型2; ( a0 p+ U) k) Y. t/ s
    SETS: VOR/1..3/:x0,y0,cita,sigma; % a% q- V/ P& D# O1 o& L+ J) N
    ENDSETS
    8 r8 l  j, B$ K, M6 ^6 YINIT: ; D/ p- f: T4 E7 S1 X4 e" B3 q
    x=1000; y=900; 6 D) ]+ I6 b- \: v& B) u" O
    ENDINIT
    : i! X2 m& e* M( Y9 TDATA: / @! V3 b% T1 u- R- L* [. e) I
    x0, y0, cita, sigma = ; a- H! t- E, S" R; u1 j3 {* g& A
    746  1393 161.2   0.8
    5 |: P9 i7 m; R7 J" j2 Q+ O8 G629  375 45.1     0.6
    4 |/ h* y5 n8 X# q% _1571 259 309.0    1.3;
    & ]4 ~, k1 }0 K) G7 P- J) J! Fx4 y4 d4 sigma4=155,987,864.3,2.0;
    % D8 p1 `# P) N5 M9 _ENDDATA 9 k1 Z& r1 E0 d6 `' \8 m* p
    calc:
    % N) U# F8 U9 h% t8 @# E@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    5 [! j4 Y, v3 |4 l1 k7 \% zendcalc 9 Y# ^8 [! @( ]$ X. }+ X
    min=x; ! }0 P# p5 r# q- t8 R" t/ h) Y
    @for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma));
    ) i8 c0 h1 _! a& j! l@for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma)); 3 n0 Q7 \( ~  E
    d4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ; # o% D( H; t" ?: L9 W9 k) h2 t
    d4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ;
    ) v) R6 v! v3 C, n) X5 \% R! UEND ! S" K/ j9 q. y0 m6 k
    注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 .
    1 @$ {3 u! @8 n- s/ ]8 R- V* {) e6 D) M0 ^. M7 u4 f# H1 n; u
      (4)模型 3 及求解. p6 V+ b! M  j5 x5 H  i) ?
    ) @" E, \& H) i1 g, `/ y
    模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量% u" q  W- p. Y- [5 ?7 t) J" T
    误差的标准差。 1 N: x% a- h, \+ \: _/ u* Y
    : x; t# s) |" ^+ c0 W, f% j
    在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。
    7 v& E+ h% P3 \/ F% T. g, |/ {5 n$ s; C, Z2 g. u

    , L. M# s5 Q* C! C: n2 g3 _( i7 ~) |: D/ p3 a
    由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为:
    % f1 j# h3 Q8 C3 P7 {* h& F% v5 H. y1 ~  z# n' y/ x7 m( ?
    MODEL:
    + m: N; u7 v/ v! B; a: [3 rTITLE 飞机定位模型3;
    5 z8 n9 K: y' R" K7 v: L, V: kSETS: 2 y7 |5 |' a2 {& H5 k: b6 o
    VOR/1..3/:x0,y0,cita,sigma,alpha; + z! I2 T/ ]. L8 E( |+ r
    ENDSETS
    % ^8 i: L, `; n  b! Z' GINIT:
    / a% l  d! p4 Q% o* P* Gx=1000; y=900; 8 h: `9 u" [7 Y/ {6 }! G
    ENDINIT 7 {3 W7 s/ t) a6 u" P! i* S
    DATA:
    7 T, o# M8 z6 t7 `+ W$ [( ~x0, y0, cita, sigma =
    ' M% W4 H1 g$ z746  1393 161.2   0.8 : I( D% }, X. g  z2 h: l8 y; H9 @! t1 C
    629  375 45.1     0.6
    . H# B6 e# [; D5 N1571 259 309.0    1.3; 2 H5 N/ V/ ?8 \* ~
    x4 y4 d4 sigma4=155,987,864.3,2.0; 2 }" l( r2 Q* ^, C6 B
    ENDDATA 7 I( p" y7 @' q+ L$ N
    calc:
    , z7 \( E$ d# c4 P@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
      t' w! I9 k. ]& `8 b) C" Iendcalc 1 r% l. v7 T" _! d# ~
    min=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2; 7 e+ s. T( Q$ G0 [7 v$ b! p* N9 U4 V
    @for(VOR: @tan(alpha)=(x-x0)/(y-y0) );
    2 Z$ ?3 K# d) f- n4 Q- p  l- _END
    ) ]1 {9 e% I2 c/ a: e$ a7 R 启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。 * |' v: ^  h& s) L% G# O: Y
    ————————————————
    + n, k/ v0 K. h0 m* G版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。  _9 z8 y. @" K0 k# S; u% f; A
    原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044
    ) o3 K, }0 \( d- J- Z/ l7 I; c+ F6 N( w) q" m2 V! m7 ~/ F) K

    , c! W& M7 V+ y( A$ s  t
    4 I) C  P6 {$ W* [' u$ [+ g
    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, 2025-12-16 12:29 , Processed in 0.371780 second(s), 51 queries .

    回顶部