为什么我这个js程序会返回NaN

为什么我这个js程序会返回NaN,第1张

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值等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/10624616.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-10
下一篇 2023-05-10

发表评论

登录后才能评论

评论列表(0条)

保存