Hacker News new | past | comments | ask | show | jobs | submit login
I made a command-line tool to assist me with writing polyrhythmic drum parts (github.com/dredozubov)
207 points by dredozubov on June 28, 2023 | hide | past | favorite | 60 comments



If you're interested in this, there's a good chance you would enjoy the TidalCycles language for generating music. It's been a mind-expanding experience for me, particularly w/r/t polyrhythms.

The landing page: https://tidalcycles.org/

An example of some music made live with it: https://www.youtube.com/watch?v=mlUOWjC5fpY


It's recently gotten a great deal easier to play with thanks to Strudel, a JS variant.

Strudel REPL: https://strudel.tidalcycles.org/

One interesting feature of Tidalcycles is Euclidean Sequences, where various 'natural' ways of distributing X notes over Y durations are easily expressed: [1] https://tidalcycles.org/docs/reference/mini_notation/#euclid... [2] https://strudel.tidalcycles.org/learn/mini-notation#euclidia...


Also worth checking out Lil Data [1], an artist affiliated with PC Music who uses TidalCycles and also has a doctorate in some pretty interesting musical research [2].

[1] https://soundcloud.com/lil-data [2] https://scholar.google.co.uk/citations?user=APvoBhUAAAAJ&hl=...


This is a very cool approach to UI. I've been struggling to design a reasonable UI for poly. I think I saw a similar thing on the youtube channel of Yogev Gabay, but I forgot the name.


+1. Lil Data is fantastic.


How would you compare Tidal to stuff like Sonic Pi? I admit Haskell appeals to me WAY more than Ruby, though it seems the install process isn't as seamless as SP is.


So I went through the tutorial and got it set up on my old linux laptop, got it making sounds and managed to go through the workbook tutorial to hear that working. Maybe this will be my excuse to get a bit better with Haskell.


This set by yaxu (Tidalcycles author) is what convinced me to get into livecoding seriously:

https://www.youtube.com/watch?v=1IzfMqs5NGw

(this set is "from scratch", meaning that it opens with an empty file and starts from there, making it clearer to understand what is going on as it builds up)


2030, USA: 9PM, San Francisco.

As we sit into our booth and the environment closes around use we are greeted with soft, soothing music.

As we get into conversation, the body language, verbal language, laughter and even facial expressions we express inform the mood of the room - and the music that it produces. A certain, unique-to-our-meeting melody. All of this is encoded and played back as music in real time.

Later we can use the melody to replay the mood and dialogue of the night - as everything that was said was encoded into the music heard - but may be decoded to have a recording of the conversation...

For further information, contact

@Cymatic.ai


This is so dope! Love seeing the analog rytm used in a coding project like this. Want to see if I can get it to work with my mk-II, should be basically the same.

those are some incredible tones you're working with in the video. are they being generated by the rytm or samples or something else?


That video is of Mike Hodnick, not myself. But to answer your question, the timbres are generally a combination of both things you mention. At its core TidalCycles triggers synths and samplers in SuperCollider. It also controls the effect chain they go through, though, so you can pattern "clean DISTORTED clean clean DISTORTED" as easily as "kick hat snare hat". And sufficiently high-frequency control of the synths will have timbral consequences, too -- alternate, for instance, between two constant frequencies sufficiently quickly and you've built a simple FM synth.


Very cool! How is this better than SuperCollider, which I have considered (and learned a bit about) in the past?


Tidalcycles actually runs SuperCollider as its sound backend, through the SuperDirt library: https://github.com/musikinformatik/SuperDirt/


Nice! But why shouldn't I just use SuperCollider directly?


They have different aims. SuperCollider gives you outstanding timbral control, but patterning at the melodic or chord level is awkward. TidalCycles is a language for musical patterns, not for generating waveforms directly. If you want to mess with both, I'd recommend starting from the definitions of the synths in SuperDirt, the collection of SuperCollider synths that TidalCycles uses.

TidalCycles does offer a lot of ways to control the timbre -- there are a bunch of effects, including some magical granular stuff. And merely triggering samples at sufficiently high frequencies, particularly frequencies that vary over time, can generate some cool sounds. But SC will give you much more control over that kind of thing.


SuperCollider is a language, an IDE, and a client/server app for audio programming.

TidalCycles uses a different language, does not tie you to any particular IDE, and is focused on music in particular, not audio in general.


