Skip to content

Proving Collatz Orbits

Another example from elementary number theory

Here, we discuss another example, based on the famous Collatz conjecture. This thing isn't quite suitable as written for a real-life M3 instance, since Binius doesn't have natural-number-valued datatypes (rather, everything is over binary tower fields). On the other hand, this is close to something that could be used, and conveys a clear idea.

The Collatz conjecture would have it that for any starting positive integer xNx \in \mathbb{N}, the procedure which sends:

x{x2if x is even3x+1if x is odd\begin{equation*} x \mapsto \begin{cases} \frac{x}{2} & \text{if $x$ is even} \\ 3 \cdot x + 1 & \text{if $x$ is odd} \end{cases} \end{equation*}

eventually reaches 1. We're going to sketch an M3-based proof that some particular public number, say xx, satisfies the hypothesis of the Collatz conjecture (that is, its orbit under the Collatz function eventually terminates at 1). For example, if we start with the number 6, we will end up with the sequence 6, 3, 10, 5, 16, 8, 4, 2, 1—which ends at 1, sure enough.

The Instance Specification

Here, we sketch the appropriate M3 instance, generally taking for granted the definition of M3. Our statement looks like:

For example, let's pick 6 as our number.

Channels

I, the verifier, am going to set up a single channel, with a simple positive-integer value (just like in the previous toy example).

Boundary Conditions

As my boundary condition, I am going to push the initial statement and pull the terminal number 1.

Upon doing this, I wind up with the following initial channel state:

               /¯\¯¯¯¯¯¯¯¯¯¯¯\
    PUSH      :   :           :    PULL
 ---------->  |   |  channel  | ---------->
      6       :   :           :      1
               \_/___________/

Tables

I'm now going to set up two tables, let's say TevenT_{\text{even}} and ToddT_{\text{odd}}.

The first table, TevenT_{\text{even}}, will have two columns:

Even Number EEHalf HH

Both will be positive-integer-valued. The second, ToddT_{\text{odd}}, will have three columns:

Odd Number OORounded-Down Half RROutput PP

Constraints

You probably see where this is going. We now need to specify what our constraints are going to be.

  • For TevenT_{\text{even}}, we are going to require that E=2HE = 2 \cdot H (as natural numbers). Note that this has the effect of ensuring that EE is even.
  • For ToddT_{\text{odd}}, we are going to have two constraints: first, O=2R+1O = 2 \cdot R + 1 (this ensures that OO is odd) and finally that P=3O+1P = 3 \cdot O + 1.

Putting the above two rules together, we see that for each input on the left, we are getting the output of the Collatz function on the right.

Flushing rules

I, the verifier, am going to flush in the following way:

  • Pull (E)(E). The even input gets pulled.
  • Push (H)(H). We push the result, half of the even input.
  • Pull (O)(O). The odd input gets pulled.
  • Push (P)(P). We push the result of that odd thing under the Collatz function.

The Claim

The claim here is as before: if you, the prover, manage to populate the above tables in such a way that my channel becomes balanced, then I, the verifier, become convinced that 6 terminates at 1 under the Collatz function.

We begin in the obvious way. The only way that you, the prover, can hope to nullify my initial push of 6 is to append some row containing 6 in the left-hand column. We won't be able to do this on the odd table (because of the constraint). So we go for the even table:

Even Number EEHalf HH
63

Now, my channel state has been affected:

               /¯\¯¯¯¯¯¯¯¯¯¯¯\
    PUSH      :   :           :    PULL
 ---------->  |   |  channel  | ---------->
      3       :   :           :      1
               \_/___________/

The pattern is clear: you, the prover, need to keep appending rows with the "outstanding liability" in the leftmost cell. At the very end, your table state will look like:

Even Number EEHalf HH
63
105
168
84
42
21
Odd Number OORounded-Down Half RROutput PP
3110
5216

At this point my channel has been balanced.

Some Remarks

It should be intuitively clear that this thing is correct and secure. (In particular, the only way to make this thing balance is by actually knowing the Collatz orbit.)

This M3 sketch illustrates something interesting: we let the choice of progression rule become completely nondeterministic, put on the prover. That is, we let the prover deal with the problem of deciding which case we're in: whether we're at an even number, which we must halve, or an odd number, which we must triple and add one to.

If we had tried to attack the Collatz problem using a more classical arithmetization scheme—like AIR—then, most likely, we would have had to write down two polynomial constraints (or perhaps more), and then select between those two on the basis of parity. In particular, we would have been doing the work of both Collatz transition functions at every step. Above, on the other hand, we were able to "break apart" the two different algebraic operations into separate tables, which had just one constraint each (and no selectors!). The key part was to link those two tables together in a secure way; we achieved that using flushing rules and our channel.

We didn't need a global execution trace to orchestrate these individual, primitive function calls. Rather, each primitive operation had its own table, and we just needed to link them with channels.