首页 > 编程语言 >数学建模——Topsis法(Python代码)

数学建模——Topsis法(Python代码)

时间:2024-07-07 19:58:17浏览次数:21  
标签:Topsis Python 矩阵 建模 指标 print ans np 正向

Topsis法

        Topsis法是一种常用的综合评价方法,能充分利用原始数据的信息,其结果能精确反映各评价方案之间的差距。该方法对数据分布及样本含量没有严格限制,数据计算简单易行。

        基本过程为先将原始数据矩阵统一指标类型(一般正向化处理)得到正向化的矩阵,再对正向化的矩阵进行标准化处理以消除各指标量纲的影响,并找到有限方案中的最优方案和最劣方案,然后分别计算各评价对象与最优方案和最劣方案间的距离,获得各评价对象与最优方案的相对接近程度,以此作为评价优劣的依据。

步骤

第一步 原始矩阵正向化

        常见的四种指标:

指标名称指标特点例子
极大型(效益型)指标越大(多)越好成绩、GDP增速、企业利润
极小型(成本型)指标越小(少)越好

费用、污染程度、坏品率

中间型指标越接近某个值越好水质量评估时的PH值
区间型指标落在某个区间最好体温、水中植物性营养物量

        将原始矩阵正向化就是要将所有的指标类型统一转化为极大型指标。

        转化公式:

        (1)极小型->极大型:max-x

        (2)中间型->极大型:{{x_{i}}}是一组中间型指标序列,最佳的数值为x_{best},正向化公式为

M=max\left \{ \left | x_{i}-x_{best} \right | \right \}x\tilde{}_{i}=1-\tfrac{\left | x_{i}-x_{best} \right |}{M}

        (3)区间型->极大型:{{x_{i}}}是一组中间型指标序列,最佳的区间为[a,b],正向化公式为

M=max\left \{ a-min\left \{ x_{i} \right \} ,max\left \{ x_{i} \right \}-b\right \}

                                        当x_{i}<a时,x\tilde{}_{i}=1-\tfrac{a-x_{i}}{M}

                                        当a\leqslant x_{i}\leqslant b时,x\tilde{}_{i}=1

                                        当x\tilde{}_{i}> b时,x\tilde{}_{i}=1-\tfrac{x_{i}-b}{M}

第二步 正向化矩阵标准化

        标准化后矩阵=(正向化矩阵每个元素/sqrt(其所在列的元素的平方和))

第三步 计算得分并归一化

        标准化后矩阵Z,定义最大值Z+、最小值Z-。

Z^{+}=\left ( Z_{1}^{+} ,Z_{2}^{+},...,Z_{m}^{+}\right ) =\left ( max\left \{ z_{11},z_{21},...z_{n1} \right \},...,max\left \{ z_{1m},z_{2m},...,z_{nm} \right \} \right )

Z^{-}=\left ( Z_{1}^{-},Z_{2}^{-},...,Z_{M}^{-} \right )=\left ( min\left \{ z_{11},z_{21},...,z_{n1} \right \} ,...,min\left \{ z_{1m},z_{2m},..,z_{mm} \right \}\right )

        定义第i个评价对象与最大值的距离D_{i}^{+}=\sqrt{\sum_{j=1}^{m}\left ( Z_{j}^{+}-z_{ij} \right )^{2}}

        定义第i个评价对象与最小值的距离D_{i}^{-}=\sqrt{\sum_{j=1}^{m}\left ( Z_{j}^{-}-z_{ij} \right )^{2}}

        我们可以计算出第i个评价对象未归一化的得分:S_{i}=\frac{D_{i}^{-}}{D_{i}^{+}+D_{i}^{-}}

        S_{i}越大D_{i}^{+}越小,即越接近最大值。

        再对得分进行归一化,S\tilde{}_{i}=\frac{S_{i}}{\sum_{i=1}^{n}S_{i}}

Python代码实现

import numpy as np

# 数据输入
print('输入参评数目:')
n = int(input())
print('输入指标数目:')
m = int(input())
print('输入类型矩阵:1.极大型,2.极小型,3.中间型,4.区间型')
kind = input().split(" ")

# 输入矩阵转化为numpy数组
print('输入矩阵:')
A = np.zeros(shape=(n, m))
for i in range(n):
    A[i] = input().split(" ")
    A[i] = list(map(float, A[i]))
print('输入矩阵为:\n{}'.format(A))

# 原始矩阵正向化
# 极小型
def minTomax(maxx, x):
    ans = maxx - x
    return np.array(ans)

# 中间型
def midTomax(bestx, x):
    M = max(abs(x - bestx))
    if M == 0:
        M = 1
    ans = 1 - abs(x-bestx)/M
    return np.array(ans)

# 区间型
def regTomax(a,b,x):
    M = max(a-min(x), max(x)-b)
    ans = []
    for i in range(len(x)):
        if x[i] < a:
            ans.append(1-(a-x[i])/M)
        elif x[i] > b:
            ans.append(1-(x[i]-b)/M)
        else:
            ans.append([1])
    return np.array(ans)

