I have many large column matrices (each is ~20k x 1). Some elements of the matrices are NaN. I want to replace them with 0 (or some number). Is there a quick way for that. Looping through each element is a very inefficient process and delays my program. The help is really appreciated.

 Akzeptierte Antwort

Guillaume
Guillaume am 27 Jun. 2016
Bearbeitet: Guillaume am 27 Jun. 2016

2 Stimmen

yourmatrix(isnan(yourmatrix)) = somevalue;
But, using NaN to mark exceptional values is much better than using 0 or some other special value.

2 Kommentare

Mehul Agrawal
Mehul Agrawal am 27 Jun. 2016
Thanks a lot. I actually wanted to do some additions of these matrices and having NaN ignores all other calculations and I will end up having NaN. For my purpose 0 is actually a unique value too (just eligible for calculations).
Steven Lord
Steven Lord am 27 Jun. 2016
For a couple releases now the sum function has accepted a flag that lets you specify whether NaN values should be included in the sum (which makes the sum NaN) or excluded (unless all the values being summed are NaN.)

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Kategorien

Produkte

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by