Effacer les filtres
Effacer les filtres

Defining a 4d double

43 vues (au cours des 30 derniers jours)
Anantha Padmanabhan
Anantha Padmanabhan le 13 Juin 2017
Commenté : Faqih Romi le 4 Août 2021
I am trying to build a 4D matrix from a velocity time series so that I can use it as an input to another program. My wind field is a M*N matrix where M is the number of points on the square grid and N is the measurement time in seconds (sampling at 1 hz). I now want to build a 4D array following which should look like this
4D_matrix=[time(1*N) velocity(M*N) x_coord(M,1) y_coord(M,1)];
How do i write this?
Thank you, Ananth
  5 commentaires
Anantha Padmanabhan
Anantha Padmanabhan le 13 Juin 2017
As said, M=676 (number of grid points) N=600 (for 10 minute simulations)
Faqih Romi
Faqih Romi le 4 Août 2021
d=[2 3 4 1; 3 2 1 4];
dd(:,:,:,1)=d(1,:,1);
dd(:,:,:,2)=d(2,:,1);

Connectez-vous pour commenter.

Réponses (2)

Guillaume
Guillaume le 13 Juin 2017
Well, you need 676^3 * 600^2 * 8 bytes ~= 890 TB of memory to store that many elements, regardless of the shape. Chances are you don't have a computer with that much memory (not even in the ballpark).
You need to rethink what you want to do. In particular, I would think that x_coord and y_coord correspond to the rows and columns of your velocity field, therefore it does not make sense to store them in additional dimensions of the same matrix (as that would wastefully repeat the same values).

Pawel Tokarczuk
Pawel Tokarczuk le 13 Juin 2017
I think what you need is something like:
Velocity = zeros([NROWS, NCOLS, NTIMES], 'double');
[ X, Y ] = meshgrid(0:NCOLS-1, 0:NROWS-1);
XX = X0 + ScaleX*X;
YY = Y0 + ScaleY*Y;
T = double(0:NTIMES-1);
TT = T0 + ScaleT*Time;
Note the order of the indices (column-major in the first two dimensions, last index varies most slowly).
Those should be the basic data structures; now, you just need to use them appropriately.
IHTH

Catégories

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

Community Treasure Hunt

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

Start Hunting!

Translated by