Bagaimana untuk Melicinkan Keluk Data Bising dengan Berkesan?

Susan Sarandon
Lepaskan: 2024-10-20 15:58:29
asal
636 orang telah melayarinya

How to Effectively Smoothen Noisy Data Curves?

Melicinkan Keluk Bising Secara Optimum

Pertimbangkan set data yang dianggarkan oleh:

import numpy as np
x = np.linspace(0, 2*np.pi, 100)
y = np.sin(x) + np.random.random(100) * 0.2
Salin selepas log masuk

Ini termasuk 20% variasi. Pendekatan seperti UnivariateSpline dan purata bergerak memberikan had.

Penapis Savitzky-Golay

Penyelesaian yang berkesan ialah penapis Savitzky-Golay, tersedia dalam scipy. Ia menggunakan regresi kuasa dua terkecil untuk menganggarkan nilai di tengah tetingkap kecil menggunakan polinomial. Tetingkap kemudian beralih untuk mengulangi proses, menghasilkan pelarasan yang dioptimumkan bagi setiap titik.

import numpy as np
import matplotlib.pyplot as plt
from scipy.signal import savgol_filter

x = np.linspace(0, 2*np.pi, 100)
y = np.sin(x) + np.random.random(100) * 0.2
yhat = savgol_filter(y, 51, 3) # window size 51, polynomial order 3

plt.plot(x,y)
plt.plot(x,yhat, color='red')
plt.show()
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana untuk Melicinkan Keluk Data Bising dengan Berkesan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!