Вы можете написать свой собственный локатор, который устанавливает тики с коэффициентом 1,01 от предыдущего местоположения тиков.Такой локатор может выглядеть как
import numpy as np; np.random.seed(42)
import matplotlib.pyplot as plt
import matplotlib.ticker
class GeomLocator(matplotlib.ticker.IndexLocator):
def __call__(self):
if self.axis.axis_name =="x":
vmin, vmax = self.axis.axes.get_xlim()
elif self.axis.axis_name =="y":
vmin, vmax = self.axis.axes.get_ylim()
return self.tick_values(vmin, vmax)
def tick_values(self, vmin, vmax):
n = int(np.log(vmax/vmin)/np.log(self._base))
ticks = np.ones(n+2)
ticks[1:] = self._base
ticks = vmin * np.cumprod(ticks)
return ticks
Тогда вы можете использовать вспомогательную сетку, чтобы показать линии сетки, расположенные вышеупомянутым локатором.
x = np.arange(301)
y = np.cumsum(np.random.randn(len(x)))
y = (y-y.min())/(y.max()-y.min()) * 7000 + 8000
fig, ax = plt.subplots()
ax.plot(x,y)
ax.yaxis.set_minor_locator(GeomLocator(1.01, None))
ax.grid(which="minor", axis="y")
plt.show()

Преимущество этого состоит в том, что в вашем коде вам вообще не нужно знать границы графика и вы можете свободно перемещать или масштабировать график с сеткой, постоянно обновляясь.