Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Python

ฉันจะพล็อตสเปกโตรแกรมแบบเดียวกับที่ specgram () ของ pylab ทำได้อย่างไร (แมทพล็อตลิบ)


ในการพล็อตสเปกโตรแกรมแบบเดียวกับที่ specgram() ของ pylab ทำ เราสามารถทำตามขั้นตอนต่อไปนี้ -

  • กำหนดขนาดรูปและปรับช่องว่างภายในระหว่างและรอบๆ แผนผังย่อย
  • สร้าง t, s1, s2, nse, x, NEFT และ Fs จุดข้อมูลโดยใช้ตัวเลข
  • สร้างร่างใหม่หรือเปิดใช้งานตัวเลขที่มีอยู่โดยใช้ แผนย่อย() เมธอดด้วย nrows=2 .
  • พล็อต t และ x จุดข้อมูลโดยใช้ plot() วิธีการ
  • จัดวางตารางในรูปแบบเส้นปัจจุบัน
  • กำหนดระยะขอบแกน X
  • พล็อตสเปกโตรแกรมโดยใช้ specgram() วิธีการ
  • จัดวางตารางในรูปแบบเส้นปัจจุบันด้วยรูปแบบเส้นประและคุณสมบัติอื่นๆ
  • หากต้องการแสดงรูป ให้ใช้ show() วิธีการ

ตัวอย่าง

import matplotlib.pyplot as plt
import numpy as np

plt.rcParams["figure.figsize"] = [7.50, 3.50]
plt.rcParams["figure.autolayout"] = True

dt = 0.0005
t = np.arange(0.0, 20.0, dt)
s1 = np.sin(2 * np.pi * 100 * t)
s2 = 2 * np.sin(2 * np.pi * 400 * t)
s2[t <= 10] = s2[12 <= t] = 0
nse = 0.01 * np.random.random(size=len(t))
x = s1 + s2 + nse
NFFT = 1024
Fs = int(1.0 / dt)

fig, (ax1, ax2) = plt.subplots(nrows=2)
ax1.plot(t, x)
ax1.grid(axis="x", ls="dotted", lw=2, color="red")
ax1.margins(x=0)

Pxx, freqs, bins, im = ax2.specgram(x, NFFT=NFFT, Fs=Fs, noverlap=900)
ax2.grid(axis="x", ls="dotted", lw=2, color="red")

plt.show()

ผลลัพธ์

ฉันจะพล็อตสเปกโตรแกรมแบบเดียวกับที่ specgram () ของ pylab ทำได้อย่างไร (แมทพล็อตลิบ)