Parallel depth first search (DFS) to find prime siteswap juggling patterns.
Prime siteswap patterns are those which cannot be expressed as compositions (concatenations) of shorter patterns. This is most easily understood by looking at siteswaps as paths on an associated "state diagram" graph. (The Wikipedia article shows an example state graph for 3 objects and maximum throw value of 5.) Valid siteswaps are closed paths (circuits) in the associated state graph. Prime patterns then correpond to cycles in the graph, i.e. circuits that visit each state in the pattern only once.
jprime
searches the juggling state graph for prime patterns, using efficiency tricks to speed up the search. The search is done in parallel using a work-stealing scheme to distribute the search across multiple execution threads.
Using jprime
I have carried out some research into prime siteswap patterns. The first is to use jprime
to count the total number of prime patterns for a given number of objects
The counting problem has been solved analytically for siteswap patterns in general. In Juggling Drops and Descents (Buhler, Eisenbud, Graham, and Wright, 1994) the following formula is derived for the total number of periodic siteswap patterns with
Note this formula treats rotated versions of the same pattern as distinct, e.g., 531
, 315
, and 153
are counted separately. Since this formula includes all prime patterns (as well as non-prime ones), and because each prime pattern occurs exactly
Counting prime patterns specifically is a more difficult problem than the general case. One set of results comes from Counting prime juggling patterns (Banaian, Butler, Cox, Davis, Landgraf, and Ponce, 2015). They find an exact formula for
As a concrete example, for 3 objects there are 11 prime siteswap patterns of period 3: 531
, 441
, 522
, 630
, 450
, 612
, 720
, 360
, 711
, 801
, and 900
. Any other period-3 pattern that one might write down is either a rotation of one of these (like 504
), or not prime (like 423
). So we have
The table below shows exact counts for the number of prime patterns at each period, found using jprime
. For the cases
2 OBJECTS 1, 1 2, 2 3, 5 4, 10 5, 23 6, 48 7, 105 8, 216 9, 467 10, 958 11, 2021 12, 4146 13, 8631 14, 17604 15, 36377 16, 73876 17, 151379 18, 306882 19, 625149 20, 1263294 21, 2563895 22, 5169544 23, 10454105 24, 21046800 25, 42451179 26, 85334982 27, 171799853 28, 344952010 29, 693368423 30, 1391049900 31, 2792734257 32, 5598733260 33, 11230441259 34, 22501784458 35, 45103949933 36, 90335055318 37, 180975948735 38, 362339965776 39, 725616088097 40, 1452416238568 3 OBJECTS 1, 1 2, 3 3, 11 4, 36 5, 127 6, 405 7, 1409 8, 4561 9, 15559 10, 50294 11, 169537 12, 551001 13, 1835073 14, 5947516 15, 19717181 16, 63697526 17, 209422033 18, 676831026 19, 2208923853 20, 7112963260 21, 23127536979 22, 74225466424 23, 239962004807 24, 768695233371 25, 2473092566267 26, 7896286237030 27, 25316008015581 28, 80572339461372 4 OBJECTS 1, 1 2, 4 3, 19 4, 83 5, 391 6, 1663 7, 7739 8, 33812 9, 153575 10, 677901 11, 3075879 12, 13586581 13, 61458267 14, 272367077 15, 1228519987 16, 5456053443 17, 24547516939 18, 109153816505 19, 490067180301 20, 2180061001275 21, 9772927018285 22, 43467641569472 5 OBJECTS 1, 1 2, 5 3, 29 4, 157 5, 901 6, 4822 7, 27447 8, 149393 9, 836527 10, 4610088 11, 25846123 12, 142296551 13, 799268609 14, 4426204933 15, 24808065829 16, 137945151360 17, 773962487261 18, 4310815784117 19, 24208263855765 6 OBJECTS 1, 1 2, 6 3, 41 4, 264 5, 1777 6, 11378 7, 76191 8, 493550 9, 3263843 10, 21373408 11, 141617885 12, 926949128 13, 6157491321 14, 40536148951 15, 268893316363 16, 1777319903383 7 OBJECTS 1, 1 2, 7 3, 55 4, 410 5, 3163 6, 23511 7, 180477 8, 1353935 9, 10297769 10, 77849603 11, 593258483 12, 4486556303 13, 34267633327 14, 260349728028 15, 1987331381633 8 OBJECTS 1, 1 2, 8 3, 71 4, 601 5, 5227 6, 44181 7, 382221 8, 3254240 9, 27976325 10, 239491149 11, 2061545183 12, 17664073336 13, 152326783983 14, 1309746576182 9 OBJECTS 1, 1 2, 9 3, 89 4, 843 5, 8161 6, 77248 7, 743823 8, 7081367 9, 67880511 10, 648866014 11, 6225810713 12, 59574064361 13, 572427402861
For a real juggler there is a physical limit to how high a person can throw. In fact many of the patterns found above (prime patterns of a given period
Here we ask a different question: If we restrict ourselves to siteswap throws no greater than some value
Since the graph jprime
. The prime pattern count increases very quickly as
2 OBJECTS 3, 3 4, 8 5, 26 6, 79 7, 337 8, 1398 9, 7848 10, 42749 11, 297887 12, 2009956 13, 16660918 14, 133895979 15, 1284371565 16, 11970256082 17, 130310396228 18, 1381323285721 3 OBJECTS 4, 4 5, 26 6, 349 7, 29693 8, 11906414 9, 30513071763 4 OBJECTS 5, 5 6, 79 7, 29693 8, 1505718865
How do these total counts break down in terms of pattern periods? As an experiment, when we find the 30,513,071,763 patterns in
We see that the distribution of pattern periods is close to a normal distribution, with the most patterns at period 40 in this case. In general there are relatively few very short or very long prime patterns, and for graph
At the extremes, for 3
) and a single prime pattern of period 74 (99500009091900009080900009700900091900900080800900908000900960000990800000
). We will have more to say about such maximally-long patterns in the next section.
As a final investigation, we aim to identify the longest prime patterns for a given number of objects
Since the state graph
The table below summarizes everything known about the longest prime siteswap patterns.
Table notes:
- When
$n < n_{bound}$ , this means there are no complete prime patterns for that case. (Consult the 1999 paper; in short a complete prime pattern is the maximum period possible, missing exactly one state on each shift cycle. Every complete prime pattern is superprime, and has a superprime inverse.) When$n < n_{bound}$ the pattern count is shown as{superprime, non-superprime}
patterns. The superprime patterns are faster to find than the non-superprime ones, and in some cases only the former have been tabulated. - There is an isomorphism between the juggling patterns in graphs
$(b, h)$ and$(h-b, h)$ , in the form of a duality transform: Take a siteswap in$(b, h)$ , reverse its throws, and subtract each from$h$ to get its dual pattern in$(h-b,h)$ . E.g.,868671
in$(6,9)$ maps to823131
in$(3,9)$ . Primality is preserved under this transform. So for example$(5,11)$ and$(6,11)$ have identical results below. - The table for
$b=2$ is truncated; the observed pattern appears to continue.
The current record holder is
2 OBJECTS H N (N_bound) Pattern count -------------------------------- 3, 3 (3), 1 4, 4 (4), 2 5, 8 (8), 1 6, 12 (12), 1 7, 18 (18), 1 8, 24 (24), 1 . . . 3 OBJECTS H N (N_bound) Pattern count -------------------------------- 4, 4 (4), 1 5, 8 (8), 1 6, 15 (16), {6, 0} 7, 30 (30), 1 8, 49 (49), 3 9, 74 (74), 1 10, 108 (108), 1 11, 149 (150), {18, 0} 12, 200 (201), {28, 2} 13, 263 (264), {4, 4} 14, 337 (338), {38, 0} 15, 424 (424), 1 16, 524 (525), {20, 10} 17, 639 (640), {34, 4} 18, 769 (770), {50, 7} 19, 917 (918), {0, 4} 20, 1082 (1083), {92, 4} 21, 1266 (1266), 1 22, 1469 (1470), {18, 4} 23, 1693 (1694), {56, 4} 24, 1938 (1939), {44, 3} 25, 2207 (2208), {0, 4} 26, 2499 (2500), {180, ?} 27, 2816 (2816), 1 28, 3158 (3159), {26, ?} 29, <3528 (3528), {?, ?} 4 OBJECTS H N (N_bound) Pattern count -------------------------------- 5, 5 (5), 1 6, 12 (12), 1 7, 30 (30), 1 8, 58 (60), {28, 16} 9, 112 (112), 5 10, 188 (188), 9 11, 300 (300), 144 12, 452 (452), 45 13, 660 (660), 16317 14, 928 (928), 63606 5 OBJECTS H N (N_bound) Pattern count -------------------------------- 6, 6 (6), 1 7, 18 (18), 1 8, 49 (49), 3 9, 112 (112), 5 10, 225 (226), {752, 86} 11, 420 (420), 59346 12, 726 (726), >=309585 6 OBJECTS H N (N_bound) Pattern count -------------------------------- 7, 7 (7), 1 8, 24 (24), 1 9, 74 (74), 1 10, 188 (188), 9 11, 420 (420), 59346 12, 843 (844), {>=(104+263), ?} (see note) 7 OBJECTS H N (N_bound) Pattern count -------------------------------- 8, 8 (8), 1 9, 32 (32), 1 10, 108 (108), 1 11, 300 (300), 144 12, 726 (726), >=309585 8 OBJECTS H N (N_bound) Pattern count -------------------------------- 9, 9 (9), 1 10, 40 (40), 1 11, 149 (150), {18, 0} 12, 452 (452), 45 9 OBJECTS H N (N_bound) Pattern count -------------------------------- 10, 10 (10), 1 11, 50 (50), 1 12, 200 (201), {28, 2} 13, 660 (660), 16317
Note for case (x-)^b
. In the case (x-)^b
shift cycle entirely, and use exactly one state on each other shift cycle, and (b) patterns that use state (x-)^b
and every other shift cycle, including exactly one shift throw on one of these other cycles. The numbers shown are the quantities found of each, respectively. Similarly, the 752 maximal superprime patterns in jprime 5 10 25 -super 0 -inverse
(308 patterns) and jprime 5 10 27 -super 1 -inverse
(444 patterns).
After cloning the repository, on a Unix system run make
to build the jprime
binary using the included makefile. jprime
requires the following compiler versions or later: GCC 12, Clang 15, MSVC 19.29, Apple Clang 14.0.3. Run the binary with no arguments to get a help message.
jprime
has two modes of operation, intended to search for prime patterns in complementary ways:
- Normal mode, the default. This finds prime patterns by searching the juggling graph directly for cycles.
- Super mode (faster). This searches the juggling graph for superprime patterns, which visit no shift cycle more than once. Invoke super mode with
-super <shifts>
on the command line, where<shifts>
is how many shift throws in total to allow. The-inverse
option prints the inverse of each pattern, if one exists. The significance here is that many of the longest prime patterns are superprime for reasons described in the paper. So a quick way to find these patterns is to search for long superprime patterns having a small number of shift throws, and find their inverses to get the desired long (superprime) patterns. The limitation of this method is that it cannot find non-superprime patterns.