extract specific values in a matrix

2 ビュー (過去 30 日間)
mehra
mehra 2019 年 8 月 28 日
コメント済み: the cyclist 2019 年 8 月 28 日
Hello
I have a 104*14 matrix and I need to get some of the values in column 10 of this matrix which corresponds to values in first column that equal to 0.03.
How can I write that in matlab?
Thanks

採用された回答

the cyclist
the cyclist 2019 年 8 月 28 日
編集済み: the cyclist 2019 年 8 月 28 日
If A is your matrix:
A(find(A(:,10)==0.03,1),10);
You might need to be careful about getting an exact match with the floating-point value 0.03, and use some kind of tolerance instead.
For example:
A(find(A(:,10)>(0.03-1.e-9) & A(:,10)<(0.03+1.e-9),1),10);
Take a look at this documentation for eps (floating point relative accuracy) if you need to be more precise.
  2 件のコメント
mehra
mehra 2019 年 8 月 28 日
編集済み: mehra 2019 年 8 月 28 日
I rewrite that code as
results(results(:,1)==0.03,10)
and it worked. Thanks
the cyclist
the cyclist 2019 年 8 月 28 日
Oh, sorry, I misread! I thought you needed the first value in column 10, rather than using the value from the first column. Glad to have helped despite my error.

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeNumeric Types についてさらに検索

タグ

Community Treasure Hunt

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

Start Hunting!

Translated by