Yadryara, here is a partial worked example run for the 'oul' program in a simple case: ./oul -n 12 3. Specifying "-n" means "no database", so we start with an assumed upper limit of
data:image/s3,"s3://crabby-images/13881/1388189eac1565900272bd4490fbd82a5d45b9f6" alt="$\infty$ $\infty$"
, and attempt to find
data:image/s3,"s3://crabby-images/15107/15107c0763424d51473feaff73525052d051885f" alt="$T(6,3)$ $T(6,3)$"
.
We initialise the allocated multiple and outstanding
data:image/s3,"s3://crabby-images/a0ee2/a0ee28f30c3007e9b119faf4445c5367b5d22f18" alt="$\tau$ $\tau$"
values:
data:image/s3,"s3://crabby-images/d87a3/d87a3e36d1baef7c780885c61c73f81e9ded3cc6" alt="$q_i = 1, t_i = 12 \forall i: 0 \le i \le 2$ $q_i = 1, t_i = 12 \forall i: 0 \le i \le 2$"
.
First job is to find fixed primes
data:image/s3,"s3://crabby-images/3230c/3230c50ff2a0cb6d97e52c800f386bf3dc0effd0" alt="$p \le k$ $p \le k$"
, in this case 2 and 3.
Recursion level 0: possible arrangements for powers of 2 over the three elements are precalculated. We initially try the first of those, and set
data:image/s3,"s3://crabby-images/c3fba/c3fbaa761f61b36f51edece34cf0761dd36301a5" alt="$q_0 = 2^2, t_0 = 4; q_2 = 2, t_2 = 6$ $q_0 = 2^2, t_0 = 4; q_2 = 2, t_2 = 6$"
.
Recursion level 1: possible arrangements for powers of 3 are similarly precalculated. We cannot use any of
data:image/s3,"s3://crabby-images/5aad7/5aad7914bb92550725b8a470feb219efd7c58a53" alt="$3^2, 3^5, 3^{11}$ $3^2, 3^5, 3^{11}$"
in
data:image/s3,"s3://crabby-images/31fbe/31fbedee7dca539aea1fce671e90648380e1e874" alt="$v_0$ $v_0$"
, so we next try assigning
data:image/s3,"s3://crabby-images/896cd/896cd0095c3d70e0342848eb6c3dabd731ea5c25" alt="$3^3$ $3^3$"
. But that leaves
data:image/s3,"s3://crabby-images/a6931/a6931d4948fd578e224a2f511e4141e05dd55eac" alt="$t_0 = 1$ $t_0 = 1$"
, so we check the case
data:image/s3,"s3://crabby-images/11ad8/11ad8859d64393bbcee65cb220d70dd8778d174b" alt="$v_0 = 108$ $v_0 = 108$"
(which fails), and immediately continue to the case
data:image/s3,"s3://crabby-images/9ac2f/9ac2fd8259b5b11b178c727ca65fa172c6be84f9" alt="$3^1$ $3^1$"
, so we now set
data:image/s3,"s3://crabby-images/8dfb7/8dfb77830aa43157ce328c6f55ec96d2ff02662e" alt="$q_0 = 2^2 \cdot 3, t_0 = 2$ $q_0 = 2^2 \cdot 3, t_0 = 2$"
.
Fixed primes are now allocated, so we proceed to the main
recurse().
Recursion level 2: we first decide which
data:image/s3,"s3://crabby-images/c36e4/c36e45e261a2be888d4dd63fa32fdef90ce4a1f1" alt="$v_i$ $v_i$"
to allocate to, by calling
best_v(). This chooses
data:image/s3,"s3://crabby-images/b4f76/b4f762b00c9c141f495ca864246ee9d0f103406a" alt="$v_1$ $v_1$"
, since
data:image/s3,"s3://crabby-images/466c7/466c7624b2ae8f31bdfbbeb210001d663ad0d2fd" alt="$t_1 = 12$ $t_1 = 12$"
is the highest remaining multiple of the highest odd factor dividing
data:image/s3,"s3://crabby-images/e13e4/e13e420d4089488e05bb4b057b6e30bb316de167" alt="$n$ $n$"
. We now loop over the powers (2, 5, 11) that can satisfy the highest odd factor dividing
data:image/s3,"s3://crabby-images/ef00e/ef00efd60453d5b2c26fbfdbd0a447b215dd6672" alt="$t_1$ $t_1$"
, starting with 2, and then start looping over primes
data:image/s3,"s3://crabby-images/50b30/50b30c2f74ff08fd40cbe9cf99367ddc69925b59" alt="$p$ $p$"
starting with
data:image/s3,"s3://crabby-images/ce9f5/ce9f501b7998e689ef6356be6ef60aaf765e909e" alt="$p=5$ $p=5$"
, the first prime after the fixed primes used above. So we set
data:image/s3,"s3://crabby-images/3bb42/3bb42a3794629b64161e52094f56343c07e21465" alt="$q_1 = 5, t_1 = 4$ $q_1 = 5, t_1 = 4$"
and recurse.
Recursion level 3:
best_v() chooses
data:image/s3,"s3://crabby-images/77ec1/77ec163822855fcc6c16336b9eb6ceafb011a7cb" alt="$v_2$ $v_2$"
as the next to allocate to, since
data:image/s3,"s3://crabby-images/674d5/674d5e7891de9ae97ef1f7c2e56e722b94c51b0d" alt="$t_2 = 6$ $t_2 = 6$"
. We now loop over the powers (2, 5) that can satisfy the highest odd factor dividing
data:image/s3,"s3://crabby-images/f58f1/f58f10244fe1f9627e8585aa4346ea6d107758c5" alt="$t_2$ $t_2$"
, starting with 2, and then start looping over primes
data:image/s3,"s3://crabby-images/50b30/50b30c2f74ff08fd40cbe9cf99367ddc69925b59" alt="$p$ $p$"
starting with
data:image/s3,"s3://crabby-images/ce9f5/ce9f501b7998e689ef6356be6ef60aaf765e909e" alt="$p=5$ $p=5$"
. We see that
data:image/s3,"s3://crabby-images/ce9f5/ce9f501b7998e689ef6356be6ef60aaf765e909e" alt="$p=5$ $p=5$"
has already been used (and since
data:image/s3,"s3://crabby-images/3d7ad/3d7ad71e039d9f5d38b1024ace34105ff4ed9e7b" alt="$p > k$ $p > k$"
, it cannot be used a second time), so advance to
data:image/s3,"s3://crabby-images/175ce/175ce500366d76a959547360d21fe975ceb5d2f4" alt="$p=7$ $p=7$"
. So we set
data:image/s3,"s3://crabby-images/8b9b2/8b9b2655dc78269df9634d7c12ebda8aadbfa1eb" alt="$q_2 = 98, t_2 = 2$ $q_2 = 98, t_2 = 2$"
and recurse.
Recursion level 4:
best_v() returns nothing, since all
data:image/s3,"s3://crabby-images/bdc01/bdc01e0e01fea5f591c89198e023deae69275c46" alt="$t_i$ $t_i$"
are now powers of 2, so we will call
walk_v() and return.
walk_v() collects the
data:image/s3,"s3://crabby-images/10d0e/10d0e586d0d16b7300f51298e6dedb515fbd0474" alt="$q_i$ $q_i$"
and
data:image/s3,"s3://crabby-images/bdc01/bdc01e0e01fea5f591c89198e023deae69275c46" alt="$t_i$ $t_i$"
, uses CRT to calculate
data:image/s3,"s3://crabby-images/d6ea4/d6ea45308d199c3e9b6afd221ff0d84b263ebdca" alt="$m: \forall i: m + i \equiv 0 \pmod{q_i}$ $m: \forall i: m + i \equiv 0 \pmod{q_i}$"
, finds
data:image/s3,"s3://crabby-images/b5b70/b5b70685c63ef8d6e125dd357bfd8aa037738460" alt="$a_q$ $a_q$"
as the least common multiple of the
data:image/s3,"s3://crabby-images/10d0e/10d0e586d0d16b7300f51298e6dedb515fbd0474" alt="$q_i$ $q_i$"
, calculates
data:image/s3,"s3://crabby-images/c3d9a/c3d9a0bdec2cde00eb3c81f9d61798a6265d4bb2" alt="$Q_i = \frac{a_q}{q_i}$ $Q_i = \frac{a_q}{q_i}$"
and
data:image/s3,"s3://crabby-images/cf2b3/cf2b32e9f59f4dbeb0cd7137d5eca4be360aa5cb" alt="$o_i = \frac{m+i}{q_i}$ $o_i = \frac{m+i}{q_i}$"
.
We have no limit at this point, so we start an infinite loop
data:image/s3,"s3://crabby-images/d5c9b/d5c9b1aeec8388b75a33adc7d6643fe345f61520" alt="$x \in {0, 1, 2, ...}$ $x \in {0, 1, 2, ...}$"
such that
data:image/s3,"s3://crabby-images/755ee/755ee1e7bdf44933b981b42ba838eadfd81442fa" alt="$v_i = q_i(x \cdot Q_i + o_i)$ $v_i = q_i(x \cdot Q_i + o_i)$"
. On each iteration of the loop, we first check that
data:image/s3,"s3://crabby-images/733b1/733b166eb776c2344f5aa820b9b89b7ca662f35e" alt="$\forall i: \gcd(x \cdot Q_i + o_i, q_i) = 1$ $\forall i: \gcd(x \cdot Q_i + o_i, q_i) = 1$"
, then
data:image/s3,"s3://crabby-images/7fe13/7fe130bcffab35098a68525a1f676f3d4f202b33" alt="$\forall i: \tau(x \cdot Q_i + o_i) = t_i$ $\forall i: \tau(x \cdot Q_i + o_i) = t_i$"
. In this case we get a match with
data:image/s3,"s3://crabby-images/66a0e/66a0ed9b0802efc15a8246f2da4f0c4fd9fc23eb" alt="$x=59$ $x=59$"
, yielding
data:image/s3,"s3://crabby-images/bf702/bf70265441b88ea2221bae43b364e068c65603d1" alt="$(870924 = 2^2 \cdot 3 \cdot 72577, 5^2 \cdot 11 \cdot 3167, 2 \cdot 7^2 \cdot 8887)$ $(870924 = 2^2 \cdot 3 \cdot 72577, 5^2 \cdot 11 \cdot 3167, 2 \cdot 7^2 \cdot 8887)$"
. So we log 870924 as a candidate and return.
Recursion level 3: we now have a limit, so we calculate what the greatest prime we need to check is: in this case that's
data:image/s3,"s3://crabby-images/3112c/3112cc61b0c052f3544d17dd2546c088e664e0c5" alt="$\lfloor \sqrt{\frac{870926}{10}} \rfloor = 275$ $\lfloor \sqrt{\frac{870926}{10}} \rfloor = 275$"
. Now we try the next prime
data:image/s3,"s3://crabby-images/75525/75525c03687b94ca30dd217c44e721386d009af3" alt="$p=11$ $p=11$"
, and call
walk_v() again to find 678324, further reducing our limit
And so we continue until all the recursions complete. By now our best candidate is 1274, and we have checked every factorization that could possibly give a smaller solution, so we declare
data:image/s3,"s3://crabby-images/d38d9/d38d9f146a4ff04213543d4899ea90eca431bdb0" alt="$T(6,3) = 1274$ $T(6,3) = 1274$"
.
I hope this makes the approach clear.