contour() function plots with a solid background (and not a transparent background, which is desired)
9 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Joanne Hall
el 25 de Sept. de 2022
Comentada: Joanne Hall
el 25 de Sept. de 2022
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!
0 comentarios
Respuesta aceptada
Star Strider
el 25 de Sept. de 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 comentarios
Paul
el 25 de Sept. de 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);
Más respuestas (0)
Ver también
Categorías
Más información sobre Data Distribution Plots en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!