-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathenvelope_data.py
54 lines (30 loc) · 1.33 KB
/
envelope_data.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
35
36
37
38
39
40
41
42
43
44
45
46
47
'''
Not currently in used in Pipeline. Will be implemented in the future to further smoothen the spectral envelope
'''
delta = 0.7 # percentage
numberOfFiles = 4
status = 0
newSoundData = []
# RC circuit characteristics
dischargeRate = 0.5 # percentage
exponentialTerm = 0.001
chargeRate = 0
currentCharge = 0
def deltaEnv(delta,numberOfFiles,soundData):
for i in range(numberOfFiles): # do for all the audio samples
for j in range(len(soundData[i])-1): # each sample is of variable size and is un-clipped
if soundData[i][j]*delta >= soundData[i][j+1]: # main envelope condition
soundData[i][j+1] = soundData[i][j]
print("done enveloping all the samples")
return soundData
def rcEnv(dischargeRate, numberOffiles, soundData): # RC circuit, to envelope the signal
for i in range(numberOfFiles):
for j in range(soundData[i].size-1):
adjDifference = soundData[i][j+1]-soundData[i][j]
if soundData[i][j] >= soundData[i][j+1]:
soundData[i][j+1] = soundData[i][j]-dischargeRate*soundData[i][j]
#dischargeRate += exponentialTerm
# if soundData[i][j] <= soundData[i][j+1]:
# soundData[i][j+1] = soundData[i][j]*1.5
print("done enveloping the samples according to RC law")
return soundData