变异系数法之matlab

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

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

目录

1.简介

2.算法原理

2.1 指标正向化

2.2 数据标准化

2.3 计算变异系数

2.4 计算权重以及得分

3.实例分析

3.1 读取数据

3.2 指标正向化

3.3 数据标准化

3.4 计算变异系数

3.5 计算权重

3.6 计算得分 

完整代码 


1.简介

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

2.算法原理

2.1 指标正向化

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

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

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

变异系数法之matlab

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

变异系数法之matlab

2.2 数据标准化

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

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

变异系数法之matlab

2.3 计算变异系数

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

  • 计算指标的均值:

变异系数法之matlab

  •  计算指标的标准差:

变异系数法之matlab

  •  计算变异系数:

变异系数法之matlab

2.4 计算权重以及得分

  • 权重为

变异系数法之matlab

  • 得分为

变异系数法之matlab

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
ESVC/SVG响应性能指标) 0.8637 0.8538 0.9038
F(有功控制能力) 0.0743 0.0665 0.0881
G(功率因素越限) 0.0409 0.0716 0.0657

3.1 读取数据

data=xlsread('D:\桌面\变异系数.xlsx')

返回:

变异系数法之matlab

3.2 指标正向化

%指标正向    化处理后数据为data1
data1=data;
%%负向指标(越小越优型指标)处理
index=[4,6,7];%负向指标位置
k=0.1;
for i=1:length(index)
  data1(:,index(i))=1./(k+max(abs(data(:,index(i))))+data(:,index(i)))
end

返回:

变异系数法之matlab

3.3 数据标准化

%数据标准化 
data2=data1;
for j=1:size(data1,2)
    data2(:,j)= data1(:,j)./sqrt(sum(data1(:,j).^2));
end
data2

返回:

变异系数法之matlab

3.4 计算变异系数

%计算变异系数
A=mean(data2) %求每列平均值
S=std(data2)  %求每列方差
V=S./A %变异系数

返回:

变异系数法之matlab

3.5 计算权重

%计算权重
w=V./sum(V)

返回:

变异系数法之matlab

3.6 计算得分 

%计算得分
s=data2*w';
Score=100*s/max(s);
for i=1:length(Score)
    %A(i,:)=[row(i), col(i), rho_1(row(i), col(i))];
    fprintf('第%d个风场百分制评分为:%d\n',i,Score(i));   
end

返回:

变异系数法之matlab

完整代码 

clc;clear;
data=xlsread('D:\桌面\变异系数.xlsx');
%指标正向    化处理后数据为data1
data1=data;
%%负向指标(越小越优型指标)处理
index=[4,6,7];%负向指标位置
k=0.1;
for i=1:length(index)
  data1(:,index(i))=1./(k+max(abs(data(:,index(i))))+data(:,index(i)));
end
%数据标准化 
data2=data1;
for j=1:size(data1,2)
    data2(:,j)= data1(:,j)./sqrt(sum(data1(:,j).^2));
end
data2;
%计算变异系数
A=mean(data2); %求每列平均值
S=std(data2);  %求每列方差
V=S./A; %变异系数
%计算权重
w=V./sum(V);
%计算得分
s=data2*w';
Score=100*s/max(s);
for i=1:length(Score)
    %A(i,:)=[row(i), col(i), rho_1(row(i), col(i))];
    fprintf('第%d个风场百分制评分为:%d\n',i,Score(i));   
end
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/130935.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • JAVA为啥要用stream流处理_java哪个部分最难学

    JAVA为啥要用stream流处理_java哪个部分最难学小应学长带你学Java

  • 深度学习 arm linux移植过程整理[通俗易懂]

    深度学习 arm linux移植过程整理[通俗易懂]一、环境搭建下载虚拟机VMwareWorkstation自行下载激活成功教程下载ubtun因运行环境使用ubtun18所虚拟机下载的ubtun18下载比较慢的话可以更换国内镜像https://cn.ubuntu.com/download/server/step1vm中安装ubtun虚拟机https://zhuanlan.zhihu.com/p/141033713下载支持包编译服务器需要安装包makecmake交叉编译链arm-linux-gunebhf例如:ap

  • Lamda表达式 集合的筛选

    Lamda表达式 集合的筛选   在项目中经常会遇到多个集合进行筛选,这时候如果用循环是一种方式,但是有点麻烦,在这里用Lamda表达式,就比较方便了,下面介绍几种方式:查找ListOne中与ListTwo不同的数据varexp2=ListOne.Where(a=>!ListTwo.Where(t=>a.ID==t.ID).Any()).ToList();查找ListOne中与Li…

  • ctpn详解

    ctpn详解一.概述对于复杂场景的文字识别,首先要定位文字的位置,即文字检测。这一直是一个研究热点。文本检测可以看成特殊的目标检测,但它有别于通用目标检测.在通用目标检测中,每个目标都有定义好的边界框,检测出的bbox与当前目标的groundtruth重叠率大于0.5就表示该检测结果正确.文本检测中正确检出需要覆盖整个文本长度,且评判的标准不同于通用目标检测,具体的评判方法参见(ICDAR2017…

    2022年10月22日
  • Webstorm2020安装、使用详细教程

    Webstorm2020安装、使用详细教程WebStorm是jetbrains公司旗下一款JavaScript开发工具。已经被广大中国JS开发者誉为“Web前端开发神器”、“最强大的HTML5编辑器”、“最智能的JavaScriptIDE”等。与IntelliJIDEA同源,继承了IntelliJIDEA强大的JS部分的功能。

  • UML旅游管理系统「建议收藏」

    UML旅游管理系统「建议收藏」一、需求概述1.1项目概述随着人们的生活质量的逐步提高,外出旅游成为人们生活中不可或缺的一项活动。开发一个旅游管理系统可以为大家提供便捷的途径。系统管理员可以发布和管理旅行路线。旅客可以查询路线,预定路线。1.2用户需求分析分析的系统的参与者有系统管理员、会员、普通用户三个群体。分别对三个群体的需求进行具体分析。系统管理员:管理员作为系统的管理者。需要对线路的数据库进行管理。比如发布新的线路,对不需要的线路进行删除、修改线路的具体信息。对于已经发布的线路,系统管理员可以查看预定的情况。同

发表回复

您的电子邮箱地址不会被公开。

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