how to count the number of zeros between 2 one's
5 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Monika Kok
el 24 de Abr. de 2016
Editada: per isakson
el 5 de Mayo de 2017
i am using the code
num = [0,0,0,0,1,1,1,1,0,0,0,0,0,0,0,0,0,1,1,1,1,0,0];
num = num(find(num==1, 1, 'first'):find(num==1, 1, 'last'));
% Measure the lengths of the stretches/runs of zeros.
measurements = regionprops(logical(~num), 'Area');
zerospan = [measurements.Area]
a = max(zerospan)
this is giving me answer as 9 which is correct for middle part. but i would also count the end around number of zeros. that is zeros starting from second last position and ending at fourth position. which should give me answer as 6.
thanks monica
0 comentarios
Respuesta aceptada
Andrei Bobrov
el 24 de Abr. de 2016
Editada: Andrei Bobrov
el 24 de Abr. de 2016
num = [0,0,0,0,1,1,1,1,0,0,0,0,0,0,0,0,0,1,1,1,1,0,0]
measurements = regionprops(logical(~num), 'Area')
m = [measurements.Area];
out = [sum(m([1,end])), max(m(2:end-1))]
1 comentario
Image Analyst
el 24 de Abr. de 2016
"which should give me answer as 6." Just be aware that this answer gives [6,9].
Más respuestas (2)
Azzi Abdelmalek
el 24 de Abr. de 2016
Editada: Azzi Abdelmalek
el 24 de Abr. de 2016
nu=~num;
s=cumsum(num)+~num(1);
ii=strfind(num,[1 0]);
jj=zeros(size(num));
jj(ii)=1;
s=s+cumsum(jj)
f=accumarray(s',(1:numel(s))',[],@(x) sum(nu(x)));
out=[ nonzeros(f(2:end-1))' sum([f(1) f(end)])]
2 comentarios
Image Analyst
el 24 de Abr. de 2016
You almost had it. You just needed to ask for the 'PixelIdxList' when you called regionprops. This gives you the index of every element in each grouping of 0's.
num = [0,0,0,0,1,1,1,1,0,0,0,0,0,0,0,0,0,1,1,1,1,0,0];
% Measure the lengths of the stretches/runs of zeros.
measurements = regionprops(logical(~num), 'Area', 'PixelIdxList');
zerospan = [measurements.Area]
% Get index of the largest run in the lengths array:
[longestRun, indexOfLongestRun] = max(zerospan)
% Get the index in the original num array:
indexOfStartOfLongestRun = measurements(indexOfLongestRun).PixelIdxList(1)
You will see that indexOfLongestRun = 9, which is where that run starts at.
Image Analyst
el 24 de Abr. de 2016
Just add the first and last area:
result = zerospan(1) + zerospan(end);
0 comentarios
Ver también
Categorías
Más información sobre Logical 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!