python 分享一个复现文献中colorbar的简单教程

前言

最近在阅读文献时,想要复现别人的结果,其中遇到的一个挑战就是复现别人绘图时用的colorbar,本文分享一下我是如何复现的。
文献中的colorbar如下图所示:
在这里插入图片描述
想要复现这样的一条colorbar,首先需要观察一下它的颜色渐变分布。上图的colorbar还是比较清晰明了的,很容易发现它是这样渐变的:

=>=>=>红
blue - white -yellow -red

非常巧的是NCL的colormap中恰好有一条是这样分布的,作者估计就是根据这个改的:
在这里插入图片描述

这样就更方面了,我们在python中,先导入这一条colormap,然后

  • 重新定义一些区间范围,以及间隔
  • 修改一些参数
    即可完美实现相同的colormap。

之前也做过类似的教程分享:自定义colormap

截取colormap

下面是代码展示:

import numpy as np

import cmaps 
      
import matplotlib.pyplot as plt

import matplotlib as mpl   

from matplotlib.colors import ListedColormap 
#######################生成画板#####################################
fig=plt.figure(figsize=(10,8),dpi=150)

ax1=fig.add_axes([0,0,1,0.05])                                                 
ax2=fig.add_axes([0,0.25,1,0.05])  
#######################定义新的colormap#########################################
norm =mpl.colors.Normalize(vmin=-0.48, vmax=0.48)    #确定colormap的最大最小值
                                         
cmap=cmaps.BlueWhiteOrangeRed  #引用NCL的colormap
                                       
newcolors=cmap(np.linspace(0,1,12))#分片操作,生成0到1的12个数据间隔的数组   
                               
newcmap=ListedColormap(newcolors[::1])  #重构为新的colormap
              
###########################################################################        
fc1=fig.colorbar(mpl.cm.ScalarMappable(norm=norm,cmap='BlueWhiteOrangeRed'),              
                 cax=ax1,                                                      
                 orientation='horizontal',    label='old cmap' ,
ticks=[-0.4,-0.32,-0.24,-0.16,-0.08,0,0.08,0.16,0.24,0.32,0.4]     ,                                                    
                 extend='both')                 
                                                   
fc2=fig.colorbar(mpl.cm.ScalarMappable(norm=norm,cmap=newcmap),                                            
                  cax=ax2,         format='%.2g'    ,                                             
                  orientation='horizontal',     label='new cmap' ,
ticks=[-0.4,-0.32,-0.24,-0.16,-0.08,0,0.08,0.16,0.24,0.32,0.4]     ,                                     
                  extend='both')  
fc2.ax.tick_params(which='major',direction='in',length=29)

其中,简单对代码做一下说明:

  • cmaps 库是专门用来调用NCL colormap的一个库,非常感谢这个开发者的贡献
  • ListedColormap 用来重构一个修改后的colormap
  • 其他的代码都比较简单,对于colorbar的修饰

对比结果如下所示:
在这里插入图片描述
可以发现,大致的特征已经比较一致了,稍加修饰即可成功完美复现原文的结果

拼接colormap

同样的,既然可以从一个colormap中截取一部分作为新的colormap,那么可以将两个colormap拼接为一个新的colormap吗?

  • 答案当然是可以的,实现的方法基本一致,无非是导入两个colormap而已
  • 使用np.vstack()函数,将两个colormap结果拼接,再重构为新的colormap
  • 下面直接上代码和结果
cmap1=cmaps.MPL_Blues_r            #蓝色                                   
cmap2=cmaps.cmocean_algae          #绿色   
###########################################################################                   
list_cmap1=cmap1(np.linspace(0,1,13))                                      
list_cmap2=cmap2(np.linspace(0,1,12))                                           
new_color_list=np.vstack((list_cmap1,list_cmap2))                            
new_cmap=ListedColormap(new_color_list,name='new_cmap ') 
###########################################################################                                                                      
fig=plt.figure(figsize=(10,8),dpi=200)                                        
ax1=fig.add_axes([0,0.15,1,0.03])                                                 
ax2=fig.add_axes([0,0.25,1,0.03])                                            
ax3=fig.add_axes([0,0.35,1,0.03])            
###########################################################################                                   
norm =mpl.colors.Normalize(vmin=-10, vmax=10)                              
fc1=fig.colorbar(mpl.cm.ScalarMappable(norm=norm,                            
                 cmap=cmap1),cax=ax1,                                     
                 orientation='horizontal',extend='both',
                 label='cmap1')                       
fc2=fig.colorbar(mpl.cm.ScalarMappable(norm=norm,                      
                 cmap=cmap2),cax=ax2,                                      
                 orientation='horizontal',extend='both',
                 label='cmap2')                    
fc3=fig.colorbar(mpl.cm.ScalarMappable(norm=norm,                         
                 cmap=new_cmap),cax=ax3,                                
                 orientation='horizontal',extend='both',
                 label='newcmap') 

