feat: modal integration
This commit is contained in:
51
server.py
51
server.py
@@ -1,16 +1,28 @@
|
||||
import threading
|
||||
|
||||
# from generate import generate
|
||||
import modal
|
||||
from contextlib import asynccontextmanager
|
||||
from fastapi import FastAPI
|
||||
from fastapi.responses import FileResponse
|
||||
from fastapi.staticfiles import StaticFiles
|
||||
from audiocraft.data.audio import audio_write
|
||||
|
||||
# the index of the current audio track from 0 to 9
|
||||
current_index = -1
|
||||
# the timer that periodically advances the current audio track
|
||||
t = None
|
||||
|
||||
prompts = [
|
||||
"gentle, calming lo-fi beats that helps with studying and focusing",
|
||||
"calm, piano lo-fi beats to help with studying and focusing",
|
||||
"gentle lo-fi hip-hop to relax to",
|
||||
"gentle, quiet synthwave lo-fi beats",
|
||||
"morning lo-fi beats",
|
||||
]
|
||||
|
||||
|
||||
model = modal.Cls.lookup("infinifi", "Model")
|
||||
|
||||
|
||||
@asynccontextmanager
|
||||
async def lifespan(app: FastAPI):
|
||||
@@ -20,20 +32,45 @@ async def lifespan(app: FastAPI):
|
||||
t.cancel()
|
||||
|
||||
|
||||
def generate_new_audio():
|
||||
global current_index
|
||||
|
||||
offset = 0
|
||||
wav = []
|
||||
if current_index == 0:
|
||||
offset = 5
|
||||
wav = model.generate.remote(prompts)
|
||||
elif current_index == 5:
|
||||
offset = 0
|
||||
wav = model.generate.remote(prompts)
|
||||
else:
|
||||
return
|
||||
|
||||
print("generating new audio...")
|
||||
|
||||
for idx, one_wav in enumerate(wav):
|
||||
# Will save under {idx}.wav, with loudness normalization at -14 db LUFS.
|
||||
audio_write(
|
||||
f"{idx + offset}",
|
||||
one_wav.cpu(),
|
||||
model.sample_rate,
|
||||
format="mp3",
|
||||
strategy="loudness",
|
||||
loudness_compressor=True,
|
||||
)
|
||||
|
||||
print("audio generated.")
|
||||
|
||||
|
||||
def advance():
|
||||
global current_index, t
|
||||
|
||||
# if current_index == 0:
|
||||
# generate(offset=5)
|
||||
# elif current_index == 5:
|
||||
# generate(offset=0)
|
||||
|
||||
if current_index == 9:
|
||||
current_index = 0
|
||||
else:
|
||||
current_index = current_index + 1
|
||||
|
||||
print(f"advancing, current index {current_index}")
|
||||
threading.Thread(target=generate_new_audio).start()
|
||||
|
||||
t = threading.Timer(60, advance)
|
||||
t.start()
|
||||
|
Reference in New Issue
Block a user