Seaborn будет просто комментировать строки и столбцы графика pcolor (mesh).Чтобы добиться того же, здесь,
import matplotlib.pyplot as plt
import pandas as pd
import numpy as np
sample = pd.DataFrame.from_dict({'x': np.tile(np.arange(2,5),(1,5))[0],
'y': np.tile(np.arange(0,5),(1,3))[0],
'value': np.random.rand(15)
})
sample_pvt = sample.pivot_table(index='x',columns='y')
sample_pvt.columns = sample_pvt.columns.droplevel(0)
plt.pcolor(sample_pvt)
plt.xticks(np.arange(len(sample_pvt.columns))+0.5, sample_pvt.columns)
plt.yticks(np.arange(len(sample_pvt.index))+0.5, sample_pvt.index)
plt.show()
data:image/s3,"s3://crabby-images/6ce58/6ce584e4c5b7a0479d562b89eab5edd26d745137" alt="enter image description here"
Чтобы вместо этого разместить пиксели в числовом правильном порядке, вам нужно сначала решить, если х иЗначения y на самом деле являются центрами или краями пикселей.Для центров:
import matplotlib.pyplot as plt
import pandas as pd
import numpy as np; np.random.seed(42)
sample = pd.DataFrame.from_dict({'x': np.tile(np.arange(2,5),(1,5))[0],
'y': np.tile(np.arange(0,5),(1,3))[0],
'value': np.random.rand(15)
})
sample_pvt = sample.pivot_table(index='x',columns='y')
sample_pvt.columns = sample_pvt.columns.droplevel(0)
x = np.linspace(sample_pvt.columns[0]-0.5, sample_pvt.columns[-1]+0.5, len(sample_pvt.columns)+1)
y = np.linspace(sample_pvt.index[0]-0.5, sample_pvt.index[-1]+0.5, len(sample_pvt.index)+1)
plt.pcolor(x, y, sample_pvt)
plt.show()
data:image/s3,"s3://crabby-images/8b989/8b9898aaf5d29db8896a748e51864795fdb01ff4" alt="enter image description here"
Для краев
x = np.linspace(sample_pvt.columns[0], sample_pvt.columns[-1]+1, len(sample_pvt.columns)+1)
y = np.linspace(sample_pvt.index[0], sample_pvt.index[-1]+1, len(sample_pvt.index)+1)
plt.pcolor(x, y, sample_pvt)
data:image/s3,"s3://crabby-images/24053/240530d8c0c04556771eaad6a3e3eb0864caa4ae" alt="enter image description here"