数学建模--层次分析法(代码Python实现)

# A = [[1,1,4,1/3,3],
#      [1,1,4,1/3,3],
#      [1/4,1/4,1,1/3,1/2],
#      [3,3,3,1,3],
#      [1/3,1/3,2,1/3,1]]
  • 该函数不包含判断矩阵是否为正互反矩阵,并且,如果矩阵已是一致矩阵,则不需要判断

有关模型的介绍参考链接: 层次分析法.

import numpy as np  #导入所需包并将其命名为np
def ConsisTest(X):  #函数接收一个如上述A似的矩阵
#计算权重
  #方法一:算术平均法
    ## 第一步:将判断矩阵按照列归一化(每个元素除以其所在列的和)
    X = np.array(X)  #将X转换为np.array对象
    sum_X = X.sum(axis=0)  #计算X每列的和
    (n,n) = X.shape  #X为方阵,行和列相同,所以用一个n来接收
    sum_X = np.tile(sum_X,(n,1))  #将和向量重复n行组成新的矩阵
    stand_X = X/sum_X  #标准化X(X中每个元素除以其所在列的和)
    
    ## 第二步:将归一化矩阵每一行求和
    sum_row = stand_X.sum(axis=1)

    ## 第三步:将相加后得到的向量中每个元素除以n即可得到权重向量
    print("算数平均法求权重的结果为:")
    print(sum_row/n)
    
  #方法二:特征值法
    ## 第一步:找出矩阵X的最大特征值以及其对应的特征向量
    V,E = np.linalg.eig(X)  #V是特征值,E是特征值对应的特征向量
    max_value = np.max(V)  #最大特征值
    #print("最大特征值是:",max_value)
    max_v_index = np.argmax(V)  #返回最大特征值所在位置
    max_eiv = E[:,max_v_index]  #最大特征值对应的特征向量
    
    ## 第二步:对求出的特征向量进行归一化处理即可得到权重
    stand_eiv = max_eiv/max_eiv.sum()
    print("特征值法求权重的结果为:")
    print(stand_eiv)
    print("———————————————————————————————")
#一致性检验
    ## 第一步:计算一致性指标CI
    CI = (max_value-n)/(n-1)
    ## 第二步:查找对应的平均随机一致性指标RI
    RI = np.array([15,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])
    ## 第三步:计算一致性比例CR
    CR = CI/RI[n]
    if CR < 0.1:
        print("CR=",CR,",小于0.1,通过一致性检验")
    else:
        print("CR=",CR,",大于等于0.1,没有通过一致性检验,请修改判断矩阵")
    return None
#ConsisTest(A)
  • 10
    点赞
  • 55
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
层次分析法(Analytic Hierarchy Process,AHP)是一种用于多准则决策的方法,其目标是通过对准则的相对重要性进行定量评估,并对各个备选方案进行排序。下面是一个使用Python实现AHP的代码示例: ```python import numpy as np from numpy import linalg class AHP: def __init__(self, matrix): self.matrix = matrix def cal_weight_by_arithmetic_method(self): n = len(self.matrix) b = np.sum(self.matrix, axis=0) normal_a = self.matrix / b average_weight = np.mean(normal_a, axis=1) return average_weight def cal_weight_by_geometric_method(self): n = len(self.matrix) b = np.prod(self.matrix, axis=1) c = np.power(b, 1/n) average_weight = c / np.sum(c) return average_weight def cal_weight_by_eigenvalue_method(self): n = len(self.matrix) w, v = linalg.eig(self.matrix) eigenvalue = np.max(w) eigenvector = v[:, np.argmax(w)] average_weight = eigenvector / np.sum(eigenvector) return average_weight # 示例用法 if __name__ == "__main__": b = np.array([[1, 1/3, 1/8], [3, 1, 1/3], [8, 3, 1]]) ahp = AHP(b) weight1 = ahp.cal_weight_by_arithmetic_method() weight2 = ahp.cal_weight_by_geometric_method() weight3 = ahp.cal_weight_by_eigenvalue_method() ``` 这段代码实现了AHP的算术平均法、几何平均法和特征值法,可以根据输入的判断矩阵计算出相应的权重。其中,`cal_weight_by_arithmetic_method()`函数实现了算术平均法,`cal_weight_by_geometric_method()`函数实现了几何平均法,`cal_weight_by_eigenvalue_method()`函数实现了特征值法。每个方法返回的是一个代表权重的一维数组。 请注意,代码中使用了NumPy库进行矩阵运算和线性代数计算。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [数学建模——层次分析法Python代码](https://blog.csdn.net/qq_45934521/article/details/118972017)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [AHP层次分析法python代码讲解(处理论文、建模)](https://blog.csdn.net/knighthood2001/article/details/127519604)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值