필터 지우기
필터 지우기

Plot only specific categorical values / scatterplot

조회 수: 18 (최근 30일)
Simon Schmidt
Simon Schmidt 2021년 4월 28일
댓글: Adam Danz 2021년 4월 29일
Hello,
I want to create a scatterplot of selected values (in this case A, B, D; without C & E) of a categorical attribute (see image).
Unfortunately I have not found a solution for this-
Help is much appreciated!
  댓글 수: 3
Simon Schmidt
Simon Schmidt 2021년 4월 28일
Hi Adam,
im having trouble with the selection. As described above I only want to plot some specific values of shop_name ("A", "B", "D")
Chad Greene
Chad Greene 2021년 4월 28일
gscatter might also be useful.

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

채택된 답변

Adam Danz
Adam Danz 2021년 4월 28일
편집: Adam Danz 2021년 4월 29일
>I only want to plot some specific values of shop_name ("A", "B", "D")
Using idexing. But with categories you also need to set which categories should appear on the axes (last line in demo). Otherwise, even with indexing, all categories will display in the plot, even if they do not contain y-values due to indexing.
Demo 1
T = table(repelem(categorical(num2cell(char(65:70))),1,2)', randi(10,12,1),'VariableNames',{'Shop','Sales'})
T = 12×2 table
Shop Sales ____ _____ A 5 A 5 B 4 B 6 C 7 C 10 D 3 D 3 E 5 E 2 F 8 F 7
selection = categorical({'A','B','D'});
idx = ismember(T.Shop, selection);
scatter(T.Shop(idx), T.Sales(idx),90,'filled')
ax = gca();
ax.XAxis.Categories = selection; % Set which categories appear
Demo 2
After adding the answer, I realized that indexing isn't really required but if you have many data points, indexing might help to speed up the process and reduce the size of the figure in memory since it only plots the data you want rather than plotting all of the data and then making only some of it visible like this approach does below.
T = table(repelem(categorical(num2cell(char(65:70))),1,2)', randi(10,12,1),'VariableNames',{'Shop','Sales'})
scatter(T.Shop, T.Sales,90,'filled')
ax = gca();
ax.XAxis.Categories = categorical({'A','B','D'});
If you want to change the visible categories you don't need to reproduce the plot, you just need to call this last line again with the selected categories.
  댓글 수: 4
Simon Schmidt
Simon Schmidt 2021년 4월 29일
Its about 2,000,000 rows of data- so i think your first solution is more handy. Thanks again!
Adam Danz
Adam Danz 2021년 4월 29일
Agreed. Glad I could help.

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

추가 답변 (0개)

카테고리

Help CenterFile Exchange에서 Annotations에 대해 자세히 알아보기

제품


릴리스

R2021a

Community Treasure Hunt

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

Start Hunting!

Translated by