how to extract n rows in a matrix column iteratively?
    6 views (last 30 days)
  
       Show older comments
    
i have a matrix A(15,1)  looking like this 
    0.4218
    0.9157
    0.7922
    0.9595
    0.6557
    0.0357
    0.8491
    0.9340
    0.6787
    0.7577
    0.7431
    0.3922
    0.6555
    0.1712
    0.7060
I want to extract always 3 rows iteratively and put it in a cell,
In the first cell i want to have 
    0.4218
    0.9157
    0.7922
in the second cell i want to have 
    0.9595
    0.6557
    0.0357
and so on..., i would then end  up with 5 cells as this {1,5}(3,1)
is there an easy way to do it without writing several for loops? 
Thanks already in advance!
0 Comments
Accepted Answer
  James Tursa
      
      
 on 3 Mar 2020
        
      Edited: James Tursa
      
      
 on 3 Mar 2020
  
      Depending on what you are doing downstream in your code, it may make more sense to simply reshape and then access the columns.  E.g.,
B = reshape(A,3,[]);
then in your code use B(:,k) to access the k'th column
But if you really want/need the cell array approach then maybe something like this would suffice
B = mat2cell(A,3*ones(1,numel(A)/3));
More Answers (1)
  Andrei Bobrov
      
      
 on 3 Mar 2020
        
      Edited: Andrei Bobrov
      
      
 on 3 Mar 2020
  
      out = num2cell(reshape(A,3,[]),1);
or
out = accumarray(ceil((1:numel(A))'/3),A,[],@(x){x});
See Also
Categories
				Find more on Matrix Indexing in Help Center and File Exchange
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!

