필터 지우기
필터 지우기

How to extract specific parts of a matrix

조회 수: 33 (최근 30일)
lech king
lech king 2021년 3월 26일
편집: Chad Greene 2021년 3월 28일
In a 512 x 512 matrix where each cell has a number between 0 and 1000, a large part of the cells in this matrix, for example, contains the value 98 (on the left) and on the other side, a large number of cells contain, for example, the value 900.
In the case of when there is only one matrix, it is easy to determine what numbers the matrix contains on both sides.
But in other matrices these numbers are different
I'm looking for a way to automatically specify these numbers on both sides of a matrix
Thank you for your help

채택된 답변

Chad Greene
Chad Greene 2021년 3월 26일
편집: Chad Greene 2021년 3월 28일
Let's see if I understand what you're trying to do. As I understand it, you have a 512x512 matrix with lots of values of 98 on the left side and lots of 900 on the right side. And you want to automatically find the most common number on the left side of the matrix, and the most common number on the right side? Here's how I'd do that:
M = 1000*rand(512); % some random numbers between 0 and 1000
M(1:10:1e5) = 98; % every tenth value on the left side is 98
M(2e5:12:end) = 900; % every 12th value on the right side is 900
imagesc(M) % displays the matrix
It's difficult to see, because only 1 in 10 values on the left side ar 98, but still 98 is the most common value on the left side. And on the right side, the most common value is 900, because it's every 12th value. Here's how you'd find the most common value on the left and right side:
LeftSide = mode(M(:,1:256),'all')
LeftSide = 98
RightSide = mode(M(:,257:end),'all')
RightSide = 900
  댓글 수: 3
Chad Greene
Chad Greene 2021년 3월 27일
Ah, okay. Then I recommend doing the same thing, but only take the mode of the elements that exceed zero. Here's how:
M = 1000*rand(512); % some random numbers between 0 and 1000
M(randi(numel(M),[numel(M)/2 1])) = 0; % set half of the pixels to zero.
M(1:10:1e5) = 98; % every tenth value on the left side is 98
M(2e5:12:end) = 900; % every 12th value on the right side is 900
imagesc(M) % displays the matrix
colormap(gray)
tmp = M(:,1:256); % a temporary matrix of just the left side
LeftSide = mode(tmp(tmp>0),'all') % the mode of left-side values that exceed 0.
LeftSide = 98
tmp = M(:,257:end);
RightSide = mode(tmp(tmp>0),'all')
RightSide = 900
lech king
lech king 2021년 3월 28일
Thank you very much for your help
It was exactly what I wanted
Excellent

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

추가 답변 (1개)

Sulaymon Eshkabilov
Sulaymon Eshkabilov 2021년 3월 26일
Logical indexing would be an easy and fast solution.
  댓글 수: 3
Sulaymon Eshkabilov
Sulaymon Eshkabilov 2021년 3월 26일
A = [1, 2, 3; 5 4 4; 6 4 4]; B = (A==4).*A
By this way, you'll get only values which are equal to 4 and the rest is "0".
Good luck.
lech king
lech king 2021년 3월 27일
Thanks for your help
The problem is that in other matrices it is not clear which number has the highest number
In other words, the main problem is to determine the number that fills the most cells in the matrix

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

카테고리

Help CenterFile Exchange에서 Data Type Conversion에 대해 자세히 알아보기

제품


릴리스

R2020a

Community Treasure Hunt

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

Start Hunting!

Translated by