变异系数法之python

变异系数法之python1.简介2.算法原理2.1指标正向化2.2数据标准化2.3计算变异系数2.4计算权重以及得分3.实例分析3.1读取数据3.2指标正向化3.3查看行数和列数3.4数据标准化3.5计算变异系数3.6计算权重3.7计算得分完整代码

大家好,又见面了,我是你们的朋友全栈君。

目录

1.简介

2.算法原理

2.1 指标正向化

2.2 数据标准化

2.3 计算变异系数

2.4 计算权重以及得分

3.实例分析

3.1 读取数据

3.2 指标正向化

3.3 查看行数和列数

3.4 数据标准化

3.5 计算变异系数

3.6 计算权重

3.7 计算得分 

完整代码 


1.简介

        变异系数法(Coefficient of variation method)又称”标准差率”(标准差与平均数的比值)是直接利用各项指标所包含的信息,通过计算得到指标的权重。是一种客观赋权的方法。此方法的基本做法是:在评价指标体系中,指标取值差异越大的指标,也就是越难以实现的指标,这样的指标更能反映被评价单位的差距。例如,在评价各个国家的经济发展状况时,选择人均国民生产总值(人均GNP)作为评价的标准指标之一,是因为人均GNP不仅能反映各个国家的经济发展水平,还能反映一个国家的现代化程度。如果各个国家的人均GNP没有多大的差别,则这个指标用来衡量现代化程度、经济发展水平就失去了意义。

2.算法原理

2.1 指标正向化

        和熵权法的指标正向化类似,正向指标越大越好,负向指标越小越好。把指标都转化成正向指标处理。此篇采用新的正向化形式,采用上一篇建模算法熵权法的处理形式也可,基本思想不变就行。这个数据集有正向指标(越大越优型指标)和负向指标(越小越优型指标)两种。

        设有m个待评对象,n个评价指标,可以构成数据矩阵X=(xij)m*n,设数据矩阵内元素,经过指标正向化处理过后的元素为xij’

负向指标:并网点电压偏差越限次数D、有功控制能力F、功率因数越限G属于此类指标

变异系数法之python

正向指标:其余所有指标属于此类,可以不用处理

变异系数法之python

2.2 数据标准化

        每个指标的数量级不一样,需要把它们化到同一个范围内比较。上一篇建模算法用到了最大最小值标准化方法。此篇可以用一个新的标准化方法,处理如下:

        设标准化后的数据矩阵元素为rij,由上可得指标正向化后数据矩阵元素为xij’

变异系数法之python

2.3 计算变异系数

处理过后可以构成数据矩阵R=(rij)m*n

  • 计算指标的均值:

变异系数法之python

  •  计算指标的标准差:

变异系数法之python

  •  计算变异系数:

变异系数法之python

2.4 计算权重以及得分

  • 权重为

变异系数法之python

  • 得分为

变异系数法之python

3.实例分析

风场名 风场1 风场2 风场3
A(高频率穿越能力) 0.743 0.7567 0.8104
B(低频率穿越能力) 0.8267 0.8033 0.7667
C(低压穿越能力) 0.8324 0.8736 0.8539
D(并网点电压偏差越限次数 ) 12 10 16
E(SVC/SVG响应性能指标) 0.8637 0.8538 0.9038
F(有功控制能力) 0.0743 0.0665 0.0881
G(功率因素越限) 0.0409 0.0716 0.0657

3.1 读取数据

读取表中全部数据

#导入数据
data=pd.read_excel('D:\桌面\变异系数.xlsx')
print(data)

返回:

变异系数法之python

只读取表中数值

label_need=data.keys()[1:]
data1=data[label_need].values
print(data1)

返回:

 变异系数法之python

3.2 指标正向化

#数据正向化处理
data2=data1
index=[3,5,6] #越小越优指标位置,注意python是从0开始计数,对应位置也要相应减1
k=0.1
for i in range(0,len(index)):
    data2[:,index[i]]=1/(k+max(abs(data1[:,index[i]]))+data1[:,index[i]])
print(data2)

返回:

变异系数法之python

3.3 查看行数和列数

#行数和列数
[m,n]=data1.shape
print(m,n)

返回:

 变异系数法之python

3.4 数据标准化

#数据标准化
data3 = data2
for j in range(0,n):
    data3[:,j]=data2[:,j]/np.sqrt(sum(np.square(data2[:,j])))
print(data3)

返回:

变异系数法之python

3.5 计算变异系数

