I made a post titled Encoding Secret Numbers only recently on the 8th of May 2025 in which I looked at how the Heinz number and Gray Code could be used to encrypt a number. An article I read today suggested another encryption method that is more arcane than the two previously mentioned. The article states that every non-negative integer n can be written as:$$ \binom{a}{1} + \binom{b}{2} + \binom{c}{3} \text{ where } a \leq b < c $$The article goes on to say that:
You can find \(a\), \(b\) and \(c\) much as you would find the representation in many other number systems: first find the largest possible \(c\), then the largest possible \(b \) for what’s left, and then the remainder is \(a\).
In order to find \(c\), we start with the observation that the binomial coefficient C(\(k\), 3) is less than \(k^3\)/6 and so \(c\) is less than the cube root of \(6n\). We can use this as an initial lower bound on \(c\) then search incrementally. If we wanted to be more efficient, we could do some sort of binary search.
Figure 1 shows the Python code to find \(a\), \(b\) and \(c\):
|  | 
| Figure 1: permalink | 
In the article the term \( \textbf{binomial number system} \) is used to describe this approach. Applying the code to the number associated with my diurnal age today (27823) we find that \(a=12\), \(b=14\) and \(c=56\) so that:$$27823= \binom{12}{1} + \binom{14}{2} + \binom{56}{3} $$This encrypted version of 27823 could be represented as 12. 14. 56 with the dots being added to prevent possible ambiguity although commas or dashes or whatever could be used as well. The encrypted number has the same number of digits as the number being encrypted.
Unless someone knew about this "binomial number system" it would be impossible to guess what number was being encrypted. Once the binomial "key" is applied however, we find that:$$12. \,14. \, \,56 \rightarrow 12 + 91 + 27720 = 27823$$What about the number 1? Well, in that case, we \(a=b=0\) and \(c=3\) because:$$1=\binom{0}{1}+\binom{0}{2}+\binom{3}{3} \rightarrow 0. \, 0. \, 3$$What about the number 2. In this case we have \(a=0\), \(b=2\) and \(c=3\) so that:$$2=\binom{0}{1}+\binom{2}{2}+\binom{3}{3} \rightarrow 0. \, 2. \, 3$$Of course for the number 3 we have \(a=1\), \(b=2\) and \(c=3\) so that:$$3=\binom{1}{1}+\binom{2}{2}+\binom{3}{3} \rightarrow 1. \, 2. \, 3$$Interestingly, the final comment that the author of the referenced article makes is that "you could use any number of binomial terms, not just three". One binomial term C(\(a\), 1) just corresponds to the positive integers since:$$ \binom{a}{1}=a$$Two binomial terms work as well of course. For example:$$\binom{2}{1}+\binom{5}{2}=2+10 =12$$Notice that this representation of 12 (and any other number) is unique because even though:$$ \binom{6}{1}+\binom{4}{3}=6 + 6=12$$this representation contravenes the rule that \(a \leq b\) since \(a=6\) and \(b=4\). All very interesting.
No comments:
Post a Comment