〇正弦波のラ(440Hz)の周波数スペクトル
import numpy as np
import matplotlib.pyplot as plt
a = 0.1
f0 = 440
fs = 44100
sec = 3
n = np.arange(fs * sec)[0:fs]
s = a * np.sin(2.0 * np.pi * f0 * n / fs)
F = np.fft.fft(s)
F_abs = np.abs(F)
F_a = F_abs / fs * 2
F_a[0] = F_abs[0] / fs
plt.plot(F_a[:int(fs/2)+1])
plt.show()
data:image/s3,"s3://crabby-images/565ee/565ee85b8a630f234132b143483de1f01d4683e5" alt=""
〇矩形波のラ(440Hz)の周波数スペクトル
import numpy as np
from scipy import signal
import matplotlib.pyplot as plt
a = 0.1
f0 = 440
fs = 44100
sec = 3
n = np.arange(fs * sec)[0:fs]
s = a * signal.square(2.0 * np.pi * f0 * n / fs)
F = np.fft.fft(s)
F_abs = np.abs(F)
F_a = F_abs / fs * 2
F_a[0] = F_abs[0] / fs
plt.plot(F_a[:int(fs/2)+1])
plt.show()
data:image/s3,"s3://crabby-images/4a889/4a889749ce78c8b6d114d213d09e7c4c5b682b41" alt=""
〇三形波のラ(440Hz)の周波数スペクトル
import numpy as np
from scipy import signal
import matplotlib.pyplot as plt
a = 0.1
f0 = 440
fs = 44100
sec = 3
n = np.arange(fs * sec)[0:fs]
s = a * signal.sawtooth(2.0 * np.pi * f0 * n / fs + np.pi/2, 0.5)
F = np.fft.fft(s)
F_abs = np.abs(F)
F_a = F_abs / fs * 2
F_a[0] = F_abs[0] / fs
plt.plot(F_a[:int(fs/2)+1])
plt.show()
data:image/s3,"s3://crabby-images/5b4c9/5b4c99a61e7745734b551728c7bc395f5803c91e" alt=""
〇のこぎり波のラ(440Hz)の周波数スペクトル
import numpy as np
from scipy import signal
import matplotlib.pyplot as plt
a = 0.1
f0 = 440
fs = 44100
sec = 3
n = np.arange(fs * sec)[0:fs]
s = a * signal.sawtooth(2.0 * np.pi * f0 * n / fs)
F = np.fft.fft(s)
F_abs = np.abs(F)
F_a = F_abs / fs * 2
F_a[0] = F_abs[0] / fs
plt.plot(F_a[:int(fs/2)+1])
plt.show()
data:image/s3,"s3://crabby-images/84f1b/84f1be8c46c9780d649a9d9fa915f35d49d06559" alt=""
☆Tips
周波数スペクトルから元の波形を再現することができる。
〇正弦波のラ(440Hz)の波形
import numpy as np
import matplotlib.pyplot as plt
a = 0.1
f0 = 440
fs = 44100
sec = 3
n = np.arange(fs * sec)[0:fs]
s = a * np.sin(2.0 * np.pi * f0 * n / fs)
F = np.fft.fft(s)
F_abs = np.abs(F)
F_a = F_abs / fs * 2
F_a[0] = F_abs[0] / fs
F_s = np.zeros(fs)
for i in range(int(fs/2)+1):
F_s += F_a[i] * np.sin(2.0 * np.pi * i * n / fs)
for i in range(fs):
F_s[i] += F_a[0]
plt.plot(F_s[:int(fs/f0)])
plt.show()
data:image/s3,"s3://crabby-images/90f95/90f950f58afb2aeb2810bcc93c97c25fa6d8c77a" alt=""
〇矩形波のラ(440Hz)の波形
import numpy as np
from scipy import signal
import matplotlib.pyplot as plt
a = 0.1
f0 = 440
fs = 44100
sec = 3
n = np.arange(fs * sec)[0:fs]
s = a * signal.square(2.0 * np.pi * f0 * n / fs)
F = np.fft.fft(s)
F_abs = np.abs(F)
F_a = F_abs / fs * 2
F_a[0] = F_abs[0] / fs
F_s = np.zeros(fs)
for i in range(int(fs/2)+1):
F_s += F_a[i] * np.sin(2.0 * np.pi * i * n / fs)
for i in range(fs):
F_s[i] += F_a[0]
plt.plot(F_s[:int(fs/f0)])
plt.show()
data:image/s3,"s3://crabby-images/33352/333528538522a7e1aec033704d8d37e36531066a" alt=""
〇三形波のラ(440Hz)の波形
import numpy as np
from scipy import signal
import matplotlib.pyplot as plt
a = 0.1
f0 = 440
fs = 44100
sec = 3
n = np.arange(fs * sec)[0:fs]
s = a * signal.sawtooth(2.0 * np.pi * f0 * n / fs + np.pi/2, 0.5)
F = np.fft.fft(s)
F_abs = np.abs(F)
F_a = F_abs / fs * 2
F_a[0] = F_abs[0] / fs
F_s = np.zeros(fs)
for i in range(int(fs/2)+1):
F_s += F_a[i] * np.sin(2.0 * np.pi * i * n / fs)
for i in range(fs):
F_s[i] += F_a[0]
plt.plot(F_s[:int(fs/f0)])
plt.show()
data:image/s3,"s3://crabby-images/6556e/6556e75303fab57ed687834b2d08d332a9e022ca" alt=""
〇のこぎり波のラ(440Hz)の波形
import numpy as np
from scipy import signal
import matplotlib.pyplot as plt
a = 0.1
f0 = 440
fs = 44100
sec = 3
n = np.arange(fs * sec)[0:fs]
s = a * signal.sawtooth(2.0 * np.pi * f0 * n / fs)
F = np.fft.fft(s)
F_abs = np.abs(F)
F_a = F_abs / fs * 2
F_a[0] = F_abs[0] / fs
F_s = np.zeros(fs)
for i in range(int(fs/2)+1):
F_s += F_a[i] * np.sin(2.0 * np.pi * i * n / fs)
for i in range(fs):
F_s[i] += F_a[0]
plt.plot(F_s[:int(fs/f0)])
plt.show()
data:image/s3,"s3://crabby-images/52792/5279283bfaa0c74241c4a5d39e7bbff264cd63a9" alt=""