Replacing unassigned values in a vector with nans instead of zeros

5 vues (au cours des 30 derniers jours)
jlt199
jlt199 le 20 Sep 2016
Morning everyone,
I'm resizing vectors in a loop. Not good I know and probably why it takes 30 minutes to run, but beside from reading through all the files a first time to determine the correct length of the vectors and then reading through a second time to fill in the vectors I can't see a better way. As there is no easy method of determining the length I need.
However, currently if a file can't be read - some of the files are dodgy and I put a try-catch statement around them - then unassigned values in the vector automatically equal zero. Is there a way to change that behaviour so that an unassigned vector value is a nan?
For example
r(1) = 2;
r(3) = 4;
>> r
r =
1 0 2
is there a way to make r(2) a nan without explicitly assigning it?
  2 commentaires
Chad Greene
Chad Greene le 20 Sep 2016
Is preallocating r an option? I'm thinking something like this:
r = nan(1,3);
r(1) = 2;
r(3) = 4
jlt199
jlt199 le 20 Sep 2016
preallocating to the correct number is not an option as it is unknown

Connectez-vous pour commenter.

Réponses (2)

Steven Lord
Steven Lord le 20 Sep 2016
Preallocate r to be a NaN vector with a number of elements equal to some upper bound on the number of elements that it could possibly contain (for instance, if you have 10 files and each could add 7 elements to the vector preallocate it to be nan(1, 70)) then fill it in and trim off the excess elements after the for loop is complete.
  5 commentaires
jlt199
jlt199 le 20 Sep 2016
Thanks Guillaume, I'm reading them using the following code:
fid = 'W:/Algorithm Dept/Flat Plat Defects/Circular Defects/';
files = dir([fid,'*.txt']);
for i = 1:length(files)
ML = readtable([fid,file.name],'HeaderLines',8,'ReadVariableNames',false);
...
end
Guillaume
Guillaume le 21 Sep 2016
The reading is efficient, but I don't see how that portion of code links to your question. Assuming you're concatenating the tables vertically and you want nans for the missing files, this is how I'd do it:
%...
ML = cell(numel(files));
for filenumber = 1:numel(files)
try
ML{filenumber} = readtable(...);
catch
...
end
end
failedread = cellfun(@isempty, ML);
maxheight = max(cellfun(@height, ML(~failedread)));
width = cellfun(@width, ML(~failedread));
assert(numel(width) > 0 && all(width == width(1)), 'table concatenation will fail')
ML{failedread} = array2table(nan(maxheight, width(1)));
allML = vertcat(ML{:});

Connectez-vous pour commenter.


Jonathan Avesar
Jonathan Avesar le 17 Sep 2019
I also have this question. I can't pre-allocate because I don't know how large the matrix will be in advance.

Catégories

En savoir plus sur Matrices and Arrays dans Help Center et File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!

Translated by