dividing a column matrix based on the no

i have a single column matrix A=0 0 0 1 1 1 1 0 0 0 0 2 2 2 2 0 0 0 0 now i have to divide this in to several matrices such whenever 0 changes to 1 or 2 i want a new matrix in this case A1= 1 1 1 1 0 0 0 0; A2=2 2 2 2 0 0 0 0 which are also single column matrices

 Respuesta aceptada

Oleg Komarov
Oleg Komarov el 16 de Mayo de 2011
A = [0 0 0 1 1 1 1 0 0 0 0 2 2 2 2 0 0 0 0].';
Split sequence (transforming in string)
out = regexp(sprintf('%d',A) ,'(1+0+|2+0+)','match');
Convert to double and store in cell array
c = cellfun(@(x) x.'-'0',out,'un',0)
c{1} % to retrieve the value
Organize eventually in structure with dynamic fields A001, A002, ..., An
numC = numel(c);
s = cell2struct(c, reshape(sprintf('A%03d', 1:numC),4,[]).',numC);
s.A001 % to retrieve the value
EDITED
With a loop
A = [0 0 0 1 1 1 1 0 0 0 0 2 2 2 2 0 0 0 0].';
c = 0;
s = 0;
% Start condition
if ismembc(A(1,1),1:2)
s = 1;
end
for n = 2:numel(A(:,1))-1
if A(n,1) == 0 && ismembc(A(n+1,1),1:2)
if s
c = c+1;
Out{c} = A(s:n,:);
end
s = n+1;
end
end
% End condition
if s < n
Out{c+1} = A(s:end,:);
end

7 comentarios

bilhan
bilhan el 16 de Mayo de 2011
i am getting
cellfun(@(x) x.'-'0',out,'un',0)
ans =
[8x1 double] [8x1 double]
how could i retrieve those arrays
please send me a code using for loop
Oleg Komarov
Oleg Komarov el 16 de Mayo de 2011
See edit and search the documentation on how to operate with cell arrays or dynamic field indexing in structures
bilhan
bilhan el 16 de Mayo de 2011
thanks for your answer
but i want this done using a for loop
Oleg Komarov
Oleg Komarov el 16 de Mayo de 2011
You should have stated it in the first request.
bilhan
bilhan el 16 de Mayo de 2011
thank you very much
bilhan
bilhan el 16 de Mayo de 2011
now ia m getting
c{1}=1111 insyead of 11110000
Oleg Komarov
Oleg Komarov el 16 de Mayo de 2011
Do you use the same A? If not post the input array/vector.

Iniciar sesión para comentar.

Más respuestas (1)

Andrei Bobrov
Andrei Bobrov el 16 de Mayo de 2011
more variant
A = A(:);
I = cumsum([0;diff(A)]~=0 & (A ~= 0));
out = arrayfun(@(x)A(I==x),1:max(I),'un',0);
same with the loop
A = A(:).';
I = cumsum([0,diff(A)]~=0 & (A ~= 0));
out = cell(1,max(I));
for j = 1:max(I),
out{j} = A(j==I);
end

4 comentarios

bilhan
bilhan el 16 de Mayo de 2011
thank you man thbats wonder ful perfect thats what i want.
bilhan
bilhan el 16 de Mayo de 2011
the same question but an extension if A is a two columned matrix and i want to divide it based on the first column same as above then
for eg:_
a=[0 0;0 1;1 1;1 0;0 1;0 0;0 1;2 0;2 1;0 0;0 1]
a1=[1 1;1 0;0 1;0 1]
a2=[2 0;2 1;0 0;0 1]
Oleg Komarov
Oleg Komarov el 16 de Mayo de 2011
I edited my solution to take into account initial conditions (if A doesn't start with a 0) and to split a matrix on the basis of the first array.
bilhan
bilhan el 17 de Mayo de 2011
thank you

Iniciar sesión para comentar.

Categorías

Más información sobre Data Type Identification en Centro de ayuda y File Exchange.

Preguntada:

el 16 de Mayo de 2011

Community Treasure Hunt

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

Start Hunting!

Translated by