Wykreśl gładką linię z PyPlot

Mam następujący prosty skrypt, który wykreśla Wykres:

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()

Jak teraz, linia biegnie prosto z punktu do punktu, który wygląda ok, ale może być lepiej moim zdaniem. Chcę wygładzić linię między punktami. W Gnuplot bym wykreślił smooth cplines.

Czy jest na to łatwy sposób w Pyplocie? Znalazłem kilka samouczków, ale wszystkie wydają się dość skomplikowane.
Author: Paul, 2011-03-12

2 answers

Możesz użyć scipy.interpolate.spline, aby wygładzić swoje dane samodzielnie:

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()

Przed: zrzut ekranu 1

Po: zrzut ekranu 2

 108
Author: Olivier Verdier,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2017-05-03 20:35:34

Zakładam, że masz na myśli dopasowanie krzywej , a nie antyaliasing z kontekstu twojego pytania. PyPlot nie ma wbudowanego wsparcia dla tego, ale możesz łatwo zaimplementować podstawowe dopasowanie krzywej samodzielnie, jak kod widziany tutaj, lub jeśli używasz GuiQwt ma moduł dopasowania krzywej . (Prawdopodobnie możesz również ukraść kod z SciPy, aby to zrobić).

 6
Author: Nick Bastin,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2011-03-12 17:04:23