数学建模 层次分析法 python计算权重

2023-11-10

这里用python语言来计算判断矩阵的权重,网上大部分是matlab语言,里面也包含一致性检验的函数,具体各函数使用方法详见代码注释的部分

import numpy as np
a=np.array([[1, 1 / 4, 2, 1 / 3], [4, 1, 8, 2], [1 / 2, 1 / 8, 1, 1 / 5], [3, 1 / 2, 5, 1]])

#一致性检验判断矩阵函数,传入矩阵,RI和矩阵的维数,可用返回1否则返回0,注意只有不对称矩阵需要检验
def consistencyTest(juzhen,RI,n):
    '''一致性检验步骤:
       n阶正互反矩阵
      ①计算CI  CI = (最大特征值-n)/(n-1)
      ②根据n找RI
      ③计算 CI/RI 的值,若小于0.1则说明这个矩阵能用,若大于0.1需要对矩阵的数据进行调整
    '''
    t, temp = np.linalg.eig(juzhen)
    max_eig = max(t)
    CI = (max_eig - n)/(n-1)
    CR = CI/RI
    if CR<0.1:
        return 0
    else:
        return 1


'''
以下是计算权重的部分
共有三种方法: ①算术平均法 qz_average
            ②几何平均法 qz_geometry
            ③特征值法   qz_deature

'''

#以下是算数平均法求权重,需要传入判断矩阵及矩阵的行数和列数,这个矩阵是方阵因此只传一个就可以了
def qz_average(juZhen,n):
    '''算数平均法:
                  ①将各列归一化
                  ②将归一化后的矩阵的各列相加成一个列向量
                  ③将这个列向量除以n,n为原列数
    '''
    #先定义一个temp便于存储最后的权重向量
    temp = np.zeros((n, 1))
    #第一步,先归一化操作,每一列都需要归一化
    for i in range(n):
        sum = 0
        for j in range(n):
            sum = sum+ a[j][i]
        for k in range(n):
            juZhen[k][i]=juZhen[k][i]/sum
    #第二步和第三步,然后各列相加求和并除以n
    for i in range(n):
        sum1 = 0
        for j in range(n):
            sum1 += juZhen[i][j]
        temp[i][0] = sum1/n
    print("算数平均法对应的权重向量为:")
    print(temp)
qz_average(a,4)

#以下是几何平均法,需要传入这个判断方阵和方阵的行
def qz_geometry(juzhen,n):
    '''几何平均法:
                ①将各列的元素按行相乘得一个新的列向量
                ②将这个列向量开n次方,n为原列数
                ③将这个列向量归一化
    '''
    #这里先创造一个temp的n行一列数组便于存储最后的权重向量
    temp = np.ones((n, 1))
    #然后是第一步,将各列的元素按行相乘存入temp中
    for i in range(n):
        for j in range(n):
            temp[i][0] *= juzhen[i][j]
    #第二步,开n次方
    temp = temp**(1/n)
    #第三步归一化操作,定义个sum存储和,然后将temp的每个元素除以这个和即可成功归一化
    sum = 0
    for i in range(n):
        sum += temp[i][0]
    for i in range(n):
        temp[i][0] /=sum
    print("几何平均法算出的权重向量为")
    print(temp)
qz_geometry(a,4)

#以下是特征值法求权重
def qz_feature(juzhen,n):
    '''特征值法:
                ①求出矩阵A的最大特征值及其对应的特征向量
                ②对求出的特征向量进行归一化 结果即是我们的权重
    '''
    #第一步,先用下面这个函数求所有的特征值和特征向量,t中存所有的特征值,temp中存这个判断矩阵的特征向量
    t,temp = np.linalg.eig(juzhen)

    #找需要的那个特征向量,找最大特征值对应的那一列,一般就是第一列
    temp1 = np.zeros((n, 1))
    for i in range(n):
       temp1 [i][0] = temp[i][0].real  #这里只取实数部分,否则后面会报错复数溢出

    #找到对应的特征向量了,对其进行归一化即是权重向量
    sum = 0
    for i in range(n):
        sum +=temp1[i][0]
    temp1 /=sum
    print("特征法求的权重向量为:",temp1,sep = "\n")
qz_feature(a,4)


数学建模比赛使用注意:
①代码查重问题,自己一定要修改内容
②如果数据过于庞大,输入比较麻烦,我在想是否能够用类似matlab的工作区来给给矩阵变量赋值,但是由于python语言学的不精目前我还没找到这种方法,希望会的大佬给蒟蒻分享一下,如果我找到的话我会更新完善这一片博客

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

数学建模 层次分析法 python计算权重 的相关文章

