🔆 文章首发于我的个人博客:欢迎大佬们来逛逛
CRITIC赋权法
算法流程
- 构建原始数据矩阵 X X X,他是一个 m ∗ n m * n m∗n 的矩阵, m m m 表示评价对象个数, n n n 表示指标个数
- 对原始数据矩阵进行正向化处理
- 计算矩阵的变异性,即计算矩阵的**标准差:**得到的 S i S_i Si 表示 第 i i i 个指标的标准差
{ x ˉ j = 1 n ∑ i = 1 n x i j S j = ∑ i = 1 n ( x i j − x ˉ j ) 2 n − 1 \left\{\begin{array}{rcl}\mathrm{\bar x_j~=~\frac1n~\sum_{i=1}^nx_{ij}}\\\\\mathrm{S_j~=\sqrt{\frac{\sum_{i=1}^n\left(x_{ij}~-\bar x_j~\right)^2}{n-1}}}\end{array}\right. ⎩ ⎨ ⎧xˉj = n1 ∑i=1nxijSj =n−1∑i=1n(xij −xˉj )2
- 描述指标的冲突性,首先计算指标之间两两的相关系数矩阵,然后计算指标的冲突性:
- 求相关系数矩阵可以直接调用matlab的
corr
函数
- 求相关系数矩阵可以直接调用matlab的
R j = ∑ i = 1 n ( 1 − r i j ) \mathrm{R_j~=\sum_{i=1}^n(1-r_{ij})} Rj =i=1∑n(1−rij)
- 计算指标的信息承重量:
C j = S j ∑ i = 1 n ( 1 − r i j ) = S j × R j \mathrm{C_j~=S_j~\sum_{i=1}^n~(1-r_{ij}~)=S_j~\times R_j} Cj =Sj i=1∑n (1−rij )=Sj ×Rj文章来源:https://www.toymoban.com/news/detail-681584.html
- 计算每个指标的客观权重:
W j = C j ∑ j = 1 p C j \mathrm{W_j=\frac{C_j}{\sum_{j=1}^pC_j}} Wj=∑j=1pCjCj文章来源地址https://www.toymoban.com/news/detail-681584.html
代码实现
%%对比性
function [Score,w]=mfunc_CRITIC(data1)
% CRITIC方法:求解每个指标对应的客观权重算法
% paramts:
% data1: 原始数据矩阵,(m,n) m为评价对象,n为评价指标
% returns:
% Score:每个评价对象的综合得分
% w: 所有指标的客观权重
% 计算标准差
STD=std(data1);
%%矛盾性
r=corr(data1);%计算指标间的相关系数
f=sum(1-r);
%%信息承载量
c=STD.*f;
%计算所有指标的权重
w=c/sum(c);
%计算得分
[m,~]=size(data1);
data= data1 ./ repmat(sum(data1.*data1) .^ 0.5, m, 1); %矩阵归一化
% data=mapminmax(data1',0.002,1);%标准化到0.002-1区间
% data=data';
s=data*w';
Score=100*s/max(s);
end
到了这里,关于数学建模:CRITIC赋权法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!