I’m a guitar player, and I use tablature notation editors such as Guitar Pro a lot. However, it gets complicated fast when I write polyrhythmic/polymetric drum parts, because shifts tend to go over the bar lines and it’s hard to make sense it’s correct visually (may be even harder if you listen to it). The other property of such parts is: it tends to unfold from simple ideas such as “I want to create a drum part that will have a 3 against 4 feel with a kick drum against a snare drum”. The other way to think about it is that it has a simple blueprint, but it’s tricky and error-prone to express in Western musical notation. This is why Polyrhythmix exists. I wanted to have a simple tool to workshop/brainstorm rhythmic ideas and evaluate them by having a MIDI playback. I’m into modern Progressive Rock/Metal music, Fusion, so it all applies very well. I have an impression it may be useful for Indian Carnatic music as well, but I would like to get some insightful confirmation on that.


Very excited to see this. It's very much a tool I would use, excited to give it a spin after work tonight. I also look forward to reading the code.

Other cool music tools I've seen implemented in rust:

* glicol - https://glicol.org/

* tune - https://github.com/Woyten/tune

A while back I wanted to make some tools to aid in composition and was using rust. Very partially baked, but a fun pet project to learn the language with. Generates just intonation pitch lattices based on my research of Ben Johnston's compositional approach. https://github.com/jcpst/johnston


Thanks for commenting and reaching out, would love to know what you think of poly. I was learning Rust along the way, so there is definitely room for improvement. From the memory allocation perspective at least, I didn't paid it much mind as the practical applications are not that memory intensive.

No clue what intonation pitch lattices are, but now I'm interested to learn!


I was having fun writing one liners with poly, leaving my file explorer open and dragging the output file straight into a Ableton channel with a drum rack set up.

I also tried making a web UI with it via Yew. I got it all compiling and running in the browser, but the crate is all about that CLI. I would have to write a lot of the code that’s in the CLI file to call the create_smf function.

It might be worth considering designing the library’s API to be a bit friendlier to an end user. I think there’s cool stuff that could be done with it. Or at least that’s something I want to do :D


Do you mind shooting me an email or opening an issue on github? I was thinking about doing the UI myself, but I wasn’t sure how to do make it nice for the end user. It’s certainly a good idea to rework the API to be UI-friendly.


I have only familiarity with western musical notation, and it too me a while to get there. Tablature and track notation (digital audio workstation) both were completely intuitive to me. Is there anything that argues for learning Western musical notation- IE, does it help express some things eloquently/efficiently/naturally? Every time I ask classically trained musicians (who started with a piano and a music book) they look at me like I'm crazy and dumb.


I like to think of western music notation as not the most intuitive choice for a lot of popular styles of music. But it's kind of like when people talk about X programming language "making hard things possible".

It's like math notation. There is a canon of work over a very long period of time that can be used as a foundation for expressing many different intricate ideas in a compact way. And in the 20th century tons of non-traditional notation styles have been thrown into the western mix.


DAWs and tablature editors mimic musical notation anyway. I suppose replication over the bars lines can be done more easily in DAWs that in tablature editors, but I still wanted a tool to generate the part from the "blueprint" rather than copy-pasting and double-checking all over the place.

What I want to do is to learn a bit more about Konnakol, which is the Indian musical art expressed in percussive syllables. I have an impression that building a bridge between Konnakol and western notation can really get the creative juices flowing.


yeah, I have a zakir hussein track where he does konnakol and it's quite impressive.


Music notation is like any natural language -- i.e. super fucking dumb dumb dumb, and yet, uniquely, it lets you communicate precisely with other musicians, which is awesome.


This looks super cool. I'm also a guitarist that, uh, isn't a very good drummer, heh. Will kick the tires, thanks for sharing!


Related: http://cgm.cs.mcgill.ca/~godfried/publications/banff.pdf

I use a eucledian pattern generator to sequence some of my drums and voices in my eurorack modular synth and it works so well


this paper is the real deal! However it might be a bit tough without context, which this post does decently:

https://medium.com/code-music-noise/euclidean-rhythms-391d87...

(it goes at length into the algorithms, but the intro is well enough; in the end you can hear some examples too)

I second the other post recommending the Tidalcycles music livecoding language, as it uses euclidean rhythms as a base from which you can compose on. Livecoding combined with euclideans is such an interesting musical paradigm that I'd name it as one of the widest musical revelations I had.


His book is really interesting too.


Somewhat related: A drum-machine DSL with dependent types:

https://media.ccc.de/v/456-tsh-a-dependently-timed-drum-mach...


Very cool! I enjoy digging into dependent typing applications.


Omg this is like sex on pizza.


> converges over 3 bars

