File size: 1,547 Bytes
4d6b66b
 
 
 
3d0ab7b
 
1a340cf
3d0ab7b
 
 
 
4d6b66b
 
 
 
 
 
3d0ab7b
 
 
 
 
 
 
4d6b66b
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
import gradio as gr
import numpy as np
import pretty_midi
from accompaniment_generator.generator.base import Generator
import os
import uuid
os.system("sudo apt install fluidsynth")
os.system("cp /usr/share/sounds/sf2/FluidR3_GM.sf2 ./font.sf2")

from midi2audio import FluidSynth



def inference(audio, num_epoch):
    generator = Generator()
    input_midi_data = pretty_midi.PrettyMIDI(audio.name)
    output_midi_data = generator(audio.name, num_epoch=int(num_epoch))
    name = uuid.uuid4()
    output_midi_data.write(f'{name}.mid')
    fs = FluidSynth("font.sf2")
    fs.midi_to_audio(f'{name}.mid', f'{name}.wav')
    fs.midi_to_audio(audio.name, f'{name}-init.wav')

    return [f'{name}-init.wav', f'{name}.wav']


title = "Accompaniment Generator"
description = "Gradio demo for MIDI-DDSP: Detailed Control of Musical Performance via Hierarchical Modeling. To use it, simply upload your midi file, or click one of the examples to load them. Read more at the links below."

article = "<p style='text-align: center'>" \
          "<a href='https://github.com/AlekseyKorshuk/accompaniment-generator' target='_blank'>Github Repo</a>" \
          "</p>"

examples = [['barbiegirl_mono.mid', 10]]

gr.Interface(
    inference,
    [gr.inputs.File(type="file", label="Input"), gr.inputs.Number(label="Number of epoch", default=10)],
    [gr.outputs.Audio(type="auto", label="Before"), gr.outputs.Audio(type="auto", label="After")],
    title=title,
    description=description,
    article=article,
    examples=examples,
).launch(debug=True)