1. use the frequency analysis to figure out the encryption key and the origin plaintext. par popnead Open

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
icon
Related questions
Question

use Linux commands to find the encryption key and original text

1. use the frequency analysis to figure out the encryption key and the original
plaintext.
using the python code provided and the cipher
Using the frequency analysis, you can find out the plaintext.
It is better to use capital letters for plaintext, so for the same letter, to know
which is plaintext and which is ciphertext. use the tr command to do this.
For example, letters m, t, and y in in.txt with letters B, P, S, respectively; the results
are saved in out.txt.
$ tr 'mty' 'BPS' <in.txt > out.txt
cipher.txt
xun gmr jznaymxu gzhhxzupmur ytmq dnvhq vavpncd vlvhpq mq txl xh mbytn
anhncxud Imii vpphngg cnyxx ngenamviid vbynh ytn rxipnu rixgnq ltmat gnavcn
v ozgmivuy axcmurxzy evhyd bxh ymcng ze ytn cxfncnuy genvhtnvpnp gd
exlnhbzi txiidlxxp Ixcnu Itx tnienp hvman cmiimxuq xb pxiivhg yx bmrty gnkzvi
tvhvqgcnuy vhxzup ytn axzuyhd
python code:
#!/usr/bin/env python3
from collections import Counter
import re
TOP_K = 20
N_GRAM = 3
# Generate all the n-grams for value n
def ngrams (n, text):
for i in range (len(text) -n + 1):
# Ignore n-grams containing white space
if not re.search(r'\s', text[i:i+n]):
yield text[i:i+n]
# Read the data from the ciphertext
with open('ciphertext.txt') as f:
text = f.read()
# Count, sort, and print out the n-grams
for N in range(N_GRAM):
print("--
--")
print("{}-gram (top {}):".format(N+1, TOP_K))
counts = Counter (ngrams(N+1, text))
sorted_counts = counts.most_common(TOP_K) # Sort
for ngram, count in sorted_counts:
print("{}: {}".format(ngram, count)) # Print
# Count
Transcribed Image Text:1. use the frequency analysis to figure out the encryption key and the original plaintext. using the python code provided and the cipher Using the frequency analysis, you can find out the plaintext. It is better to use capital letters for plaintext, so for the same letter, to know which is plaintext and which is ciphertext. use the tr command to do this. For example, letters m, t, and y in in.txt with letters B, P, S, respectively; the results are saved in out.txt. $ tr 'mty' 'BPS' <in.txt > out.txt cipher.txt xun gmr jznaymxu gzhhxzupmur ytmq dnvhq vavpncd vlvhpq mq txl xh mbytn anhncxud Imii vpphngg cnyxx ngenamviid vbynh ytn rxipnu rixgnq ltmat gnavcn v ozgmivuy axcmurxzy evhyd bxh ymcng ze ytn cxfncnuy genvhtnvpnp gd exlnhbzi txiidlxxp Ixcnu Itx tnienp hvman cmiimxuq xb pxiivhg yx bmrty gnkzvi tvhvqgcnuy vhxzup ytn axzuyhd python code: #!/usr/bin/env python3 from collections import Counter import re TOP_K = 20 N_GRAM = 3 # Generate all the n-grams for value n def ngrams (n, text): for i in range (len(text) -n + 1): # Ignore n-grams containing white space if not re.search(r'\s', text[i:i+n]): yield text[i:i+n] # Read the data from the ciphertext with open('ciphertext.txt') as f: text = f.read() # Count, sort, and print out the n-grams for N in range(N_GRAM): print("-- --") print("{}-gram (top {}):".format(N+1, TOP_K)) counts = Counter (ngrams(N+1, text)) sorted_counts = counts.most_common(TOP_K) # Sort for ngram, count in sorted_counts: print("{}: {}".format(ngram, count)) # Print # Count
Expert Solution
steps

Step by step

Solved in 3 steps

Blurred answer
Knowledge Booster
Encryption and decryption
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
Recommended textbooks for you
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education