Mode identification on a Graph.

3 ビュー (過去 30 日間)
mpho bosupeng
mpho bosupeng 2021 年 4 月 24 日
回答済み: Clayton Gotberg 2021 年 4 月 24 日
Hello everyone,
I am a beginner with MATLAB and i need some assistance. I need to produce a graph similar to this one attached. I want to include the vertical dotted lines and the labelling on the graph (HF, IF, AND Trend). My question is how to I do this, I only know that this will need some threshold.
Thanks.
  3 件のコメント
mpho bosupeng
mpho bosupeng 2021 年 4 月 24 日
編集済み: mpho bosupeng 2021 年 4 月 24 日
Thanks @Clayton Gotberg. The code is
plot(time,signal)
xlabel('year')
ylabel('PIL')
IMFH=IMF_R(1:end,2*L+1:end-2*L);
NumIMFH=size(IMFH,1);
sumIMFH=0;
for j=1:NumIMFH
sumIMFH=IMFH(j,:)+sumIMFH;
STH(j)=nanmean(sumIMFH)/std(sumIMFH);
indiH(j)=j;
end
figure
plot(indiH(1:end-1),STH(1:end-1),'ok')
ylabel('\mu/\sigma')
xlabel('c_j')
I need to analyze the points to find the regions
Adam Danz
Adam Danz 2021 年 4 月 24 日
You can also add the vertical lines using xline()
> I need to analyze the points to find the regions
Ok, let us know exactly what you need help with.

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

採用された回答

Clayton Gotberg
Clayton Gotberg 2021 年 4 月 24 日
It looks like you already have the code to find out where the divisions should be. In that case, all that remains to be solved is:
  1. The plot is missing the vertical lines to separate the regions
  2. The plot doesn't have the region labels
HF_IF_divider = ; % this value should be the point in x at which the HF and IF regions touch
IF_Trend_divider = ; % this value should be the point in x where IF and Trend meet
plot(data) % replace with all of the plotting you've done so far
hold on
% Add the vertical lines
xline(HF_IF_divider,'k--') % Thanks @Adam Danz for mentioning this great function
xline(IF_Trend_divider,'k--') % 'k' means black lines, '--' means dashed lines
label_x = [1/2*HF_IF_divider, 1/2*(IF_Trend_divider+HF_IF_divider),...
1/2*(length(signal)+IF_Trend_divider)]; % x positions of labels
label_y = [0.5 0.5 0.5]; % Change this to modify the height of the label
zone_names = ["HF" "IF" "Trend"];
text(label_x,label_y,zone_names,'HorizontalAlignment','center','VerticalAlignment','middle','FontSize',12);

その他の回答 (0 件)

カテゴリ

Help Center および File Exchange2-D and 3-D Plots についてさらに検索

タグ

Community Treasure Hunt

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

Start Hunting!

Translated by