一、引言在进行综合评价的过程中权重的确定确实是很重要的,对最终的结果会起着决定性的影响。现在大多数采用的都是主客观结合的组合赋权法。主观赋权用的最多的是AHP,客观赋权用的多的是熵值法、粗糙集的方法,正如楼主所讲的,客观赋权完全依赖于样本数据,当样本数据变化时,权重也会发生变化,从统计规律来讲,随着样本容量的增加,权重的变化应该越来越小,最终趋于一个稳定的值,但在我们实际的评价过程中不可能让样本数达到足够大,因此我们实际还是要把整个评价系统看作是一个不确定性的系统,运用已知的信息来最大限度的挖掘系统的规律,所以我们在有限样本下求出的只能是近似值。主观权重方法简单,但人为因素太强;客观权重又过于依赖样本,这两种方法都存在着信息的损失,采用组合赋权就是最大限度的减少信息的损失,使赋权的结果尽可能的与实际结果接近。现在组合赋权的核心问题在于如何确定两种方法的权重分配,目前这方面的研究比较多,但个人认为大部分方法的数学推导过于繁琐,应用性比较差,基本上不具备可操作性,至于如何准确的
进行组合赋权,现在似乎还没有一套很好的方法。 二、主观赋权:层次分析法AHP2.1 优缺点优点:它完全依靠主观评价做出方案的优劣排序,所需数据量少,决策花费的时间很短。从整体上看,AHP在复杂决策过程中引入定量分析,并充分利用决策者在两两比较中给出的偏好信息进行分析与决策支持,既有效地吸收了定性分析的结果,又发挥了定量分析的优势,从而使决策过程具有很强的条理性和科学性,特别适合在社会经济系统的决策分析中使用。 缺点:用AHP进行决策主观成分很大。当决策者的判断过多地受其主观偏好影响,而产生某种对客观规律的歪曲时,AHP的结果显然就靠不住了。 适用范围:尤其适合于人的定性判断起重要作用的、对决策结果难于直接准确计量的场合。要使AHP的决策结论尽可能符合客观规律,决策者必须对所面临的问题有比较深入和全面的认识。另外,当遇到因素众多,规模较大的评价问题时,该模型容易出现问题,它要求评价者对问题的本质、包含的要素及其相互之间的逻辑关系能掌握得十分透彻,否则评价结果就不可靠和准确。 改进方法: (1) 成对比较矩阵可以采用德尔菲法获得。 (2) 如果评价指标个数过多(一般超过9个),利用层次分析法所得到的权重就有一定的偏差,继而组合评价模型的结果就不再可靠。可以根据评价对象的实际情况和特点,利用一定的方法,将各原始指标分层和归类,使得每层各类中的指标数少于9个。 2.2 基本步骤步骤一、建立递阶层次结构模型:目的层,准则层,方案层1 ~: P( j8 Z+ Z# ?5 t+ ?
步骤二、构造出各层次中的所有判断矩阵;判断矩阵为两两指标重要性的判断,一般判别矩阵构造如下。 $ z3 l' i1 E2 [* Y; G8 b+ M: d
: A; q* K2 E* ]; P& `
" H9 S9 A- I6 U D
步骤三:层次单排序及一致性检验;
; K$ e" t; U6 |' _+ Z6 I
! Z2 ?: W, C! Z8 E+ T
步骤四:层次总排序及一致性检验整套算法实际上是用了两次重要性权重。 准则层,从准则的重要性矩阵(nxn矩阵)中,抽取重要性权重。它的现实意义是 每个准则的重要程度,也就是步骤三。 方案层,对每个准则,m个方案都有个mxm矩阵(总共是n个mxm矩阵)。也就是说,对每个准则,都可以算出m个方案的重要性权重。 然后n个重要性权重组合起来,与准则层的重要性权重相乘。就得到了每个方案的重要性权重,也就是层次总排序。 2.3 程序实现" c9 b! w5 _! Y5 m
class AHP:
7 }- P/ @3 q4 Y! {1 D. \ def __init__(self, criteria, b):2 ]# p( q* q/ c# C
self.RI = (0, 0, 0.58, 0.9, 1.12, 1.24, 1.32, 1.41, 1.45, 1.49)+ G" z& u, T$ A
self.criteria = criteria; {7 f: S4 a/ u8 w
self.b = b* {4 W8 h& g% w" R; p( f/ `5 |
self.num_criteria = criteria.shape[0]
0 A# T* S' h# L+ M3 N% |! f self.num_project = b[0].shape[0]
% } C3 a" _9 G. i' e+ f! D2 K: u* `2 i+ E v3 X6 }
def cal_weights(self, input_matrix):
* _. V/ T# V! @ D8 @8 X input_matrix = np.array(input_matrix)5 X2 O, r! z- n2 R
n, n1 = input_matrix.shape
4 k7 Q7 V2 ^+ y% D; L6 Z' k assert n == n1, '不是一个方阵'
) u0 i( C6 K6 ~/ K `- C5 ` for i in range(n):: {4 m7 l2 J6 k4 p, h# n0 Y2 x
for j in range(n):6 c' T) Q8 u3 u, @$ m
if np.abs(input_matrix[i, j] * input_matrix[j, i] - 1) > 1e-7:
) D$ G3 q8 c: U8 | raise ValueError('不是反互对称矩阵')
& ~2 L H( v4 I/ V, u
, N+ K) \9 g2 a) k5 b m* ^' f6 K eigenvalues, eigenvectors = np.linalg.eig(input_matrix)
! G( C4 W) x7 s5 ?- Y) }2 L! [. [: s1 p; {8 d1 Y
max_idx = np.argmax(eigenvalues)
Y, p# Y( p( {% z max_eigen = eigenvalues[max_idx].real+ t1 W- B+ ]8 o2 X' k6 u
eigen = eigenvectors[:, max_idx].real! S2 b9 z" U& h7 L: Q
eigen = eigen / eigen.sum()) N. a# ~$ i9 B6 V& L& p
) Q! N- U! F5 o( K5 @: z
if n > 9:
2 u) B. j& q$ q: j, d+ B, ` CR = None
; ~6 L, z' a& z9 k& g/ [ |& n warnings.warn('无法判断一致性')' _1 V4 d' \: m
else:
1 [0 n2 @5 t; a% D8 R: Z CI = (max_eigen - n) / (n - 1)
h5 ^% C/ b+ ^ CR = CI / self.RI[n]
: [: v% S/ Z3 v5 W$ b return max_eigen, CR, eigen
( T$ @0 L, C6 X' X8 `9 C& ~
' w9 ?: @) C7 p; d# f# z2 |" I8 Z def run(self):2 A3 F$ y* ^$ Q s- C4 r0 K L
max_eigen, CR, criteria_eigen = self.cal_weights(self.criteria)
! `0 g+ u: U# O print('准则层:最大特征值{:<5f},CR={:<5f},检验{}通过'.format(max_eigen, CR, '' if CR < 0.1 else '不'))
! l0 I* @3 p8 D A print('准则层权重={}\n'.format(criteria_eigen))9 S$ B' G. E5 y6 S2 H( {
3 n+ |6 T4 P; {8 ~; I. [; L9 h) _- e
max_eigen_list, CR_list, eigen_list = [], [], []+ \# J6 k/ m8 j# L5 F
for i in self.b:* B. u/ F) o' w; K9 p& H$ L, m
max_eigen, CR, eigen = self.cal_weights(i)0 g4 {" a4 N' i: }+ {
max_eigen_list.append(max_eigen)* r- \% u% b0 j$ X
CR_list.append(CR)
) r9 G1 X+ {) R: e eigen_list.append(eigen)
% O. f( l% X2 U+ b* F: G
) x1 f& O6 i/ N7 B8 N" S pd_print = pd.DataFrame(eigen_list,
: ?" T( n) i9 r7 l index=['准则' + str(i) for i in range(self.num_criteria)],6 R$ _+ l7 j& M+ L% y" |
columns=['方案' + str(i) for i in range(self.num_project)],
* x5 l! i$ G f* ?) l! | )
! ?) O$ h8 f( d7 G7 V7 p1 ^' q pd_print.loc[:, '最大特征值'] = max_eigen_list, O9 A0 F: t- h' V# p
pd_print.loc[:, 'CR'] = CR_list
: Q7 A3 z s# E% C# k+ X% ~ pd_print.loc[:, '一致性检验'] = pd_print.loc[:, 'CR'] < 0.1
, z0 {' Q* o; r" I! [/ E4 Q: C7 j( W print('方案层')
% L L- b) T5 j! c, X n: x6 h/ ? print(pd_print)0 ?8 K: k6 M* e. Z# J/ a
! P0 s% p- Q X, `6 w
# 目标层
1 A' ]0 T7 F: M6 ~) x1 e obj = np.dot(criteria_eigen.reshape(1, -1), np.array(eigen_list))
8 b, `1 h. M* j) Y1 v0 }" Y) F print('\n目标层', obj)
8 @1 L9 c/ v2 O$ y9 Q" ~ print('最优选择是方案{}'.format(np.argmax(obj)))6 l9 R: W$ I) f) y% m
return obj5 Z5 _6 |9 j* e. M; ]( ?
8 L7 c/ V0 ]3 e3 S o二、客观赋权因子分析、熵权法等,不再赘述,见yys
( x6 J; H/ ~% p3 Z- s三、组合赋权常见的主要有:方差最大化赋权法、最佳协调赋权法、组合目标规划法,组合最小二乘法。
: X# ?& a0 s: _7 J. f2 Y0 O
8 S, R7 g2 J) H$ |$ Y$ V( M6 P7 K
0 V- M# F0 l; B9 N! f |