QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1749|回复: 1
打印 上一主题 下一主题

数学建模--灰色关联分析

[复制链接]
字体大小: 正常 放大
杨利霞        

5273

主题

82

听众

17万

积分

  • TA的每日心情
    开心
    2021-8-11 17:59
  • 签到天数: 17 天

    [LV.4]偶尔看看III

    网络挑战赛参赛者

    网络挑战赛参赛者

    自我介绍
    本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。

    群组2018美赛大象算法课程

    群组2018美赛护航培训课程

    群组2019年 数学中国站长建

    群组2019年数据分析师课程

    群组2018年大象老师国赛优

    跳转到指定楼层
    1#
    发表于 2020-4-13 16:26 |只看该作者 |正序浏览
    |招呼Ta 关注Ta
    ( A, l5 E/ k; |$ N5 v
    数学建模--灰色关联分析写在前面:5 I+ p; f0 M' q. G" E6 \4 ]
    笔记为自行整理,内容出自课程《数学建模学习交流》,主讲人:清风
    * m5 i" N; A. V  b1 o9 x3 y
    9 }5 N  C+ C' R* y8 P4 a灰色关联分析概述
      t5 V/ \4 ~* U5 \
    ' i) `* X& Z' u一般的抽象系统,如社会系统、经济系统、农业系统、生态系统、教育系统等都包含有许多种因素,多种因素共同作用的结果决定了该系统的发展态势。人们常希望知道在众多的因素中,哪些是主要因素,哪些是次要因素;哪些因素对系统发展影响大,哪些因素对系统发展影响小;哪些因素对系统发展起推动作用需强化发展,哪些因素对系统起阻碍作用需加以抑制;…这些都是系统分析中人们普遍关心的问题。例如,粮食生产系统,人们希望提高粮食总产量,二影响粮食总产量的因素是多方面的,有播种面积以及水利、化肥、土壤、种子、劳力、气候、耕作技术二号政策环境等。' h. P& p( z+ X
    ' `- \, `$ L: @" ?
    为了实现少投入多产出,并取得良好的经济效益、社会效益和生态效益,就必须进行系统分析。! b7 F( ~) [% g( h. G4 ]! j
    ) ~- g# K6 v) ^, c& t
    数理统计中的回归分析、方差分析、主成分分析等都是用来进行系统分析的方法。这些方法存在以下问题:) a: u2 V4 I5 D9 E! f
    9 O! ]0 C5 h! u3 Y9 A
    要求有大量数据,在数据量少、不满足大样本要求时上诉方法均失效。! G' {& v, z% }& u; o8 _
    要求样本服从某个典型的概率分布,要求各因素数据与系统特征数据之间呈线性关系且各因素之间彼此无关。这种要求往往难以满足。+ r1 j. _8 h; D3 L
    计算量大,一般要考计算机帮助。
    3 G. Y0 E0 |9 ~/ V1 b% q* |可能出现量化结果与定性分析结果不一致的现象,导致系统的关系和规律遭到歪曲和颠倒。0 r1 A* x, z  {3 d9 s* M
    灰色关联分析的基本思想是根据序列曲线几何形状的相似程度来判断其联系是否紧密。曲线越接近,相应序列之间的关联度就越大,反之就越小。
    1 ?& i5 b! e7 g2 r" i7 H9 }* E参考:刘思峰.灰色系统理论及其应用(第五版)[M].北京:科学出版社,2010:62.
    8 C- x% _' l' [+ w* I应用:进行系统分析
    2 ]# ]2 C, h3 _6 v/ V; s
    1 W1 J, s/ C. u9 z' }# h: w$ c( J) `3 T: d
      B/ C& }8 Y4 F4 Z- s: _) F7 G5 R# ?
    ①. 画统计图
    / o. k, q( R( |
    % j& Y1 o+ s$ q4 a% N9 s/ J! j: _1 W$ }
    进行简单的分析:/ a: U7 q# t3 G
    % J! z7 _/ U- ?
    四个变量均呈现上升的趋势。
    % `1 _/ N" ?) u9 a) u第二产业的增幅较为明显。/ v) J  Y3 R4 |+ B! |
    第二产业和第三产业的差距在后三年更大。: w+ |+ }7 A3 d9 B% d- @4 k
    ②. 确定分析序列1 ]& g7 v; P! T; \# t

    ( q& o7 r( R$ S& |' ]+ O$ x6 e- B母序列(又称参考序列、母指标):能够反映系统行为特征的数据序列。3 E6 C' p  D/ ]3 |& W4 o
    子序列(又称比较序列、子指标):影响系统行为的因素组成的数据序列。
    : f6 I- ^8 h* o3 O5 n! Z, K, |本例中,国内生产总值就是母序列,第一、二、三产业是子序列。) u" R% b4 }, c# g

    6 c9 o- K) J4 d3 t! X8 z2 q" J③. 对变量进行预处理(消去量纲,缩小变量范围简化计算)
    8 f! Z& g& N6 e9 e  K# u. A1 m. m
    方法:对每个指标中的元素,用该元素除以所在指标的均值
    : F' u2 R: T( h* w2 E9 r3 J) f7 c3 O9 {2 g
    ④. 计算子序列中各个指标与母序列的关联系数
    ! I0 H( _! k* ]  c
    . {2 G- C- u9 x. f9 N8 I# E
    % ~# O7 a' ~2 U  Z3 E+ Fx0=(x0(1),x0(2),...,x0(n))T x_0=(x_0(1),x_0(2),...,x_0(n))^Tx $ I* O  C4 ?" f+ J2 S6 ?! r& [
    0; v' v2 B/ H" }& t
    ​       
    . s, i% L- W9 }, t* Q" l =(x
    # R1 K+ w2 i" B0 f0
    4 {4 x0 m; x& D  }​       
    3 H# ~9 O: b% C3 |: {, M# l (1),x ' \/ y& o+ E5 T! ?
    0( S5 H/ A& r! h/ [
    ​        - ^) S+ [0 T( {
    (2),...,x : t$ S9 B0 K$ g
    0
    ! b, J; u7 p/ x; @​        # c. O6 K) [! W1 j' q$ v
    (n)) ) z% O3 @" W% h5 d% c; |
    T. z( f* Q* B% d# W: T; x# ]
    ' k9 h3 k- a. }) s! q" R! l
    x1=(x1(1),x1(2),...,x1(n))T x_1=(x_1(1),x_1(2),...,x_1(n))^Tx
    5 |2 w' `6 K# X6 b13 D# d/ {5 c2 Z/ N" o2 d$ X& O7 t
    ​       
    ( i4 K! g# C3 t  P8 }0 M =(x
    , b+ y$ Q3 j  l6 h' W0 O5 C+ A18 b1 [% E/ C- f5 V( @9 _
    ​       
    ! o( ]) n7 h+ l/ f" |6 j) o (1),x 2 c$ _) g3 L- C6 Z5 A0 C2 @# q& _
    1
    $ B: I1 b  U# P5 T6 |& x% Z​        3 [; i* l/ h1 t( ?
    (2),...,x $ N& O' y4 r* n0 K4 V0 p
    1
    ; I! C( L( L! R/ z​        4 U4 P& `& n& b
    (n))
    * Z' T! N) x5 P7 {' F( F: F+ NT  z. K& O2 }5 S: r

    * H& n; h$ _$ `; z! Z7 Lx2=(x2(1),x2(2),...,x2(n))T x_2=(x_2(1),x_2(2),...,x_2(n))^Tx
    ! p# M/ F9 c% y2
    ) J8 X$ E3 i6 ?​        & b$ J" Q& X7 u0 W
    =(x & q* D9 K- P, u5 a
    21 `; J1 g3 J# l, N: n- p9 q
    ​       
    * u  B: U  t4 c! O+ s0 U  M+ a (1),x 5 \: y( }* q( k6 b# I9 c
    2
    , z0 Y; ~3 R, R# H; Q% T  r​       
    0 h, [  v. g  W% m+ J/ I1 I (2),...,x 3 }! d. Y) E# L; I, U- o
    21 }: t- \) @$ [+ g9 I0 ]/ V
    ​       
    1 B/ \6 E( L0 I; u0 B6 V (n))
    6 B% v* G% f5 C' e; `- J( h! \T
    ! D& D  V* j3 `, {4 M1 s; Q' T7 w% L+ j8 s  i- b4 I3 c
    x3=(x3(1),x3(2),...,x3(n))T x_3=(x_3(1),x_3(2),...,x_3(n))^Tx 2 G8 [- K: a' d$ e6 u, K
    3
    5 T4 R3 k- ]* w- J​       
    8 l3 Y7 y. r. W! H =(x
    8 ]' A- R5 n$ h3 H9 ^- e; w8 c& M  ]7 K/ P3
    1 C4 ?1 X2 R4 ]4 ~* I& U" y​        ( y, n0 c  ~; j% M+ A2 c5 O4 S; t
    (1),x
    - x1 g- j- M" U( ~: ?( J% M3
    & T0 s* s8 {( t, L) b8 M​       
    8 I& J) ]* a7 D  I0 m (2),...,x ' c& ]! r8 h0 X. k0 _, |0 U
    3
    4 H  ?1 j! b  }& _! n5 N1 ~​       
    ' q: S' K) f/ v! s# H8 ] (n)) 9 q: H% \# |; _- m% ~! ?7 _/ e
    T
    ) B- K& r/ i) N" V7 |' h) c9 w' F( b: Y+ x$ T
    记a=min∣x0(k)−xi(k)∣ a=min{|x_0(k)-x_i(k)|}a=min∣x ' M' ~/ h2 P* n" o- Z7 @1 e% V
    0
    + ]+ _; T5 X" f" n* h​        2 V6 D- U: z  T5 Y0 I, v
    (k)−x 5 Z& F$ c( ?! @8 n
    i- J. I6 J$ ^3 M& z1 A' ~
    ​       
    0 T1 c& D0 t$ x! e: O! J" A) ~ (k)∣(每个子序列中的每个元素减去对应的母序列中的元素,找到最小的那个),b=min∣x0(k)−xi(k)∣ b=min{|x_0(k)-x_i(k)|}b=min∣x
      |  Q& B4 I1 x07 X2 C7 I6 y- [) j$ f; R
    ​       
    " ?; y, g, R" E2 C (k)−x " x5 M1 y4 p# a" e0 B
    i0 N9 @# `) y2 u" A
    ​       
    ( x- c0 |; Y/ s4 J (k)∣
    / l" J% K8 Z# ^" U) |a aa为两级最小差,b bb为两级最大差。
    * A& ^) Y7 ~7 L& h+ D8 l. Y; o
    ) ~* ~8 k4 z% ?5 q' o定义:γ(x0(k),xi(k))=a+ρb∣x0(k)−xi(k)∣+ρb ρ:分辨系数(一般取0.5) \gamma\left( x_0\left( k \right) ,x_i\left( k \right) \right) =\frac{a+\rho b}{|x_0\left( k \right) -x_i\left( k \right) |+\rho b}\ \rho \text{:分辨系数(一般取0.5)}γ(x + k9 ]& `) H( R' k( L3 l. f
    0
    2 Q3 g/ q  @, W0 T1 k* J​       
    # ~( q0 @, ^6 w! N# f* i2 {: E, u2 K (k),x " L& }7 k0 o" v0 H
    i% K+ ]- v8 W! P2 E
    ​       
    - }) \9 E# B! x5 l+ F/ M$ J# Q* ~7 e (k))= 7 N" o' Q: A4 L9 x" Y( g
    ∣x
    ; T7 H9 {/ o: f4 p, a0 {08 d' w" A6 I2 n# U# g+ p+ T$ p5 u$ E
    ​        * U/ U, o% i1 L* \% M  V8 ?
    (k)−x
    : F. }$ P% \- L; p/ y2 v7 |; ?i
    0 n& k7 u+ c6 u4 X4 [" G​       
    + i. s5 l# o8 C9 b* M& c (k)∣+ρb) K. H. }. v! S: G' v
    a+ρb
    - u' F  u6 X9 f9 L5 E9 |( z0 s​       
    7 C' ~* u- T5 A: ]2 g, @  ρ:分辨系数(一般取0.5)
    8 T2 O/ y( Q' Q% O8 T7 a( _9 o2 c# l$ w3 o

    ( m% y/ k; n4 I5 x7 P# A⑤. 定义γ(x0,xi)=1n∑nk=1γ(x0(k),xi(k)) \gamma \left( x_0,x_i \right) =\frac{1}{n}\sum_{k=1}^n{\gamma \left( x_0\left( k \right) ,x_i\left( k \right) \right)}γ(x + ^% M3 H$ @( |5 ], {. Y6 g6 m
    0
    5 O; e! K  e4 J1 [3 U​        2 v$ Z/ M2 n, r& y
    ,x
    ! F/ w1 o) D$ n* Z- \i3 H+ }: E9 e6 O2 f+ J# I5 ]
    ​       
      Y' @9 r/ f9 l  z* w* Z5 J: f" T )= 8 W; k. h0 |1 f' ?
    n% F+ O0 S, v; [; r2 s  v
    1
    4 a, e; O( `& N. L& u7 U. K' N- ^​        2 M9 G: B/ |; S9 S$ w* n) ~  r
    . l* ]* e4 p* A$ s  B7 E
    k=1
    6 K$ W* j& T  B* }2 y8 @n
    ; U! g0 D* P; Y& H( T​       
    - s# A( b4 H- E/ q: S4 z8 P γ(x : s% q2 d/ ^9 p  A6 n0 H$ Y
    0- y) a) ]; U( o
    ​       
    " G1 O5 l4 {! z* B (k),x
    + V, r* _9 Z9 q/ `+ v. j( H" I% Zi* v, _* M$ E  p
    ​        ; U* `& {4 W3 o2 X
    (k)) 为x0 x_0x
    # h# K1 e8 v5 S" S0
    & S+ J+ K! q: a% ^8 i​        . ]& B) i2 w1 |! \9 N' {
    和xi x_ix 1 Q: A2 ]0 s( B3 ~
    i
    1 S) }9 e3 y7 \​       
    . Y# R3 t; @0 ^' @9 u' ~ 的灰色关联度. |2 c# V' j+ n( b6 W

    - a" B. R. T5 q/ jγ(x0,x1)=0.5084,γ(x0,x2)=0.6243,γ(x0,x3)=0.7573 \gamma(x_0,x_1)=0.5084,\gamma(x_0,x_2)=0.6243,\gamma(x_0,x_3)=0.7573γ(x
    ! J. [4 [7 Q0 T. J0( h+ g$ \. ]6 X" E0 a& B
    ​        # U* }# e0 ^  f) V; w# |, |4 s2 [3 [
    ,x 8 j4 a3 [/ {- Y. W
    1" i; A! o5 t1 z/ u. w9 x( ~
    ​       
    : }( F* Y! q/ {$ G )=0.5084,γ(x 6 _1 q9 G! {, [* T3 X
    0
    $ I! p# C/ i2 i- d​       
    4 ?( e' y8 C( j7 D) i. Q. M ,x
    - q0 L8 Q6 Q7 a* A. q2, b7 y' R# {) B2 ^+ @, L* K
    ​        , F( L" L& u9 V" `- f/ O
    )=0.6243,γ(x 4 F- r3 m4 W7 }9 p1 {
    0
    ' M7 f' h7 t1 N2 J​        + @* o* ~; `% |5 N
    ,x
    % h4 {+ L4 a. y& X) }  X3
    3 R2 o) N+ g! X- _1 b, B+ a/ M6 e5 i​        % `4 I1 n( h3 J% ^
    )=0.7573
    " Z  Y6 s% q: s0 }6 b. o+ @8 K2 Q' z7 @" a2 {0 `
    ⑥. 通过比较三个子序列和母序列的关联度可以得到结论:该地区在2000年至2005年间的国内生产总值收到第三产业的影响最大。
    + l2 r! ?0 d/ K0 U( E, ~$ R/ d6 n8 c' f4 N2 q3 \. `0 j
    代码(python实现)% g- |) ]! m, W

    $ X7 v- L5 U& N7 ~2 m% c$ `import numpy as np
    0 ^& T, B) q3 N) V- u. Dx_mat = np.loadtxt('gdp.csv', encoding='utf-8-sig', delimiter=',')  #推荐使用csv格式
    ' S! f0 i2 v4 q5 W3 P- g17 @% D1 p& ~, K9 \
    2% V" M* k7 R0 S; C0 T' @
    ## 定义函数求解关联度
    9 q! ]2 Y$ G, t; r; p7 Xdef gray_analysis(x):
    ! m; p7 Q6 d, e" _$ C+ L% b    x_mean = x.mean(axis=0)" Y) q8 H" E: n% f5 `, L
        x = x/x_mean
    ( p1 r& d( Q1 H) F: Z* Y# w: b    Y = x[:,0]  #提取母序列" l3 ~# F6 Y- h  v
        X = x[:,1:]  #提取所有子序列
    " u5 h0 ^0 F3 ~5 ?    abs_x0_xi = np.abs(X-np.tile(Y.reshape(Y.shape[0],1),(1,np.shape(X)[1])))+ v$ y# S3 x0 g1 E1 j) o; Z1 c
        a = np.min(abs_x0_xi), p8 L: z. q7 _0 a7 H- r% f, [
        b = np.max(abs_x0_xi)
    - e; o- Q. F# d" R5 b    rho = 0.5& c$ e5 @8 Q9 u
        gamma_mat = (a+rho*b)/(abs_x0_xi+rho*b)6 h6 |, h  u( r4 @/ C$ u7 w% {
        corre_degree = np.mean(gamma_mat,axis=0)
    , s! K& E$ M, ]9 C6 P' u. ]    print("子序列中各个指标的灰色关联度分别为:",corre_degree)
    + [& [  E. g6 f/ G. z) b————————————————1 h" p, [9 d. B( ]' d
    版权声明:本文为CSDN博主「脑汁」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
    , Q1 R% ?, k. E- C原文链接:https://blog.csdn.net/ddjhpxs/article/details/1054872611 m' B7 X1 x6 V+ H! D( L' n7 Q
      D% T: R- e* Z

    & b0 D' {1 ^4 s; R
    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    xiEnqing        

    0

    主题

    1

    听众

    4

    积分

    升级  80%

    该用户从未签到

    自我介绍
    SIMPLE
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-20 18:55 , Processed in 0.298224 second(s), 57 queries .

    回顶部