QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3730|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置?
    0 W. E/ t" g$ U+ }2 m  [: Z' u" a( k5 ~
    ! V( Y9 p% R' w8 O) Q

    * }3 M* x" a; |" B) v9 t3 D1 k' w4 n- g5 n$ x. b  M
      (1)问题分析 4 G7 x/ `2 J, W; S

    ( _* o) j. ?3 L& i/ L5 K. v 记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算    c$ a/ H7 q) V. C( i
    ' K+ E. q! u% N3 ]2 e! V

    / }4 a! M7 B" G% I
    9 w6 H3 b$ C3 D(2)模型 1 及求解 $ m. n& q; }1 o4 p/ p- h

    4 E7 T: m+ K8 d" g2 \ 图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )
    4 `, E3 w% C7 l7 Q7 e
    5 b5 |2 u3 ^" H- i对 DME 测量得到的距离,显然有      ( 2 )5 P. ?* ]3 e0 T0 s

    ) Z* N6 i% k* v! m% |, h! C直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解
    + S7 k4 U2 W' n" ^- V. C, Z
    8 K6 L2 k, u9 X% [9 e; m" E  V; n6 K ( 3 )7 ]) v' I; {$ R( ?7 v) m6 J
    式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:
    * C$ ~4 ~; w/ z
    . X' K& K* ~8 `! X5 SMODEL:
      m5 ?$ b( B8 d  m* O" P# w& x- LTITLE 飞机定位模型1;
    / M8 j, i3 _, S" h  b" e6 }8 {$ aSETS: . @3 ~! F6 a) K9 W9 S! @( F
    VOR/1..3/:x0,y0,cita,sigma;
    , J, z' _& }! L, F6 q- W9 h# w- |ENDSETS
    ' h: z% g2 V. j. R8 n+ VDATA: 4 r0 D: n* {" `9 ~
    x0, y0, cita, sigma =
    / g) q2 o6 A7 Q) {746  1393 161.2   0.8
    % N' R" |3 G8 c# D629  375 45.1     0.6
    ) Q  F& H, U4 B& O3 C/ `, ?1571 259 309.0    1.3;
    6 X+ c, U8 m. I  {( h+ u) Q+ ]x4 y4 d4 sigma4=155,987,864.3,2.0;
    ; k0 Q  N+ S' s9 N( G1 |6 nENDDATA 5 P1 o7 ]- a! B% H/ x
    calc: * k/ }: a# d  i6 ?9 _2 v5 n
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); % j, D' ]2 B! T1 U6 Y0 J
    endcalc - s4 i! y6 V3 z6 v, i
    min=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4)));
    , H( d+ Y* ^1 uEND
    ) A) H, L: ?9 U+ o+ c/ r! u上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函
    ; Y/ Z+ S! O8 \$ c! r0 [4 t/ s数值为 0.4729562,这里的解受π 的取值影响很大。 , k4 y/ j0 s' M+ {2 v! t- E
    0 r7 y9 U) l: G, \
    (3)模型 2 及求解; a) g. m+ }6 l4 e9 D4 Z) s
    $ E* a- D! ^& N- l" m  o) E4 t
    注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:
    ) Z5 O$ o' u  {: w7 j9 k. \- k! W$ m9 u* r; n( S& Q

    1 v3 g1 v2 D2 Q# x
    $ A- ?5 \3 ~4 n9 M  也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。
    ) {: l5 m( C9 C# a$ ` 以 min x 为例,相应的 LINGO 程序为:  
    - I& e. ]) L  P+ @' p
    8 ?3 K& Q& o6 T+ SMODEL:
    ; M0 W; Y5 c& C9 o/ I3 uTITLE 飞机定位模型2; 6 q% D5 {; w% J
    SETS: VOR/1..3/:x0,y0,cita,sigma; ( k  b& t/ T& A4 z6 ?, F
    ENDSETS # N$ L. N2 h* r4 s3 m
    INIT: 4 v: S* T6 H" I
    x=1000; y=900;
    & l4 ^% J& U$ [( ~7 S! u. @ENDINIT
    : K/ J1 X; q' l' M8 PDATA:
    : i4 W  w' r) M# e; n! J3 X: @x0, y0, cita, sigma =
    . y: I1 k- x/ ^# M  d8 u746  1393 161.2   0.8 7 @( }. z/ F' ^9 e& c
    629  375 45.1     0.6
    & c# M6 E% H/ g- r+ C0 d1571 259 309.0    1.3;
    7 L7 m0 l  ]( Ex4 y4 d4 sigma4=155,987,864.3,2.0;
    * G2 Q: i5 o" q8 KENDDATA
    & P2 ?6 T9 Z, {6 k- Dcalc: : y4 f% [4 L$ l$ L) M# z; j
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); / J* f: Z4 P, g3 m' j6 U% D) P, G8 M4 O
    endcalc 3 U9 s7 q" U5 e
    min=x; % V' X& [% P/ @' I8 w; b
    @for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma)); & f/ M; g( n4 M! f; z2 k2 I9 \
    @for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma));
    8 U" f( ?& D' c( \" Ud4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ; 2 C- k+ t6 ?7 E4 m# S1 P
    d4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ;
    6 A! ^, S; x0 [$ C. R& F& ~END
    4 R2 g$ C7 B  k. U& A注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 .
    5 A4 D9 d; `: a; @* w% |9 [2 k3 D" @- C" G2 D
      (4)模型 3 及求解1 V  d; u( l' h0 M' P) P- S, U
    , r) P1 N/ n# _' [1 D  k3 n; @
    模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量
    7 s6 y6 H) I8 L7 v误差的标准差。
    - E! {) w) ?! f# U$ u9 e8 h4 z6 G. e% U  ^" c* e  O# U
    在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。
    ; \8 k5 d2 `- K9 z5 H1 M% \$ @$ ]& j4 q& H5 m) z' |
    , i& z- S. X- w1 ~% b
    3 h9 ]( z1 ^! F' R1 Y1 [
    由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为:
    ; [1 r7 Z- ^# ]" ?2 k
    % T; ?$ b3 @$ ~4 Z2 f( j- f9 vMODEL: 2 T  J# ^. j# t. \! k3 Q+ A9 c/ a
    TITLE 飞机定位模型3;
    $ h2 X5 a7 L6 b& o! c! \SETS:
    ) Y5 \, F6 v: w4 `; Q# U) G  VVOR/1..3/:x0,y0,cita,sigma,alpha; & f2 L) J$ _5 v/ C; \) E  }( H
    ENDSETS ' q0 p6 N7 [% G4 u
    INIT: 0 {3 D" P5 Z% Y9 p; `
    x=1000; y=900; ( L6 J0 J: b0 L* f/ X4 @* o# z
    ENDINIT
    $ S7 S! S$ d3 i& r) f1 uDATA: 4 S* H' a, T% p7 H. }
    x0, y0, cita, sigma = $ f$ v7 y4 l2 `7 ~4 r
    746  1393 161.2   0.8
    . `# B& Z" [; J' r629  375 45.1     0.6
    % X/ L2 ?, J7 z- R' E. y9 [- z1571 259 309.0    1.3;
    , P) [/ T( ]8 g; zx4 y4 d4 sigma4=155,987,864.3,2.0;
    " d! K! [/ \" p; u9 aENDDATA 7 S# G1 v$ [# F) n( l
    calc:
    # O3 ]# N+ A0 M' \; {1 P@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); # L2 N5 c4 E. j3 E
    endcalc
    # U1 B) ]/ u1 Omin=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2; " I( L- I: B7 y' l+ a
    @for(VOR: @tan(alpha)=(x-x0)/(y-y0) );
    5 N  s9 V1 M1 f! k' @% MEND. ?0 E2 F& u; K3 k3 ?* S3 }
    启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。 5 v" ~1 w; k5 u, Z
    ————————————————
    - w# M" U2 ~, n3 B) o3 G$ C版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。! k  ~1 U1 w$ Z# h- i- T' i  X
    原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044
    0 c+ n2 U1 G' ~# L' y
    + X6 J1 d3 v! A* u8 s9 @! E- C! e0 g5 R6 o
    6 w4 i. x0 Q9 v: l
    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-22 16:01 , Processed in 0.549313 second(s), 50 queries .

    回顶部