split mtatrix and name automatically

2 Ansichten (letzte 30 Tage)
mehra
mehra am 5 Nov. 2022
Bearbeitet: Stephen23 am 5 Nov. 2022
Hello guys
I have a mat file (attached) which is a 10004*15 matrix. I need to split it into 15 seprated matrixes like (10004*1). and I need to name these matrixes like ur1, ur2, ...ur15.
I know that ı can split matrixes by using the following code:
ur1=ur(:,15);
ur2=ur(:,14)
% and so on....
but I want to know if I can use it in a for loop so that I can have fewer lines (since I need to use the same code for other data files and it will be so long).
Also I want to ask if there is a way to name my output matrixes automatically.
  5 Kommentare
mehra
mehra am 5 Nov. 2022
As I mentioned my goal was to see by using (n,1) matrix in my function the results would be better despiked. I needed to try both to compare the results.
thanks
Stephen23
Stephen23 am 5 Nov. 2022
Bearbeitet: Stephen23 am 5 Nov. 2022
"... I need to name these matrixes like ur1, ur2, ...ur15."
If the code requires lots of numbered variable names then you are doing something wrong.
Using indexing is simpler, neater, easier, and much more efficient than your approach. What is stopping you from using the indexing directly, or a simple cell array?

Melden Sie sich an, um zu kommentieren.

Akzeptierte Antwort

the cyclist
the cyclist am 5 Nov. 2022
Bearbeitet: the cyclist am 5 Nov. 2022
Anywhere that you could have used the variable name ur1, you can almost always just reference ur(:,1) directly instead, and not used the dynamically named variables. (Please read this post about why dynamically named variables are a terrible idea in general.)
If you must break out into individual variables, then using a cell array is typically a better idea:
% Initialize empty cell array
urc = cell(15,1);
% Fill them
for nc = 1:15
urc{nc} = ur(:,nc); % Note the use of curly brackets to denote contents of cell. See docs.
end
  1 Kommentar
mehra
mehra am 5 Nov. 2022
Bearbeitet: mehra am 5 Nov. 2022
Thank you ,
I also rather not using dynamically named variable but previously I used it in that way my despiking function but apparently it did not despiked and my values were still included outliers. It ıs mentioned in the guidance of ''func_despike_phasespace3d'' that fi in [fo, ip] = func_despike_phasespace3d( fi, i_plot, i_opt ) should be (n,1) matrix. So I thought it maybe better to split the matrixes and use them as one-dimensional matrix.
My previous code is like:
for np=1:15;
ur(:,np)=Data.Profiles_VelX(:,np);
vr(:,np)=Data.Profiles_VelY(:,np);
w1r(:,np)=Data.Profiles_VelZ1(:,np);
w2r(:,np)=Data.Profiles_VelZ2(:,np);
[u(:,np), ip1] = func_despike_phasespace3d( ur(:,np),8, 2); %here I have directly refered to the matrix
[v(:,np), ip2] = func_despike_phasespace3d( vr(:,np),8, 2);
[w1(:,np), ip3] = func_despike_phasespace3d( w1r(:,np), 8, 2);
[w2(:,np), ip4] = func_despike_phasespace3d( w2r(:,np), 8, 2);
w(:,np)=(w1(:,np)+w2(:,np))/2;
end

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (0)

Kategorien

Mehr zu Creating and Concatenating Matrices finden Sie in Help Center und File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by