Я пытаюсь повернуть текст на график, который отображается в логарифмическом масштабе.Когда я вычисляю углы (на основе решения в этот ответ ) , углы неправильно округляются до 0 или 90 градусов .Это потому, что углы сначала вычисляются в линейном масштабе, а затем преобразуются.Этот расчет в линейном пространстве является причиной проблемы.Даже в ситуации, когда я знаю градиент (в линейном или логарифмическом масштабе), я не уверен, как правильно разместить это значение на графике.
MWE
import matplotlib as mpl
rc_fonts = {
"text.usetex": True,
'text.latex.preview': True,
"font.size": 50,
'mathtext.default': 'regular',
'axes.titlesize': 55,
"axes.labelsize": 55,
"legend.fontsize": 50,
"xtick.labelsize": 50,
"ytick.labelsize": 50,
'figure.titlesize': 55,
'figure.figsize': (10, 6.5), # 15, 9.3
'text.latex.preamble': [
r"""\usepackage{lmodern,amsmath,amssymb,bm,physics,mathtools,nicefrac,letltxmacro,fixcmex}
"""],
"font.family": "serif",
"font.serif": "computer modern roman",
}
mpl.rcParams.update(rc_fonts)
import matplotlib.pylab as plt
from mpl_toolkits.axes_grid1.inset_locator import inset_axes, InsetPosition, mark_inset
import numpy as np
x = np.linspace(0, 20, 100)
y = np.exp(x**2)
g = 2*x*y # Gradient.
lg = 2 * x # Gradient on a log scale.
plt.clf()
plt.plot(x, y)
plt.yscale('log')
for x in [0,2,4,7,18]:
angle_data = np.rad2deg(np.arctan2(2 * x * np.exp(x**2), 1))
y = np.exp(x**2)
angle_screen = plt.gca().transData.transform_angles(np.array((angle_data,)), np.array([x, y]).reshape((1, 2)))[0]
plt.gca().text(x, y, r'A', rotation_mode='anchor', rotation=angle_screen, horizontalalignment='center')
plt.ylim(1e0, 1e180)
plt.xlim(-1, 20)
plt.xlabel(r'$x$')
plt.title(r'$\exp(x^2)$', y=1.05)
plt.savefig('logscale.pdf', format='pdf', bbox_inches='tight')
Несколько идей?
Я пытался использовать тот факт, что для очень больших функций я могу вычислить разницу из 90 градусов, используя arctan (x)~ pi / 2 - arctan (1 / x), а предыдущий угол использует приближение низкого угла, поэтому равен 1 / x.Однако после включения этого в transform_angles
это округляется неправильно.
Небольшой взлом решения
Если я угадаю соотношение сторон фигуры (с0,6), а затем также откорректирую разницу в масштабах (х в [0:20]
при log10 (у) в [0:180]
, что дает разницу в 9), тогда я могу получить следующее, хотя я не думаю, что это особенно устойчиво, особенно если я хочу что-то настроить позже.
# The 9 comes from tha fact that x is in [0:20], log10(y) is in [0, 180]. The factor of 0.6 is roughly the aspect ratio of the main plot shape.
plt.gca().text(x, y, r'A', rotation_mode='anchor', rotation=np.rad2deg(np.arctan(0.6 * x/9.0)), horizontalalignment='center')