数学建模社区-数学中国
标题:
常见数学建模方法学习总结及资料汇总
[打印本页]
作者:
杨利霞
时间:
2021-7-19 16:33
标题:
常见数学建模方法学习总结及资料汇总
) n% M% J9 D- ?; |! a
常见数学建模方法学习总结及资料汇总
# g7 k: U0 F( }' c' D+ T) ]
数学建模方法
! [( l& a4 u& `" i& t
前言
- W X' u3 }) E! R5 w# Z4 K) A
层次分析法(AHP)
3 Q$ Y0 z6 Z# `" G& R0 L+ T
多属性决策模型
9 b* \; G9 w) n' m' J
模拟退火模型
A/ d: L p- \: F8 P G
种群竞争模型
& Y$ C! I" ^. a$ Y, k# I
遗传算法模型
7 |' X# q5 ?8 H( b
线性规划模型
) p7 p: q% e) b# _
非线性规划模型
" T1 y X9 v7 x" B; T2 h
PCA主成分分析
* I2 c. [+ a( {& ^& |6 v
聚类分析
2 ]) X, ~+ y1 M, d
多元回归分析
/ b L' ~9 K2 c7 y
前言
9 P q1 X K8 \0 u
这是我在进行初级的数学建模时进行的一些原理学习,网上资料显得比较杂乱无章,这里我对一些数学建模方法的文档和视频资料进行了收集并汇总了以下写的好的,在学习时跟着这些资料学习并看看我的汇总就可以达到一个比较好的效果啦~
' G! W# l2 B$ @! p, T& v1 O/ Q
* v; c" \* r- ]+ J! Z$ J
1 e' m, q( C, Z* e/ {: P2 Z
层次分析法(AHP)
7 y: l* a) W) S* n$ i9 o, a) |
应用:决策。(择优选择方案、优劣等级划分…)
. z- Q7 G b8 [, j; {1 [6 q
2 S1 i. Z h: _( ~* I
8 S7 i, g4 Y1 h5 n$ S
原理:根据问题的性质,使问题归结为最低层(供决策的方案、措施)到中间层(指标),中间层到最高层(总目标)的相对权值,通过一系列计算,来确定优劣性。
7 ?( _7 S! H ~# U" y, X1 Z
其中,中间层到最高层的相对权值,表示考虑方案的不同指标对最终结果选择的权重。最底层到中间层的相对权值,表示单个指标下,表现多个方案的好坏对比的权重。
7 U% T3 I" U) s8 u; S7 c
+ e8 w0 i; b3 I H
, g% w5 s! c. v" h( Q/ ~4 I
基本步骤:
1 ]3 y% l' r! j
1、划分层次(层次模型):分为目标——准则层(指标)——方案层。
2 E4 A- U9 j, B* J
2、构造判断矩阵(又称成对比较矩阵)。根据1~9尺度进行相应填写。
& o& q# }/ q) S0 E# F, |' }
3、一致性检验与求权重矩阵 。CR(一致性比率)<0.1则成对比较矩阵通过。一致性检验是检验判断构造的矩阵是否合格。权重矩阵是用来计算最终方案权值的。
/ x6 b+ W' a M$ r
4、根据权重矩阵求最优方案。
# O" g& ?; ~$ b. J- z7 K( Q9 J+ a* m2 i
7 @. o/ K9 `' _4 R: N s
9 ?& ?: _$ d) L; }: E% s" Y
视频学习:
7 t$ t( i4 V: t: v
先看:
6 M) Y$ a6 R7 P3 s6 [5 o6 `
链接: AHQ初步学习
4 ?4 _+ i2 |! w$ B* X, ]
后看: AHQ加深理解
, H( m& o& l8 Z6 @/ [" U5 t( E- ?
& B- a8 J- o. v+ [+ I- S
# ~% {3 ^/ c- X* [: l
多属性决策模型
0 N6 L# r6 T0 o2 a' e
应用:决策。
) v& t5 K+ m2 t9 ]4 A
6 [, _) V+ m1 @0 H
1 e1 Q: }( m6 J! T- f( A0 {8 _) m9 e
原理:类似于一般的加权求总分。主要思想是把量纲不同的数值转化为同一个量纲,然后构建权重矩阵,计算加权分值进行决策。
3 E( _7 ^' z; r
6 n. j* g1 [3 z! ]9 ~
7 Z2 v" A: {+ u
基本步骤:
3 L7 J: p0 a* s* M M
加权算数平均算子,属性值类型归一化。
6 i4 z0 A# s& s( w3 ^7 ]8 S
1、根据属性类型,划分为效益型、成本型等,对决策矩阵(属性值构成的矩阵)进行归一化。
' p( K4 ^% f6 p
2、构建成对比较矩阵,得到各个属性指标权重矩阵。(同AHP,也要进行一致性检验)
" n/ A# O% X6 R! H! N8 ?7 |: Q
3、根据权值矩阵与归一化的决策矩阵确定每个方案的最终权值,进行决策。
( o" k, g2 c% F
, r R) n( G8 U% Y; T/ E: v! \
" Y# [* P: o& o) E# t& c4 W4 e( N
文档资料:多属性决策模型
/ I1 j: `6 B, c5 }, H
视频资料:多属性决策模型
: g+ o' K$ ~5 P7 P1 M* o
: h/ N; d8 [8 e- [8 |* n
6 h0 f" N D% w4 y7 c, n$ t
层次分析法和多属性决策模型的区别:层次分析法针对于定性问题定量分析,多属性决策模型则不然。即如果“属性值”并不是一个能用“数值”很好地表示的值的话,采用AHP的1~9尺度是更优方案。如果“属性值”全都是适合的“数值”的话,就用多属性决策模型的方案。
' L# Z8 g6 T& A; \2 r! M
) l8 f( I) J0 q& {3 J8 T
( E2 E9 ^* h' j! I/ o# ^
模拟退火模型
; s9 ?8 p) v2 ^( q$ G1 ?
应用:无法确定能否在规定时间内找到最优解的NP问题——旅行商问题(TSP,访问每一座城市并回到最初城市的最短回路);背包问题(在限定的总重量下,如何选择物品使总价值最高);最大流问题(充分利用管道能力,使总流量最大);图着色问题(用最少的颜色,对地图进行着色);…
5 g5 s, c2 [& T0 q* s; o$ y
: ^9 E7 m0 ~/ f7 F
, E* @9 k- y2 r/ Y
原理:一种寻找最优解的算法,传统的算法可能被局限于局部最优解,模拟退火算法给出一定概率使计算中能够跳出局部最优解继续求解,当求出更优解时可以得到答案。
; s/ O* h3 F7 h2 N* ^- @
4 Z6 @9 C4 x; @" q
; r6 j# `( }0 G/ f$ [5 O$ Z
基本步骤:
9 R B9 z8 i1 |8 l2 K& v; E# U. S
1、初始化。(T温度,S初始解状态,迭代次数)
" f) h$ C) e5 H! y8 z. y
2、如果计算的最新状态趋近于最优解,则把这个最优解作为下一次计算的起点。
' [4 m3 x8 @2 ?) J4 B
3、如果计算的最新状态趋远于最优解,则根据方案取一定概率,使新的状态作为下一次计算的起点。
7 B+ C& [) O( T4 R9 I6 ]
4、重复1、2、3步骤,直至达到平衡状态并满足条件。
1 c! I. R" A. j, Y$ W
s; M, h! R( w9 {; w
m% y2 B: w4 L* s( Q& `
文档资料:
- j- S& G6 y! ` v* R
模拟退火模型通俗理解
* P- ^: Y$ s$ l% K1 f' g
模拟退火模型加深理解
0 g1 `( o8 K1 w: W9 T
8 E) D, U) r+ u; q+ U3 Y. h0 w
/ {: Z% e. d- H0 t. ]5 ]" ]
种群竞争模型
. Z" [( n. Q7 n5 l0 r) `4 B
应用:种群之间的竞争,优胜劣汰;产品的市场竞争模型…
+ C4 _% k# p/ n
! r& v2 e& Q) Y! g& V
2 D$ I1 H/ z5 b/ i% h' m+ n3 O
原理:当两个物种共同生存,相互会起到阻滞作用时建立的模型。种群竞争设置的参数为【初始数量,自然增长率,环境容量,种群对资源的消耗量】。
: T9 V& \" k' A% L- K. U- V
- i4 i" U7 p, g- ]6 E$ e
! ~* E0 O# d2 I" \1 {8 b$ p
基本步骤:无。这个模型的资料大多都很简略。
+ m) }0 @( B9 \" r L3 a
% s& V$ z2 p/ Z) }2 X
1 I6 _" v* H6 n% G4 v
文档资料:种群竞争模型
+ v: R3 F0 _# ?3 g: F9 s. h
, c. {* g+ D. i0 X9 ?6 c
$ i1 j- H/ d( a1 v% j' j
遗传算法模型
7 ]- [5 P' Y- @$ I
应用:对于同一个物种,有着个体之间性能的差异,遗传算法针对的是物种内的优胜劣汰。
! _1 B$ r2 b) Q
) w. b2 L5 M! f- A
3 T/ F9 L+ }7 c' p; ]' u/ H
原理:建立遗传算法模型,通过N代的遗传、交叉、变异、复制,找到问题的最优解。
9 m& y- K- E$ U, C5 f j. f
基本步骤:
4 y' m( v' P! i
( s0 ?" Z9 H8 Z$ w9 M+ k% j
" _+ ~" T: U7 W- c! a
1、根据初始化种群个体来初始化编码和数据。
, Q+ E: |9 Q2 E! D) K
2、评估个体的适应度,作为优胜劣汰的评价标准。
9 b; y+ D R& t. `; W
3、通过选择、交叉、变异、复制(为了保证最优个体能存活,对当代最优个体直接复制到下一代)来决定下一代的种群群体。
: E3 r2 T% G% G3 f
4、重复步骤1~3,最好的迭代结果次数是种群群体性能趋于稳定时。
( p" H; t% l" S
$ f0 _2 x4 e- u0 @2 F
# _5 d" g/ x3 V4 F
文档资料:
% `$ E. a; V7 I6 I
遗传算法通俗理解
# n [$ s$ I% n6 O! f. {2 o
遗传算法加深理解
. i5 q1 G5 h; H q
( d2 Q- {: e0 E4 B0 V3 H
: q" H+ U8 t5 w% P3 I. W d* }0 F
线性规划模型
" b! i! @# L0 c! q0 j
应用:对于有线性限制的问题求最优解。
4 ?+ @/ E, [. z1 v E y
5 g+ c# t) u) C7 [/ D7 T
7 _; G8 P: U8 L7 j0 ]1 Q7 U
原理:根据限制建立线性关系,根据决策函数求最优解。高中的东西了。如果存在最优解,只能在可行域的边界找到(一般为顶点)。
. ]' H9 |0 R J
4 }* ?+ |$ b; X9 b
3 ^( L, V. M3 U/ A6 H
基本步骤:
! x7 A. N1 s+ \6 h) c6 K
1、假设/寻找决策变量。(影响目标结果且有条件限制的变量)
: B m _7 \- Q8 o7 D' q9 |9 n0 l
2、建立目标函数。(需要求最优解的东西)
$ j8 d) Z1 W0 D: j# V, E
3、寻找约束条件。(变量之间的约束关系)
: Z' d; {0 j# e6 b/ Q' y! D3 \
4、求解。
, K& Q0 G6 c8 g0 q+ O
( V# @" r2 {% N) l7 R1 d& A1 c! v
0 L3 M. W% g( Y. d* ?* t" t
文档:线性规划
) l+ J% f: [( Q
+ j9 F( B. u" W4 ]1 u1 l
. ~! F' h% V$ C: m
非线性规划模型
( |2 h. w1 {* o& s
应用:对于有非线性限制的问题求最优解(约束函数或者目标函数含有非线性关系)。
v* h# @: j& r
+ g! f0 B, o6 [8 h# ~( h7 O3 m
! L+ ^1 g4 ~- b4 C/ `8 R
原理:解决非线性规划模型,这种模型没有通用的解决方案,各个方法都有自己适用的范围。最优解可能在可行域的任意一点找到。通常非线性规划模型可以概括为:
' Y" s3 H+ |: `. ?$ u' m( b: y
5 {. P9 h. _9 k+ m* b% W
& y' n: N1 v1 J g
其含义为:优化目标为f(x),受限于一个等式h(x)与一个不等式g(x)。
( Q( m8 [$ o3 ^$ E, _2 a( L, A
o! e& {( C, m9 |# ^+ A
]6 V6 q- c1 @- t: l0 |& d% Y
基本步骤:
" Z9 l1 k) i" f+ V+ A7 r# }1 o; M
1、同线性规划,找出决策变量;建立目标函数;寻找约束条件。
( _4 R, K- }: a& k W
2、求解过程中,选定初始点x,构建点x在趋于最优解的搜索方向,以该搜索方向为基础,设定搜索步长,找到下一个迭代点。
. l2 u- |4 q/ x4 F- x9 B( ^
3、以新迭代点为初始点,重复进行2步骤。
3 n: v& |/ R! G/ ?8 K4 l
: D+ X+ L( N6 E" m T* j1 ~0 r
: j, E, P9 J/ C
文档资料(比较多,稍微看看就好):非线性规划
! O' M5 k: z. B) Q
! e/ U$ T- K2 _9 p5 j4 o9 ~
) a* J, I( P) v# z- h
PCA主成分分析
8 ^- @) b" ?/ m* [" J9 i
应用:降维。
6 r+ y, A# x0 Q% [5 J
7 J2 e8 B5 a. F* F9 s5 S4 J
) L. j: N5 D: a, |
原理:在损失较少信息的基础上实现降维。周志华西瓜书上提到的最近重构性和最大可分性,实际上是关于协方差与方差的问题。协方差代表维度之间的相关性,方差可以表示维度可以保留的信息。故PCA降维的优化目标为:在N维中选择R维作为“主成分”,这R维之间两两之间协方差尽量小,方差尽量大。
1 D$ I( P' g3 I/ {: C( C% N. t
4 \; O6 R' p) [. J+ {8 _6 P7 j
( x3 L2 W& }- Y8 t& i
基本步骤:涉及线性代数、矩阵分析。文档资料中有兴趣自行了解。
3 [' Y1 v# ^' h% \+ @( q9 R/ U# S
& [# ~, g! k) G
/ P/ X2 z! z% |$ t8 j
文档资料:
1 p8 m& B' T+ T! _" {5 e+ k" a
PCA理解与基本概念
( X5 R6 M: @' u0 P' X+ E/ n, `8 q
PCA维度的选择
5 ?1 \0 D1 ]' j w/ J% c" q
' k/ l) _2 K+ L
2 @. p4 S+ w0 r/ n* J
聚类分析
# a4 n. m3 k. W4 b4 m' z9 N
应用:无监督分类。
6 p9 N+ c+ z$ w {
- |$ u; P% I; \* b. ^' [
9 Z; E. F1 t7 i; P# H5 z& k
原理:对没有标示性的数据,按照算法,进行簇划分。
1 u5 K3 `* R5 w& r9 H6 k6 N$ Q
, O# n# X$ Z0 \3 J9 l
/ R& H4 j" }; l5 |- Q, ?2 g
基本步骤:
! T1 m* D: X5 n1 Q
聚类算法分很多类别。最常使用是基于距离和基于密度的聚类方案,具体方案选择结合实际。
! G2 x2 q \. i( @% q: {! l1 l) ?7 I1 C
在基于距离聚类中比较典型的是k-means聚类,通过多次迭代更新中心点,找到多个中心点(簇的中心)与多个簇,实现:簇内点紧凑,簇间分离程度高。需要设置K(簇数)的值,效率高。
$ N4 R, s+ |( ^6 E R
基于密度的聚类有DBSCAN和MeanShift(均值漂移)等,主要思路是根据数据点的紧凑程度,将聚合程度较高的数据形成簇。
! D' d* K8 e2 W! j" }
基于密度的聚类相比于基于距离的聚类,可以找到数据点分布呈不规则形状的簇,效率要差一些,相比之下,基于距离的聚类,同一个簇中各个数据点都不会太偏离中心点,效率高。
J9 ]3 \1 M$ J2 C
( M8 k6 g [$ J/ y- L2 j- j
' q `% \& n2 I0 b( \
鸢尾花分类的聚类代码,用来辅助学习与理解。
" u5 n u! c# w) B: R/ t
1
8 D. l" t" D: R6 C% T; b4 z+ u
from sklearn import datasets
4 |/ G L& i+ Y7 p
from sklearn import model_selection
+ P, e5 {- ?: B7 O& o
from sklearn.cluster import KMeans
, Q/ Q" m4 s* {; m3 a! z
import matplotlib.pyplot as plt
& C$ a3 B$ q l
; p4 Q9 M2 D; z/ E
5 D: h2 t( p2 n. n4 s* u/ f
# step1.加载数据
; e7 Q$ x$ U! G F8 d1 ~+ c% O$ M( T W
iris = datasets.load_iris()
/ t9 x% j) S% P& r) H' J
* l( E8 L" t* N4 d; e
8 w" x$ F8 j0 s+ c, ~& Y6 r
# 2.取特征空间中的4个维度
4 m. g4 u) w, f" s$ G- Z
X = iris.data[:,:4]
+ f$ Z7 H) k+ r/ o- E5 b) z
5 X- I' e3 V9 a- F* p% Z
8 o: C4 I k& ^4 {; N5 z0 [
# 3.搭建模型,构造KMeans聚类器
' e/ C: P$ b9 F
estimator = KMeans(n_clusters=3)
. m- f% }: B/ O. _
7 f5 ?) W) Q, J! n: T# E
8 C- D3 `( R! @! q% v) W! b
#开始聚类训练
$ P0 M% F7 w& w, H; Q2 i) X
estimator.fit(X)
! F& Y# P( x; Q% h- O# O
6 Y7 D3 b% I- ]2 H9 \
) L$ g# C4 L* Y* K
# 获取聚类标签
* I) ~9 `' x+ q
label_pred = estimator.labels_
* L! Z3 l' {5 s' h! k
L3 l! e: v& k- s+ G* k- W9 r
$ U0 m) E. o9 ?- q# l, \# z2 M
# 绘制数据分布图(以花萼长度和宽度为展示依据)
0 C& I* I) O! ~$ C8 l
# plt.scatter(X[:, 0], X[:, 1], c="red", marker='o', label='see')
' Q$ e6 j% y7 F" Q
# print(X[:,0])
3 T& \# m/ U6 b# \
# plt.xlabel('calyx length')
9 P1 ^! y, Y% R: y# W9 i& j
# plt.ylabel('calyx width')
( |3 ~$ B- h' B0 j$ I( \
# plt.legend(loc=2)
' M2 W0 k; o! ?; [/ n. r
# plt.show()
/ g* u& Y. L4 _" i! s; `
1
( @5 L' u" [: a: t' z. R! N
2
9 W/ b7 T. |; F3 m1 E
3
. H" }: w! Y, B/ N o
4
8 \( K$ J2 o9 g( s1 q
5
/ W! u V) l, v) L6 }& l
6
: n7 K+ g* t3 v) F! e- O+ Z$ z8 p
7
2 y' D$ L7 X$ ?5 @9 d2 N' A
8
! \3 j2 k: X( V
9
4 p7 v2 Y8 p; x; @
10
6 K% w0 u5 r9 v- R) N f- \5 F: k
11
/ p/ y3 Y. ?3 \) Q& p% t# p
12
' ]% f( o7 o3 s
13
7 R( A+ d! g% v2 s
14
: }$ I& V# ]7 L; v- U7 s) d2 q7 x, U
15
R( V" J5 i( h" r0 G6 W
16
' y' [: j/ _6 F* g8 p3 {% R
17
% J- ^4 U$ n+ I! P9 C1 q
18
4 I" F+ h3 l0 ?
19
) C6 R0 V# f3 { y" {# T
20
0 q* \0 ?% T! T' u& V
21
) O) u, e; B; `8 j, \. T+ R& ~8 h
22
3 M/ _% L* U/ M6 e2 ]9 }. y
23
; `& G4 |! y- |0 J7 {
24
2 B" n1 h: y- _$ e' p% ?5 W3 K# ~6 ?4 A
25
0 b, I8 b( G$ F3 B4 b! n
26
( r: E* I9 \6 O! g4 X6 `
27
& X- l u& o% p [
以下为聚类结果图,针对两个维度进行了显示。
4 V0 ]: d" D( W& G# D
+ n0 v9 ?) ?% y2 w8 ^
5 U* g4 y! B8 Y( _6 s/ v4 F( |
5 N8 D" }1 M2 W8 s
" J& O/ d+ B1 S7 e: i
多元回归分析
6 y& R0 \ T5 g7 @( p
应用:主要用于描述关系或进行预测。
5 _7 @( c7 b/ L6 d2 |( K
& L. s4 y+ V# ] i! P
& p) w; H2 D% r) D8 w$ H
原理:建立因变量和多个自变量之间的线性或者非线性关系。常见的回归分析是线性回归,在线性回归中因变量y也可以不作为结果,而作为另一个需要得到的结果g(x)的因变量,即:
1 D) b& @# g% R, Z" S
,这样的的线性回归称为广义线性回归。
4 l- d4 D7 Y! a; E7 g2 o$ n/ Q+ i
基本步骤:主要分为线性回归和非线性回归。就不总结了大伙自己看看吧。
' ^( w. _! @: x6 _. Q* B
7 k# A: T( n4 z7 m$ D$ A
# r( b# l2 r0 ?3 T6 k$ D
文档资料:挺多的不找了,大部分都是线性回归,非线性回归资料少。
# i. L% h6 P, y9 U
- p- `: [2 E3 v6 @9 P
6 k' K/ h) ]" n( C. J
下面两个图分别是线性回归和非线性回归的图。
+ e4 M) Q7 i) e1 G, f/ c& m( ?
5 B+ y9 K* f8 Y! q/ ]
+ [$ W7 T0 Q) f3 X: z. M- @
6 a: x: \5 {/ t+ Y, t2 e6 Y. N
4 l9 l8 w7 s. X
————————————————
, g2 k. {7 f) E% _3 [: e& l
版权声明:本文为CSDN博主「Rulcy」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
: V9 e: U+ m6 ], e" j' U" Q
原文链接:https://blog.csdn.net/weixin_44371912/article/details/106934687
% v) F/ S! ?& N4 ^. k& T
% x5 Q% ?! P0 S; M$ Q, _ k- q1 M
& E# n1 s+ V! u$ R
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5