目录

数学建模之层次分析法含MATLAB代码

数学建模之层次分析法(含MATLAB代码)

数学建模层次分析法


1. 层次分析法的基本原理和步骤

层次分析法的基本原理与步骤

人们在进行社会的、经济的以及科学管理领域问题的系统分析中,面临的常常是

一个由相互关联、相互制约的众多因素构成的复杂而往往缺少定量数据的系统。层次

分析法为这类问题的决策和排序提供了一种新的、简洁而实用的建模方法。

https://i-blog.csdnimg.cn/blog_migrate/35c9ad8295a17ddb676bd0187adfeafc.png

基本原理

https://i-blog.csdnimg.cn/blog_migrate/cebcd7400b4390ea04a92d178581ee38.png

运用层次分析法建模,大体上可按下面四个步骤进行:

(i)  建立递阶层次结构模型;
(ii) 构造出各层次中的所有判断矩阵;
(iii)层次单排序及一致性检验;
(iv) 层次总排序及一致性检验。

https://i-blog.csdnimg.cn/blog_migrate/1ba8deb0b432e69ad1109fca6cb451df.png

https://i-blog.csdnimg.cn/blog_migrate/bd8d8ae715b7dc7dd0dbaf467d3ffd67.png

https://i-blog.csdnimg.cn/blog_migrate/d9fc0c9feb591b94aa0ede2debb2b0d7.png

https://i-blog.csdnimg.cn/blog_migrate/490e0332f2079fdfc6d16982333d9779.png


1.1 层次单排序及一致性检验

https://i-blog.csdnimg.cn/blog_migrate/6a03f5991daf6874585ee1c75c7aa1a9.png

https://i-blog.csdnimg.cn/blog_migrate/340e7daca21a61d925ee759957d74672.png

https://i-blog.csdnimg.cn/blog_migrate/1b33c3500588f48d40080e65697f21d1.png

https://i-blog.csdnimg.cn/blog_migrate/0b62d1cb239b3ac0bb2d71be6ccfafe2.png

https://i-blog.csdnimg.cn/blog_migrate/a2e235c0978894f53be9d9a822248e9e.png

https://i-blog.csdnimg.cn/blog_migrate/4b5632f591432e5a50731082fa72b4d2.png

https://i-blog.csdnimg.cn/blog_migrate/b643f794705adef5d4990dd350da7c0d.png

举例

https://i-blog.csdnimg.cn/blog_migrate/63d92826d126a01ce0bd45bab847271b.png

https://i-blog.csdnimg.cn/blog_migrate/cb5a2c4cf6cb6b67f775279455a71792.png


1.2 层次总排序及一致性检验

https://i-blog.csdnimg.cn/blog_migrate/88d2e066846ab2dd1eb3e4d6584db7bc.png

https://i-blog.csdnimg.cn/blog_migrate/145bdd6d57807f5dc5d6f24871a7e2d2.png

https://i-blog.csdnimg.cn/blog_migrate/0bd740d25e8bcbcf29fbece4d1d1662c.png

https://i-blog.csdnimg.cn/blog_migrate/ba372b179f6010ceb1075ca05a6a9d45.png

https://i-blog.csdnimg.cn/blog_migrate/d964d5e36b636c3fc235083082a398d0.png

举例

例 2 挑选合适的工作。经双方恳谈,已有三个单位表示愿意录用某毕业生。该

生根据已有信息建立了一个层次结构模型,如图 2 所示。

https://i-blog.csdnimg.cn/blog_migrate/bf0d68704e8445e1cb0bfd71156f448a.png

https://i-blog.csdnimg.cn/blog_migrate/149066bd26f577fc02f3bc0a952ad91d.png


2. matlab代码

% 层次分析及一致性检验代码使用:
%(1)构造判断矩阵A
%(2)将下文代码复制粘贴到Matlab中即可
% 例如:A=[1 3 5;0.33 1 3;0.2 0.33,1]
disp('请输入准则层判断矩阵A(n阶)');
A=input('A=');
[n,n]=size(A); % 得到矩阵的阶数
[V,D]=eig(A); % 求得特征向量和特征值
% 求出最大特征值和它所对应的特征向量
tempNum=D(1,1); % 特征值的初值
pos=1; % 标记的第一个数
for h=1:n
    if D(h,h)>tempNum
        tempNum=D(h,h);
        pos=h; % 最大特征值的位置
    end
end
w=abs(V(:,pos)); % 找最大特征值对应的特征向量
w=w/sum(w); % 归一化处理
t=D(pos,pos); % t指的是最大的特征值
disp('准则层特征向量w=');disp(w);disp('准则层最大特征根t=');disp(t);
% 一致性检验
CI=(t-n)/(n-1);RI=[0 0 0.52 0.89 1.12 1.26 1.36 1.41 1.46 1.49 1.52 1.54 1.56 1.58 1.59 1.60 1.61 1.615 1.62 1.63];
CR=CI/RI(n);
if CR<0.10
    disp('此矩阵的一致性可以接受!');
    disp('CI=');disp(CI);
    disp('CR=');disp(CR);
else disp('此矩阵的一致性验证失败,请重新进行评分!');
end

3. 应用过程举例

https://i-blog.csdnimg.cn/blog_migrate/87e3066c2e56297d8b801fff6ebf161f.png

https://i-blog.csdnimg.cn/blog_migrate/25c1b02461813de4f9918f67d55cb08c.png

https://i-blog.csdnimg.cn/blog_migrate/4bd634d0b3f6ddc0d11562a79b2bdb36.png

https://i-blog.csdnimg.cn/blog_migrate/397a5cd913eb02498de92215b61ec746.png

https://i-blog.csdnimg.cn/blog_migrate/5de816543f5da06b5eda6183e1aa4fd6.png

https://i-blog.csdnimg.cn/blog_migrate/eaa8777010f77614ec6d64d63ec65e2f.png


4. 参考资料

  • 《数学建模算法与应用》(司守奎)
  • 《数学建模算法与应用习题解答》(司守奎)