数学建模之相关系数

 

 

 

 

 

用matlab也可求出以上数据,代码如下 

clear;clc

load Xdata.mat

[PR,PP] = corrcoef(X);%皮尔逊相关系数与P的矩阵

[SR,SP] = corr(X,'type','Spearman');%斯皮尔逊相关系数与P的矩阵

%RX = rank_data(X(:,1));

%以下为斯皮尔曼相关系数计算过程中等级的计算尝试
[~ ,index] = sort(X(:,1));% ~表示我们不需要第一个输出值(即我们排序后的X)
                          % 注意这里的index是我们排序后的X在原向量中的位置

[~ ,RX] = sort(index);% 对index进行一次升序,得到的rx就是我们想要的等级

for i = 1:size(X(:,1),1)  % 设置一个循环  (假设此时程序运行到了i = 2)
        position = (X(:,1) == X(i) ); % 得到X中与X(i)相等的位置,返回一个列向量,向量值全为1或0
                                              % (i= 2时,position = [0 1 0 1 0]' )
        RX(position == 1) = sum(RX .* position) / sum(position);  % 对RX进行处理 
end

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值