Posts

  • My ISMIR 2024 paper on automatic Roman numeral analysis

    This past November, I had the privilege of giving a paper on a deep learning model for Roman numeral analysis at ISMIR, the International Society for Music Information Retrieval. As I show, my model exceeds the previous state of the art for this task by a wide margin. Here’s the abstract:

    Music is plentiful, but labeled data for music theory tasks like roman numeral analysis is scarce. Self-supervised pretraining on unlabeled data is therefore a promising means of improving performance on these tasks, especially because, during pretraining, a model may be expected to acquire latent representations of musical abstractions like keys and chords. However, existing deep learning models for roman numeral analysis have not used pretraining, instead training from scratch on labeled data, while conversely, pretrained models for music understanding have generally been applied to sequence-level tasks not involving explicit music theory, like composer or genre classification. In contrast, this paper applies pretraining methods to a music theory task by fine-tuning a masked language model, MusicBERT, for roman numeral analysis. We apply token classification to predict labels for each note, then aggregate the predictions of simultaneous notes to obtain a single label at each time step. Conditioning the chord predictions on key predictions gives more coherent labels. The resulting model outperforms previous roman numeral analysis models by a substantial margin.

  • My new work “Night Path,” performed by Sahara von Hattenberger

    This year, with the kind assistance of the Canada Council for the Arts, the intrepid cellist Sahara von Hattenberger commissioned me to write a piece for her upcoming album. The ensemble was a fun challenge: cello with jazz rhythm section (piano, bass and drums). The album will be released soon on Odd Sound, but my piece is now available as a single on Spotify, Apple Music, and other streaming platforms.

  • My Bach article in Music Theory Analysis

    I’m happy to announce that a paper I began during my Master’s degree, “The Beginning of the Middle: Initiation and Reinitiation in Bach’s Binary-form Keyboard Works,” has been published in the journal Music Theory and Analysis. (The pace of publication in small humanities fields like music theory can be glacial, although I must own that in this case I am not entirely blameless if this article took a long time to come out.) This is a work of good old-fashioned music theory where I investigate Bach’s use of form in his keyboard suites, music that has played a long and important role in my life.

  • DIY persistent shuffle on Spotify

    On Spotify, I like to make long—15 hours or more—playlists of music I’d like to get to know. Then I put the playlists on in the background and absorb the music passively while I work.

    I’d like to hear all the music on the playlist. But I’m not going to listen to it all at once. And when I hit pause and go listen to something else, then come back to the playlist again, Spotify doesn’t “remember” the tracks that I already heard.

    If I were listening to each playlist in order, then I could remember the last track I listened to, and then return to it next time I listen to the playlist. But would take a lot of memory and effort and, what’s more, I don’t want to listen to my playlists in the same order every time.

    Instead, I’d rather have my playlists on shuffle. But it’s in the nature of randomness that, just by chance, I will hear some tracks much more often than others.

    Consider the chart below, where I’ve simulated listening 10 times to a shuffled playlist of 100 tracks, each time listening to between 10% and 40% of the playlist. (The orange line shows the theoretical distribution that the simulation should follow; you can see that it matches exactly.)1

    Simulation of Spotify shuffle

    As you can see , the number of times each track is heard varies widely. Nearly 25% of tracks are heard only once or less. A similar proportion are heard four or more times.

    I solved this problem for myself, but I needed to write a Python script to do so. This script works with pairs of playlists, a “source” playlist and a “filtered” playlist. The “filtered” playlist is empty at first. Whenever the “filtered” playlist is empty, the script puts all of the songs from the “source” playlist onto it. Then each time I listen to a track from the “filtered” playlist, the script removes it from that playlist. The result is that I can listen to the filtered playlist all the way through.

    Setting this up has been a real boon to my listening. Over the past year, in this way, I’ve gotten to know a huge amount of obscure chamber music, the recent studio recordings of Brad Mehldau, and the complete discography of Steely Dan, along with a great deal else.

    You’re more than welcome to use this script yourself, although it will take a fair bit of computer savoir faire to get it set up.

    1. For simplicity, I’m assuming that Spotify shuffle is uniformly random. But in fact, I don’t think it is, which makes the problem worse than I have described. When shuffling tracks, Spotify appears to favor tracks that it A) thinks you particularly like (because you have listened to them before), or B) thinks people like in general (because they have been listened to a lot). That is, it seems to tend to put these tracks earlier in the queue. This may be good user design (in general, people are probably pleased when they put a playlist on and their favorite song comes right on). But it compounds the problem I describe above, because it means that, after (purely by chance) you listen to a track 5, 6, or 7 times, Spotify will put it in the queue ahead of the tracks that you’ve only heard once or twice, or not at all. 

  • Efficient Rhythms at the Society for Music Theory

    At the Composition Interest Group meeting at the 2022 conference of the Society for Music Theory, I presented an original work created with my program Efficient Rhythms. I also created an annotated animation of the work, which attempts to illustrate the various procedures taking place:

    There’s also a recording of the full presentation.

  • Spaced repetition for jazz practice

    One side effect of my doing a PhD is I’m now a big user of Anki.

    Anki is flash card software using spaced repetition. That means that the wait between each time you review a given flash card depends on

    1. how many times you’ve seen that card before, and
    2. how easy you tend to find the card.

    At first you see new cards a lot, but as you learn them better and better, you see them less and less often.

    Before Anki, I read a lot and never remembered any of it. Now, I read a lot and sometimes remember some of it. This is a huge improvement! But it’s not the main point of this blog post.

    I used to flatter myself that I was an Anki power user. But then I was disabused of this notion by the Reddit posts of Anki savant SigmaX. As a musician, I was especially struck by his notion of using Anki not just to memorize atoms of information, but also to schedule the practice of skills. Inspired by these posts, I’ve been scheduling my jazz practice with Anki. That’s what this post is about.

    Continue reading...
  • Continuous rhythms in Welcome (to my nutso garden)

    Welcome (to my nutso garden) is a recent piece of mine. The title was inspired by a friend who said it sounds like “demented children’s-show theme-music.”

    As you may have guessed, this piece was a collaboration between me and my computer. The main thing we were experimenting with was “continuous” rhythms.

    What are continuous rhythms? Well, most if not all, human music uses “rational” rhythms, where the durations are small-integer ratios of one another.1 For example, a quarter-note is 2 times an eighth-note, 3 times a triplet, 4/3rds of a dotted eighth-note, and so on.

    But computers don’t need to restrict themselves in this way! If the rhythms in this piece sound a bit unusual, a bit spastic, or a bit hard to grok, it’s because in choosing its rhythms, the computer here is arbitrarily chopping up the number line, rather than sticking with small-integer ratios.

    1. You can read more about small-integer ratios in human music in this wonderful article: Nori Jacoby and Josh H. McDermott. 2017. “Integer Ratio Priors on Musical Rhythm Revealed Cross-Culturally by Iterated Reproduction.” Current Biology 27 (3): 359–70. https://doi.org/10.1016/j.cub.2016.12.031. 

  • Welcome to the new and improved (?) malcolmsailor.com

    Welcome to my new website! It may still be rickety or incomplete here and there, so if you notice anything amiss please feel free to notify me.