How to add percent change in barplot?
조회 수: 18 (최근 30일)
Hello everyone and happy new year!
I have a barplot (average deaths per degree of temperature, 30-37oC) to which I want to add the percentage change from bar to bar. Attached you can find the excel file I am proccessing and here is the part of code that produces tha barplot.
Is there an efficient way to do so?
Thanks in advance!
PS. I am on R2019a.
Daily_Data = readtable('Daily_Data_MoT.xlsx');
idx = Daily_Data.Daily_T(:) > 30;
Daily_Data_new = Daily_Data(idx,:);
[G, Temperature] = discretize(Daily_Data_new.Daily_T, 30:37);
d_mean = accumarray(G, Daily_Data_new.Daily_Deaths, [length(Temperature), 1], @mean);
bar(Temperature, d_mean); xlabel('T (oC)'); ylabel('Average deaths');
Steve Eddins 2021년 1월 4일
편집: Steve Eddins 님. 2021년 1월 4일
If you want text labels instead of a line plot (Cris' suggestion), then try this code. It gets the Bar object as the output argument from bar, and then computes the percent change and where to put the labels using the XData and YData properties of the Bar object.
b = bar(Temperature, d_mean); xlabel('T (oC)'); ylabel('Average deaths');
x = b.XData;
y = b.YData;
percent_change = 100 * diff(y) ./ y(1:end-1);
for k = 1:length(percent_change)
추가 답변 (1개)
Cris LaPierre 2021년 1월 4일