BB(3,4)
The Busy Beaver problem for 3 states and 4 symbols is unsolved, with the existence of Cryptids in the domain being given by the discovery of Bigfoot in BB(3,3). The current BB(3,4) champion is 1RB3LB1RZ2RA_2LC3RB1LC2RA_3RB1LB3LC2RC (bbch). It runs for  steps before halting. It was discovered by Pavel Kropitz in 2024 and was analysed by Shawn Ligocki in the same year.
Top Halters
The top 20 longest running halting BB(3,4) TMs are:
| Standard format | (approximate) runtime | 
|---|---|
| 1RB3LB1RZ2RA_2LC3RB1LC2RA_3RB1LB3LC2RC(bbch) | |
| 1RB1RZ1LA2RB_1RC3RC1LA2LB_2LB2RC1LC3RB(bbch) | |
| 1RB0LB1RZ3LA_0LC3RB3RC1LB_2RB2LA3RA1LC(bbch) | 
Phase 1
The initial phase of enumeration and reduction of holdouts took place in December 2024 and was done by Terry Ligocki using the Ligockis' C++ and Python codes. The initial enumerations generated 600,253,156,787 TMs of which 42,391,877,333 were holdout TMs. Also found were 202,014,400,019 halting TMs and 355,846,879,435 infinite TMs. The number of holdouts was reduced to 434,787,751 TMs (a 98.97% reduction).
Two C++ programs were run before the filters in the table.
lr_enum 3 4 8 /dev/null /dev/null 3x4.unk.txt false 00 <= XX < 47: lr_enum_continue 3x4.in.XX 1000 /dev/null /dev/null 3x4.unk.txt.XX XX false
Both do the initial enumeration and simple filtering. The "/dev/null" in both commands would be files where the halting and infinite TMs would be stored. The first command generates the TMs from a TNF tree for BB(3,4) of depth 8 and outputs the holdouts to 3x4.unk.txt. This file was then divided into 48 pieces, 3x4.in.XX, 0 <= XX < 47. The second commands (one for each XX) continues the enumeration by running each TM for 1,000 steps. It classifies each as halting, infinite, or unknown/holdout. Again, the halting and infinite TMs are "written" to /dev/null, i.e., they aren't saved. The holdouts are stored in 48 files: 3x4.unk.txt.XX.
For these runs the first command generated a total of 22,366,747 TMs: 932,198 halting, 235,446 infinite, and 21,199,103 holdouts. The second took the 22,366,747 holdout TMs and generated a total of 600,253,156,787 TMs: 202,014,400,019 halting, 355,846,879,435 infinite, and 42,391,877,333 holdouts. These holdouts were used as a starting point of the filters below.
The "Description" column in the table below contain the command run. Two options are not given, "--infile=..." and an "--outfile=...". These are necessary and specify where to read and write the results, respectively. Note: The work flow was to divide the input holdouts into 48 pieces, run the command on each piece simultaneously on one of 48 cores, and then combine the 48 results into a group of holdouts.
The details are given in this table:
(done to reduce column size: = % Reduced, = Runtime (hours), = Decided, = Processed)
| Done by | Holdout TMs | TMs/sec/core | Description | Data | ||||
|---|---|---|---|---|---|---|---|---|
| Input | Output | |||||||
| Terry Ligocki | 42,391,877,333 | 32,247,381,725 | 23.93% | 788.0 | 3,576.08 | 14,943.74 | Reverse_Engineer_Filter.py | Google Drive | 
| Terry Ligocki | 32,247,381,725 | 12,789,441,316 | 60.34% | 6,185.2 | 873.85 | 1,448.22 | CPS_Filter.py --block-size=1 | |
| Terry Ligocki | 12,789,441,316 | 4,332,283,583 | 66.13% | 4,771.0 | 492.39 | 744.62 | CPS_Filter.py --block-size=2 | |
| Terry Ligocki | 4,332,283,583 | 2,796,143,404 | 35.46% | 7,873.1 | 54.20 | 152.85 | CPS_Filter.py --block-size=3 | |
| Terry Ligocki | 2,796,143,404 | 1,398,734,288 | 49.98% | 10,239.4 | 37.91 | 75.85 | Enumerate.py --max-loops=1_000 --block-size=2 --time=10 --lin-steps=0 --no-reverse-engineer --save-freq=10_000 | |
| Terry Ligocki | 1,398,734,288 | 764,851,053 | 45.32% | 3,203.1 | 54.97 | 121.30 | Enumerate.py --max-loops=10_000 --block-size=12 --no-steps --time=0.01 --lin-steps=0 --no-ctl --no-reverse-engineer --save-freq=10_000 | |
| Terry Ligocki | 764,851,053 | 581,654,405 | 23.95% | 1,925.3 | 26.43 | 110.35 | CPS_Filter.py --min-block-size=4 --max-block-size=12 --max-steps=1_000 | |
| Terry Ligocki | 581,654,405 | 434,787,751 | 25.25% | 9,042.5 | 4.51 | 17.87 | CPS_Filter.py --min-block-size=4 --max-block-size=6 --max-steps=10_000 | |
Phase 2
XnoobSpeakable and Lúkos are working on applying mxdys' deciders/parameters to the remaining holdouts. The previous holdouts list by Terry Ligocki was split up into 8696 files containing 50,000 holdouts each* (*the last one actually has 37,751) and the deciders were applied to the files individually. These files can be called subtasks. Lúkos made a Python script to compute the subtasks in parallel, based off of XnoobSpeakable's earlier imperfect script.
Certain data such as TMs/sec/core is unavailable, because the amount of time the computation took was not kept track of.
Stage 3 is a lr_enum_continue computation to 1 million steps. While Lúkos did not contribute to computing stage 3, he did create a Python script to compute it in bulk, which XnoobSpeakable used.
For the "Contribution" column, the first number is the amount of subtasks solved by XnoobSpeakable, the 2nd is the amount solved by Lúkos. Note that the counts are unequal, because Lúkos has a slower CPU with a lower core count. According to XnoobSpeakable, the time contribution from both contributors is roughly equal. Lúkos also worked on the Python scripts used, while XnoobSpeakable worked on compiling holdouts lists and finding optimal deciders to apply.
Peacemaker II worked on verifying the validity of the results as well as providing solved TM counts per decider. Stages 1, 2, and 4 have been validated - no dropped TMs.
*Phase 2 stage 6 is currently being computed.
The details will be given in this table:
| Done by | Holdout TMs | % Reduced | Description | Subtasks | Contribution | Data | |
|---|---|---|---|---|---|---|---|
| Input | Output | ||||||
| XnoobSpeakable, Lúkos | 434,787,751 | 64,777,377 | 85.1% | Phase 2 stage 1 | 8696 | 7696 / 1000 | Google Drive | 
| XnoobSpeakable, Lúkos | 64,777,377 | 37,016,957 | 42.9% | Phase 2 stage 2 | 1296 | 1000 / 296 | Google Drive | 
| XnoobSpeakable | 37,016,957 | 26,266,261 | 29.0% | Phase 2 stage 3 | 741 | 741 / 0 | Google Drive | 
| XnoobSpeakable, Lúkos | 26,266,261 | 22,396,711 | 14.7% | Phase 2 stage 4 | 526 | 485 / 41 | Google Drive | 
| XnoobSpeakable, Lúkos | 22,396,711 | 17,983,810 | 19.7% | Phase 2 stage 5 | 448 | 390 / 58 | Google Drive | 
| XnoobSpeakable, Lúkos | 22,396,711 | --- | --- | Phase 2 stage 6 | 360 | 286 / 60* | --- | 
Phase 2 Data
Here we will list the deciders applied during the various stages of Phase 2. Each line shows a decider and how many TMs that decider solved (last number; provided by Peacemaker II). Each decider within a stage was not applied in a specific order.
Phase 2 stage 1:
chr_LRUH 4 chr_H 4 MitM_CTL NG maxT 1000 NG_n 2 run 86569103
chr_LRUH 4 chr_H 4 MitM_CTL NG maxT 1000 NG_n 1 run 26093656
chr_LRUH 12 chr_H 12 MitM_CTL NG maxT 3000 NG_n 2 run 13972946
MitM_CTL RWL_mod sim 1001 maxT 1000 H 6 mod 3 n 2 run 7190617
chr_LRUH 10 chr_H 6 MitM_CTL NG maxT 1000 NG_n 2 run 90302784
MitM_CTL CPS_LRU sim 1001 maxT 1000 LRUH 16 H 1 tH 1 n 4 run 4342619
MitM_CTL CPS_LRU sim 1001 maxT 1000 LRUH 12 H 0 tH 1 n 2 run 11764327
chr_LRUH 2 chr_H 2 MitM_CTL NG maxT 1000 NG_n 1 run 55465842
MitM_CTL RWL_mod sim 1001 maxT 1000 H 2 mod 2 n 1 run 17805678
MitM_CTL CPS_LRU sim 1001 maxT 100000 LRUH 2 H 0 tH 0 n 1 run 12623067
chr_LRUH 2 chr_H 0 MitM_CTL NG maxT 3000 NG_n 2 run 2240499
MitM_CTL CPS_LRU sim 1001 maxT 1000 LRUH 4 H 1 tH 1 n 2 run 10223131
chr_LRUH 6 chr_H 4 MitM_CTL NG maxT 10000 NG_n 1 run 2901053
chr_LRUH 22 chr_H 12 MitM_CTL NG maxT 3000 NG_n 2 run 28515052Phase 2 stage 2:
MitM_CTL RWL_mod sim 1001 maxT 1000 H 3 mod 4 n 8 run 1030303
MitM_CTL RWL_mod sim 1001 maxT 3000 H 8 mod 2 n 2 run 1465523
chr_LRUH 18 chr_H 12 MitM_CTL NG maxT 10000 NG_n 4 run 5232902
chr_LRUH 18 chr_H 12 MitM_CTL NG maxT 3000 NG_n 2 run 1720994
MitM_CTL RWL_mod sim 1001 maxT 3000 H 8 mod 3 n 2 run 555883
MitM_CTL CPS_LRU sim 1001 maxT 1000 LRUH 3 H 1 tH 0 n 6 run 290547
MitM_CTL RWL_mod sim 1001 maxT 1000 H 2 mod 3 n 1 run 67506
chr_LRUH 10 chr_H 8 MitM_CTL NG maxT 10000 NG_n 2 run 1577979
chr_LRUH 6 chr_H 6 MitM_CTL NG maxT 3000 NG_n 2 run 1604533
MitM_CTL RWL_mod sim 1001 maxT 3000 H 4 mod 4 n 6 run 10012948
MitM_CTL CPS_LRU sim 1001 maxT 1000 LRUH 8 H 0 tH 0 n 4 run 526822
MitM_CTL CPS_LRU sim 1001 maxT 1000 LRUH 16 H 1 tH 1 n 1 run 34821
MitM_CTL CPS_LRU sim 1001 maxT 1000 LRUH 6 H 0 tH 1 n 3 run 356375
MitM_CTL RWL_mod sim 1001 maxT 1000 H 2 mod 3 n 20 run 1970422
MitM_CTL RWL_mod sim 1001 maxT 1000 H 6 mod 3 n 1 run 443339
MitM_CTL CPS_LRU sim 1001 maxT 10000 LRUH 3 H 0 tH 1 n 2 run 518824
MitM_CTL RWL_mod sim 1001 maxT 10000 H 2 mod 2 n 1 run 61865
MitM_CTL CPS_LRU sim 1001 maxT 3000 LRUH 6 H 1 tH 1 n 2 run 288834Phase 2 stage 3 was not computed with mxdys' main.exe, but rather with lr_enum_continue from busy-beaver for 1 million steps; the command is provided below:
lr_enum_continue ./in.txt 100000 ./halt.txt ./inf.txt ./unknown.txt "" falsePhase 2 stage 4:
chr_LRUH 0 chr_H 0 MitM_CTL NG maxT 3000 NG_n 2 run 202520
chr_LRUH 0 chr_H 0 MitM_CTL NG maxT 3000 NG_n 1 run 559013
MitM_CTL RWL_mod sim 1001 maxT 3000 H 1 mod 4 n 1 run 1584
chr_asth 0 chr_LRUH 1 chr_H 1 MitM_CTL NG maxT 10000 NG_n 1 run 148544
chr_LRUH 0 chr_H 0 MitM_CTL NG maxT 100000 NG_n 1 run 812666
chr_asth 0 chr_LRUH 48 chr_H 48 MitM_CTL NG maxT 10000 NG_n 3 run 2043171
MitM_CTL RWL_mod sim 1001 maxT 1000 H 4 mod 2 n 1 run 102052Phase 2 stage 5 (no TM count per decider is available at this time):
MitM_CTL CPS_LRU sim 1001 maxT 3000 LRUH 6 H 0 tH 1 n 10 run
MitM_CTL CPS_LRU sim 1001 maxT 30000 LRUH 16 H 1 tH 1 n 1 run
MitM_CTL RWL_mod sim 1001 maxT 1000 H 3 mod 6 n 2 run
chr_LRUH 2 chr_H 0 MitM_CTL NG maxT 10000 NG_n 3 run
MitM_CTL RWL_mod sim 1001 maxT 3000 H 4 mod 5 n 2 run
MitM_CTL CPS_LRU sim 1001 maxT 30000 LRUH 3 H 1 tH 0 n 2 run
MitM_CTL RWL_mod sim 1001 maxT 3000 H 3 mod 1 n 1 run
MitM_CTL RWL_mod sim 1001 maxT 1000 H 2 mod 3 n 2 run
chr_LRUH 0 chr_H 0 MitM_CTL NG maxT 100000 NG_n 5 run
MitM_CTL RWL_mod sim 1001 maxT 10000 H 4 mod 4 n 2 run
MitM_CTL CPS_LRU sim 1001 maxT 3000 LRUH 6 H 0 tH 1 n 3 run
MitM_CTL CPS_LRU sim 1001 maxT 1000 LRUH 16 H 1 tH 0 n 1 run
MitM_CTL RWL_mod sim 1001 maxT 10000 H 6 mod 3 n 1 run
chr_LRUH 4 chr_H 2 MitM_CTL NG maxT 30000 NG_n 3 run
chr_LRUH 16 chr_H 12 MitM_CTL NG maxT 30000 NG_n 2 run
MitM_CTL CPS_LRU sim 1001 maxT 1000 LRUH 8 H 2 tH 1 n 2 run
chr_asth 0 chr_LRUH 12 chr_H 12 MitM_CTL NG maxT 10000 NG_n 3 run
MitM_CTL CPS_LRU sim 1001 maxT 3000 LRUH 16 H 1 tH 0 n 6 run
MitM_CTL CPS_LRU sim 1001 maxT 100000 LRUH 16 H 0 tH 0 n 1 run
chr_LRUH 6 chr_H 2 MitM_CTL NG maxT 10000 NG_n 2 run
MitM_CTL CPS_LRU sim 1001 maxT 1000 LRUH 3 H 1 tH 0 n 2 run
chr_LRUH 2 chr_H 0 MitM_CTL NG maxT 3000 NG_n 1 run
MitM_CTL RWL_mod sim 1001 maxT 3000 H 2 mod 3 n 1 run
chr_LRUH 3 chr_H 1 MitM_CTL NG maxT 100000 NG_n 2 run
MitM_CTL CPS_LRU sim 1001 maxT 3000 LRUH 6 H 1 tH 0 n 4 run
MitM_CTL RWL_mod sim 1001 maxT 3000 H 2 mod 2 n 2 run
MitM_CTL RWL_mod sim 1001 maxT 3000 H 4 mod 4 n 1 run
MitM_CTL CPS_LRU sim 1001 maxT 100000 LRUH 4 H 2 tH 0 n 1 run
chr_LRUH 4 chr_H 0 MitM_CTL NG maxT 1000 NG_n 2 run
MitM_CTL RWL_mod sim 1001 maxT 30000 H 2 mod 1 n 1 run
MitM_CTL RWL_mod sim 1001 maxT 3000 H 3 mod 6 n 1 run
chr_asth 0 chr_LRUH 8 chr_H 8 MitM_CTL NG maxT 10000 NG_n 2 run
chr_asth 0 chr_LRUH 60 chr_H 60 MitM_CTL NG maxT 30000 NG_n 2 run
MitM_CTL CPS_LRU sim 1001 maxT 10000 LRUH 3 H 0 tH 0 n 1 run
MitM_CTL RWL_mod sim 1001 maxT 30000 H 3 mod 2 n 1 run
chr_LRUH 4 chr_H 4 MitM_CTL NG maxT 3000 NG_n 1 run
MitM_CTL CPS_LRU sim 1001 maxT 3000 LRUH 4 H 1 tH 1 n 2 run
MitM_CTL RWL_mod sim 1001 maxT 1000 H 3 mod 3 n 1 run
chr_asth 0 chr_LRUH 4 chr_H 4 MitM_CTL NG maxT 3000 NG_n 2 runPhase 2 stage 6 (in progress):
python "+str(pl.Path("../../Code/Enumerate.py"))+" --infile="+str(pl.Path("./in.txt"))+" --outfile="+str(pl.Path("./out.pb"))+" --max-loops=990_000 --tape-limit=9_900 --no-steps --time="+str(time)+" --recursive --exp-linear-rules  --lin-steps=0 --no-ctl --save-freq=10_000XnoobSpeakable is running Enumerate.py with a 0.15s/TM time limit, Lúkos is running it with a 0.75s/TM time limit.