变异系数法之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
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

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

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


相关推荐

  • 中缀表达式转后缀表达式方法_后缀表达式怎么求值

    中缀表达式转后缀表达式方法_后缀表达式怎么求值前言数据结构与算法中经常遇到中缀表达式转前缀表达式的题目,网上的教程大都很不直观,自己学的时候,也走了很多弯路,现在把一个简单易懂的算法教程分享出来。中缀转后缀举个例子,一个式子:(5+20+1∗3)/14(5+20+1*3)/14(5+20+1∗3)/14如何把该式子转换成后缀表达式呢?其实就是分三步:1、按运算符优先级对所有运算符和它的运算数加括号,(原本的括号不用加)2、把运算…

    2025年7月22日
    0
  • Java打印九九乘法表

    Java打印九九乘法表1.使用双重for循环打印九九乘法表Java源代码如下:for(inti=0;i<=9;i++){for(intj=1;j<=i;j++){System.out.print(i+”*”+j+”=”+i*j+””);}System.out.println();}打印结果如图:2.使用双重for循环打印九九乘法表,跳过第五行Java源代码如下:for(inti=0;i<=9;…

    2022年7月25日
    12
  • TCP三次握手 与 四次断开 的详细过程剖析

    TCP三次握手 与 四次断开 的详细过程剖析

    2021年8月27日
    61
  • Vue常用指令(一)

    Vue常用指令(一)1、v-once 只渲染元素和组件一次。随后的重新渲染,元素/组件及其所有的子节点将被视为静态内容并跳过。代码:<body><div id=”app”> <p v-once>原始值: {{msg}}</p> <p>后面的: {{msg}}</p> <input typ…

    2022年6月13日
    28
  • 10个调试Java的技巧建议收藏

    调试不仅可以查找到应用程序缺陷所在,还可以解决缺陷。对于Java程序员来说,他们不仅要学会如何在Eclipse里面开发像样的程序,更需要学会如何调试程序。本文介绍了Java程序员必知的10个调试技巧,

    2021年12月20日
    43
  • xray安全漏洞检测(高效能)

    xray安全漏洞检测(高效能)风险告知:请勿在未授权情况下,对网站进行安全扫描,存在很大的法律风险,详细请了解网络安全法。血的案例:”白帽黑客”找漏洞被抓引争议世纪佳缘否认”钓鱼”–传媒–人民网在正式运行xray生成配置文件config.yaml后,请优先修改配置项,确认扫描范围,再重新启动xray如不预先配置,默认扫描所有站点,存在非常大的法律风险,请知悉!!!xray是一款功能强大的安全评估工具,主要特性有:检测速度快。发包速度快;漏洞检测算法高效。 支持范围广。大至OWASPTo.

    2022年5月15日
    52

发表回复

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

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