QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 3839|回复: 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 坐标(假设飞机和这些设备在同一平面上)。如何根据这些信息精确地确定当前飞机的 位置? # Y' }, w8 M9 r

    ' ?/ G7 i! `& ^; t: ?$ ?( o: M3 h# U, m. y$ k# |/ j0 _
    # z3 Q8 S# P5 @% P4 E

    8 y6 X$ d( [8 n9 M' [1 J  (1)问题分析 % ?8 B+ G' w) X8 q/ B

    9 X8 _# w" @- N, e 记 4 种设备 VOR1、VOR2、VOR3、DME 的坐标为  (以 km 为单位),i=1,2,3,4 ;VOR1、VOR2、VOR3 测量得到的角度为 (从图中可以看出,按照航空飞行管理的惯例,该角度是从北开始,沿顺时针方向的角度,取值在  之间),角度的误差限为;DME 测量得到的距离为 (单位:km),距离的误差限为 4 σ。设飞机当前位置的坐标为 ,则问题就是在表 9 的已知数据下计算  7 Y& `0 n1 r! E7 B

    " T$ h. I& p! `6 ?+ m; E' a  n3 I7 T( J- r6 f/ q

    & X5 q4 d  u% M. T! H* C(2)模型 1 及求解 * T# b5 {/ \: F
    ! C) o8 V7 `4 a* D4 r/ m" ~2 E
    图中角度  是点   和点 的连线与 y 轴的夹角(以 y 轴正向为基准,顺时针方向夹角为正,而不考虑逆时针方向的夹角),于是角度 的正切     ( 1 )2 n+ Z# `0 ?. K. Y6 i- a
    % T+ q8 }0 V' R3 D5 A$ Z$ q( `4 y
    对 DME 测量得到的距离,显然有      ( 2 )
      P9 P* a# ^* l8 z- J
    ( C! M2 N. G0 @6 o% r0 ?直接利用上面得到的 4 个等式确定飞机的坐标 y x, ,这是一个求解超定(非线性) 方程组的问题,在最小二乘准则下使计算值与测量值的误差平方和最小(越接近 0 越 好),则需要求解
    % ~8 q0 v- ]& d- f9 p5 ?- z& T/ |2 c
    ( 3 ); S4 ~- ~4 w# j) W+ u
    式(3)是一个非线性(无约束)最小二乘拟合问题。很容易写出其 LINGO 程序 如下:
    6 V0 d& I2 d5 a/ m. m$ F5 w1 ]! Y* i$ {
    MODEL:
    # A, A7 a2 Q: M! z' KTITLE 飞机定位模型1; ) B' A( f! P% G+ `* E$ A* I8 _* q( y
    SETS:
    6 W& _( Z% C: _3 b* q3 RVOR/1..3/:x0,y0,cita,sigma;
    ) C% q: C7 ]! p! |' n  k; W3 SENDSETS
    5 b5 S9 ]1 B5 Z4 TDATA:
    " q  h; V+ ?+ z! E2 R7 |x0, y0, cita, sigma =
    4 T" Q7 K8 q+ R9 Q# R) k2 v' L1 ?746  1393 161.2   0.8
    2 a. e( ?  s; H4 R! F629  375 45.1     0.6 ' Y! @/ a( }$ l5 p# @* U- L* W
    1571 259 309.0    1.3;
    ( C/ f" p3 f! @) l/ U5 V; \5 Q. dx4 y4 d4 sigma4=155,987,864.3,2.0; 7 \- Y1 ?; E# G: L* C3 i
    ENDDATA
      i' ~% v( O5 ]% }calc: 7 _) r+ W3 o' {/ I% h
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    ; K- G) ^, m& Pendcalc 2 {" v3 x  t; N0 _# w
    min=@sum(VOR:@sqr((x-x0)/(y-y0)-@tan(cita)))+@sqr(d4-@sqrt(@sqr(x -x4)+@sqr(y-y4)));
    , O" s5 }0 V- Q6 l, c7 b; y2 hEND: K8 r6 w$ t, N$ d! @
    上述程序必须使用全局求解器进行求解,否则求得的是一个局部最优解。用 “LINGO|OPTIONS”菜单命令启动“Global Solver”选项卡上的“Use Global Solver”选项,然后求解,可以得到全局最优解 x=1019.306 ,y= 987.2909  ,对应的目标函
    ; c7 ^9 d% Q$ T& d6 A数值为 0.4729562,这里的解受π 的取值影响很大。
    ' b' ~* N+ H/ M4 c9 i  A; H; q5 Q5 }
    . F% q9 X5 ^7 Y  c3 m( j4 h; d(3)模型 2 及求解" h* r3 @7 H- ~/ {6 J! u6 b
    1 H7 B5 Z" r' i
    注意到这个问题中角度和距离的单位是不一致的(角度为弧度,距离为公里),因 此将这 4 个误差平方和同等对待(相加)不是很合适。并且,4 种设备测量的精度(误差限)不同,而上面的方法根本没有考虑测量误差问题。如何利用测量设备的精度信息? 这就需要看对例中给出的设备精度如何理解。 一种可能的理解是:设备的测量误差是均匀分布的。以 VOR1 为例,目前测得的角度为  ,测量精度为 ,所以实际的角度应该位于区间   内。对其它设备也可以类似理解。由于 很少,即测量精度很高,所以在相应区间内正切函数 tan 的单调性成立。于是可以得到一组不等式:( m# [+ a1 Z* G. C8 t, K% J8 E
    , n2 k2 v' B6 E0 n! @, a

    * V( |7 P& K. X+ E) T0 s" {# Y/ q6 w. h* z2 u2 z. r& `$ D% P  Y
      也就是说,飞机坐标应该位于上述不等式组成的区域内。 由于这里假设设备的测量误差是均匀分布的,所以飞机坐标在这个区域内的每个 点上的可能性应该也是一样的,我们最好应该给出这个区域的 x和 y 坐标的最大值和最小值。于是我们可以分别以 min x ,  max x ,  min y,  max y为目标,以上面的区域限制条件为约束,求出x 和 y 坐标的最大值和最小值。
    3 E0 H: y/ ~5 ~' k* o, R- \) e3 Y 以 min x 为例,相应的 LINGO 程序为:  / \( a8 z. R' O
    1 B9 c5 `! w4 i
    MODEL: 8 r+ j+ }: h- V  ?! i
    TITLE 飞机定位模型2;
    & V) ~0 X! [3 C# `5 \SETS: VOR/1..3/:x0,y0,cita,sigma; 7 j: Y6 a- c" V8 o0 [5 g1 P) S
    ENDSETS # Y" T, `4 I4 M1 h2 I3 p6 I
    INIT: : B% x6 \5 i/ j' e0 w* v( z& @
    x=1000; y=900;   q3 C5 A1 d! N% \3 R% l, F6 g
    ENDINIT
    - G# A: @3 N2 H. Z9 h  NDATA: & ^+ |; v! j% W
    x0, y0, cita, sigma =
    ' ]' c8 E' x" q; }. F746  1393 161.2   0.8 $ J" g6 G- \' Z) W" M( o3 g" j
    629  375 45.1     0.6 2 ^  L: V! f* A. K, ~, `
    1571 259 309.0    1.3; : k7 C' y9 H1 `$ k" H
    x4 y4 d4 sigma4=155,987,864.3,2.0; 3 l! G3 r3 o) I
    ENDDATA
    6 d5 ?- u. I1 X, W* Hcalc:
    2 h  y1 s0 o! X, n! ]/ A; h@for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180); - f0 C3 i3 D8 E; n- y2 X
    endcalc
    ' f+ P; `% x6 H9 D' |$ J1 f& pmin=x;
      G+ O7 C- C5 a; N' o@for(VOR:(x-x0)/(y-y0)>@tan(cita-sigma));
    : L  |& l, a0 v2 z8 K" m@for(VOR:(x-x0)/(y-y0)<@tan(cita+sigma)); 8 h4 P1 n$ r9 j" U, U
    d4-sigma4 <((x-x4)^2+(y-y4)^2)^.5 ;
    4 @5 s( z0 N5 L& N$ Zd4+sigma4 >((x-x4)^2+(y-y4)^2)^.5 ; - O. A, Q1 R; f# V- R: O; r
    END 5 U& Y  _5 Z0 \* ~* L$ Z; x  [/ W/ L
    注意:用 LINGO9 求解非线性问题,必须对决策变量进行初始化,否则 LINGO 可 能找不到可行解。决策变量的初值也有范围限制,取的不合适也可能找不到可行解。 求得的 x的最小值为 974. 8433。类似地(只需要换目标函数就可以了),可得 到 x的最大值为 982.2005, y 的最小值为 717.1614, y 的最大值为 733.1582。 因此,最后得到的解是一个比较大的矩形区域,大致为 . $ q+ H" K0 Z. q0 a! g/ Q& }
    ) Z! P9 b. U$ P% t' J5 [
      (4)模型 3 及求解$ v; ]+ ~! L( W) ^& a% J1 h

    ' x8 @5 h" u6 W, S  @模型 2 得到的只是一个很大的矩形区域,仍不能令人满意。实际上,模型 2 假设 设备的测量误差是均匀分布的,这是很不合理的。一般来说,在多次测量中,应该假设设备的测量误差是正态分布的,而且均值为 0。本例中给出的精度 可以认为是测量* |6 V3 s6 i$ J. c5 l  a; u/ g
    误差的标准差。 . C: p' z( }0 A! L" {

    ) V( Q; g. A* Z6 B在这种理解下,用各自的误差限   对测量误差进行无量纲化(也可以看成是一种加权法)处理是合理的,即求解如下的无约束优化问题更合理。 ! v+ U2 h2 B. ?  K9 v0 O* m2 }
    7 [0 d2 ]$ T! a  `5 A& `) P, _# y
    : v+ E8 X) C- c# r

    5 N0 u8 E3 c& N3 e: g8 d 由于目标函数是平方和的形式,因此这是一个非线性最小二乘拟合问题。相应的 LINGO 程序为:
    & C3 p  k( Q. U, C0 E# H+ B
    ! c0 ~& v/ G! Q  j( F- `. @& T% ~MODEL: - V1 j% ^# l5 B% e. e0 {
    TITLE 飞机定位模型3;
    2 d8 y5 l0 o! b9 p0 M1 [5 JSETS: ' g2 e5 x3 W6 G% [
    VOR/1..3/:x0,y0,cita,sigma,alpha; , w$ i( |6 M, F: ?& P( Y
    ENDSETS + {9 [; B4 w: F" G$ u
    INIT:
    . [. p; T/ u3 F0 ^; F+ `# tx=1000; y=900; & U' @+ C0 {$ C! Q! g  l2 M: a
    ENDINIT : Q( a4 w- B- u
    DATA: ' g0 J( ]3 l$ _! @# V
    x0, y0, cita, sigma = ! L' \: u# q, o8 Z+ f
    746  1393 161.2   0.8 # M9 t  G' T$ G
    629  375 45.1     0.6
    ( g* c* z& A  Q0 P( c0 U7 p1571 259 309.0    1.3; ( B5 F& d3 ~7 f( E
    x4 y4 d4 sigma4=155,987,864.3,2.0;
    5 }" ?( v7 w, V& o5 [# ~2 zENDDATA 3 B0 y# X% |7 C' t
    calc: 8 _0 X' u" w6 m! h' b8 Q! Z
    @for(VOR:cita=cita*3.14159/180;sigma=sigma*3.14159/180);
    % v1 K& H& {" T. W! R5 V. Pendcalc
    6 R5 |5 x1 V/ y& c0 Amin=@sum(VOR:((alpha-cita)/sigma)^2)+((d4-((x-x4)^2+(y-y4)^2)^.5 )/ sigma4 )^2;
    ( l) R0 x4 f) \& B, ]% Y, V@for(VOR: @tan(alpha)=(x-x0)/(y-y0) ); " c: H! h" }1 e& l# @5 Z7 F5 }
    END& b: f+ }/ H: ?) b+ g
    启动 LINGO 的全局最优求解程序求解,得到全局最优解 x=978.3071,y= 723.9841,对应的目标函数的值为 0.668035。 这里得到的误差比模型 1 的大,这是因为模型 1 中使用的是绝对误差,而这里使用的是相对于精度 的误差。对角度而言,分母  很少,所以相对误差比绝对误差大,这是可以理解的。
    / P$ K7 G4 c( x" r/ x————————————————
    ) R! W, S* i" }; {6 p& N* l版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    0 Q: h, Y4 ^/ M/ _3 E原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89389044
    4 @" w6 `/ Q% d& L5 M) J- @6 ?$ t
    ! H1 p- u1 j0 c2 P3 ?: [

    2 N/ i, Y$ u' v3 v1 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, 2026-6-13 10:45 , Processed in 1.245207 second(s), 50 queries .

    回顶部