ThatOtherAndrew

ThatOtherAndrew

0-day streak
https://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/0bcf102b-d5a2-4f83-a730-bc006fc12230-a9b3f321-dc10-48a5-bc44-534872e3f1e2.png
summer-of-making emoji
github emoji
🎉 The first movement of the Celestial Suite is done! 🎉 I've been composing a symphony orchestra arrangement of the Celeste OST by Lena Raine as I have admired her work for a long time now, and wanted to try a little bit of orchestral scoring, which I've never done before. The first movement is based off the Prologue chapter of the game. Score: musescore.com/user/27306878/scores/19944166 Video: youtu.be/f78diHebH5w
🎉 Synchrotron is Somewhat Usable™️! 🎉 ❓ *What is Synchrotron? Synchrotron is a graph-based audio processing engine, inspired by tools such as Supercollider, Pure Data and the Blender node editor. What's more, it's written entirely in Python! :python: ❓ How do I use it? Install with `pip install git+<https://github.com/ThatOtherAndrew/Synchrotron.git>`, then use the `synchrotron-server` command to start the server. You can connect to the server either through the `synchrotron-console` TUI, or using the web UI at <https://github.com/ThatOtherAndrew/SynchrotronUI> ✨ ❓ What features does it have currently? • Standalone server for full versatility in various use cases • Custom DSL (domain-specific language) built from the ground up, called Synchrolang • Web server with documented REST API • Elegant and expressive Python API • (Almost) fully functioning web user interface • A variety of simple nodes to get started with • Support for live playback, accelerated rendering to WAV files, and MIDI input and processing ❓ How can I learn more? • Documentation is currently very limited, but I'd be more than happy to chat to anybody reading this about my project as I'm pretty passionate about it and proud of what I've managed so far! Fun fact, I have presented a live demo of Synchrotron to @clairebookworm and musician Charmaine Lee and they both have endorsed this project :O
https://scrapbook-into-the-redwoods.s3.amazonaws.com/53912340-9a4e-4181-8df6-2f717ed88ae9-image.pnghttps://scrapbook-into-the-redwoods.s3.amazonaws.com/df8d3c13-72af-41eb-a6f2-90e4e329c359-image.png
Trying my hand at some composition again! Let's see if this is something I can see through to the end :p
summer-of-making emoji
https://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/2ac1bc3e-ce23-4fe0-ac39-4014b93bcfd8-1208e682-27c3-41a7-a355-02cbb9bce9da.pnghttps://scrapbook-into-the-redwoods.s3.us-east-1.amazonaws.com/26257879-50e4-49c1-990f-5fda2bdb5e26-cc4a9292-6b93-4709-82f9-a55461fcf792.png
github emoji
summer-of-making emoji
Progress update on my Python live synthesiser! The web interface now sports a console, the DSL has been redesigned a little, new nodes have been added, the UI has been improved, and more! :D To try it out, check out github.com/ThatOtherAndrew/Synchrotron :> Here's some sample code you can use to try out a basic pulse-width modulation square wave synth example:
new 0.2 pwm_mod_freq;
new 0.24 scale_val;
new SineNode pwm_mod;
new 0.75 offset_val;
new MultiplyNode scale;
new 440 freq;
new AddNode offset;
new SquareNode square;
new PlaybackNode out;

link square.out -> out.left;
link square.out -> out.right;
link pwm_mod_freq.out -> pwm_mod.frequency;
link pwm_mod.out -> scale.a;
link scale_val.out -> scale.b;
link scale.out -> offset.a;
link offset_val.out -> offset.b;
link freq.out -> square.frequency;
link offset.out -> square.pwm;
summer-of-making emoji
python emoji
This is Synchrotron, a live audio synthesis engine written pretty much from scratch in pure Python, inspired by existing projects such as Pure Data and SuperCollider! What you're seeing here is a console with Synchrolang, a language I created to interact with the Synchrotron audio server. The video shows off a basic demo using sine waves at different frequencies!