Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kennethnym/infinifi
infinifi plays gentle lofi music in the background indefinitely
https://github.com/kennethnym/infinifi
artificial-intelligence audiocraft lo-fi lo-fi-radio machine-learning musicgen pytorch
Last synced: 7 days ago
JSON representation
infinifi plays gentle lofi music in the background indefinitely
- Host: GitHub
- URL: https://github.com/kennethnym/infinifi
- Owner: kennethnym
- License: apache-2.0
- Created: 2024-07-20T10:53:13.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-11-26T18:10:15.000Z (2 months ago)
- Last Synced: 2025-01-13T10:03:57.175Z (14 days ago)
- Topics: artificial-intelligence, audiocraft, lo-fi, lo-fi-radio, machine-learning, musicgen, pytorch
- Language: Python
- Homepage: https://infinifi.cafe
- Size: 13.3 MB
- Stars: 283
- Watchers: 2
- Forks: 16
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- starred - kennethnym/infinifi - infinifi plays gentle lofi music in the background indefinitely (Python)
README
# infinifi
infinifi is a cosy little website that plays calm, gentle lo-fi music in the background to help you relax and study!
## audio generation
infinifi works by continuously generating 5 1-minute lofi music clips in the background using Meta's [MusicGen](https://github.com/facebookresearch/audiocraft/blob/main/docs/MUSICGEN.md) model. Each clip is generated using a slightly different prompt to provide music clips with different, but still cosy vibes.
## frontend
the frontend is written using pure HTML/CSS/JS with no external dependencies. it queries `/current.mp3` to obtain the current lofi music clip. after the clip ends, it re-queries again, which will return a different clip. since each clip is completely different, the frontend applies a fade-in and fade-out effect at the start and the end of each clip.
## inference
infinifi consists of two parts, the inference server and the web server. 5 audio clips are generated each time an inference request is received from the web server. the web server will request for an inference every set interval. after the request is made, it polls the inference server until the audio is generated and available for download. it then downloads the 5 generated clips and saves it locally. at most 10 clips are saved at a time.
when the inference server is down, the web server will recycle saved clips until it is back up again.
## requirements
- python >= 3.10 (tested with python 3.12 only)
## running it yourself
i have recently changed the networking between the web server and the inference server. at the moment, the inference happens on fal infrastructure (`fal_app.py`), and i have yet to update the standalone inference server code `inference_server.py` to match the new architecture.
## feature requests
if you have any feature idea, feel free to use the issue tracker to let me know!
## credits:
- cats by [@PixElthen](https://x.com/pixelthen)