24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1894  |  回复: 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的回帖
相关版块跳转 我要订阅楼主 科学的事 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 286求调剂 +11 PolarBear11 2026-03-26 11/550 2026-03-28 09:55 by 李上岸0921
[考研] 材料求调剂一志愿哈工大324 +7 闫旭东 2026-03-28 9/450 2026-03-28 08:51 by Xu de nuo
[考研] 286求调剂 +4 丢掉懒惰 2026-03-27 7/350 2026-03-28 08:07 by baoball
[考研] 291求调剂 +7 孅華 2026-03-22 7/350 2026-03-28 04:02 by fmesaito
[考研] 330一志愿中国海洋大学 化学工程 085602 有读博意愿 求调剂 +3 wywy.. 2026-03-27 4/200 2026-03-28 03:32 by fmesaito
[考研] 265求调剂11408 +3 刘小鹿lu 2026-03-27 3/150 2026-03-27 20:53 by nihaoar
[考研] 一志愿211院校 344分 东北农业大学生物学学硕,求调剂 +5 丶风雪夜归人丶 2026-03-26 8/400 2026-03-27 19:22 by 丶风雪夜归人丶
[考研] 一志愿上海理工能源动力(085800)310分求调剂 +3 zhangmingc 2026-03-27 4/200 2026-03-27 19:01 by 给你你注意休息
[考研] 269专硕求调剂 +10 金恩贝 2026-03-21 10/500 2026-03-27 15:10 by caszguilin
[考研] 351求调剂 +4 麦克阿磊 2026-03-24 4/200 2026-03-27 00:32 by wxiongid
[考研] 求调剂 一志愿 本科 北科大 化学 343 +6 13831862839 2026-03-24 7/350 2026-03-26 22:57 by 不吃魚的貓
[考研] 一志愿北京化工大学材料与化工(085600)296求调剂 +9 稻妻小编 2026-03-26 9/450 2026-03-26 16:16 by 不吃魚的貓
[考研] 一志愿上海交大生物与医药专硕324分,求调剂 +6 jiajunX 2026-03-22 6/300 2026-03-25 23:05 by licg0208
[考研] 网络空间安全0839招调剂 +4 w320357296 2026-03-25 6/300 2026-03-25 17:59 by 255671
[考研] 求调剂一志愿武汉理工大学材料工程(085601) +5 WW.' 2026-03-23 7/350 2026-03-24 14:50 by sprinining
[考研] 284求调剂 +3 yanzhixue111 2026-03-23 6/300 2026-03-23 22:58 by pswait
[考研] 361求调剂 +3 Glack 2026-03-22 3/150 2026-03-23 22:03 by fuyu_
[考研] 280分求调剂 一志愿085802 +4 PUMPT 2026-03-22 7/350 2026-03-22 22:13 by 星空星月
[考研] 材料学硕301分求调剂 +7 Liyouyumairs 2026-03-21 7/350 2026-03-21 22:31 by peike
[考研] 一志愿南大,0703化学,分数336,求调剂 +3 收到VS 2026-03-21 3/150 2026-03-21 18:42 by 学员8dgXkO
信息提示
请填处理意见