A glimpse into the world of Voice Leading
I am going to describe the surprisingly interesting musical phenomenon which first piqued my interest into how, from certain simple musical questions, unexpected patterns and relationships can emerge and even be partially explained through mathematics. However, to make sure that non-musicians can get something out of this post, I’ll begin describing such musical phenomenon from a mathematical perspective.
(PC use is recommended for reading this post; there are some issues on mobile)
Consider the following experiment:
- Pick any circle.
- Choose a
chordfinite amount of points contained in that circle. TransposeRotate each of thosenotespoints, along the chosen circle, by the same amount and in equal direction (clockwise or anticlockwise).- We’ll discuss this step later in the post, but the main idea of the following graphs is that every point which has been colored corresponds to a
chordfinite set of points in the circle, which satisfies the main property that I’ll explain at length later in this post.
Now comes the good stuff …
# Display interactive graph 1
music_graph(2,150,0,0)
# Display interactive graph 2
music_graph(3,90,0,0)
# Display interactive graph 3
music_graph(4,120,0,0)
Reader: Ok, so what the hell was that?
Author: Yeah … sorry for the spoilers. Now I’ll provide the necessary background to understand step 4 and the graphs shown.
Visual examples
From a musical perspective, we’ll be dealing with chords (finite sets of at least two distinct notes) and their transpositions (translating them by some distance), but, from a mathematical perspective, we’ll be working with points in a circle (the border, not the inside) and rotating them by some angle.
For simplicity, we’ll work with the unitary circle, the circle with radius 1 and whose center is the origin of the Cartesian Plane. Each point in the unitary circle can be thought of as a possible musical note, if we conveniently match them.
In that sense, let’s work with the following pairing:
Note | C | Db | D | Eb | E | F | Gb | G | Ab | A | Bb | B |
---|---|---|---|---|---|---|---|---|---|---|---|---|
Angle |
|
|
|
|
|
|
|
|
|
|
|
|
Let’s start with a simple case: Rotating the chord “C major” by
Such chord is comprised of the notes C, E and G; notes which we can represent
in the Cartesian Plane (given the note
C :
E :
G :
However, it’s much simpler to represent chords not by the coordinates of the
points which comprise such chord, but by the unique angles,
inside
In that sense, let’s work with the following equivalence:
C major
where the angles in the vector representation of the chord will be written
in degrees and from lowest to highest angle.
Now, let’s rotate each of the points which comprise C major by
From a musical perspective, we’ve transposed the C major chord by
The set of trajectories that the notes/points from C major take along the unitary circle to get to the notes in Eb major is called the voice leading between C major and Eb major.
Let me clarify that the voice leadings which we’ll be dealing with in this post are precisely those which satisfy that
no pair of distinct notes from the initial chord end up at the same note in the transposed chord.
In that sense, when we tranpose/rotate any chord made up of
That’s because every note
Curious fact: We actually only need to check
Going back to our concrete case, let’s see some voice leading examples for the transposition from C major to Eb major in the following video:
Notice from the video that the trajectories which define the voice leading correspond
to the shortest of the two paths that a point could have taken to get to the other.
In the case where both paths have the same length, that is, for a
In this post, we’ll focus on two properties that we’d like a voice leading (VL) between a chord and some of its transpositions to have:
- The sum of the length of the trajectories which define VL, also known as the voice leading size, is the smallest one out of all the possible voice leadings between the initial chord and its transposition.
Any voice leading which satisfies this property is said to be a minimal voice leading. - The trajectories which define VL share the same direction, that is, they are
all clockwise or all anticlockwise.
Any voice leading which satisfies this property is said to have no contrary motion.
Partly, what I’ve shown you in the initial graphs is which chords, of some fixed chord size, satisfy that after transposing/rotating them by a certain amount, there exists a voice leading, between the initial and transposed chord, that is a minimal voice leading and has no contrary motion. If some chord satisfies such property, we’ll say that it has an unidirectional minimal voice leading.
I wouldn’t blame you if you were just thinking the following:
“Why would a minimal voice leading be unidirectional?.
The properties 1. and 2. do NOT seem related at all”.
You’d be partly right, in fact, because the property 1. deals with
minimizing trajectories’ lenghts, while the property 2. refers only to such
trajectories’ directions.
However, both properties happen to be fairly related, and even extremely related
when we focus on
Let’s get back to our example, rotating the C major by
Does it exist an unidirectional minimal voice leading in that case?
After checking by hand the
Of course, there is some ambiguity with respect to the direction of the
trajectory in voice leading 3 which has a size of
Notice that voice leading 1 and voice leading 2 fail to be minimal
voice leadings because their respective voice leading sizes,
Also note that voice leading 1 has no contrary motion but voice leading 2
does have contrary motion.
Putting it all together
We are 80% ready to understand the graphs shown previously.
The first step is to choose a chord size (
The second step is to chose some rotation (‘rotation’), a value between
In that sense, if we use the vector representation of chords via their angles,
as we did with C major ‘=’
However, we can be more efficient and work only with a special subset of such
domain, which would be the new domain of music_graph(..), yet still achieve
our goal of finding for which chords of size
Important property: If there exists a unidirectional minimal voice leading
with respect to some rotation
As a consequence, based on the fact that for the rotation
This means that the domain of music_graph(…) can be reduced in one dimension, after which it would take the following form as the new domain of music_graph(…):
The third step is to check, for every chord
Practically, we can’t check each of those chords, because
there’s an infinite amount of them, but the computer will check a sufficient
amount so that we can accurately approximate how the graph of music_graph(…)
actually looks like.
Let’s denote the set of chords in
The fourth step is displaying, appropriately, on the 3-dimensional space
Case
The domain in
The elements of ‘success’ are special chords represented by
Case
The domain in
The elements of ‘success’ are special chords represented by
Case
The domain in
The elements of ‘success’ are special chords represented by
Case
We’ve runned out of dimensions, because now the graphs are either
4 dimensional or 5 dimensional.
For that reason, in order to be able to visualize the graph
in a 3 dimensional space,
Which angles will remain fixed is what the last two numbers in
the command music_graph(…) refer to.
How to interpret the function
music_graph(chord_size, rotation,
We already know what chord_size and rotation refer to.
The extra caveat to consider is that the chords represented in
Now you can see why in the case
The fifth step, the final one, is to color appropriately the points
displayed in the fourth step.
After having chosen the parameters in
music_graph(chord_size, rotation,
Blue will be the color of the displayed point
(fourth step) for which its associated chord had the smallest minimal
voice leading size (min_VL) with respect to the minimal voice leading sizes of all
the chords in ‘success_approximation’.
Red will be the color of the displayed point
(fourth step) for which its associated chord had the biggest minimal
voice leading size (max_VL) with respect to the minimal voice leading sizes of all
the chords in ‘success_approximation’.
The other points displayed in the fourth step will be colored with
a color between blue and red, depending on the position of their minimal voice
leading size in the interval
Notice that there may be more than one chord in ‘success_approximation’
with the smallest (or biggest) minimal voice leading size, out of the minimal
voice leading sizes of all the chords in ‘success_approximation’.
Besides this, it may also be the case that, for certain parameters in
music_graph(chord_size, rotation,
Of course, we don’t have to stop at the case of chords with size 6, we could consider, for example, chords of size 666 and so on. However, I only coded the function music_graph(…) till chord size 6, so that’s the limit for now.
I encourage you to play around with the graphics in this post. For example, notice the bizarre fact that each of the graphs shown contains regions where the minimal voice leading size remains constant, that is, where the coloring applied doesn’t change.
In conclusion, I hope that after reading this post, you’ve gained some
appreciation for music. We only focused on rotating points along a circle,
while checking for certain properties of the trajectories of the points,
a very simple problem indeed; yet, the graphs shown displayed no
simplicity whatsoever. Do we even know which mathematical equation determines
the shape of the graphs? From what I’ve researched online,
it’s not known publicly.
I do know that precise mathematical equation, but I’d rather not share
it till I present it in my undergraduate thesis.
Thanks for reading!
This post took a huge amount of work, so I am glad you made it till here.
I’ve also implemented an online
graph calculator
so that you can play around changing the inputs of the function music_graph(…)
and see what bizarre shapes come into existence.
Finally, a couple more graph examples in case you are curious about how other cases look like:
music_graph(2,90,0,0)
music_graph(2,180,0,0)
music_graph(3,65,0,0)
music_graph(3,180,0,0)
music_graph(4,155,0,0)
music_graph(4,180,0,0)
music_graph(5,55,2,0)
music_graph(6,35,2,3)
music_graph(6,180,3,4)