| import numpy as np |
| import gradio as gr |
|
|
| notes = ["C", "C#", "D", "D#", "E", "F", "F#", "G", "G#", "A", "A#", "B"] |
|
|
| def generate_tone(note, octave, duration): |
| sr = 48000 |
| a4_freq, tones_from_a4 = 440, 12 * (octave - 4) + (note - 9) |
| frequency = a4_freq * 2 ** (tones_from_a4 / 12) |
| duration = int(duration) |
| audio = np.linspace(0, duration, duration * sr) |
| audio = (20000 * np.sin(audio * (2 * np.pi * frequency))).astype(np.int16) |
| return sr, audio |
|
|
| demo = gr.Interface( |
| generate_tone, |
| [ |
| gr.Dropdown(notes, type="index"), |
| gr.Slider(4, 6, step=1), |
| gr.Textbox(value="1", label="Duration in seconds"), |
| ], |
| "audio", |
| ) |
| if __name__ == "__main__": |
| demo.launch() |
|
|