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

24 visualizzazioni (ultimi 30 giorni)
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!

Risposta accettata

Star Strider
Star Strider il 25 Set 2022
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 Commenti
Paul
Paul il 25 Set 2022
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);

Accedi per commentare.

Più risposte (0)

Categorie

Scopri di più su Contour Plots in Help Center e File Exchange

Community Treasure Hunt

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

Start Hunting!

Translated by