Powiedzmy, że mam dane wejściowe:
data = np.random.normal(loc=100,scale=10,size=(500,1,32))
hist = np.ones((32,20)) # initialise hist
for z in range(32):
hist[z],edges = np.histogram(data[:,0,z],bins=np.arange(80,122,2))
Mogę to wykreślić za pomocą imshow()
:
plt.imshow(hist,cmap='Reds')
uzyskiwanie:
Jednak wartości na osi X nie są zgodne z danymi wejściowymi (tj. Średnia ze 100, zakres od 80 do 122). Dlatego chciałbym zmienić oś X, aby pokazać wartości w edges
.
Próbowałem:
ax = plt.gca()
ax.set_xlabel([80,122]) # range of values in edges
...
# this shifts the plot so that nothing is visible
i
ax.set_xticklabels(edges)
...
# this labels the axis but does not centre around the mean:
Jakieś pomysły, jak zmienić wartości osi, aby odzwierciedlić dane wejściowe, których używam?
pcolor
zamiast,imshow
jak wspomniano w tej odpowiedzi .