contour() function plots with a solid background (and not a transparent background, which is desired)

11 次查看(过去 30 天)
Dear matlab,
I'm plotting a colored spectrogram with contourf().
Then, I would like to plot statistics on top of this plot by adding a solid line, outlining the regions of statistically significance difference.
In the past, this was achieved by 'hold on' and plotting contour() 'on top of' the other contour plot. (code below)
However, now the second contour plot does plot the soline line circumscribing stat-sig different data BUT the background is a solid color and it overrides/sits on top of the first contoru plot and I can't see the original spectrogram (its all one color purple). Please help. code below. Thanks much in advance.
%%
phas_freqs = 1:1:20;
ampl_freqs = 1:2:70;
% modindex_comodulogram = 20x35 double matrix of numbers
% z_modulation = 20x35 double matrix of Z-VALUES OF THE modindex_comodulogram
figure(8), clf
contourf(phas_freqs,ampl_freqs,modindex_comodulogram',40,'linecolor','none');
hold on
contour(phas_freqs,ampl_freqs,logical(z_modulation)',1,'linecolor','m','LineWidth',3);
%%%%%%%%%%%%%%%%%%%%%%%%%%
I PLOTTED BOTH IN SEPARATE PLOTS BELOW.
I WOULD LIKE TO PUT THE LINE PLOT 'ON TOP' OF THE SPECTROGRAM IN ONE PLOT. please help!

采纳的回答

Star Strider
Star Strider 2022-9-25
Perhaps something like this —
[X,Y,Z] = peaks(50);
figure
surf(X,Y,Z, 'EdgeColor','none')
hold on
contour3(X, Y, Z, 'Color','m', 'LineWidth',2)
hold off
view(0, 90)
colormap(turbo)
Expedriment with this code and your data ato get the desired result.
.
  8 个评论
Paul
Paul 2022-9-25
Can also get there with the original code by saving the clim after the first plot and setting to that vlaue after the second.
LD = load(websave('JH_onePlotBothMatrices','https://www.mathworks.com/matlabcentral/answers/uploaded_files/1136090/JH_onePlotBothMatrices.mat'));
modindex_comodulogram = LD.plv_modindex_comodulogram;
z_modulation = LD.z_modulation;
phas_freqs = 1:1:20;
ampl_freqs = 1:2:70;
% modindex_comodulogram = 20x35 double matrix of numbers
% z_modulation = 20x35 double matrix of Z-VALUES OF THE modindex_comodulogram
figure(8), clf
contourf(phas_freqs,ampl_freqs,modindex_comodulogram',100,'linecolor','none');
colormap(turbo) % <— OPTIONAL
clim = get(gca,'CLim');
hold on
%contour(phas_freqs,ampl_freqs,z_modulation'+0.5, [0 0],'linecolor','m','LineWidth',3);
contour(phas_freqs,ampl_freqs,logical(z_modulation)',1,'linecolor','m','LineWidth',3);
set(gca,'CLim',clim)
view(0,90)
xlabel('Frequency for phase')
ylabel('Frequency for amplitude')
% title("PAC in " + string(EEG.setname) ": " string(EEG.chanlocs(chani).labels)) % Using 'string' Arrays
colorbar
a=colorbar;
ylabel(a,'Modulation Index','FontSize',10);

请先登录,再进行评论。

更多回答(0 个)

类别

Help CenterFile Exchange 中查找有关 Contour Plots 的更多信息

Community Treasure Hunt

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

Start Hunting!

Translated by