MATLAB中出现NAN怎么回事
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MATLAB中出现NAN怎么回事相关的知识,希望对你有一定的参考价值。
出图像时结果显示很乱
NaN是Not-a-Number的简写,中文译为“非数”,表示计算结果为不定。
关于出现NaN的原因,楼上两位都说是因为分母为0或被除数为0,这是不确切的。比如1/0得到的是Inf而不是NaN。
计算结果出现NaN,一般有这样几种情况:0/0,Inf/Inf,Inf-Inf,Inf*0,这几种情况都会导致结果不确定,所以会得到NaN。
需要说明的是,由于数值计算的浮点数表示范围是有限的,Inf并不是数学上真正意义的无穷大,例如计算组合值C(300,200),可以用nchoosek(300,200)得到正确的结果(当然,由于浮点数的精度问题,并不是精确的结果),但如果直接根据定义计算 300!/200!/100!,就会得到NaN:
>> nchoosek(300,200)Warning: Result may not be exact. Coefficient is greater than 10^15,
and is only good to 15 digits.
(Type "warning off MATLAB:nchoosek:LargeCoefficient" to suppress this warning.)
> In D:\\MATLAB6p5\\toolbox\\matlab\\specfun\\nchoosek.m at line 50
ans =
4.1583e+081
>> factorial(300)/factorial(200)/factorial(100)
ans =
NaN
就题主贴出的图而言,看不出和NaN有什么关系。NaN通常在绘图中被用于表示不显示的部分,例如,把一条曲线中间去掉一些点,使之视觉上成为多条线段。而题主所贴的曲线看不出有断开的部分。至于说曲线看起来乱,那要看相应的数据是怎样计算出来的,如果题主不给出代码,别人是无法判断的。
参考技术A在matlab中的NaN的含义是没有意义的数,not a number,一般有这几种情况:0/0,Inf/Inf,Inf-Inf,Inf*0等,都会导致结果不确定,所以会得到NaN。
数据处理时,在实际工程中经常数据的缺失或者不完整,此时我们可以将那些缺失设置为nan,Matlab处理缺失的数据时就会跳过或者其他处理——这个是Matlab优越于其他语言的表现之一。另外但读取数据时,某个字符不是数据,那么Matlab自动将它认为nan处理。
拓展说明:
Matlab中提供的nanmean, nanmax, nanmin, nanstd, nansum, nanvar这么多函数可以处理包含nan的数据。
参考技术B 计算错误,非数字追问什么情况下会出现这种情况
什么情况下会出现这种情况
追答这是看你的算法了,分母为零的可能性最大
参考技术C NAN 有可能出现被除数是 0 的情况。从Excel向MATLAB中导入数据出现了nan怎么处理
是因为数据过大过小导致?
1、在matlab中生成数据,并且写入到excel文件中。具体代码如下图所示:
2、下面来看一下生成的myExample.xlsx文件里面是否含有matlab所生成的数据。有图中可以看出,生成的数据已经全部写入了myExample.xlsx文件。
3、从excel的第一个worksheet中读取数据,代码如下图所示:
4、从上一步生成的excel文件myExample.xlsx中读取局部的数据,具体代码及结果如下图所示:
5、读取一列数据,从excel文件myExample.xlsx中读取一整列的数据,具体代码及结果如下图所示:
6、从excel文件myExample.xlsx中分别读取数值型、文本型和未处理的数据,具体代码及结果如下图所示:
以上是关于MATLAB中出现NAN怎么回事的主要内容,如果未能解决你的问题,请参考以下文章
matlab怎么计算出来的数很多都是NaN的值呢?怎么回事啊