finding values from matrix

Dear All
I have a matrix which is given by A= [20 140]. I want to find the location of elements in A which are greter than 45. Here is the matlab script which I tried to work upon but it gives me the whole value rather than location with respect to each coumn.
for i = 1:20
Loc(ii,:)= find(A(i,:)>45);
end
Thank you for your help

Réponses (3)

Azzi Abdelmalek
Azzi Abdelmalek le 15 Juil 2013
Modifié(e) : Azzi Abdelmalek le 15 Juil 2013

2 votes

out=A(A>45)
If you want the location:
idx=find(A>45) % corresponding indices
out=A(idx)

3 commentaires

Ede gerlderlands
Ede gerlderlands le 15 Juil 2013
This gives me the total values. What I want is the position(location) of values which are greater than 45. The locationhas to be with respect to the column ex. for column 1, 5, 65 ,78 etc... for column two 4, 5,8,12,...
Ok
A=randi(200,5) % Example
[ii,jj]=find(A>45)
Azzi Abdelmalek
Azzi Abdelmalek le 15 Juil 2013
Modifié(e) : Azzi Abdelmalek le 15 Juil 2013
A=[0 46 10 1; 47 5 48 5; 3 19 25 70]
out=arrayfun(@(x) max(find(A(x,:)>45)),1:size(A,1))

Connectez-vous pour commenter.

Matt J
Matt J le 15 Juil 2013

1 vote

[i,j]=find(A>45);

7 commentaires

Ede gerlderlands
Ede gerlderlands le 15 Juil 2013
I think am not clear with you. Is it not possible to get the location per co;umn? this gives me the over all location? isn't that? tnx
Matt J
Matt J le 15 Juil 2013
Modifié(e) : Matt J le 15 Juil 2013
Show us the desired output for this small example matrix
A=[0 46 10 1; 47 5 48 5; 3 19 25 70]
And explain what form the output should take (cell, matrix, structure, etc...)
Ede gerlderlands
Ede gerlderlands le 15 Juil 2013
The answer will be 2 for the first column 1 and 3 foe the second as well as 4 for the third column. the output should be in str. Thank you
Matt J
Matt J le 15 Juil 2013
The example matrix I gave you has 4 columns...
Ede gerlderlands
Ede gerlderlands le 15 Juil 2013
sorry, it has to be rows
Matt J
Matt J le 15 Juil 2013
for k=1:size(A,1)
S(k).locs = find(A(k,:)>45);
end
Edwin Herrera Vasco
Edwin Herrera Vasco le 4 Mai 2020
Thanks!!!

Connectez-vous pour commenter.

Iain
Iain le 15 Juil 2013

0 votes

A = [45 46; 42 43];
logical_address = A>45;
A(logical_address) %gives you a single 46.
linear_index = find(logical_address);
A(linear_index) % gives you a single 46.
[rowno, colno ] = sub2ind(size(A),linear_index);
A(rowno,colno ) % gives you a single 46
Looking at your code, I think you're trying to do that row by row.
find(A(i,:)>45) will give a vector containing the column number of each column which is >45 in that row of A - the length of this may vary from row to row, so you can't store the result in a simple vector - you'd need to use a cell array.

Catégories

En savoir plus sur Loops and Conditional Statements dans Centre d'aide et File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by