Find indices for the minimum positive values in a cell

20 visualizaciones (últimos 30 días)
EldaEbrithil
EldaEbrithil el 19 de Jun. de 2020
Editada: EldaEbrithil el 19 de Jun. de 2020
Hi all
i am not able to find the indices for the minimum positive values inside a 2x7 cell. I would find the cell number (containing this minimum element) and its position inside the cell. For example in the first cell the minimum positive value have index [row,column]=[1,2].
This is my 2x7 cell:
C = {[5 0.0001;0 0.1],3,-2,2,3,[-0.1 5],[2 0.0001];[1 2],[0.0001 1],2,4,5,[1 -0.1],6};
Thank you for the help
Regards

Respuesta aceptada

Rik
Rik el 19 de Jun. de 2020
You can always consider cellfun if you want to apply a function to every element of your cell. It might not be the fastest option though.
C = {[5 0.0001;0 0.1],3,-2,2,3,[-0.1 5],[2 0.0001];[1 2],[0.0001 1],2,4,5,[1 -0.1],6};
[rows,cols]=cellfun(@myfun,C);
function [row,col]=myfun(A)
A(A<0)=inf;%make sure it isn't the minimum
[~,idx]=min(A(:));
[row,col]=ind2sub(size(A),idx);
end
  9 comentarios
Rik
Rik el 19 de Jun. de 2020
If you mean closest to 0, why did you say only positive? And do you want the actual value itself, or the indices, as you originally described?
Since inside the function you're working with a local copy of the array, you can simply use the abs function to remove the sign.
function [row,col]=myfun(A)
A=abs(A);
[~,idx]=min(A(:));
[row,col]=ind2sub(size(A),idx);
end
Please stop changing the requirements. Note that you can run this function as normal:
[row,col]=myfun([-1 -0.1]);
Think long and hard about what it is you want. Only then can you hope to solve this.
EldaEbrithil
EldaEbrithil el 19 de Jun. de 2020
Editada: EldaEbrithil el 19 de Jun. de 2020
Sorry I had not specified very well in the last message. When i introduced the negative cell I wanted to take a step forward, redirecting myself to another goal, that is to find the value closest to zero. Thank you very much for the help

Iniciar sesión para comentar.

Más respuestas (1)

Suhas Maddi
Suhas Maddi el 19 de Jun. de 2020
Editada: Suhas Maddi el 19 de Jun. de 2020
Hii Elda,You can use a for loops to go through each element in the cell and find indexes of minimum values for each cell element using the min() function.For more information and detailed examples, You can refer to : https://www.mathworks.com/help/matlab/ref/min.html
%You want to find minimum element and it's index in first Cell element
%M is the minimum value and [x,y] is the index of the minimum value in the cell element.
[M,I]=min(min(C{1,1}));
[x,y]=find(C{1,1}==M)
%To do this for the whole cell,You can use for loops to iterate through each element.
I hope this helps you.
  3 comentarios
Suhas Maddi
Suhas Maddi el 19 de Jun. de 2020
Hii Elda,Yes Kind of in the lines of what you have mentioned.If you want to store the indices of minimum elements for each cell element,You can use a vector or matrix or another cell array Hope this helps.
EldaEbrithil
EldaEbrithil el 19 de Jun. de 2020
ok something like that i suppose:
for i=1:2
for j=1:7
%You want to find minimum element and it's index in first Cell element
%M is the minimum value and [x,y] is the index of the minimum value in the cell element.
[M(i,j),I]=min(min(C{i,j}));
[x(i,j),y(i,j)]=find(C{i,j}==M(i,j));
%To do this for the whole cell,You can use for loops to iterate through each element.
end
end
But i want only >0 terms and this code include 0 as minimum element

Iniciar sesión para comentar.

Categorías

Más información sobre Loops and Conditional Statements en Help Center y File Exchange.

Etiquetas

Productos


Versión

R2019a

Community Treasure Hunt

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

Start Hunting!

Translated by