24小时热门版块排行榜    

CyRhmU.jpeg
查看: 1780  |  回复: 9

科学的事

银虫 (正式写手)

[求助] MATLAB NaN求助

在MATLAB中,center=ones(251,2)在程序中运行结果会出现NaN,但在命令窗口中就只是1了,不知道是为什么?请各位高手不吝赐教!!!
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

A-little-bit-more
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

adcpk

金虫 (初入文坛)

【答案】应助回帖


感谢参与,应助指数 +1
jjdg: 金币+1, 感谢参与 2013-05-27 00:46:54
应该是你的程序有问题吧,发来看看
2楼2013-05-27 00:25:21
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

chaofan1231

银虫 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
过程中肯定出现0做分母这一类的问题了。楼主好好检查一下你的矩阵中的数据
3楼2013-05-27 08:11:49
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

科学的事

银虫 (正式写手)

引用回帖:
2楼: Originally posted by adcpk at 2013-05-27 00:25:21
应该是你的程序有问题吧,发来看看

%%%%%%%%%%%%%%%%%%%%%网络训练和构建部分%%%%%%%%%%%%%%%%%%%%%%%%%%
%导入数据
load data-for-article.mat
X=E;
X1=X(:,1:25);  %训练数据
X2=X(:,26:end);%预测数据
centerNum=2;%设定中心个数
[datarow,datacolumn]=size(X1);% 计算向量大小
center=ones(datarow,centerNum);     %设定初始中心
distancedata=zeros(centerNum,datacolumn);
step=1000;
newCenter=caculateCenter1(centerNum,X1,datacolumn,datarow,center);
    while(sum(sum(newCenter~=center)))&step
        center=newCenter;
        times=1000-step+1;
        newCenter=caculateCenter1(centerNum,X1,datacolumn,datarow,center);
        step=step-1;
    end
按说我的程序一开始并没有运算啊,前几句话就出现了center=ones(datarow,centerNum);     %设定初始中心,可是变量中还是显示NaN.难道是他后面参加的运算中有分母为零的情况,他的原始数据也会变成NaN?
A-little-bit-more
4楼2013-05-27 09:10:33
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zhangzhiguang

至尊木虫 (文坛精英)

【答案】应助回帖

感谢参与,应助指数 +1
楼主说的是运算过程中显示center为nan是吧?而不是结果
好好学习,天天向上!
5楼2013-05-27 10:58:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

zhangzhiguang

至尊木虫 (文坛精英)

【答案】应助回帖

这个程序也不全,表面上看也看不出问题,这里面caculateCenter1这个函数,你仔细看看,或发出来看看
好好学习,天天向上!
6楼2013-05-27 11:06:33
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

科学的事

银虫 (正式写手)

引用回帖:
6楼: Originally posted by zhangzhiguang at 2013-05-27 11:06:33
这个程序也不全,表面上看也看不出问题,这里面caculateCenter1这个函数,你仔细看看,或发出来看看

function newCenter=caculateCenter1(centerNum,x,datacolumn,datarow,center)
%************计算新的中心*******************%
kindNum=linspace(0,0,centerNum);%代表的是每一类的样本的个数
sum=zeros(datarow,centerNum);
newCenter=zeros(datarow,centerNum);
  for i=1:datacolumn
    for j=1:centerNum
    distancedata(j,i)=(x(:,i)-center(:,j))'*(x(:,i)-center(:,j));%计算各第i点到就各个中心的距离
    end
    t=find(distancedata(:,i)==min(distancedata(:,i)));%i到第t个中心近
    for j=1:centerNum
        if t==j
            sum(:,j)=sum(:,j)+x(:,i);
            kindNum(j)=kindNum(j)+1;
        end
    end
   
   % distancedata(2,i)=(x(:,i)-center(:,2))'*(x(:,i)-center(:,2));%计算各个点到z2的距离
  % if distancedata(1,i)<distancedata(2,i)
   %  sum(:,1)=sum(:,1)+x(:,i);%kinddata记录属于z1的值
    % kindNum(1)=kindNum(1)+1;%记录属于z1的个数
  % else
   %  sum(:,2)=sum(:,2)+x(:,i);%kinddata记录属于z2的值
   %  kindNum(2)=kindNum(2)+1;%记录属于z1的个数
  % newCenter1=sum(:,1)./kindNum(1);%计算新的中心
  %newCenter2=sum(:,2)./kindNum(2);
  %newCenter=[newCenter1 newCenter2];%合并新的中心
   end

for j=1:centerNum
    newCenter(:,j)=sum(:,j)./kindNum(j);%计算新的中心
end
这个也没有出现分母什么的
A-little-bit-more
7楼2013-05-27 13:08:07
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

科学的事

银虫 (正式写手)

引用回帖:
5楼: Originally posted by zhangzhiguang at 2013-05-27 10:58:00
楼主说的是运算过程中显示center为nan是吧?而不是结果

结果也是
A-little-bit-more
8楼2013-05-28 08:45:08
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

justyet

金虫 (著名写手)

【答案】应助回帖

分母是0,结果是inf而不是nan
是不是你的数据有问题?
9楼2013-06-01 12:39:16
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

科学的事

银虫 (正式写手)

引用回帖:
9楼: Originally posted by justyet at 2013-06-01 12:39:16
分母是0,结果是inf而不是nan
是不是你的数据有问题?

数据应该没有问题,但现在还不知道到底在那个地方出的问题
A-little-bit-more
10楼2013-06-01 16:55:05
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 科学的事 的主题更新
信息提示
请填处理意见