%function std_attrValues= vecStd(attrValues)
%if iscolumn(attrValues)~=1% 如果不是指标数据列向量,则提示错误
%warndlg('输入数据必需为列向量,数据标准化处理失败,返回空值!','失败!');
%std_attrValues=[]; % 调用错误时返回空值
%else
m=length(attrValues); % 列向量长度
std_attrValues=ones(m,1); % 初始化标准化属性值,与属性值一样是个m×1的列向量
sqAttr=attrValues.^2; % 原数据每个值的平方
sqSumByAttr=sum(sqAttr,1); % 列向量的平方和
sqrtByAttr=sqrt(sqSumByAttr); % 对平方和开根号
if sqSumByAttr==0
warndlg('指标值全为0,不能采用向量归一化法进行标准化处理,返回空值,请选择其他方法!','失败!');
std_attrValues=[]; % 调用错误时返回空值
else
for i=1:m
std_attrValues(i,1)=attrValues(i,1)/sqrtByAttr;% 计算标准化属性值
end
disp('数据标准化处理成功!');
end
%end
%end
Matlab中数据的标准化处理
最新推荐文章于 2024-07-13 15:14:03 发布