Ограничительная метка на контурном участке - PullRequest
0 голосов
/ 20 октября 2018

Я пытаюсь построить функцию, используя contour() функцию matplotlib.pyplot.Я пытался добавить clabel к графику, но не хочу, чтобы ярлыки добавлялись для каждого уровня, только для первых.Из различных демонстраций и документации я получил следующее:

import matplotlib.pyplot as plt
import numpy as np

def f(x1, x2):
    return (x2 - x1)**4 + 8 * x2 * x1 - x1 + x2 + 3

x1 = np.linspace(-2,2,1000)
x2 = np.linspace(-2,2,1000)

X1, X2 = np.meshgrid(x1, x2)
F = f(X1, X2)
F = np.clip(F, a_min=None, a_max=50)

contours = plt.contour(X1, X2, F, 50, cmap="rainbow")
print(contours.levels)
plt.clabel(contours, contours.levels[0:8], inline=True, fontsize=10, fmt="f = %1.1f", use_clabeltext=True)

plt.title('Q3a Solution')
plt.xlabel('x1')
plt.ylabel('x2')


plt.show()

Код работает при запуске в matplotlib версии 2.1.2, однако при запуске того же кода в версии 3.0.0 появляется следующая ошибка:

Traceback (most recent call last):
  File "Tutorial1.py", line 16, in <module>
    plt.clabel(contours, contours.levels[0:8], inline=True, fontsize=10, fmt="f = %1.1f", use_clabeltext=True)
  File "/usr/local/lib/python3.7/site-packages/matplotlib/pyplot.py", line 2496, in clabel
    return gca().clabel(CS=CS, *args, **kwargs)
TypeError: clabel() got multiple values for argument 'CS'

Я просмотрел все, но не могу понять, изменилось ли использование clabel или это ошибка ...

1 Ответ

0 голосов
/ 20 октября 2018

Это ошибка в matplotlib 3.0.0, которая теперь исправлена ​​.Он будет доступен с выходом 3.0.1.

Обратите внимание, что это ошибка pyplot.Это не происходит при использовании объектно-ориентированных методов.Следовательно, он также отсутствует в примере контурной метки .Пожалуйста, обратитесь к этому примеру.

Самым простым решением здесь является использование axes 'методов вместо pyplot, то есть plt.gca().clabel вместо plt.clabel

import matplotlib.pyplot as plt
import numpy as np

def f(x1, x2):
    return (x2 - x1)**4 + 8 * x2 * x1 - x1 + x2 + 3

x1 = np.linspace(-2,2,1000)
x2 = np.linspace(-2,2,1000)

X1, X2 = np.meshgrid(x1, x2)
F = f(X1, X2)
F = np.clip(F, a_min=None, a_max=50)

contours = plt.gca().contour(X1, X2, F, 50, cmap="rainbow")
print(contours.levels)
plt.gca().clabel(contours, contours.levels[0:8], inline=True, fontsize=10, 
                 fmt="f = %1.1f", use_clabeltext=True)

plt.title('Q3a Solution')
plt.xlabel('x1')
plt.ylabel('x2')


plt.show()
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...