Python matplotlib的使用并自定義colormap的方法
0.前言
添加colormap的對象是灰度圖,可以變成熱量圖,從而更加明顯的發(fā)現(xiàn)一些規(guī)律,適用于一些雷達圖像等
from PIL import Image # 將彩色圖片轉(zhuǎn)換成黑白圖片 im=Image.open("./pic.jpg").convert('L') # 保存圖片 im.save("image.jpg")
1.從灰色圖片中讀取數(shù)據(jù),轉(zhuǎn)換成colormap圖
import matplotlib.pyplot as plt import matplotlib.image as mpimg import matplotlib as mpl from PIL import Image import numpy as np # 自定義colormap def colormap(): return mpl.colors.LinearSegmentedColormap.from_list('cmap', ['#FFFFFF', '#98F5FF', '#00FF00', '#FFFF00','#FF0000', '#8B0000'], 256) # 讀取灰度圖 data=mpimg.imread('./gray.jpg') # 如果需要固定colorbar的范圍,可以設(shè)置參數(shù)vmin,vmax,具體參考 #http://matplotlib.org/api/image_api.html # 設(shè)定每個圖的colormap和colorbar所表示范圍是一樣的,即歸一化 plt.imsave('colormap.jpg',data, cmap=colormap())
這里沒有顯示出來colorbar的數(shù)值分布,得到的圖像是等大的
2.從txt文本中讀取二維數(shù)據(jù),轉(zhuǎn)換成自定義colormap圖
#python 3 import numpy as np import matplotlib.pyplot as plt import matplotlib as mpl import matplotlib.colors as colors # load data def loaddata(i): # 文件編號 path = './input/data/trainPingliu/trainPingliu%d.txt' % i data = np.loadtxt(path) return data # 生成圖片格式自定義 def colormap(): # 白青綠黃紅 cdict = ['#FFFFFF', '#9ff113', '#5fbb44', '#f5f329', '#e50b32'] # 按照上面定義的colordict,將數(shù)據(jù)分成對應(yīng)的部分,indexed:代表順序 return colors.ListedColormap(cdict, 'indexed') # for i in range(1, 10000): # 加載數(shù)據(jù) data = loaddata(1) fig = plt.figure() # 加載圖片設(shè)置 my_cmap = colormap() # 第一個子圖,按照默認配置 ax = fig.add_subplot(221) ax.imshow(data) # 第二個子圖,使用api自帶的colormap ax = fig.add_subplot(222) cmap = mpl.cm.bwr # 藍,白,紅 ax.imshow(data, cmap=cmap) # 第三個子圖增加一個colorbar ax = fig.add_subplot(223) cmap = mpl.cm.winter # 冬季風(fēng)格 im = ax.imshow(data, cmap=my_cmap) plt.colorbar(im) # 增加colorbar # 第四個子圖可以調(diào)整colorbar ax = fig.add_subplot(224) cmap = mpl.cm.rainbow # 這里設(shè)置colormap的固定值 norm = mpl.colors.Normalize(vmin=-1, vmax=1) im=ax.imshow(data,cmap=cmap) plt.colorbar(im,cmap=cmap, norm=norm,ticks=[-1,0,1]) # 顯示 plt.show()
以上這篇Python matplotlib的使用并自定義colormap的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python操作JSON實現(xiàn)網(wǎng)絡(luò)數(shù)據(jù)交換
這篇文章主要介紹了Python操作JSON實現(xiàn)網(wǎng)絡(luò)數(shù)據(jù)交換,JSON的全稱是 JavaScript Object Notation,是一種輕量級的數(shù)據(jù)交換格式,關(guān)于JSON的更多相關(guān)內(nèi)容感興趣的小伙伴可以參考一下2022-06-06python?中collections的?deque使用詳解
這篇文章主要介紹了python中collections的deque使用詳解,deque是一個雙端隊列,如果要經(jīng)常從兩端append的數(shù)據(jù),選擇這個數(shù)據(jù)結(jié)構(gòu)就比較好了,更多相關(guān)內(nèi)容,需要的小伙伴可以參考下面文章內(nèi)容2022-09-09windows10系統(tǒng)中安裝python3.x+scrapy教程
本文給大家主要介紹了在windows10系統(tǒng)中安裝python3以及scrapy框架的教程以及有可能會遇到的問題的解決辦法,希望大家能夠喜歡2016-11-11pandas中DataFrame檢測重復(fù)值的實現(xiàn)
本文主要介紹了pandas DataFrame檢測重復(fù)值,主要包括了檢查整行整列的檢測,以及多列是否重復(fù),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05python實現(xiàn)自動登錄人人網(wǎng)并采集信息的方法
這篇文章主要介紹了python實現(xiàn)自動登錄人人網(wǎng)并采集信息的方法,涉及Python模擬登陸及正則匹配的相關(guān)技巧,需要的朋友可以參考下2015-06-06python神經(jīng)網(wǎng)絡(luò)slim常用函數(shù)訓(xùn)練保存模型
這篇文章主要為大家介紹了python神經(jīng)網(wǎng)絡(luò)使用slim函數(shù)進行模型的訓(xùn)練及保存模型示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-05-05