How to extract matrix value given condition on another column

조회 수: 1 (최근 30일)
Jesutoyosi Awoyeye
Jesutoyosi Awoyeye 2017년 9월 5일
편집: Jesutoyosi Awoyeye 2017년 9월 5일
So i have a matrix: [1 2 3 4; 5 6 7 8; 1 0 1 1]
The condition is that the third column must equal one. Then I take that corresponding row to extract the value from column 2.
So i need a code that extracts 5, 7, and 8 into a separate matrix.

답변 (1개)

Cam Salzberger
Cam Salzberger 2017년 9월 5일
Hello Jesutoyosi,
Based on your example matrix, I believe you meant that you want to extract from row 2 every value that is a 1 in row 3.
In that case, logical indexing is your best friend.
whichCols = oldMat(3,:) == 1;
newMat = oldMat(2,whichCols);
Or, because 1 is able to be converted to true, and 0 to false, you can just do this:
newMat = oldMat(2, logical(oldMat(3,:)));
-Cam
  댓글 수: 1
Jesutoyosi Awoyeye
Jesutoyosi Awoyeye 2017년 9월 5일
편집: Jesutoyosi Awoyeye 2017년 9월 5일
Will this same code apply to all dimensions? The dimension of the matrix that I am dealing with is 195x6. I am extracting values from column 4 given that the values in column 6 is 1.

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Creating and Concatenating Matrices에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by