total=total+interp(xf,yf)a;中调用了interp,interp定义如下:
function interp(a,b,x){
return a(1-x)+bx;
}
这个函数有三个参数,其中x没有传值,值为undefined,x参与到了运算,返回结果为NaN。
for (i = 0; p[i] = '\0'; i++) 注意里面的反斜杠的方向。
nan -- 表示 出错,“不是一个数” not a number 的缩写。
按 IEEE 754 国际标准,当运算中出现无效数据时,给出 NaN 许多情况会出现,例如 0 除 0,负数开平方,
vs出现nan值是程序出现未知数导致。根据查询相关资料信息,vs出现nan值,意思是Not,ANumber,表示未定义或不可表示的值,是在程序运行出现未知数的时候,会出现的代码显示。vs出现nan值是在单元格中出现未知数,缺少数值,需要针对程序进行检查错漏。
第一列到倒数第二列都是nan,之后最后一列有值
那么其他值以什么标准来填新值呢?
哪怕多知道第一列的值,中间的还可以根据一前一后两个值插值计算得出
如果有足够的数据,至少第一点和最后一点知道,还是可以通过interp1插值填充的
只是要处理一下避开nan点
假设你原来数据是a
使用find(isnan(a))可以返回所有数据中是nan的值的位置
可以根据其填充新值
很显然,你建立的接迭代格式不收敛,发散了。这要从你自己的算法上找原因,你可以找分母上的数,是否很接近于0,之类的。比如我在我的matlab平台下监控了Sij的分母上的数随着迭代次数的增加变化情况。迭代进行500多次后就已经出现了不合理的值,你可以试试下面的代码。
clear;
m = 32;
n = 128;
N0 =5;
X0 = rand(m,N0);
C0 = cov(transpose(X0));
[V0,D0] = eig(C0);
XX = rand(m,n);
ppp=zeros(1);
iii=1
for K = 1:n
X=XX(:,K);
lmda = 1/K;
alfa=V0X;
C0=(1-lmda)C0+lmdaXtranspose(X);
P=zeros(32);
for i=1:m
p = (alfa(i)^2-D0(i,i))/K;
P(i,i) =p;
end;
Q=zeros(32);
for i=1:m-1
for j=i+1:m
if j==i
Sij=0;
else
ppp(iii)=(D0(j,j)-D0(i,i)+P(j,j)-P(i,i));
iii=iii+1;
Sij = (alfa(i)alfa(j))/(D0(j,j)-D0(i,i)+P(j,j)-P(i,i))lmda;
end
Q(i,j)=Sij;
Q(j,i)=-Sij;
end
end
V0 = V0(eye(32)+Q);
D0 = D0+P;
T1=zeros(m);
for i=1:m
V1=V0(:,i);
T1(i,i)=-norm(V1);
end
V0=V0T1;
T2=zeros(m);
for i=1:m
V=V0(:,i);
T2(i,i)=norm(V)^2;
end
D0=D0T2;
end
figure
plot(1:iii-1,ppp)
figure
plot(1:800,ppp(1:800))
以上就是关于为什么我这个js程序会返回NaN全部的内容,包括:为什么我这个js程序会返回NaN、c++程序问题,提示-nan(ind)。vs2015版、vs出现nan值等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)