21466
Comment:
|
30604
|
Deletions are marked like this. | Additions are marked like this. |
Line 5: | Line 5: |
This page was first created at Sage Days 103, 7-10 August 2019 by Sarah Arpin, Catalina Camacho-Navarro, Holly Paige Chaos, Amy Feaver, Eva Goedhart, Rebecca Lauren Miller, Alexis Newton, and Nandita Sahajpal. We would also like to acknowledge Katherine Stange, who allowed us to use code from her cryptography course as a starting point for many of these interacts. Dr. Stange's original code and course page can be found at http://crypto.katestange.net/ |
This page was first created at Sage Days 103, 7-9 August 2019 by Sarah Arpin, Catalina Camacho-Navarro, Holly Paige Chaos, Amy Feaver, Eva Goedhart, Rebecca Lauren Miller, Alexis Newton, and Nandita Sahajpal. Text edited by Holly Paige Chaos, Amy Feaver, Eva Goedhart, and Alexis Newton. This project was led by Amy Feaver. We acknowledge Katherine Stange, who allowed us to use code from her cryptography course as a starting point for many of these interacts. Dr. Stange's original code and course page can be found at http://crypto.katestange.net/ |
Line 18: | Line 18: |
The shift cipher is a classical cryptosystem that takes plaintext and shifts it through the alphabet by a given number of letters. For example, a shift of 2 would replace all A's with C's, all B's with D's, etc. When the end of the alphabet is reached, the letters are shifted cyclically back to the beginning. Thus, a shift of 2 would replace Y's with A's and Z's with B's. === Shift Cipher Encryption === |
|
Line 20: | Line 24: |
The shift cipher is a classical cryptosystem that takes plaintext and shifts it through the alphabet by a given number of letters. -EG For example, a shift of 2 would replace all A's with C's, all B's with D's, etc. When you reach the end of the alphabet, the letters are shifted cyclically back to the beginning. Thus, a shift of 2 would replace Y's with A's and Z's with B's. -AF === Shift Cipher Encryption === |
You can use this interact to encrypt a message with a shift cipher. |
Line 28: | Line 28: |
print "Put your message in between the provided quotes (with no additional quotes or apostrophes!), and select your desired shift: " | pretty_print(html("<h1>Shift Cipher Encryptor</h1>")) print "Put your message inside the provided quotes (with no additional quotes or apostrophes!), and select your desired shift: " |
Line 39: | Line 40: |
Line 40: | Line 42: |
If you know that your message was encrypted using a shift cipher, you can use the known shift value to decrypt. If this is not known, brute force can be used to get 26 possible decrypted messages. |
by Sarah Arpin, Alexis Newton If you know that your message was encrypted using a shift cipher, you can use the known shift value to decrypt. If this is not known, brute force can be used to get 26 possible decrypted messages. The chi-squared function ranks the brute force results by likelihood according to letter frequency. |
Line 46: | Line 49: |
pretty_print(html("<h1>Shift Cipher Decryptor</h1>")) | |
Line 51: | Line 55: |
decrypt = S.deciphering(shift_by,ciphertext) | decrypt = S.deciphering(shift_by%26,ciphertext) |
Line 63: | Line 67: |
An affine cipher combines the idea of a shift cipher with a multiplicative cipher. In this particular example, we map consecutive letters of the alphabet to consecutive numbers, starting with A=0 (you can also do this cipher differently, and starting with A=1). The user selects two values, a and b. The value a is the multiplier and must be relatively prime to 26 in order to guarantee that each letter is encoded uniquely. The value b is the addend. Each letter's value is multiplied by a, and the product is added to b. This is then replaced with a new letter, corresponding to the result modulo 26. === Affine Cipher Encryption === |
|
Line 65: | Line 74: |
An affine cipher combines the idea of a shift cipher with a multiplicative cipher. In this particular example, we map consecutive letters of the alphabet to consecutive numbers, starting with A=0 (you can also do this cipher differently, and starting with A=1). The user selects two values, a and b. The value a is the multiplier and must be relatively prime to 26 in order to guarantee that each letter is encoded uniquely. The value b is the addend. Each letter's value is multiplied by a, and the product is added to b. This is then replaced with a new letter, corresponding to the result modulo 26. -AF | You can use this interact to encrypt a message with the affine cipher. Notice that the only choices for a can be numbers that are relatively prime to 26. This cipher will encipher a letter m of your message as a*m + b. |
Line 69: | Line 78: |
print "Put your message in between the provided quotes (with no additional quotes or apostrophes!), and select your desired a,b: " print "Notice that the only choices for a can be numbers that are relatively prime to 26" print "This cipher will encipher the letters m of your message as a*m + b" |
pretty_print(html("<h1>Affine Cipher Encryptor</h1>")) print "Put your message in between the provided quotes (with no additional quotes or apostrophes!), and select your desired a and b: " |
Line 82: | Line 91: |
=== Affine Cipher Decryption === by Sarah Arpin, Alexis Newton If you know that your message was encrypted using an affine cipher, you can use the known a and b values to decrypt. If these are not known, brute force can be used to get a list of possible decrypted messages. The chi-squared function ranks these results by likelihood according to letter frequency. {{{#!sagecell #Last edited 8/7/2019 3:01pm pretty_print(html("<h1>Affine Cipher Decryptor</h1>")) print "Enter the encrypted text in quotes, and enter a guess for the a and b:" @interact def shift_decrypt(text = input_box('"XNSILPCVA"'), a=[1,3,5,7,9,11,15,17,19,21,23,25], b =[0..25]): S = AffineCryptosystem(AlphabeticStrings()) ciphertext = S.encoding(text) decrypt = S.deciphering(a,b,ciphertext) print "If the a =", a, "and the b =",b, ", then the original message was:" print decrypt decrypt = S.brute_force(ciphertext,ranking="none") print "\nThese are the possibilities for the plaintext:" print decrypt decrypt = S.brute_force(ciphertext,ranking = "chisquare")[:10] print "\nThese are the top 10 possibilities ranked by likelihood with the chi-squared function:" print decrypt }}} |
|
Line 85: | Line 120: |
A simple cipher to encrypt messages in which each letter is assigned to another letter. Brute force or frequency analysis can be used to decrypt. -EG {{{#!sagecell }}} === Playfair Cipher === A special type of substitution cipher in which the plaintext is broken up into two-letter digraphs with some restrictions. Those digraphs are encrypted using a Polybius square, (i.e. a 5x5 grid in which each letter of the alphabet is its own entry with the exception of ij which are placed together). The positions of the letters in the digraph determine how the digraph is encrypted. |
A substitution cipher encrypts messages by assigning each letter of the alphabet to another letter. For instance, if A is assigned to F, then all A's in the original message will be substituted with F's in the encrypted message. Brute force or frequency analysis can be used to decrypt a message encrypted with a substitution cipher. {{{#!sagecell }}} == Playfair Cipher == by Catalina Camacho-Navarro Based on code from Alasdair McAndrew at trac.sagemath.org/ticket/8559. A playfair cipher is a special type of substitution cipher in which the plaintext is broken up into two-letter digraphs with some restrictions. Those digraphs are encrypted using a Polybius square, (i.e. a 5x5 grid in which each letter of the alphabet is its own entry with the exception of ij which are placed together). The positions of the letters in the digraph determine how the digraph is encrypted. {{{#!sagecell ##PLAYFAIR CIPHER def change_to_plain_text(pl): plaintext='' for ch in pl: if ch.isalpha(): plaintext+=ch.upper() return plaintext def makePF(word1): #creates 5 x 5 Playfair array beginning with "word" word=change_to_plain_text(word1) alph='ABCDEFGHIKLMNOPQRSTUVWXYZ' pf='' for ch in word: if (ch<>"J") & (pf.find(ch)==-1): # ensures no letter is repeated pf+=ch for ch in alph: if pf.find(ch)==-1: #only uses unused letters from alph pf+=ch PF=[[pf[5*i+j] for j in range(5)] for i in range(5)] return PF def pf_encrypt(di,PF): # encrypts a digraph di with a Playfair array PF for i in range(5): for j in range(5): if PF[i][j]==di[0]: i0=i j0=j if PF[i][j]==di[1]: i1=i j1=j if (i0<>i1) & (j0<>j1): return PF[i0][j1]+PF[i1][j0] if (i0==i1) & (j0<>j1): return PF[i0][(j0+1)%5]+PF[i1][(j1+1)%5] if (i0<>i1) & (j0==j1): return PF[(i0+1)%5][j0]+PF[(i1+1)%5][j1] def insert(ch,str,j): # a helper function: inserts a character "ch" into tmp='' # a string "str" at position j for i in range(j): tmp+=str[i] tmp+=ch for i in range(len(str)-j): tmp+=str[i+j] return tmp def playfair(pl1,word): # encrypts a plaintext "pl" with a Playfair cipher pl=change_to_plain_text(pl1) PF=makePF(word) # using a keyword "word" pl2=makeDG(pl) tmp='' for i in range(len(pl2)//2): tmp+=pf_encrypt(pl2[2*i]+pl2[2*i+1],PF) return tmp def makeDG(str): # creates digraphs with different values from a string "str" tmp=str.replace('J','I') # replace all 'J's with 'I's c=len(tmp) i=0 while (c>0) & (2*i+1<len(tmp)): if tmp[2*i]==tmp[2*i+1]: tmp=insert("X",tmp,2*i+1) c-=1 i+=1 else: c-=2 i+=1 if len(tmp)%2==1: tmp+='X' return tmp pretty_print(html("<h1>Playfair Cipher Encryptor</h1>")) print('Enter your message and the key to construct you polybius square. Warning: both the message and the key must be in quotes.') @interact def _(Message=input_box(default="'message'"),Key=input_box(default="'key'"),showmatrix=checkbox(True, label='Show polybius square')): if showmatrix: poly=makePF(Key) for i in range(5): print(poly[i]) print '\nCiphertext:',playfair(Message,Key) }}} |
Line 99: | Line 223: |
Frequency analysis is a technique for breaking a substitution cipher that is based on the frequencies that letters appear (in large chunks of text) in the English language. For example, E is the most common letter in the English language, so if a piece of encrypted text had many instances of the letter Q, you would guess that Q had been substituted in for E. The next two interacts create a couple of basic tools that could be useful in cracking a substitution cipher. -AF | Frequency analysis is a technique for breaking a substitution cipher that utilizes the frequencies that letters appear in the English language. For example, E is the most common letter in the English language, so if a piece of encrypted text had many instances of the letter Q, you would guess that Q had been substituted in for E. The next two interacts create a couple of basic tools that could be useful in cracking a substitution cipher. |
Line 103: | Line 227: |
Line 106: | Line 229: |
This tool looks at the percentage of appearances of each letter in the input text, and plots these percentages. The encrypted input text is a bit strange, but was constructed by Amy Feaver to give a short block text that matched the frequencies of letters in English relatively well, to make this message easier to decrypt. -AF | This tool looks at the percentage of appearances of each letter in the input text and plots these percentages. The encrypted input text is a bit strange, but was constructed by Amy Feaver to give a short block of text that matched the frequencies of letters in the English language relatively well, to make this message easier to decrypt. |
Line 111: | Line 234: |
print "This interact prints a bar graph of the distribution of the letters in the input text. Warning: the smaller the input text the less accurate the distribution will be. Letters that do not occur will not appear in the graph." |
pretty_print(html("<h1>Letter Frequency Counter</h1>")) print "This interact prints a bar graph showing the distribution of letters in the input text. Warning: the smaller the input text the less accurate the distribution will be. Letters that do not occur will not appear in the graph." |
Line 114: | Line 237: |
Line 139: | Line 263: |
Code by Rebecca LaurenMiller, Kate Stange This interact prints suggested translation of the input text, by matching frequencies of letters in the input to letter frequencies in the English language. With the output you will see that some letters were substituted in correctly, and others were not. Usually frequency analysis requires additional work and some trial and error to discover the original message, especially if the input text is not long enough. -AF |
by Rebecca Lauren Miller, Katherine Stange This interact prints a suggested translation of the input text by matching frequencies of letters in the input to frequencies of letters in the English language. With the output you will see that some letters were substituted in correctly, and others were not. Usually frequency analysis requires additional work and some trial and error to discover the original message, especially if the input text is not long enough. |
Line 147: | Line 270: |
print "Warning: the shorter the input text the less accuate the distribution will be." | pretty_print(html("<h1>Frequency Analysis Decryption Guesser</h1>")) print "Warning: the shorter the input text is, the less accuate the distribution will be." |
Line 169: | Line 293: |
A Vigenère cipher is an example of a polyalphabetic cipher. Using a secret codeword as the key, the Vigenère encrypts each letter of a message by shifting it according to the corresponding letter in the key. For example, we will use the key "CAT" to encrypt our default text "SECRETS HI". To do this the message is first broken up into three-letter chunks, because the key is three letters long, and each letter of the chunk is shifted by the value of the corresponding letter in the key. The standard shifts are A=0, B=1, C=2, etc. So in our example, S shifts by C=2 letters to U, E shifts by A=0 letters and remains at E, and C shifts by T=19 letters to V. Thus "SECRETS HI" becomes UEVTEMUHB when encrypted. To decrypt the message, simply use the keyword to undo the encryption process. Cryptography by Simon Rubinstein-Salzedo was used as reference for this interact. === Vigenère Cipher Encryption === |
|
Line 171: | Line 299: |
Using a secret code word, encrypt each letter by shifting it the corresponding letter in the code word. -EG === Vigenère Cipher Encryption === |
|
Line 177: | Line 301: |
pretty_print(html("<h1>Vigenère Cipher Encryptor</h1>")) |
|
Line 190: | Line 316: |
{{{#!sagecell #This decrypts your message: Final 8/7/19. Written by Rebecca Lauren Miller, Holly Paige Chaos, Katherine Stange. print "Put your message and codeword in quotes: " |
by Holly Paige Chaos, Rebecca Lauren Miller, Katherine Stange {{{#!sagecell #Last edited 8/7/19 at 12:00pm pretty_print(html("<h1>Vigenère Cipher Decryptor</h1>")) print "Put your message and codeword inside the quotes: " |
Line 206: | Line 335: |
== One-time Pad == | == One-Time Pad == |
Line 244: | Line 373: |
=== Hill Cipher Encryption === |
|
Line 248: | Line 380: |
pretty_print(html('<h2>Hill Cipher Encryptor</h2>')) |
|
Line 310: | Line 440: |
=== Hill Cipher Decryption === by Holly Paige Chaos, Alexis Newton |
|
Line 314: | Line 445: |
pretty_print(html('<h2>Hill Cipher Decryptor</h2>')) | |
Line 417: | Line 547: |
Named for the authors Rivest, Shamir, Aldeman, RSA uses exponentiation and modular arithmetic to encrypt and decrypt messages between two parties. Each of those parties has their own secret and public key. To see how it works, following along while Alicia and Bernadette share a message. -EG {{{#!sagecell }}} |
Named for the authors Rivest, Shamir, Aldeman, RSA uses exponentiation and modular arithmetic to encrypt and decrypt messages between two parties. Each of those parties has their own secret and public key. To see how it works, following along while Alice and Babette share a message. -EG === RSA, From Alice's Perspective === by Sarah Arpin, Eva Goedhart Babette sent Alice an encrypted message. You , as Alice, will provide information so that you can read Babette's message. {{{#!sagecell #Last edited 8/9/19 at 11:16am print "Hi, Alice! Let's set up RSA together." @interact def rsa(p = input_box(default = 11,label = "p (>10): "), q = input_box(default = 23,label = "q (>10): "),e = input_box(default = 7,label = "e:")): print "************************************************************************************************" print "WARNINGS: p and q should be different primes, both larger than 10." print "e should be relatively prime to phi(pq). To check this, see the factorization of phi(pq) below." print "************************************************************************************************" print "" p = ZZ(p) q = ZZ(q) e = ZZ(e) phi = (p-1)*(q-1) print "phi(pq) = ",phi.factor() print "" N = p*q R = IntegerModRing(phi) d = (e^(R(e).multiplicative_order()-1)).mod(phi) print "Alice's public key is: N = pq =",N,", e =",e,"." print "Alice's private key is: p =",p,", q = ",q,", d = ",d,", where the decryption key d is the inverse of e modulo phi(N)." secret_message_from_babette = "Hi Dr. Strange!" ascii_secret = [] for char in secret_message_from_babette: ascii_secret.append(ord(char)) encrypted_ascii = [] for ascii in ascii_secret: encrypted_ascii.append(power_mod(ascii,e,N)) decrypted_ascii = [] for ascii in encrypted_ascii: decrypted_ascii.append(power_mod(ascii,d,N)) print "Babette's encrypted message to you is: ", encrypted_ascii print "" print "To decrypt, we raise each one of these to the ",d,", modulo ",N,":" print decrypted_ascii print "" decrypted_secret = "" for ascii in decrypted_ascii: decrypted_secret += chr(ascii) print "Going from ascii to letters, we figure out the secret is: " print decrypted_secret }}} === RSA, From Babette's Perspective === by Sarah Arpin, Eva Goedhart {{{#!sagecell #Last edited 8/8/19 at 12:30pm print "Hi, Babette! Let's send a message to Alice using RSA." p = next_prime(100) q = next_prime(p) phi = (p-1)*(q-1) e = 13 N = p*q R = IntegerModRing(phi) d = (e^(R(e).multiplicative_order()-1)).mod(phi) print "Alice's public key is: N =",N,", e =",e,"." message = raw_input("Type a message for Alice:") ascii_secret = [] for char in message: ascii_secret.append(ord(char)) print "We turn these characters into ascii:" print ascii_secret print "" print "Then we encode them by raising each ascii number to the e-th power modulo N." encrypted_ascii = [] for ascii in ascii_secret: encrypted_ascii.append(power_mod(ascii,e,N)) print encrypted_ascii print "" @interact def rsa(): print "Alice receives our secret and uses her private key to decrypt the message." decrypted_ascii = [] for ascii in encrypted_ascii: decrypted_ascii.append(power_mod(ascii,d,N)) print decrypted_ascii print "" decrypted_secret = "" for ascii in decrypted_ascii: decrypted_secret += chr(ascii) print "Going from ascii to letters, she figures out your message was: " print decrypted_secret }}} === RSA With Digital Signatures === by Sarah Arpin, Eva Goedhart {{{#!sagecell }}} |
Sage Interactions - Cryptography
This page was first created at Sage Days 103, 7-9 August 2019 by Sarah Arpin, Catalina Camacho-Navarro, Holly Paige Chaos, Amy Feaver, Eva Goedhart, Rebecca Lauren Miller, Alexis Newton, and Nandita Sahajpal. Text edited by Holly Paige Chaos, Amy Feaver, Eva Goedhart, and Alexis Newton. This project was led by Amy Feaver.
We acknowledge Katherine Stange, who allowed us to use code from her cryptography course as a starting point for many of these interacts. Dr. Stange's original code and course page can be found at http://crypto.katestange.net/
If you have cryptography-related interactions that you are interested in adding to this page, please do so. You can also contact Amy Feaver at [email protected]
goto interact main page
Contents
Shift Cipher
The shift cipher is a classical cryptosystem that takes plaintext and shifts it through the alphabet by a given number of letters. For example, a shift of 2 would replace all A's with C's, all B's with D's, etc. When the end of the alphabet is reached, the letters are shifted cyclically back to the beginning. Thus, a shift of 2 would replace Y's with A's and Z's with B's.
Shift Cipher Encryption
by Sarah Arpin, Alexis Newton
You can use this interact to encrypt a message with a shift cipher.
Shift Cipher Decryption
by Sarah Arpin, Alexis Newton
If you know that your message was encrypted using a shift cipher, you can use the known shift value to decrypt. If this is not known, brute force can be used to get 26 possible decrypted messages. The chi-squared function ranks the brute force results by likelihood according to letter frequency.
Affine Cipher
An affine cipher combines the idea of a shift cipher with a multiplicative cipher. In this particular example, we map consecutive letters of the alphabet to consecutive numbers, starting with A=0 (you can also do this cipher differently, and starting with A=1). The user selects two values, a and b. The value a is the multiplier and must be relatively prime to 26 in order to guarantee that each letter is encoded uniquely. The value b is the addend. Each letter's value is multiplied by a, and the product is added to b. This is then replaced with a new letter, corresponding to the result modulo 26.
Affine Cipher Encryption
by Sarah Arpin, Alexis Newton
You can use this interact to encrypt a message with the affine cipher. Notice that the only choices for a can be numbers that are relatively prime to 26. This cipher will encipher a letter m of your message as a*m + b.
Affine Cipher Decryption
by Sarah Arpin, Alexis Newton
If you know that your message was encrypted using an affine cipher, you can use the known a and b values to decrypt. If these are not known, brute force can be used to get a list of possible decrypted messages. The chi-squared function ranks these results by likelihood according to letter frequency.
Substitution Cipher
by Catalina Camacho-Navarro
A substitution cipher encrypts messages by assigning each letter of the alphabet to another letter. For instance, if A is assigned to F, then all A's in the original message will be substituted with F's in the encrypted message. Brute force or frequency analysis can be used to decrypt a message encrypted with a substitution cipher.
Playfair Cipher
by Catalina Camacho-Navarro
Based on code from Alasdair McAndrew at trac.sagemath.org/ticket/8559.
A playfair cipher is a special type of substitution cipher in which the plaintext is broken up into two-letter digraphs with some restrictions. Those digraphs are encrypted using a Polybius square, (i.e. a 5x5 grid in which each letter of the alphabet is its own entry with the exception of ij which are placed together). The positions of the letters in the digraph determine how the digraph is encrypted.
Frequency Analysis Tools
Frequency analysis is a technique for breaking a substitution cipher that utilizes the frequencies that letters appear in the English language. For example, E is the most common letter in the English language, so if a piece of encrypted text had many instances of the letter Q, you would guess that Q had been substituted in for E. The next two interacts create a couple of basic tools that could be useful in cracking a substitution cipher.
Letter Frequency Counter
by Rebecca Lauren Miller, Katherine Stange
This tool looks at the percentage of appearances of each letter in the input text and plots these percentages. The encrypted input text is a bit strange, but was constructed by Amy Feaver to give a short block of text that matched the frequencies of letters in the English language relatively well, to make this message easier to decrypt.
Frequency Analysis Decryption Guesser
by Rebecca Lauren Miller, Katherine Stange
This interact prints a suggested translation of the input text by matching frequencies of letters in the input to frequencies of letters in the English language. With the output you will see that some letters were substituted in correctly, and others were not. Usually frequency analysis requires additional work and some trial and error to discover the original message, especially if the input text is not long enough.
Vigenère Cipher
A Vigenère cipher is an example of a polyalphabetic cipher. Using a secret codeword as the key, the Vigenère encrypts each letter of a message by shifting it according to the corresponding letter in the key. For example, we will use the key "CAT" to encrypt our default text "SECRETS HI". To do this the message is first broken up into three-letter chunks, because the key is three letters long, and each letter of the chunk is shifted by the value of the corresponding letter in the key. The standard shifts are A=0, B=1, C=2, etc. So in our example, S shifts by C=2 letters to U, E shifts by A=0 letters and remains at E, and C shifts by T=19 letters to V. Thus "SECRETS HI" becomes UEVTEMUHB when encrypted. To decrypt the message, simply use the keyword to undo the encryption process. Cryptography by Simon Rubinstein-Salzedo was used as reference for this interact.
Vigenère Cipher Encryption
by Holly Paige Chaos, Rebecca Lauren Miller, Katherine Stange
Vigenère Cipher Decryption
by Holly Paige Chaos, Rebecca Lauren Miller, Katherine Stange
One-Time Pad
by Sarah Arpin, Alexis Newton
Hill Cipher
Hill Cipher Encryption
by Holly Paige Chaos, Alexis Newton
Hill Cipher Decryption
by Holly Paige Chaos, Alexis Newton
RSA
Named for the authors Rivest, Shamir, Aldeman, RSA uses exponentiation and modular arithmetic to encrypt and decrypt messages between two parties. Each of those parties has their own secret and public key. To see how it works, following along while Alice and Babette share a message. -EG
RSA, From Alice's Perspective
by Sarah Arpin, Eva Goedhart
Babette sent Alice an encrypted message. You , as Alice, will provide information so that you can read Babette's message.
RSA, From Babette's Perspective
by Sarah Arpin, Eva Goedhart
RSA With Digital Signatures
by Sarah Arpin, Eva Goedhart