Borrar filtros
Borrar filtros

Find range between two array's indexes

1 visualización (últimos 30 días)
Max Bernstein
Max Bernstein el 20 de Jul. de 2016
Comentada: Stephen23 el 20 de Jul. de 2016
Hello,
I have two arrays of different sizes and I Would like to find certain range between them, where the start index is from one array and ends with another array. For example:
A = [4192 23330 23342 29974 49089 49093 49096 55753 57035 57039]
B = [22780 48556 56522]
The desired output would be
C = [4192 22780; 29974 48556 ; 49096 56522]
Note that A and B can change in size, but array B is always the end point value.
Thanks, Max
  1 comentario
Stephen23
Stephen23 el 20 de Jul. de 2016
Editada: Stephen23 el 20 de Jul. de 2016
Should the example really be this? :
C = [4192 22780; 29974 48556 ; 55753 56522]
Or if not, please explain why 49096 is selected, and not 55753.

Iniciar sesión para comentar.

Respuesta aceptada

Stephen23
Stephen23 el 20 de Jul. de 2016
Editada: Stephen23 el 20 de Jul. de 2016
Assuming that the rule really should pick the closest values from A that a re less than the values in B:
>> A = [4192 23330 23342 29974 49089 49093 49096 55753 57035 57039];
>> B = [22780 48556 56522];
>>
>> X = A(any(diff(bsxfun(@lt,A(:),B(:).')),2));
>> C = [X(:),B(:)]
C =
4192 22780
29974 48556
55753 56522
  2 comentarios
Max Bernstein
Max Bernstein el 20 de Jul. de 2016
Sorry for the mistake, but yes it should be the closest values from A that are less than B.
I got an error using your code:
>> X = A(any(diff(bsxfun(@lt,A(:),B)),2));
Error using bsxfun
Non-singleton dimensions of the two input arrays must match each other.
Stephen23
Stephen23 el 20 de Jul. de 2016
@Max Bernstein: this error happens because the vector B you are using is a column vector, whereas the vector B you gave in your example is a row vector. I fixed my code to work with both of these.

Iniciar sesión para comentar.

Más respuestas (1)

Thorsten
Thorsten el 20 de Jul. de 2016
If you use that highest value that is still smaller than the corresponding B, you can write:
C = [A(arrayfun(@(i) find(A < B(i), 1, 'last'), 1:numel(B))); B]'
But this differs from your desired output. So what is the rule according to which you pick the values form A?
  1 comentario
Max Bernstein
Max Bernstein el 20 de Jul. de 2016
Sorry for the mistake, but yes it should be the closest values from A that are less than B.
Your answer works great, my desired output is:
C = [A(arrayfun(@(i) find(A < B(i), 1, 'last'), 1:numel(B))), B]'
replaced ; with ,

Iniciar sesión para comentar.

Categorías

Más información sobre Matrix Indexing en Help Center y File Exchange.

Productos

Community Treasure Hunt

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

Start Hunting!

Translated by