#计算变异系数
A=np.average(data3, axis=0) #计算均值
S=np.std(data3, axis=0) #计算标准差
V=S/A #计算变异系数
print('变异系数:',V)

返回:

变异系数法之python

3.6 计算权重

# 计算权重
w=V/sum(V)
print('权重:',w)

返回:

变异系数法之python

3.7 计算得分 

#计算得分
s=np.dot(data3,w)
Score=100*s/max(s)
for i in range(0,len(Score)):
    print(f"第{i+1}个风场百分制得分为:{Score[i]}")

返回:

变异系数法之python

完整代码 

#导入库
import pandas as pd
import numpy as np
#导入数据
data=pd.read_excel('D:\桌面\变异系数.xlsx')
# print(data)
label_need=data.keys()[1:]
data1=data[label_need].values
# print(data1)

#数据正向化处理
data2=data1
index=[3,5,6] #越小越优指标位置,注意python是从0开始计数,对应位置也要相应减1
k=0.1
for i in range(0,len(index)):
    data2[:,index[i]]=1/(k+max(abs(data1[:,index[i]]))+data1[:,index[i]])
# print(data2)

#行数和列数
[m,n]=data1.shape
# print(m,n)

#数据标准化
data3 = data2
for j in range(0,n):
    data3[:,j]=data2[:,j]/np.sqrt(sum(np.square(data2[:,j])))
# print(data3)

#计算变异系数
A=np.average(data3, axis=0) #计算均值
S=np.std(data3, axis=0) #计算标准差
V=S/A #计算变异系数
# print('变异系数:',V)

# 计算权重
w=V/sum(V)
# print('权重:',w)

#计算得分
s=np.dot(data3,w)
Score=100*s/max(s)
for i in range(0,len(Score)):
    print(f"第{i+1}个风场百分制得分为:{Score[i]}")
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/131487.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • [分享]在线的代码片段测试工具 jsbin[通俗易懂]

    [分享]在线的代码片段测试工具 jsbin[通俗易懂]有些时候,我们往往有这样的需求:临时测试一个代码片段,不想打开编辑器来新建一个文件,测试完毕又删除想给别人分享一个代码,html文件,css文件,js文件,打个包?向别人展个某个效果,发个文件过去?把代码部署到自己服务器上面?针对这些需求,我们使用在线的代码片段测试工具,也许来得更加简单和方便了。针对前端的在线代码片段工具很多,比较常见的有jsbin和jsfiddle以及codepen.而我最喜欢的就是jsbin了,它有着更多的特性给我带来了极大的方便:任意控制要展示的窗口点击这些标

    2025年7月31日
    3
  • 》》css3–动画[通俗易懂]

    <!DOCTYPEhtml><html><head><metacharset=”utf-8″/><title>功能特权-QQ登录</title><linkrel=”ShortcutIcon”href=”im…

    2022年4月13日
    60
  • python中的补码

    python中的补码

    2020年11月8日
    213
  • CEGUI环境的搭配[通俗易懂]

    CEGUI环境的搭配[通俗易懂]提前准备工具及安装包:1、CMake:一款编译工具下载地址2、CEGUI的源码及依赖项第一个箭头所指,代表是Windows系统的源码包,第二个则是Unix和Linux系统的源码包。配置环境步骤(针对windows平台,图形化操作)Linux下,或者Windows下dos命令也可以完成相应操作,输入相关命令即可。将源码包以及依赖项进行解压如:然后打…

    2022年7月24日
    9
  • angular面试题及答案_angular面试

    angular面试题及答案_angular面试1.生命周期钩子生命周期的顺序,见下图:ngOnChanges:当组件数据绑定的输入属性发生变化是触发,该方法接收一个SimpleChanges对象,包括当前值和上一个属性值。首次调用一定发生在ngOnInit前,值得注意的是该方法仅限于对象的引用发生变化时才会触发。 ngOninit:初始化指令或组件,在angular第一次显示展示组件的绑定属性后调用,该方法只会调用一次 ng…

    2022年10月17日
    2
  • 浙江:9月起中小学增加体育活动时间

    浙江:9月起中小学增加体育活动时间  新华网杭州8月23日电(记者屈凌燕)为保证小学生每天1小时体育活动时间,浙江省教育厅日前对中小学教学计划作出调整,从9月的新学年起,中小学增加体育活动时间,例如小学1、2年级体育课程由原每周3课时增至4课时。  从新学年起,…

    2022年5月13日
    36

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号