Azzera filtri
Azzera filtri

How do I create a logarithmic scale colormap or colorbar?

1.076 visualizzazioni (ultimi 30 giorni)
I need to color 'surf' plots on a log scale and subsequently displace the log-based colorbar.

Risposta accettata

MathWorks Support Team
MathWorks Support Team il 22 Nov 2023
Modificato: MathWorks Support Team il 22 Nov 2023
Please follow the steps below to create a log colobar in 'surf' plot:
% Plot the surface plot
[X, Y] = meshgrid(1:0.5:10,1:20);
Z = sin(X) + cos(Y);
figure;
surf(X, Y, Z)
% Show the colorbar
colorbar
% Set the log colobar
set(gca,'ColorScale','log')
Note: This feature was introduced in MATLAB R2018a.
For more information, refer to the following documentation page, "Axes Properties":
https://www.mathworks.com/help/matlab/ref/matlab.graphics.axis.axes-properties.html#budumk7-ColorScale

Più risposte (2)

lvn
lvn il 9 Nov 2023
Modificato: Rena Berman il 22 Nov 2023
  4 Commenti
Walter Roberson
Walter Roberson il 31 Mar 2020
You can tell by the wording of the official answer that it was written for an older version of MATLAB.
Pat
Pat il 11 Mag 2023
Modificato: Walter Roberson il 5 Set 2023
Hi Kristoffer Walker,
If you still need assistance with this issue, please create a MathWorks Technical Support Case. We would be happy to help you out.

Accedi per commentare.


Berthold Reisz
Berthold Reisz il 15 Mar 2019
Try the following:
% let A be your data
A = 100*rand(100,100);
% plot log10 of A
pcolor(log10(A))
% get the minimum and maximum value of A
c1 = min(min(A));
c2 = max(max(A));
% set limits for the caxis
caxis([log10(c1) log10(c2)]);
% preallocate Ticks and TickLabels
num_of_ticks = 5;
Ticks = zeros(1,num_of_ticks);
TickLabels = zeros(1,num_of_ticks);
% distribute Ticks and TickLabels
for n = 1:1:num_of_ticks
Ticks(n) = log10(round(c2)/num_of_ticks*n);
TickLabels(n) = round(c2)/num_of_ticks*n;
end
% set Ticks and TickLabels
colorbar('Ticks',Ticks,'TickLabels',TickLabels)

Categorie

Scopri di più su 2-D and 3-D Plots in Help Center e File Exchange

Prodotti


Release

R2018a

Community Treasure Hunt

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

Start Hunting!

Translated by