bars of what length? a 3 against 4 polyrhythm converges after 12 beats, so here it's 3 bars of 4 beats, which is a "bar" for the second rhythm you passed in (`'4-x'`) but four or two bars for your first rhythm (depending on if you write it 6/8 or 3/4, this one could go both ways).

Would be worth letting us know in the CLI, if you think about more esoteric polyrhythms it gets more confusing.


It defaults to 4/4, unless you supply a different time signature through CLI.


The example continues, and says converges after 2 bars in 3/4 time.

4/4 is the default.


This is cool!

I have a web-based polyrhythm generator as well based around Euclidean rhythms.

https://e-drums-stg.vercel.app/

currently working on a v2 with a much better mobile interface and fewer clicks)


I'll definitely take a look at that! I've decided against an UI for Polyrhythmix for now, as I don't have a good sense of how to make it easy to use, but retain the flexibility I can get with a DSL programmable input.


Nice. Looking forward for v2


This is cool and reminds me a bit of Jens Johansson's old tool:

http://www.panix.com/~jens/polymath-old.par


Another cool grid-breaking language for Polyrhythms and euclidian and beyond sequences is Nestup. https://nestup.cutelab.nyc/

In addition to the website and github, It also has a great implementation as a Max for Live device and can drive Ableton. I’ve enjoyed it since it’s initial release.

An interesting interview with the creators from MusicHackspace is here: https://www.youtube.com/live/wZeadB56YFs


I really enjoy the art of Matt Garstka (drummer of Animals As Leaders): https://www.youtube.com/watch?v=NpFnbgqHmjQ

Also Demetori (Touhou) is great: https://www.youtube.com/watch?v=po69XUGd2v0


I shall nickname it "The Haakinator".

https://en.wikipedia.org/wiki/Tomas_Haake


> 32xx16xx - Kick pattern from "Bleed" by Meshuggah

I had to think about that for a bit, but yeah, that's what it is alright


Glad it makes sense not only to me! I've tried to make an understandable description in a README, but if you have an idea of how to explain it better, it's very welcome.


If anyone is interested what can be made with Poly, I've composed this earlier today: https://soundcloud.com/createdestroyforget/out?si=1745dbb1c6...


It’s great to see the musicians of HN post things like this


I'll have to play around with this. Here's something similar for microrythms that I found on GitHub a while ago: https://github.com/davetremblay/Marathon


This is super cool and I can’t wait to try it out. There’s more than one polyrhythm I’m trying to arrange, and being able to quickly hear it without having to come up with a sticking or arrangement would really help.


I'd love to have some feedback from other users, let me know if you need any help!


Your README cuts off:

> For example (3,8x(3,16x-xx(3,32xx-x)))) would read as "Three


Fixed it, thanks. I'm still struggling to find words that will explain it well though, as it's still unconventional.


Anyone who's interested in synth DSL should really check out Sonic Pi, it does MIDI, polyrhythms and it's very easy to do generative sequences in it.


I've been learning a lot about the other projects in the space from comments. Thanks everyone!


for immediate visualisation of polyrhythms, I really liked the Buchla 252e UI with the big circle. But Buchla stuff tends to be way over my usual budgets. I wonder if there is anything like it in plug-in or Eurorack format?


This is awesome, I was just asking ChatGPT if it would make me some midi files.


Thank you very much for sharing your code with everyone. I am very sorry for laughing really loudly and waking my dog when I discovered that it was written in Rust, instead of Python or another dynamic language. After taking a step back, I realized that I could learn a bit about Rust by looking at your code. If I found interesting ideas, they would have likely been translated into another language anyway, unless I was really lucky and you picked Clojure.


Can't be honest about being taken aback without getting crowd downvoted by trigger-happy Rustaceans. You don't have to be that defensive I was honestly surprised by the choice of language for the application.


I don't understand the basis for the grandparent comment, that is, why is the use of rust such a surprise? I only use dynamic scripting languages (so I can't speak from experience) but from what I understand rust is a great language; extremely fast and easier/safer to work with than c++. Why wouldn't it be a good choice for OP's CLI?


I've been mostly doing Haskell for last 9 years, but I find Rust to be awesome nowadays. Great feedback from the type checker, no unnecessary runtime, great tooling. It's unique in a sense that it's fast, but quite safe at the same type. If it would have Higher-Kinded Types, it would be even better for me personally, but it's a tricky compromise from a compiler design perspective.

Also, I find static linking to work great with Rust, so it's quite easy to distribute your app.




Consider applying for YC's W25 batch! Applications are open till Nov 12.

Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: