Why am I getting the error that the 'dimensions of arrays concatenated are not consistent'?

1 visualización (últimos 30 días)
I have a list of DOY numbers that also contain the hours and minutes that I want to convert to datetime. The variable is DOYfilt and has size 1408x1. On the 434th number in the loop, matlab gives me an error: 'Error using vertcat: Dimensions of arrays being concatenated are not consistent.'. What would be going on in the loop that would cause this when it was working beforehand?
u10_date=[];
for i=1:length(DOYfilt)
date=datestr(DOYfilt(i) + datenum('2012/01/01'));
u10_date=[u10_date;date];
end

Respuestas (1)

Deepak
Deepak el 22 de Ag. de 2024
Hi @Shayma Al Ali, from my understanding, you have a double array named “DOYfilt” of size 1408 x 1. You want to convert it into a datetime by adding it to the date (‘2012/01/01’) with the help of the “datestr” method in MATLAB.
You are getting an error on the 434th iteration because the values in “DOYfilt” at the 433rd and 434th indices are 50.9931 and 51.000 respectively and the dates formed at those indices are “20-Feb-2012 23:50:00” and “21-Feb-2012” respectively. Since the datatypes of these dates are different, appending them to the “u10_date” array throws an error.
To resolve this issue, we can pre-allocate the “u10_date” array as a cell array with the same size as “DOYfilt”. Then, at each index, we can save a datetime in the array. Finally, we can convert this cell array to a char array.
Here is the MATLAB code that addresses this task:
u10_date = cell(length(DOYfilt), 1); % Preallocate a cell array
for i = 1:length(DOYfilt)
date = datestr(DOYfilt(i) + datenum('2012/01/01'));
u10_date{i} = date; % Store each date string in a cell
end
u10_date_char = char(u10_date);
Attaching the documentation of methods used for reference:
I hope this resolve the issue.

Categorías

Más información sobre Dates and Time en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by