|
这段代码实现了熵权法模型的权重计算。下面是代码的解释: 函数定义: ( F3 O5 ?8 R, w- |
- 函数名为shang,接受三个输入参数:x(决策矩阵),standard(是否已经处理化),flag(判断类型)。
- 返回权重向量w。7 f( _0 |; F6 i. C H& i: P6 U
变量初始化: 6 C L, h5 ~( X# R ?' v, i
- 获取决策矩阵x的最小值a和最大值b。
- 获取决策矩阵的行数rows和列数cols。
- 如果函数调用时只提供两个参数,并且standard为0(表示尚未进行处理),则将flag设置为全1向量(表示所有指标都是高优指标)。
2 @9 q( r6 h8 m0 ?' G$ h$ r7 u; b+ v
标准化指标: ) T% D6 v" J- x" U' A
- 如果参数standard为0,表示决策矩阵尚未进行处理化。
- 使用循环将决策矩阵x的每个元素进行标准化处理。* z5 m5 g% C' A- q7 j
- 如果flag(j)为1,表示该指标为高优指标,使用线性映射将值映射到0到1之间。
- 否则,表示该指标为低优指标,使用线性映射将值映射到1到0之间。0 }2 c$ _. }6 K a4 T O1 v
计算概率矩阵p:
9 ]1 T$ y' \8 r z+ m9 q& D- 计算标准化矩阵x每列的和he。
- 使用循环计算概率矩阵p,即将标准化矩阵x的每个元素除以对应列的和he(j)。8 k; n( T3 H% m+ F* D6 b
指标归一化: ' f, [6 R9 }& F( B7 f5 r
- 使用循环将概率矩阵p的每个元素进行指标归一化处理。: d! ]7 h9 D( T6 z& A# k
- 如果p(i,j)等于0,将z(i,j)设置为0。
- 否则,将z(i,j)设置为p(i,j)的自然对数log(p(i,j))。
1 ]2 K: u! N1 N/ U% G
计算e值: 3 R0 Q( K- \% I# u C* G
- 初始化e为大小为1 x cols的零向量。
- 对概率矩阵p和归一化矩阵z进行逐元素乘积得到矩阵Q。
- 使用循环计算e值,即对Q的每列求和,乘以常数k。
' f2 q# e+ E) E1 T
计算权重w: " G* U! ?$ p; B8 J( f- O
- 计算e值的和he。
- 使用循环计算权重w,即将(1 - e(i))除以(cols - he)。该步骤将权重归一化,使得所有权重之和为1。
& {0 ?9 {" k* N4 b, ]
该函数的作用是根据熵权法模型,计算决策矩阵中每个指标的权重。熵权法模型是一种多指标决策方法,通过标准化指标和概率计算,得到每个指标的权重,用于综合评价和决策分析。
; i3 c: t$ q3 }/ q2 D4 ?) K7 F( @. l3 Y( x5 y0 }% T! H
) p# \9 ?5 M" F0 {% P |