Здесь я вижу два варианта:
Построить все фигуры по одной оси
Поскольку это не похоже на необходимость в специальных полярных осях, вы можете просто нанести заливки на все одинаковые оси в соответствующих положениях шестиугольников.
import numpy as np
import matplotlib.pyplot as plt
from matplotlib.patches import RegularPolygon
def hex_plot(ws,a=1):
"""
plots a m (rows) x n (cols) hexagonal grid with offset rows where a is
the hexagon's side length and m and n are determined by the first two
dimensions of the weight vectors ws
"""
m,n,l = ws.shape
offsety = .75 * 2*a
offsetx = np.sqrt(3) * a
oddrow = np.sqrt(3)/2 * a
theta = np.linspace(0, 2*np.pi, l+1)
fig,ax = plt.subplots(figsize=(7.5,7.5))
ax.set_aspect('equal')
ax.set_zorder(1)
cs = {}
for i in range(m):
for j in range(n):
offsetr = oddrow if i % 2 != 0 else 0
cp = (j*offsetx+offsetr,-i*offsety)
cs[(i,j)] = cp
hexg = RegularPolygon(cp,numVertices=6,radius=a,
facecolor='white',edgecolor='k')
ax.add_patch(hexg)
ax.text(cp[0], cp[1], "{},{}\n{:.2f},{:.2f}".format(i,j,cp[0],cp[1]),
ha='center', va='center', size=10)
r = ws[i,j,:]
r = np.concatenate((r, [r[0]]))
x,y = (np.c_[r*np.sin(theta), r*np.cos(theta)] + cp).T
ax.fill(x,y, color="C0")
ax.autoscale()
ax.set_xticks([])
ax.set_yticks([])
plt.show()
hex_plot(np.random.rand(5,4,6),a=1)
data:image/s3,"s3://crabby-images/3ee34/3ee34d7dcbfb92776df68cc3b1a6d7316918be63" alt="enter image description here"
Использование inset_axes
Если вам действительно нужны оси, например, чтобы показать сетки, вы можете расположить inset_axes
в соответствующих позициях.
import numpy as np
import matplotlib.pyplot as plt
from matplotlib.patches import RegularPolygon
from mpl_toolkits.axes_grid1.inset_locator import inset_axes
from matplotlib.projections import get_projection_class
def hex_plot(ws,a=1):
"""
plots a m (rows) x n (cols) hexagonal grid with offset rows where a is
the hexagon's side length and m and n are determined by the first two
dimensions of the weight vectors ws
"""
m,n,l = ws.shape
offsety = .75 * 2*a
offsetx = np.sqrt(3) * a
oddrow = np.sqrt(3)/2 * a
theta = np.linspace(0, 2*np.pi, l+1)
fig,ax = plt.subplots(figsize=(7.5,7.5))
ax.set_aspect('equal')
ax.set_zorder(1)
cs = {}
axcs = {}
for i in range(m):
for j in range(n):
offsetr = oddrow if i % 2 != 0 else 0
cp = (j*offsetx+offsetr,-i*offsety)
cs[(i,j)] = cp
hexg = RegularPolygon(cp,numVertices=6,radius=a,
facecolor='white',edgecolor='k')
ax.add_patch(hexg)
ax.text(cp[0], cp[1], "{},{}\n{:.2f},{:.2f}".format(i,j,cp[0],cp[1]),
ha='center', va='center', size=10)
axins=inset_axes(ax, width="100%", height="100%",
bbox_to_anchor=(cp[0]-offsetx/2, cp[1]-offsety/2, offsetx, offsety),
bbox_transform=ax.transData, borderpad=0,
axes_class=get_projection_class("polar"),
)
axins.set_zorder(4)
axcs[(i,j)] = axins
r = ws[i,j,:]
r = np.concatenate((r, [r[0]]))
axins.fill(theta,r)
axins.set_yticklabels([])
axins.set_xticklabels([])
ax.autoscale()
ax.set_xticks([])
ax.set_yticks([])
plt.show()
hex_plot(np.random.rand(5,4,6),a=1)
data:image/s3,"s3://crabby-images/33b7f/33b7f4e20d01c222922b17f42eb6c6530e87fec8" alt="enter image description here"