结果如下所示:
在这里插入图片描述

  • 可以发现还是非常perfect的,感兴趣的兄弟们快去尝试吧~

          					一个努力学习python的ocean er
                      		水平有限,欢迎指正!!!
                        	欢迎评论、收藏、点赞、转发、关注。
                        	关注我不后悔,记录学习进步的过程~~
    
  • 16
    点赞
  • 76
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 在Python,我们可以使用Matplotlib库来创建子图并共用一个colorbar。下面是一个示例代码: ```python import matplotlib.pyplot as plt import numpy as np # 创建一个2x2的子图布局 fig, axes = plt.subplots(2, 2, figsize=(8, 6)) # 生成一些示例数据 data1 = np.random.rand(10, 10) data2 = np.random.rand(10, 10) data3 = np.random.rand(10, 10) # 在第一个子图绘制热图 im1 = axes[0, 0].imshow(data1, cmap='viridis') axes[0, 0].set_title('Subplot 1') # 在第二个子图绘制热图 im2 = axes[0, 1].imshow(data2, cmap='viridis') axes[0, 1].set_title('Subplot 2') # 在第三个子图绘制热图 im3 = axes[1, 0].imshow(data3, cmap='viridis') axes[1, 0].set_title('Subplot 3') # 创建一个共用的colorbar cbar = fig.colorbar(im3, ax=axes.ravel().tolist(), shrink=0.6, aspect=20) cbar.set_label('Colorbar') # 调整子图之间的间距 fig.tight_layout() # 显示图形 plt.show() ``` 在上述代码,我们通过`plt.subplots`创建了一个2x2的子图布局,并使用`fig.colorbar`函数为其的第一个子图创建了一个共用的colorbar。`ax=axes.ravel().tolist()`参数指定了要在哪些子图显示colorbar,`shrink`和`aspect`参数用于调整colorbar的大小和纵横比。最后,使用`tight_layout`函数调整子图之间的间距,并通过`plt.show`显示图形。 这样,我们就实现了三个子图共用一个colorbar的功能。注意,上述示例的示例数据都是随机生成的,你可以根据自己的数据进行相应的修改和适应。 ### 回答2: 在Python,我们可以使用matplotlib库来绘制图形和颜色条。要实现三个子图共用一个颜色条,可以按照以下步骤操作: 首先,导入所需的库: ```python import matplotlib.pyplot as plt import numpy as np ``` 然后,创建三个子图并生成数据: ```python fig, axs = plt.subplots(1, 3, figsize=(12, 4)) # 创建一个包含三个子图的画布 data1 = np.random.rand(10, 10) # 生成第一个子图的数据 data2 = np.random.rand(10, 10) # 生成第二个子图的数据 data3 = np.random.rand(10, 10) # 生成第三个子图的数据 ``` 接下来,将三个子图绘制出来: ```python im1 = axs[0].imshow(data1, cmap='hot') # 绘制第一个子图,并将颜色条保存在im1 im2 = axs[1].imshow(data2, cmap='hot') # 绘制第二个子图,并将颜色条保存在im2 im3 = axs[2].imshow(data3, cmap='hot') # 绘制第三个子图,并将颜色条保存在im3 ``` 然后,确定颜色条的位置和大小,并将其添加到画布上: ```python cbar_ax = fig.add_axes([0.92, 0.3, 0.02, 0.4]) # 确定颜色条的位置和大小 fig.colorbar(im1, cax=cbar_ax) # 将颜色条添加到画布上,并指定参考图像为im1 ``` 最后,显示图形: ```python plt.show() ``` 这样,就实现了三个子图共用一个颜色条的效果。 ### 回答3: 三个子图能够共用一个colorbar,可以通过matplotlib的gridspec来实现。gridspec提供了更灵活的子图布局方式。 首先,我们创建一个包含三个子图的网格(spec)。我们可以通过gridspec的`subplots`方法来实现: ```python import matplotlib.pyplot as plt import matplotlib.gridspec as gridspec # 创建一个包含三个子图的网格,每行一个子图 gs = gridspec.GridSpec(3, 1) # 创建第一个子图 ax1 = plt.subplot(gs[0]) # 创建第二个子图 ax2 = plt.subplot(gs[1]) # 创建第三个子图 ax3 = plt.subplot(gs[2]) ``` 接下来,我们可以在每个子图上绘制不同的数据,并为每个子图设置相同的colorbar。这可以通过调用`colorbar`方法并传入子图对象以及关联的绘图对象(例如图像、散点图等)来实现。 ```python # 在第一个子图上绘制数据1 ax1.imshow(data1) # 在第二个子图上绘制数据2 ax2.imshow(data2) # 在第三个子图上绘制数据3 ax3.imshow(data3) # 创建共享的colorbar cbar = plt.colorbar(ax=axs, orientation="vertical") ``` 这样就可以在三个子图之间共享一个colorbar了。需要注意的是,共享的colorbar应该基于相同范围的数据创建(例如,数据1、数据2和数据3的值范围应相同),以保证颜色映射的一致性。 最后,通过调用`plt.show()`展示出这三个子图以及共享的colorbar。 ```python plt.show() ``` 这样,我们就成功地在三个子图之间实现了共享一个colorbar的效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

简朴-ocean

继续进步

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值