Borrar filtros
Borrar filtros

Plot a 2-dimensional matrix with 2 different colormaps for negative and positive values

3 visualizaciones (últimos 30 días)
I have a big matrix consisting of values ranging from negative to positive. When I plot that by just imagesc and apply colorbar it is shpwoing gradiant over all. My requirement is to apply one colormap for negative values (probably cool) and the other colormap for positive values (probabliy hot) in a same plot as attached ( so there will be clear difference between negative and positive values).

Respuesta aceptada

Dyuman Joshi
Dyuman Joshi el 25 de Ag. de 2023
Editada: Dyuman Joshi el 25 de Ag. de 2023
%Random data for example
y = (-7:5)+(-7:5)';
%Get the maximum and minimum values of the array
p = max(y,[],'all');
n = min(y,[],'all');
%Display via imagesc
imagesc(y)
%Two colormaps
col = [cool(abs(n));hot(p)];
%Multiply the input with the same number to get more divisions on colors
%col = [cool(3*abs(n));hot(3*p)];
cb = colorbar('Ticks',n:p);
colormap(col)
  3 comentarios
THONTI BEERAIAH
THONTI BEERAIAH el 28 de Ag. de 2023
Thank you, however you solution worked nice for matrix with integers. I have a matrix which has noninteger values where the method is not working. I am uploading one matrix (as text file) so could you please do the same for the uploaded data?
Dyuman Joshi
Dyuman Joshi el 28 de Ag. de 2023
For non-integer values, round the values away from zero -
%Random data for example
vec = (-7.5:0.5:5);
y = vec+vec';
%Get the maximum and minimum values of the array
p = max(y,[],'all');
n = min(y,[],'all');
%As the input to colormaps must be positive (because it's an index)
%to round away from zero, we take ceil() of the absolute value
f = @(x) ceil(abs(x));
%Display via imagesc
imagesc(y)
%Two colormaps
col = [cool(f(n));hot(f(p))];
cb = colorbar('Ticks',n:p);
colormap(col)

Iniciar sesión para comentar.

Más respuestas (0)

Categorías

Más información sobre Colormaps en Help Center y File Exchange.

Productos


Versión

R2022b

Community Treasure Hunt

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

Start Hunting!

Translated by