Плановая плавная линия с PyPlot

У меня есть следующий простой script, который отображает график:

import matplotlib.pyplot as plt
import numpy as np

T = np.array([6, 7, 8, 9, 10, 11, 12])
power = np.array([1.53E+03, 5.92E+02, 2.04E+02, 7.24E+01, 2.72E+01, 1.10E+01, 4.70E+00])

plt.plot(T,power)
plt.show()

Как и сейчас, линия идет прямо от точки к точке, которая выглядит нормально, но может быть лучше, на мой взгляд. Я хочу сгладить линию между точками. В Gnuplot я бы построил с smooth cplines.

Есть ли простой способ сделать это в PyPlot? Я нашел несколько учебников, но все они кажутся довольно сложными.

Ответ 1

Вы можете использовать scipy.interpolate.spline чтобы сгладить ваши данные самостоятельно:

from scipy.interpolate import spline

xnew = np.linspace(T.min(),T.max(),300) #300 represents number of points to make between T.min and T.max

power_smooth = spline(T,power,xnew)

plt.plot(xnew,power_smooth)
plt.show()

Сплайн устарел в scipy 0.19.0, используйте вместо него класс Bspline.

Переход от spline к Bspline не является простым копированием /Bspline и требует небольшой настройки:

from scipy.interpolate import make_interp_spline, BSpline

xnew = np.linspace(T.min(),T.max(),300) #300 represents number of points to make between T.min and T.max

spl = make_interp_spline(T, power, k=3) #BSpline object
power_smooth = spl(xnew)

plt.plot(xnew,power_smooth)
plt.show()

До: screenshot 1

После: screenshot 2

Ответ 2

Я предполагаю, что вы имеете в виду привязка кривой, а не сглаживание из контекста вашего вопроса. PyPlot не имеет встроенной поддержки для этого, но вы можете легко реализовать некоторые базовые настройки кривой, например, код здесь, или если вы используете GuiQwt, у него есть кривая . (Возможно, вы также могли бы украсть код из SciPy, чтобы это сделать).

Ответ 3

В этом примере сплайн работает хорошо, но если функция не является гладкой по своей природе и вы хотите иметь сглаженную версию, вы также можете попробовать:

from scipy.ndimage.filters import gaussian_filter1d

ysmoothed = gaussian_filter1d(y, sigma=2)
plt.plot(x, ysmoothed)
plt.show()

если вы увеличите сигму, вы можете получить более сглаженную функцию.

Продолжайте с осторожностью с этим. Он изменяет исходные значения и может не соответствовать вашим ожиданиям.