Modular Arithmetic
The set of integers in mathematics are denoted with double struck Z.
data:image/s3,"s3://crabby-images/9f0f3/9f0f377fae56d7688577af017c20b29643664142" alt="image.png"
It stands for "zahlen" which means numbers in German. In , counting from 0 to 10 are simply
data:image/s3,"s3://crabby-images/181a4/181a43ce69763b51a972e44087106eb7cc687438" alt="image.png"
Meanwhile the set of integers modulo is denoted by
data:image/s3,"s3://crabby-images/78e7e/78e7e1a59214a6a303dcbe32bc2a1ba05069a512" alt="image.png"
and counting 1 to 10 in works as follows
data:image/s3,"s3://crabby-images/4d466/4d4662b2ff8a0e9be090f35727aa6f0425d29b6f" alt="image.png"
This sequence repeats every 6 numbers starting from 0. The modulo operator
data:image/s3,"s3://crabby-images/65985/65985274c67caf1a61b58ed806ab89670384b4d9" alt="image.png"
while returns the remainder of divided by
, also yields the
-th number in the sequence of integers modulo
(
). The 10th number in the sequence of integers modulo 6
data:image/s3,"s3://crabby-images/9bad1/9bad1b82e693d4846f8146d4559262145a6d4629" alt="image.png"
is also the remainder of 10 divided by 6.
Periodicity
Two integers a,b are in the same equivalence class modulo n if both integers returns the same remainder after division by n. The -th and
-th number in the sequence of
will be the same.
Take 10 and 16 modulo 6 for example
data:image/s3,"s3://crabby-images/3f472/3f47265e50356078fc8f5efac501fd9ff9ee247f" alt="image.png"
In the sequence of , integers within the same equivalence class are the same.
data:image/s3,"s3://crabby-images/ba803/ba80362c4be7f47fe160992bfcb270444e61eff6" alt="image.png"
In congruence relations, this can be written as follows
data:image/s3,"s3://crabby-images/c4b53/c4b532e252f7962a9c6614212e2b89b999489e50" alt="image.png"
stating that a is congruent to b modulo n. Two integers are said to be congruent modulo n if they returns the same remainder when divided by n. With modulo operator, this will be
data:image/s3,"s3://crabby-images/27541/27541bf5cf21ab33b8be3c5b5da438c7fa92f9b4" alt="image.png"
Notice the repeating nature of sequence. For example n=6
data:image/s3,"s3://crabby-images/e2c88/e2c88bb18a0c7081b2c55b3195728a7739cfe759" alt="image.png"
Any term is the same as the n-th next term.
data:image/s3,"s3://crabby-images/20227/20227753110d9da90cc31fe3122a402e443fc03c" alt="image.png"
This can be generalized further given any integer q
data:image/s3,"s3://crabby-images/310cf/310cfa3df098f95093a8635cbc37fd1adc5265e3" alt="image.png"
showing that and
are congruent modulo
.
Compare it to sequence
data:image/s3,"s3://crabby-images/5abf4/5abf4ce63758c5ac95bb32827f64c91bec244f61" alt="image.png"
The only scenario where
data:image/s3,"s3://crabby-images/90131/901317ec40f85d9488e9c0965ab648246b7dac77" alt="image.png"
is when (if and only if?) .
Quotient Remainder Theorem
Division between any two integers does not always yield another integer. Division between 22 and 7
data:image/s3,"s3://crabby-images/e4ee7/e4ee7bbb962848cea337e8f7e4709de48f74aa65" alt="image.png"
left a remainder of 1. Quotient Remainder Theorem states that given any integer a and a natural number n, there exist another two integers q and r such that
data:image/s3,"s3://crabby-images/39a3f/39a3fefd6d1159ff86f45d977081952168b77fa4" alt="image.png"
this can be rewritten with modulo operator into
data:image/s3,"s3://crabby-images/9abc5/9abc5775b0303def04f13821b76174b05a382b19" alt="image.png"
and the division above can be rewritten algebraically into
data:image/s3,"s3://crabby-images/c1b19/c1b19026f4e08327ff8cf579569f6bb28af0c151" alt="image.png"
or with modulo operator
data:image/s3,"s3://crabby-images/6246c/6246c40e4775fc89303f44a42132c55d138f3664" alt="image.png"
This is used to better demonstrate
Modular Addition
Given two integers and
, a positive integer n, and
data:image/s3,"s3://crabby-images/ed591/ed591a71ee473045da91bcd1669df5f6eeb56052" alt="image.png"
This can be algebraically written into
data:image/s3,"s3://crabby-images/edfe9/edfe94bcd0a87ce2428fb67ba668db83f8e1ea3f" alt="image.png"
with integers and
. Add together
and
gives
data:image/s3,"s3://crabby-images/11160/1116098f51053984c1f409c49c5b4c40c268a364" alt="image.png"
Take modulo on both sides
data:image/s3,"s3://crabby-images/e8776/e8776c9f67460ab5a4217c931badfb43042b0c9e" alt="image.png"
Because
data:image/s3,"s3://crabby-images/1fc6d/1fc6d4315ffa302d6c39b25537f0b96d95f89274" alt="image.png"
and
data:image/s3,"s3://crabby-images/2092a/2092ad88b0ce737e616fa86c93f32bcdc0f5196b" alt="image.png"
we can drop out from the equation which results into a more tidy equation
data:image/s3,"s3://crabby-images/19f27/19f27b3037ffbb71e8c83564b737b1065266be68" alt="image.png"
Plugging back the definitions of and
gives
data:image/s3,"s3://crabby-images/f2dfb/f2dfb69d25645aeb1740578a1b582ede89ffa78f" alt="image.png"
The equation above can be used as a tool to simplify additions under modulo operator. For example
Substituting gives similar equation for subtraction
data:image/s3,"s3://crabby-images/e0c22/e0c22cea9c15cba73d87ee9d95d89db96920e362" alt="image.png"
In case of negative integers inside modulo operator,
data:image/s3,"s3://crabby-images/58644/58644b5ede6772e38ed92d7156beff9d42e45602" alt="image.png"
Modular Multiplication
Similar to addition, start with two integers and
, a positive integer n, and
data:image/s3,"s3://crabby-images/ed591/ed591a71ee473045da91bcd1669df5f6eeb56052" alt="image.png"
This can be algebraically written into
data:image/s3,"s3://crabby-images/edfe9/edfe94bcd0a87ce2428fb67ba668db83f8e1ea3f" alt="image.png"
multiplying and
gives
data:image/s3,"s3://crabby-images/5f41d/5f41d5886ed40fb1fb60485283fc2ceb208659b9" alt="image.png"
take modulo on both sides
data:image/s3,"s3://crabby-images/17741/177410959e13bdf845f4f49311a826041522bfd2" alt="image.png"
removing inside the modulo gives
data:image/s3,"s3://crabby-images/9224f/9224f331b444ba40cdac5fab9ce05f2395e8051d" alt="image.png"
Plugging back the definitions of and
gives
data:image/s3,"s3://crabby-images/a2e63/a2e633274aa495bd5bd682ed3ab4f3c37edd5447" alt="image.png"
The equation above can be used as a tool to simplify multiplications under modulo operator similar to additions under modulo operator. For example 190 squared divided by 7
which is easier to evaluate this way. It would've taken longer to first find out that
data:image/s3,"s3://crabby-images/1179f/1179fe42387cfbf21839fb44c71f4a4365a4a8a7" alt="image.png"
Sidenote :
-Some programming language like Python uses percent sign (%) for modulo operator. In excel, modulo operator is written with '=mod([number];[divisor])'
-I am very sorry for night mode readers as the latex rendered are transparent.
-There's more to modular arithmetic but i'm going to leave it here. I might add more on my next posts.