forked from m-kazuki/AuxIVA
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsound_mixing.py
37 lines (28 loc) · 1.24 KB
/
sound_mixing.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
import numpy as np
from scipy.signal import stft, istft
class Preprocessing():
def __init__(self,s,r):
'''
sは音源信号行列((3,441000))
rは音源が並んでいる円の半径(スカラー)
'''
self.s = s
self.r = r
def mixing(self):
all2bDis = self.r
a2cDis = self.r * np.sqrt(2+np.sqrt(2))
a2aDis = self.r * np.sqrt(2-np.sqrt(2))
b2aDis = self.r * np.sqrt(2)
all2bTime = all2bDis/340.5 #これが基準
a2cTime = a2cDis/340.5
a2aTime = a2aDis/340.5
b2aTime = b2aDis/340.
F,_,S = stft(self.s, 44100, "boxcar", 256, 128)
n_bin = len(F)
X = np.empty_like(S)
for f in range(n_bin):
X[0,f,:] = S[0,f,:]*np.exp(-1j*2*np.pi*F[f]*a2aTime)+S[1,f,:]*np.exp(-1j*2*np.pi*F[f]*b2aTime)+S[2,f,:]*np.exp(-1j*2*np.pi*F[f]*a2cTime)
X[1,f,:] = S[0,f,:]*np.exp(-1j*2*np.pi*F[f]*all2bTime)+S[1,f,:]*np.exp(-1j*2*np.pi*F[f]*all2bTime)+S[2,f,:]*np.exp(-1j*2*np.pi*F[f]*all2bTime)
X[2,f,:] = S[0,f,:]*np.exp(-1j*2*np.pi*F[f]*a2cTime)+S[1,f,:]*np.exp(-1j*2*np.pi*F[f]*b2aTime)+S[2,f,:]*np.exp(-1j*2*np.pi*F[f]*a2aTime)
_, x = istft(X, 44100, "boxcar", 256, 128)
return x