matlab 分数运算,在MATLAB中如何用PLS确定最优主成分数

CODE:

function [r,rmsecv,yp] = loocv2(x,y,lv,sel)

if nargin <4;sel = 1;end

T = size(x,1);

yp = zeros(size(y));

for i = 1:T

x1 = x(i,:);

ind = 1:T;ind(i) = [];

x2 = x(ind,:);

y2 = y(ind,:);

if eq(sel,0)

[x2,mx] = mncn(x2);

x1 = scale(x1,mx);

[y2,my] = mncn(y2);

elseif eq(sel,1)

[x2,mx,stdx] = auto(x2);

x1 = scale(x1,mx,stdx);

[y2,my,stdy] = auto(y2);

end

b = simpls(x2,y2,lv);

yp0 = x1 * b(:,lv);

if eq(sel,0)

yp0 = rescale(yp0,my);

elseif eq(sel,1)

yp0 = rescale(yp0,my,stdy);

end

yp(i) = yp0;

end

r = corr(yp,y);

rmsecv = rms(y-yp);

function [mcx,mx] = mncn(x)

%MNCN Mean center scale

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值