Siteswap

Siteswap, also called quantum juggling or the Cambridge notation, is a numeric juggling notation used to describe or represent juggling patterns. The term may also be used to describe siteswap patterns, possible patterns transcribed using siteswap. Throws are represented by non-negative integers that specify the number of beats in the future when the object is thrown again: "The idea behind siteswap is to keep track of the order that balls are thrown and caught, and only that."[3] It is an invaluable tool in determining which combinations of throws yield valid juggling patterns for a given number of objects, and has led to previously unknown patterns (such as 441). However, it does not describe body movements such as behind-the-back and under-the-leg. Siteswap assumes that "throws happen on beats that are equally spaced in time."[4]
For example, a three-ball cascade may be notated "3 ", while a shower may be notated "5 1".[4]
Origin
[edit]The notation was invented by Paul Klimek in Santa Cruz, California in 1981, and later developed by undergraduates Bruce "Boppo" Tiemann, Joel David Hamkins, and the late Bengt Magnusson at the California Institute of Technology in 1985, and by Mike Day, mathematician Colin D Wright, and mathematician Adam Chalcraft in Cambridge, England in 1985 (whence comes an alternative name).[5][a] Hamkins wrote computer code in 1985 to systematically generate siteswap patterns—the printouts were taken immediately to the Athenaeum lawn at Caltech to be tried out by himself, Tiemann, and Magnusson. The numbers derive from the number of balls used in the most common juggling patterns. Siteswap has been described as, "perhaps the most popular" name.[8]
The name siteswap comes from the ability to generate patterns by "swapping" landing times of any 2 "sites" in a siteswap using the swap property.[9] For example, swapping the landing times of throws "5" and "1" in the siteswap "51" generates the siteswap "24".
Vanilla
[edit]
Its simplest form, sometimes called vanilla siteswap, describes only patterns whose throws alternate hands and in which one ball is thrown from each hand at a time. If one were juggling while walking forward, something like the adjacent diagram would be seen from above, sometimes called a space-time diagram or ladder diagram. In this diagram, three balls are being juggled. Time progresses from the top to the bottom.
This pattern can be described by stating how many throws later each ball is caught. For instance, on the first throw in the diagram, the purple ball is thrown in the air (up out of the screen, towards the bottom left) by the right hand, next the blue ball, the green ball, the green ball again, and the blue ball again and then finally the purple ball is caught and thrown by the left hand on the fifth throw, this gives the first throw a count of 5. This produces a sequence of numbers which denote the height of each throw to be made. Since hands alternate, odd-numbered throws send the ball to the other hand, while even-numbered throws send the ball to the same hand. A 3 represents a throw to the opposite hand at the height of the basic three-cascade; a 4 represents a throw to the same hand at the height of the four-fountain, and so on.
| Throw name | Beats in air | Switches hands | Description | 
|---|---|---|---|
| 0 | — | — | Empty hand | 
| 1 | 1 | Yes | Throw from one hand to the other | 
| 2 | 0 | No | Momentary hold | 
| 3 | 3 | Yes | Throw from a 3 ball cascade | 
| 4 | 4 | No | Throw from a 4 ball fountain | 
| 5 | 5 | Yes | Throw from a 5 ball cascade | 
| 6 | 6 | No | Throw from a 6 ball fountain | 
| 7 | 7 | Yes | Throw from a 7 ball cascade | 
| 8 | 8 | No | Throw from a 8 ball fountain | 
| 9 | 9 | Yes | Throw from a 9 ball cascade | 
| a | 10 | No | Throw from a 10 ball fountain | 
| b | 11 | Yes | Throw from a 11 ball cascade | 
| ... | ... | ... | ... | 
There are three special throws: a 0 is a pause with an empty hand, a 1 is a quick pass straight across to the other hand, and a 2 is a momentary hold of an object. Throws longer than 9 beats are given letters starting with a. The number of beats a ball is in the air usually corresponds to how high it was thrown, so many people refer to the numbers as heights, but this is not technically correct; all that matters is the number of beats in the air, not how high it is thrown. For example, bouncing a ball takes longer than a throw in the air to the same height, and so can be a higher siteswap value while being a lower throw.
Each pattern repeats after a certain number of throws, called the period of the pattern. The period is the number of digits in the shortest non-repeating representation of a pattern. For example, the pattern diagrammed on the right is 53145305520 which has 11 digits and therefore has a period of 11. If the period is an odd number, like this one, then each time the sequence is repeated, the sequence starts with the other hand, and the pattern is symmetrical because each hand is doing the same thing (although at different times). If the period is an even number then on every repeat of the pattern, each hand does the same thing it did last time and the pattern is asymmetrical.
The number of balls used for the pattern is the average of the throw numbers in the pattern.[2] For example, 441 is a three-object pattern because (4+4+1)/3 is 3, and 86 is a seven-object pattern. All patterns must therefore have a siteswap sequence that averages to an integer. Not all such sequences describe patterns; for example 543 with integer average 4 but its three throws all land at the same time, colliding.
Some hold to a convention in that a siteswap is written with its highest numbers first. One drawback to doing so is evident in the pattern 51414, a 3-ball pattern which cannot be inserted into the middle of a string of 3-throws, unlike its rotation 45141 which can.
Synchronous
[edit]
Siteswap notation can be extended to denote patterns containing synchronous throws from both hands. The numbers for the two throws are combined in parentheses and separated by a comma. Since synchronous throws are only thrown on even beats, only even numbers are allowed.[10] Throws that move to the other hand are marked by an x following the number. Thus a synchronous three-prop shower is denoted (4x,2x), meaning one hand continually throws a low throw or 'zip' to the opposite hand, while the other continually makes a higher throw to the first. Sequences of bracketed pairs are written without delimiting markers. Patterns that repeat in mirror image on the opposite side can be abbreviated with a *. For example, Instead of (4,2x)(2x,4) (3-ball box pattern), can be abbreviated to (4,2x)*.
Multiplexing
[edit]
A further extension allows siteswap to notate patterns involving multiple throws from either or both hands at the same time in a multiplex pattern. The numbers for multiple throws from a single hand are written together inside square brackets. For example, [33]33 is a normal 3-ball cascade, with a pair of balls always thrown together.
Passing
[edit]
Simultaneous juggling: <xxx|yyy> notation means one juggler does 'xxx' while another does 'yyy'. 'p' is used to represent a passing throw. For example, <3p 3|3p 3> is a 6 prop '2 count' passing pattern, where all left hand throws are passes and right hand throws are selves. This can also be used with synchronous patterns; a two-person 'shower' is then <(4xp,2x)|(4xp,2x)>
Fractional notation
[edit]If the pattern contains fractions, e.g. <4.5 3 3 | 3 4 3.5> the juggler after the bar is supposed to be half a count later, and all fractions are passes.
Social Siteswap
If both juggle the same pattern (although shifted in time), the pattern is called a social siteswap and only half of the pattern needs to be written: <4p 3| 3 4p> becomes 4p 3 and <4.5 3 3| 3 4.5 3> becomes 4.5 3 3. (note that in the latter case, 4.5 will be straight passes from one juggler, crossing passes (i.e. left to left or right to right hand) from the other juggler. Social siteswaps can also be created for more than 2 jugglers (e.g. 4p 3 3 or 3.7 3 for 3 jugglers, where 3.7 is meant to mean 3.66666.... or 3 2⁄3. Then each juggler should start 1⁄3 count after the previous one.)
Note that some jugglers use fractions to note multi-handed patterns.
Multi-handed
[edit]Multi-hand notation was developed by Ed Carstens in 1992 for use with his juggling program JugglePro.[7] Siteswap notation in its simplest form ("Vanilla siteswap") assumes that only one ball is thrown at a time. It follows that any valid siteswap for two hands will also be valid for any number of hands, on the condition that the hands throw after each other. Commonly used multi-hand siteswaps are 1-handed (diabolo) siteswap, and 4-handed (passing) siteswap.
1-handed (diabolo)
The siteswap is performed by a single hand, or a diabolo player throwing diabolos at different heights.
4-handed
Valid siteswaps can be juggled by a 4-handed juggler, or for 2 jugglers coordinating 4 hands, on the condition that hands throw alternately.
In practice, this is most easily obtained if the jugglers throw by turns, one sequence being (Right hand of juggler A, right hand of juggler B, left hand of A, left hand of B).
Mixed-up Notation
Some jugglers, when noting 4-handed siteswap, divide the siteswap values by the number of jugglers. This leads to a fractional notation similar to the notation for social siteswaps, but the order of the notation can be different.
State diagrams
[edit]
Just after throwing a ball (or club or other juggling object), all balls are in the air and are under the influence of gravity. Assuming the balls are caught at a consistent level, then the timing of when the balls land is already determined. We can mark each point in time when a ball is going to land with an x, and each point in time when there is not yet a ball scheduled to land with a -. This describes the current state and determines what number ball can be thrown next. For instance, we can look at the state just after our first throw in the diagram, it is xx--x. We can use the state to determine what can be thrown next. First we take the x off the left hand side (that's the ball that's landing next) and shift everything else to the left filling in a - on the right. This leaves us with x--x-. Since we caught a ball (the x we removed from the left) we can't "throw" a 0 next. We also can't throw a 1 or a 4, because there are already balls scheduled to land there. So assuming that the highest we can accurately throw a ball is to a height of 5, then we can only throw a 2, 3, or a 5. In this diagram, the juggler threw a 3, so an x goes in the third spot, replacing the -, and we have x-xx- as the new state.
The diagram shown illustrates all possible states for someone juggling three items and a maximum height of 5. From each state one can follow the arrows and the corresponding numbers produce the siteswap. Any path which produces a cycle generates a valid siteswap, and all siteswaps can be generated this way. The diagram quickly becomes bigger when more balls or higher throws are introduced as there are more possible states and more possible throws.
Another method of representing siteswap states is represent a ball with a 1 instead of an x, and represent a spot where there's no ball scheduled to land with a 0 instead of a -. Then the state can be represented with a binary number, such as binary 10011. This format makes it possible to represent multiplex states, i.e. the number 2 represents that 2 balls land on that beat.
| Throw State | 0 | 1 | 2 | 3 | 4 | 5 | 
|---|---|---|---|---|---|---|
| 111 | 111 | 1101 | 11001 | |||
| 0111 | 111 | |||||
| 1011 | 111 | 0111 | 01101 | |||
| 1101 | 111 | 1011 | 10101 | |||
| 00111 | 0111 | |||||
| 01011 | 1011 | |||||
| 01101 | 1101 | |||||
| 10011 | 1011 | 0111 | 00111 | |||
| 10101 | 1101 | 0111 | 01011 | |||
| 11001 | 1101 | 1011 | 10011 | 
A siteswap state diagram can also be represented as a state-transition table, as shown on the right. To generate a siteswap, pick a starting state row. Index into the row via the corresponding throw column. The state entry at the intersection is the transitioned to state when that throw is made. From the new state, one can index into the table again. This process can be repeated so that when the original state is reached, a valid siteswap will be created.
Mathematical properties
[edit]Validity
[edit]
Not all siteswap sequences are valid.[10] All vanilla, synchronous, and multiplex siteswap sequences are valid if their state transitions create a cycle in their state diagram graph.[10] Sequences that do not create a cycle are invalid. For example, the pattern 531 can be mapped to a state diagram as shown on the right. Since the transitions in this sequence create a cycle in the graph, this pattern is valid.
There are other methods of determining a sequence's validity based on the flavor of siteswap.
A vanilla siteswap sequence where is the period of the siteswap, is valid when the cardinality of the set (written in Set-builder notation) is equal to the period whereTo find if a pattern is valid, first create a new sequence formed by adding to the first number, to the second number, to the third number and so on. Second, calculate the modulus (remainder) of each number with the period. If none of the numbers are duplicated in this final sequence, then the pattern is valid.[11]
For example, the pattern 531 would produce or . Since the pattern 531 has a period of 3, the results from the previous example would produce or . In this case, 531 is valid since the numbers are all unique. Another example, 513 is an invalid pattern because the first step produces or , the second step produces or , and the final sequence contains at least a duplicate of one number, in this case a 2.
A synchronous siteswap is valid if
- it only contains even numbers and
- it can be converted into a valid vanilla siteswap using the slide property.
otherwise it is invalid[citation needed].
Swap property
[edit]New valid vanilla sequences can be generated by swapping adjacent elements from another valid vanilla siteswap sequence, adding 1 to the number being swapped to the left and subtracting 1 from the number being swapped to the right.[11] The swap property will convert the valid sequence with arbitrary value , to generate the new valid sequence .
For example, the swap property performed on the inner two throws of the sequence 4413 would move the 4 to the right subtracting 1 from it to become 3 and move the 1 to the left adding 1 to it to become 2. This produces the new valid siteswap pattern 4233.
Slide property
[edit]A valid synchronous sequence can be converted to a valid asynchronous sequence and vice versa using the slide property. Given the synchronous sequence , two new vanilla sequences can be formed: and , whereandThe slide property gets its name by sliding the throw times of one of the hands by one time unit so that the throws align asynchronously.[10] For example, the siteswap (8x,4x)(4,4) would create two asynchronous (vanilla) siteswaps using the slide property: 9344 and 5744.
Prime patterns
[edit]Siteswaps may be considered either prime or composite.[10] A siteswap is prime if the path created in its state diagram does not traverse any state more than once. Siteswaps that are not prime are called composite.
A non-rigorous but simpler method of determining if a siteswap is prime is to try to split it into any valid shorter pattern which uses the same number of props.[10] For example, 44404413 can be split into 4440, 441, and 3; therefore, 44404413 is a composite. Another example, 441, which uses three props, is prime, as 1, 4, 41, and 44 are not valid three prop patterns (as 1/1≠3, 4/1≠3, (4+1)/2≠3, and (4+4)/2≠3). Sometimes this process does not work; for example, 153 (better known by its rotation 531) looks like it can be split into 15 and 3, but checking that the cycle has no repeating nodes in the graph traversal indicates that it is prime by the more rigorous definition.
It has been shown empirically that the longest prime siteswaps bounded by height contain mostly the throws and .[12] The longest prime patterns with height 22 (with 3 ball maximum), for 9 balls (with 13 maximum height), and for heights and ball counts in between, were enumerated by Jack Boyce in February 1999 using a program called jdeep.[13] The full list of longest prime siteswaps generated by jdeep (with '0' throws represented by a '-' and maximum height throws represented by a '+') can be found here.
Mathematical connections
[edit]Connections to abstract algebra
[edit]Vanilla siteswap patterns may be viewed as certain elements of the affine symmetric group (the affine Weyl group of type ).[14] One presentation of this group is as the set of bijective functions f on the integers such that, for a fixed n: f(i + n) = f(i) + n for all integers i. If the element f satisfies the further condition that f(i) ≥ i for all i, then f corresponds to the (infinitely repeated) siteswap pattern whose ith number is f(i) − i: that is, the ball thrown at time i will land at time f(i).
Connections to topology
[edit]A subset of these siteswap patterns naturally label strata in the positroid stratification of the Grassmannian.[15]
List of symbols
[edit]- Number: Relative duration (height) of a toss. 1, 2, 3...
- Brackets []: Multiplex. [333]33.
- Chevrons and vertical bar <|>: Simultaneous and passing patterns.
- P: Pass. <333P|333P>
- Fraction: Pass 1/y beats later. <4.5 3 3 | 3 4 3.5>
 
- Parentheses (): Synchronous pattern.
- *: Synchronous pattern that switches sides. (4,2x)(2x,4) = (4,2x)*
- x: Toss to the other hand during a synchronous pattern.
 
Programs
[edit]There are many free computer programs available which simulate juggling patterns.
- Juggling Lab - An open source animator which was written in Java and interprets nearly all siteswap syntax.
- Passist - web based, open source 3D animator developed for passing patterns
- Gunswap - A web based, open source, 3d juggling animator and pattern library.
- JoePass! works on Windows, Macintosh and Wine (For Linux) - development stopped as of April 2024[16]
- Jongl - 3D animator capable of displaying multihand (passing) patterns.
There are also some games to play with siteswap:
- Siteswap Game developed by Sebi Haushofer (for Java)
See also
[edit]Notes
[edit]- ^ 
- "Invented independently around 1985 by Paul Klimek of the University of California at Santa Cruz, Bruce Tiemann of the California Institute of Technology and Michael Day of the University of Cambridge."[4]
- "...site swap patterns...in the form invented by some of Bruce Tiemann, Bengt Magnusson, and Joel Hamkins"[6]
- "Invented around 1985 by three people independently: Bruce "Boppo" Tiemann at Caltech, Paul Klimek in Santa Cruz, and Mike Day in Cambridge."[3]
- "...Bruce Tiemann (Boppo) and the late Bengt Magnusson....Other contributors to the development of site swap theory include Jack Boyce, Allen Knutson, Ed Carstens, and jugglers on the computer network."[7]
- "Jack Boyce (also at Caltech) came up with the juggling state model to explain the phenomenon of excited-state tricks."[3]
- "To give credit where it is due, the notation as presented here was independently (and previously) invented by Paul Klimek, with whom we have had helpful discussions."[2]
 
References
[edit]- ^ Donahue, Bill (December 3, 2004). "The Mathematics of... Juggling". Discover Magazine. Retrieved June 30, 2017.
- ^ a b c Tiemann, Bruce and Magnusson, Bengt (1991). "A Notation for Juggling Tricks, A LOT of Juggling Tricks", Juggle.org. Accessed July 8, 2014. original url
- ^ a b c Knutson, Allen. "Siteswap FAQ". Juggling.org. Retrieved June 30, 2017.
- ^ a b c Beek, Peter J.; Lewbel, Arthur (November 1995). "The Science of Juggling" (PDF). Scientific American. 273 (5): 92–97. Bibcode:1995SciAm.273e..92B. doi:10.1038/scientificamerican1195-92. ISSN 0036-8733. JSTOR 24982089. Archived from the original (PDF) on March 4, 2016.
- ^ Hayes, David F.; Shubin, Tatiana (2004). Mathematical Adventures for Students and Amateurs. Mathematical Association of America. p. 99. ISBN 0883855488. OCLC 56020214.
- ^ Knutson, Allen. "(in) IBM-PC Programs". Juggling.org. Retrieved October 3, 2023.
- ^ a b Lewbel, Arthur (1996). "The Academic Juggler: The Invention Of Juggling Notations Archived July 14, 2014, at the Wayback Machine", Juggle.org.
- ^ Sethares, William Arthur (2007). Rhythm and Transforms. Springer. p. 40. ISBN 9781846286407. OCLC 261225487.
- ^ Boyce, Jack (October 11, 1997). "Patterns from Lodi 1997 Workshop". sonic.net. Archived from the original on December 7, 2004. Retrieved July 8, 2020.
- ^ a b c d e f Beever, Ben (2001). "Siteswap Ben's Guide to Juggling Patterns", p.6, JugglingEdge.com. BenBeever.com at the Wayback Machine (archived August 10, 2015).
- ^ a b Polster, Burkard. "The Mathematics of Juggling" (PDF). qedcat.com. Retrieved April 22, 2020.
- ^ Boyce, Jack. "The Longest Prime Siteswap Patterns" (PDF). jonglage.net. Retrieved April 27, 2020.
- ^ Boyce, Jack (February 17, 1999). "jdeep.c". sonic.net. Archived from the original on December 7, 2004. Retrieved April 27, 2020.
- ^ Ehrenborg, Richard; Readdy, Margaret (October 1, 1996). "Juggling and applications to q-analogues". Discrete Mathematics. 157 (1): 107–125. doi:10.1016/S0012-365X(96)83010-X. ISSN 0012-365X.
- ^ Knutson, Allen; Lam, Thomas; Speyer, David (November 15, 2011). "Positroid Varieties: Juggling and Geometry". arXiv:1111.3660 [math.AG].
- ^ http://koelnvention.de/w/?page_id=151
Further reading
[edit]- Polster, Burkard (2003). The Mathematics of Juggling. New York: Springer. ISBN 0-387-95513-5. Retrieved August 23, 2012.
External links
[edit]- "Symmetric Passing Patterns", PassingDB.com.
- DSSS: The Diabolo Siteswap Simulator, ArtofDiabolo.com.
- Juggling Lab (Downloadable animator)
- Gunswap Juggling (Online animator)
- TWJC Siteswap Calculator (Helpful Vanilla, Multiplex and Synchronous siteswap validator)
- "Staggered Symmetric Passing Patterns for 2 jugglers" by Sean Gandini (social siteswaps)
- Smith, H.J. "Juggler Numbers" at the Wayback Machine (archived August 6, 2003)
- Wright, Colin (September 29, 2017). "Juggling by Numbers" (video). YouTube. Brady Haran. Retrieved October 4, 2017.
