readmatrix produces NaN values after parsing a .txt file
조회 수: 120 (최근 30일)
이전 댓글 표시
Hi there guys,
I've encountered weird phenomena while working with readmatrix(). I produce several .txt files with emphemerides data in an orbital propagator software and want to work on the position and velocity data further in Matlab. The thing is that after parsing those .txt files with readmatrix() I receive weird NaNs in random places. For instance, for your convenience I will only provide matrixA with the least amount of NaNs, but there are other files where the number reaches up to 221, which after parsing results in 2 NaNs (see code section below).
Thing is, when I started to manually check my .txt files, I found out that there are no NaNs in txt files themselves. At the row/col id provided by the find(isnan()) routine, I expected to see smth weird in the txt file itself. However, what I can see is reasonable and expected number, so the problem is probably in the way how I set up readmatrix itself. Can you give me any suggestion on how to deal with this NaN generation issue? I will also attach an archived matrixA.txt for your convenience.
Thanks beforehand!
matrixA=readmatrix('matrixA.txt');
[row,col]=find(isnan(matrixA))
row =
45636
19918
col =
3
4
댓글 수: 3
채택된 답변
darova
2020년 4월 20일
See this solution
I don't have readmatrix. I tried importdata
A = importdata('matrixA.txt');
data = A.data;
find( isnan(data(:)) )
result
ans =
Empty matrix: 0-by-1
댓글 수: 0
추가 답변 (1개)
Ameer Hamza
2020년 4월 18일
The data in your txt file is separated using an irregular number of spaces. For some reason, it confuses readmatrix in a few rows. Try this
data = readmatrix('matrixA.txt', ...
'Delimiter', ' ', ...
'ConsecutiveDelimitersRule', 'join');
댓글 수: 3
Ameer Hamza
2020년 4월 20일
I didn't have this problem in R2020a. There might be some issues fixed in this release.
참고 항목
카테고리
Help Center 및 File Exchange에서 Startup and Shutdown에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!