X = np.zeros(shape=(n,1))
for i in range(m):
    if kind[i] == '1':
        v = np.array(A[:, i])
    elif kind[i] == '2':
        maxx = max(A[:, i])
        v = minTomax(maxx, A[:, i])
    elif kind[i] == '3':
        print('输入最优值:')
        bestx = eval(input())
        v = midTomax(bestx, A[:, i])
    elif kind[i] == '4':
        print('输入区间[a,b]中a的值:')
        a = eval(input())
        print('输入区间[a,b]中b的值:')
        b = eval(input())
        v = regTomax(a, b, A[:, i])
    if i == 0:
        X = v.reshape(-1, 1)
    else:
        X = np.hstack([X, v.reshape(-1, 1)])
print('统一指标后的矩阵为:\n{}'.format(X))


# 正向化矩阵标准化
X = X.astype('float')
for j in range(m):
    X[:, j] = X[:, j]/np.sqrt(sum(X[:, j] ** 2))
print('标准化后的矩阵为:\n{}'.format(X))

# 计算得分并归一化
Zmax = np.max(X, 0)
Zmin = np.min(X, 0)
Dmax = np.sqrt(np.sum(np.square(np.tile(Zmax, (n, 1))-X), 1))
Dmin = np.sqrt(np.sum(np.square(np.tile(Zmin, (n, 1))-X), 1))
S = Dmin/(Dmax+Dmin)
score = 100 * S/sum(S)
for i in range(len(score)):
    print(f"第{i+1}个标准化后百分制得分为:{score[i]}")

 示例

结果:

标签:Topsis,Python,矩阵,建模,指标,print,ans,np,正向
From: https://blog.csdn.net/2301_76716143/article/details/140243069

相关文章

  • python 调用 bat,传入参数,bat中实现如果有参数传入则读取参数,没有的话就使用内部的变量
    以下是一个Python调用BAT脚本并向其传递参数的示例,同时BAT脚本中会判断是否有参数传入并进行相应处理:Python代码:pythonimportsubprocess#定义要传递的参数parameter="example_parameter"#调用BAT脚本并传递参数subprocess.run(["your_bat_script.b......
  • Python极简美学:用一行代码完成的26个日常任务!
    Python以其简洁优雅著称,能够用最少的代码行数实现强大的功能。本文特别为Python初学者设计,旨在展示Python如何以一行代码解决常见的编程任务,让你体验Python的极简美学。通过这些实例,你不仅能够学习到Python的基础知识,还能掌握一些高效编码的小技巧。1.计算列表平均值number......
  • Python和MATLAB微机电健康推导算法和系统模拟优化设计
    ......
  • 基于Python实现的博客内容推荐系统
    前言大家好!今天来给大家分享一个基于Python实现的博客内容推荐系统。这个项目源自于一个想法:如何为博客用户提供他们最感兴趣的内容。正如大家所知道的,内容推荐系统在电商、视频平台和社交媒体中应用广泛,能显著提升用户体验和平台粘性。那么,如何为我们的博客(比如你自己的W......
  • Python算法模版:图论中的最小生成树算法
        最小生成树具有什么特性,相信学过相关知识的同学知道(没学过的可以自己了解一下),就是说最小生成树的边权值之和最小,相对应的其最大边权也是最小的,适合解决n个城市,m条边,然后叫你求最小划分路径是什么样的。Kruskal算法模版    首先,肯定要对题目所给的数据进......
  • python函数和c的区别有哪些
    Python有很多内置函数(buildinfunction),不需要写头文件,Python还有很多强大的模块,需要时导入便可。C语言在这一点上远不及Python,大多时候都需要自己手动实现。C语言中的函数,有着严格的顺序限制,如果要调用函数,该函数需要在本次调用之前就需要被实现,或者在程序开头事先声明,而Py......
  • python如何查看内置函数
    如何通过命令查看python中的所有内置函数和内置常量举例python版本:利用python中的语句输出python中的所有内置函数及内置常量名:dir(__builtin__)输出一个列表:In [1]: dir(__builtin__)Out[1]:['ArithmeticError','AssertionError','AttributeError','BaseEx......
  • SpringBoot-校园疫情防控系统-93033(免费领源码+开发文档)可做计算机毕业设计JAVA、PHP
    springboot校园疫情防控系统摘 要信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也是技术最为难以攻克的课题。针对校园疫情防控等问题,对校园疫情防控进行研究分析,然后开发设计出......
  • Python——习题练习 part1
     本人于下学期该学习python,在听黑马程序员网课后,在此总结记录我的在课程学习后的习题练习。没有详细的解题过程,仅有代码和注释,如有错误希望大家多多指出。目录一,字符串格式化 二,条件判断01if语句 02ifelse语句 03ifelif组合 04判断语句综合案例 三,循环01......
  • 基于Django+微信小程序的旅游资源信息管理系统(免费领源码+数据库)可做计算机毕业设计JA
    django广西-东盟旅游资源信息管理系统小程序摘 要在社会快速发展和人们生活水平提高的影响下,旅游产业蓬勃发展,旅游形式也变得多样化,使旅游资源信息的管理变得比过去更加困难。依照这一现实为基础,设计一个快捷而又方便的基于小程序的旅游资源信息管理系统是一项十分重要并且......