forked from jaakkopasanen/AutoEq
-
Notifications
You must be signed in to change notification settings - Fork 0
/
utils.py
91 lines (73 loc) · 2.62 KB
/
utils.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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
# -*- coding: utf-8 -*-
import re
import numpy as np
from scipy.special import expit
def generate_frequencies(f_min, f_max, f_step):
frequencies = []
f = f_min
while f <= f_max:
frequencies.append(f)
f *= f_step
return np.array(frequencies)
def log_tilt(f, steepness):
"""Creates a tilt for equalization.
Args:
f: Frequency array
steepness: Slope steepness in dB/octave
Returns:
Tilted data
"""
# Center frequency in logarithmic scale
c = 20.0 * np.sqrt(20000.0 / 20.0)
# N octaves above center
n_oct = np.log2(f / c)
return n_oct * steepness
def smoothing_window_size(f, octaves):
"""Calculates moving average window size in indices from octaves."""
# Octaves to coefficient
k = 2 ** octaves
# Calculate average step size in frequencies
steps = []
for i in range(1, len(f)):
steps.append(f[i] / f[i - 1])
step_size = sum(steps) / len(steps)
# Calculate window size in indices
# step_size^x = k --> x = ...
n = np.log(k) / np.log(step_size)
# Round to integer to be usable as index
n = round(n)
if not n % 2:
n += 1
return n
def log_f_sigmoid(f, f_lower, f_upper, a_normal=0.0, a_treble=1.0):
f_center = np.sqrt(f_upper / f_lower) * f_lower
half_range = np.log10(f_upper) - np.log10(f_center)
f_center = np.log10(f_center)
a = expit((np.log10(f) - f_center) / (half_range / 4))
a = a * -(a_normal - a_treble) + a_normal
return a
def log_log_gradient(f0, f1, g0, g1):
"""Calculates gradient (derivative) in dB per octave."""
octaves = np.log(f1 / f0) / np.log(2)
gain = g1 - g0
return gain / octaves
def is_file_name_allowed(name):
return not (
# Prohibited file name characters, including ASCII control characters
bool(re.search(r'[<>:"/\\\|\?\*\u0000-\u001F]', name))
# Windows has some reserved file names
or bool(re.match(r'(?:CON|PRN|AUX|NUL|COM1|COM2|COM3|COM4|COM5|COM6|COM7|COM8|COM9|LPT1|LPT2|LPT3|LPT4|LPT5|LPT6|LPT7|LPT8|LPT9)(?:\.[a-zA-Z0-9]+)?$', name))
# Files on Windows cannot end in space or dot
or bool(re.search(r'[ \.]$', name))
)
def make_file_name_allowed(name):
# Remove prohibited characters
name = re.sub(r'[<>:"/\\\|\?\*\u0000-\u001F]', '', name)
# Add suffix for reserved file names
name = re.sub(
r'(CON|PRN|AUX|NUL|COM1|COM2|COM3|COM4|COM5|COM6|COM7|COM8|COM9|LPT1|LPT2|LPT3|LPT4|LPT5|LPT6|LPT7|LPT8|LPT9)(\.[a-zA-Z0-9]+)?$',
'\1-tmp\2',
name)
# Remove leading dot and space
name = re.sub(r'[ \.]$', '', name)
return name