24小时热门版块排行榜    

查看: 2021  |  回复: 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的回帖
相关版块跳转 我要订阅楼主 科学的事 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[公派出国] 售T0P一区SCI文章,我:8O5.51.O.54,科目齐全,可+急 +3 9skg9htng1 2026-06-20 3/150 2026-06-21 18:00 by q1p9ixelzp
[考研] 售T0P一区SCI文章,我:8O5.51.O.54,科目齐全,可+急 +3 9skg9htng1 2026-06-20 4/200 2026-06-21 17:45 by q1p9ixelzp
[论文投稿] 售T0P一区SCI文章,我:8O5.51.O.54,科目齐全,可+急 +3 9skg9htng1 2026-06-20 3/150 2026-06-21 17:40 by q1p9ixelzp
[论文投稿] 售T0P一区SCI文章,我:8O5.51.O.54,科目齐全,可+急 +3 9skg9htng1 2026-06-20 3/150 2026-06-21 17:37 by q1p9ixelzp
[公派出国] 售T0P一区SCI文章,我:8O5.51.O.54,科目齐全,可+急 +4 vlfdw50o0u 2026-06-20 4/200 2026-06-21 17:25 by ky8v3skvft
[考博] 售T0P一区SCI文章,我:8O5.51.O.54,科目齐全,可+急 +4 vlfdw50o0u 2026-06-20 5/250 2026-06-21 17:20 by ky8v3skvft
[博后之家] 售T0P一区SCI文章,我:8O5.51.O.54,科目齐全,可+急 +4 vlfdw50o0u 2026-06-20 6/300 2026-06-21 17:05 by ky8v3skvft
[公派出国] 售T0P一区SCI文章,我:8O5.51.O.54,科目齐全,可+急 +4 vlfdw50o0u 2026-06-20 5/250 2026-06-21 17:00 by ky8v3skvft
[教师之家] 售T0P一区SCI文章,我:8O5.51.O.54,科目齐全,可+急 +5 vlfdw50o0u 2026-06-20 7/350 2026-06-21 16:57 by ky8v3skvft
[论文投稿] 售T0P一区SCI文章,我:8O5.51.O.54,科目齐全,可+急 +3 vlfdw50o0u 2026-06-20 5/250 2026-06-21 16:45 by ky8v3skvft
[教师之家] 售T0P一区SCI文章,我:8O5.51.O.54,科目齐全,可+急 +4 vlfdw50o0u 2026-06-20 7/350 2026-06-21 16:40 by ky8v3skvft
[论文投稿] 售T0P一区SCI文章,我:8O5.51.O.54,科目齐全,可+急 +4 vlfdw50o0u 2026-06-20 9/450 2026-06-21 16:37 by ky8v3skvft
[基金申请] E0414, 我的本子有没有希望? +7 布布和一二 2026-06-17 8/400 2026-06-21 15:44 by lwliwei1989
[基金申请] 青A35岁以下通知答辩了吗 +3 暨阳一只柴 2026-06-17 3/150 2026-06-21 09:39 by kudofaye
[考博] 【全奖博士/科研助理/博后招生】新加坡南洋理工大学机械与航空航天学院 +3 robohaha 2026-06-15 4/200 2026-06-21 00:36 by lanbing1
[文学芳草园] 有谁可曾问过你过的还好吗? +13 myrtle 2026-06-14 22/1100 2026-06-20 23:50 by 波澜任欢
[硕博家园] 一篇论文同时出现在两个期刊,一模一样,这算不算学术不端,请各位老师斧正。 +11 mahl005 2026-06-14 12/600 2026-06-18 17:01 by 770904134
[基金申请] 希望面上有个好结果 +7 碧水00 2026-06-16 7/350 2026-06-18 12:18 by wuke100666
[论文投稿] 三区计算机方向期刊推荐 +5 1457340941 2026-06-15 5/250 2026-06-17 13:16 by 会议编辑
[论文投稿] sci论文二审求助 +5 潘倍倍 2026-06-15 5/250 2026-06-16 10:15 by xs74101122
信息提示
请填处理意见