Nei*_*bst 6 python matplotlib python-3.x imshow
我正在尝试hsv使用imshowin 绘制值matplotlib.问题是我正在使用的方法返回一个具有三个值的元组,hsv但是imshow将其解释为rgb.有没有办法告诉imshow价值观是hsv多少?
这是我的代码:
import matplotlib.pyplot as plt
import numpy as np
import matplotlib.colors as mcolors
def G(x, y):
s = x + 1j*y
return (s+2)/(s**2 + s + 1)
x = np.linspace(-3, 3, 1000)
y = np.linspace(-3, 3, 1000)
xx, yy = np.meshgrid(x, y)
norm = mcolors.Normalize()
zz = G(xx, yy)
phase = np.angle(zz)
mag = np.abs(zz)
# color converter
c = mcolors.ColorConverter().to_rgb
# Custom rgb Colormap
rgb = make_colormap(
[c('red'), c('yellow'), 0.33, c('yellow'), c('green'), c('cyan'), 0.5, c('cyan'),
c('blue'), c('magenta'), 0.833, c('magenta'), c('red')])
# Turn data points into rgb values
z_data_rgb = rgb(norm(phase))
# normalizing the intensity values
intensity = norm(mag)
# defining light source
ls = mcolors.LightSource()
# plotting
plt.imshow(ls.blend_hsv(z_data_rgb, intensity), extent=[-3, 3, -3, 3])
plt.show()
Run Code Online (Sandbox Code Playgroud)
如果它正常工作,根据强度值,绘图上的某些区域的饱和度应该低于其他区域.
谢谢
为什么不使用hsv_to_rgb和绘制rgb颜色?
from matplotlib.colors import hsv_to_rgb
rgb = hsv_to_rgb(hsv)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5251 次 |
| 最近记录: |