add read_single_channel function
Browse files
app.py
CHANGED
@@ -28,6 +28,56 @@ from pydub import AudioSegment
|
|
28 |
# for p in predictions:
|
29 |
# col2.subheader(f"{ p['label'] }: { round(p['score'] * 100, 1)}%")
|
30 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
31 |
def create_default_value():
|
32 |
if "def_value" not in st.session_state:
|
33 |
def_val_npy = np.random.choice([0, 1], size=32 - len_start_bit)
|
@@ -97,6 +147,7 @@ def main():
|
|
97 |
if add_watermark_button: # 点击按钮后执行的
|
98 |
if audio_file and watermark_text:
|
99 |
with st.spinner("Adding Watermark..."):
|
|
|
100 |
watermark = model.get_watermark(wav, default_sr)
|
101 |
# watermarked_audio, encode_time_cost = add_watermark(tmp_input_audio_file, watermark_text)
|
102 |
# st.write("Watermarked Audio:")
|
|
|
28 |
# for p in predictions:
|
29 |
# col2.subheader(f"{ p['label'] }: { round(p['score'] * 100, 1)}%")
|
30 |
|
31 |
+
def read_as_single_channel_16k(audio_file, def_sr=16000, verbose=True, aim_second=None):
|
32 |
+
assert os.path.exists(audio_file)
|
33 |
+
|
34 |
+
file_extension = os.path.splitext(audio_file)[1].lower()
|
35 |
+
|
36 |
+
if file_extension == ".mp3":
|
37 |
+
data, origin_sr = librosa.load(audio_file, sr=None)
|
38 |
+
elif file_extension in [".wav", ".flac"]:
|
39 |
+
data, origin_sr = soundfile.read(audio_file)
|
40 |
+
else:
|
41 |
+
raise Exception("unsupported file:" + file_extension)
|
42 |
+
|
43 |
+
# channel check
|
44 |
+
if len(data.shape) == 2:
|
45 |
+
left_channel = data[:, 0]
|
46 |
+
if verbose:
|
47 |
+
print("Warning! the input audio has multiple chanel, this tool only use the first channel!")
|
48 |
+
data = left_channel
|
49 |
+
|
50 |
+
# sample rate check
|
51 |
+
if origin_sr != def_sr:
|
52 |
+
data = resampy.resample(data, origin_sr, def_sr)
|
53 |
+
if verbose:
|
54 |
+
print("Warning! The original samplerate is not 16Khz; the watermarked audio will be re-sampled to 16KHz")
|
55 |
+
|
56 |
+
sr = def_sr
|
57 |
+
audio_length_second = 1.0 * len(data) / sr
|
58 |
+
# if verbose:
|
59 |
+
# print("input length :%d second" % audio_length_second)
|
60 |
+
|
61 |
+
if aim_second is not None:
|
62 |
+
signal = data
|
63 |
+
assert len(signal) > 0
|
64 |
+
current_second = len(signal) / sr
|
65 |
+
if current_second < aim_second:
|
66 |
+
repeat_count = int(aim_second / current_second) + 1
|
67 |
+
signal = np.repeat(signal, repeat_count)
|
68 |
+
data = signal[0:sr * aim_second]
|
69 |
+
|
70 |
+
return data, sr, audio_length_second
|
71 |
+
|
72 |
+
|
73 |
+
def my_read_file(audio_path, max_second):
|
74 |
+
signal, sr, audio_length_second = read_as_single_channel_16k(audio_path, default_sr)
|
75 |
+
if audio_length_second > max_second:
|
76 |
+
signal = signal[0:default_sr * max_second]
|
77 |
+
audio_length_second = max_second
|
78 |
+
|
79 |
+
return signal, sr, audio_length_second
|
80 |
+
|
81 |
def create_default_value():
|
82 |
if "def_value" not in st.session_state:
|
83 |
def_val_npy = np.random.choice([0, 1], size=32 - len_start_bit)
|
|
|
147 |
if add_watermark_button: # 点击按钮后执行的
|
148 |
if audio_file and watermark_text:
|
149 |
with st.spinner("Adding Watermark..."):
|
150 |
+
wav = my_read_file(wav,max_second_encode)
|
151 |
watermark = model.get_watermark(wav, default_sr)
|
152 |
# watermarked_audio, encode_time_cost = add_watermark(tmp_input_audio_file, watermark_text)
|
153 |
# st.write("Watermarked Audio:")
|