随机推荐

  • linux虚拟化cpu的绑定,为虚拟机vCPU绑定物理CPU

    使用taskset命令将vCPU线程绑定到指定的物理CPU 例如 某虚拟机的qemu进程及两个vCPU线程如下 root kelvin ps eLo ruser pid ppid lwp psr args grep qemu grep v
  • vue项目内存溢出

    报错信息 终端安装包 npm install increase memory limit fixbug cross env g package json的script中添加如下代码 fix memory limit cross env LI
  • 解决nginx反响代理web service的soap:address location问题

    问题 通过nginx代理webservice soap address location不是nginx的代理地址 而是原始地址 解决方法如下 nginx配置改为 upstream webservice server 192 168 3 13
  • Windows1.0到Windows10三十年进化史,你还记得自己最初使用的系统吗?

    从1985年Windows 1 0正式诞生到2015年Windows 10诞生 微软花了三十年的时间 从像素化桌面到现在扁平化的界面 让我们来看一下Windows 1 0到Windows10三十年来的变化 1 1985年11月20日 微软发
  • 计算共形几何是计算机科学和,科学网—计算共形几何概览 - 顾险峰的博文

    如果您觉得以下内容比较生疏 不必过于焦虑 请继续关注本公众号 我们将会详尽解释以下所涉及的概念 定理 算法和应用 在未来岁月中 让我们共同学习 共同成长 计算共形几何是计算机科学和纯粹数学之间的交叉学科 其目的是将现代几何 经典几何的概念和
  • 【论文阅读】How transferable are features in deep neural networks?

    研究目标 问题陈述 训练在图像上的深度神经网络 往往前面一层或几层学到的特征都是类似Gabor filters or color blobs的特征 作者叫它们first layer features 这些特征是所有图像所共有的特征 作者叫它
  • gerrit push (change closed)解决办法

    Remember DESKTOP MEFCTAV MINGW64 Desktop VFC vnfres master git push origin HEAD refs for master Enumerating objects 27 d
  • docker 全局日志控制

    vim etc docker daemon json log driver json file log opts max size 1g max file 1 max size 500m 意味着一个容器日志大小上限是500M max fil
  • 网站主题切换

    文章目录 网站主题切换 前言 思路 全部写在 style 属性中 全部写在外部 css 文件中 引用不同的 link 文件 通过 class 命名空间的方式 webpack 插件 webpack theme color replacer 实
  • 【论文翻译+笔记】Neural Machine Reading Comprehension: Methods and Trends

    1 Introduction 过去的MRC技术的特点 hand crafted rules or features 缺点 不能泛化 performance may degrade due to large scale datasets of
  • ADC转换不准确?启用内部参考电压缓冲器 (VREFBUF)

    电压基准缓冲器VREFBUF 一 VREF 描述 1 VDDA 有时与VREF 键合 2 VREF 与 VREF 3 VREF 作用 二 VREFBUF 电压参考缓存器 1 简介 2 功能描述 3 VREFBUF 修边 三 VREFBUF寄
  • 【第40篇】TransFG:用于细粒度识别的 Transformer 架构

    TransFG 用于细粒度识别的 Transformer 架构 摘要 介绍 相关工作 细粒度视觉分类 Transformer 方法 视觉转换器作为特征提取器 TransFG 架构 实验 实验设置 消融研究 定性分析 结论 摘要 论文地址 h
  • stm32cubemx使用mpu6050

    文章目录 接线图 代码 常见问题 接线图 一般情况下 大家买的 mpu 6050 有两种 1 就是 单个的 mpu6050 芯片 2 就是 mpu6050 模块 如果 是第一种情况的话 大家可以参考 下图所示 如果是第二种情况的话 一般来说
  • 简易自动电阻测试仪

    这次练习的题目是2011年的简易自动电阻测试仪 设计并制作一台简易自动电阻测试仪 要求就是测量量程为 100 1k 10k 10M 四档 并且前三档可以自动切档 3 位数字显示 最大显示数必须为 999 能自动显示小数点和单位 测量速率大于
  • Feign简介与简单应用

    一 点睛 Feign是Netflix开发的声明式 模板化的HTTP客户端 Feign可以帮助我们更快捷 优雅地调用HTTP API 在Spring Cloud中 使用Feign非常简单 创建一个接口 并在接口上添加一些注解 代码就完成了 F
  • 注册小鲸鱼88888专用网站

    点击注册充值即可 高效不限速 不限设备 注意这里的地址并没有错 只是你需要想办法正确能进入就行 懂的大佬一定知道用一定的方法访问的 有问题的话可以邮箱 grantwtt 163 com
  • Warning: failed to get default registry endpoint from daemon

    操作系统 CentOS 7 执行命令 docker info docker search docker pull 执行用户 非root 有sudo权限 Docker报错 1 报错现象及原因 2 其它报错 3 配置docker开机自启动 1
  • FFmpeg进阶: 音频变声滤镜

    声音最重要的两个元素就是语速和语调 改变声音的辨识度主要也是从这两方面入手 我们可以通过对音频数据进行插值或者抽值修改 以达到降低语速和增加语速的目的 同时我们也可以通过对数据进行线性拉伸来调节音调 语速调整 语调调整 就可以让我们的声音千
  • QtCreator编译 fatal error: Killed signal terminated program cc1plus问题解决

    原因 编译器消耗的内存超过了系统的限制 强制停止了 解决方式 减少编译时进程数量 make j4
  • 数学建模 层次分析法 python计算权重

    这里用python语言来计算判断矩阵的权重 网上大部分是matlab语言 里面也包含一致性检验的函数 具体各函数使用方法详见代码注释的部分 import numpy as np a np array 1 1 4 2 1 3 4 1 8 2