Today • What does it mean for a cipher to be: – Computational secure? Unconditionally secure? • Perfect secrecy – Conditional probability – Definition of perfect secrecy – Systems that provide perfect secrecy • How secure when we reuse a key? – Entropy – Redundancy of a language – Spurious keys, unicity distance Cryptography Perfect secrecy Slide 1 Contact before work • Turn to a neighbor and ask: What do you think of this week’s homework problems? Easy or hard? Interesting or dull? Why or why not? • Why do Contact Before Work? – Helps us know our teammates. We work better with people we know and like. – Helps start the meeting on time. Cryptography Perfect secrecy Slide 2 Announcements • Today at 4:20: – Mark Gritter(CSSE faculty candidate, from Stanford) • Content Location with Name-Based Routing • Olin 267 • Questions on homework? – Due Thursday • Friday: annual Undergraduate Mathematics Conference here at Rose-Hulman! – So no class Friday. – We ask that you go to a talk at the conference instead! • See schedule on Mathematics home page. Cryptography Perfect secrecy Slide 3 What is perfect secrecy? • Exercise: – Do the following by yourself (1 minute) and then in groups of about four (3 to 5 minutes) • Give (mathematical) definitions for a cipher to be: – Computationally secure – Unconditionally secure (“perfect secrecy”) • Consider: Is your definition precise enough that I – Computer-invariant? could use it to determine whether, e.g., – Information-invariant? cipher A is twice as computationally – Kinds of attack? secure as cipher B”? Cryptography Perfect secrecy Slide 4 Computationally secure • Stallings: A cipher is computationally secure if: – Cost of breaking the cipher exceeds value of the encrypted information – Time required to break the cipher exceeds useful lifetime of the encrypted information • Is this: – Computer-invariant? – Information-invariant? – Practical to determine? Cryptography I find Stalling’s definition unsatisfying. Can you do better? Perfect secrecy Slide 5 Unconditionally secure • Stallings: A cipher is: – Computationally secure if: • Cost of breaking the cipher exceeds value of the encrypted information • Time required to break the cipher exceeds useful lifetime of the encrypted information – Unconditionally secure if: Huh? Can we be more precise? • Ciphertext generated does not contain enough information to determine uniquely the corresponding plaintext – No matter how much ciphertext – No matter how much time/resources available to attacker Cryptography Perfect secrecy Slide 6 Where we are going: • Unconditionally secure: – Ciphertext generated does not contain enough information to determine uniquely the corresponding plaintext • To make this precise, we need: – What is a cipher? – What does it mean to determine the plaintext? Uniquely? • We will see that: – Shift cipher, substitution cipher, Vigenere cipher are: • Not computationally secure – against even a ciphertext-only attack, – given a sufficient amount of ciphertext • Unconditionally secure (!) – if [an important condition that we will see soon] [can you guess it?] Cryptography Perfect secrecy Slide 7 What is a cryptosystem? • Three finite sets: – P = set of possible plaintexts – C = set of possible ciphertexts – K = set of possible keys • Encryption and decryption functions e and d. For each k in K: – ek : P C dk : C P • Exercise: What has to be true of ek and dk? • Answer: for any plaintext x and key k: dk(ek(x)) = x Cryptography Perfect secrecy Slide 8 Conditional probability • So now we know: – What is a cipher? • Next: – What does it mean to determine the plaintext? Uniquely? • To answer this, we need probability theory: – – – – – – random variable, sample space probability distribution joint probability distribution conditional probability distribution independent random variables Bayes’ theorem Cryptography Perfect secrecy Slide 9 Random variable Probability distribution • Definition: A random variable – is a function from the sample space to a set of numbers • (for us, the nonnegative integers) • Examples: – The number of aces in a bridge hand – The number of multiple birthdays in a room of n people • I’ll assume discrete random variables throughout these notes • Definition: The probability distribution of a random variable X – Gives, for each possible value x that X can take, the probability of x – Written Pr (x) • Example: – Let X = number of heads after 3 coin tosses. • p(0) = 1/8 Cryptography p(1) = 3/8 p(2) = 3/8 Perfect secrecy p(3) = 1/8 Slide 10 Joint probability distribution Conditional probability distribution • Definitions: Let X and Y be random variables. – The joint probability Pr (x, y) is the probability that X is x and Y is y. – The conditional probability Pr ( x | y ) is the probability that X is x given that Y is y and is (by definition) Pr (x, y) / Pr (y) • In the example to the right: X – Pr (c, B)? Pr (b, B)? – Pr (a | B )? Pr (B | a)? a • Answers: – Pr (c, B) = 0.05 Pr (b, B) = 0.25 – Pr (a | B ) = 0.10 / (0.10 + 0.25 + 0.05) = 0.4 – Pr (B | a) = 0.10 / (0.25 + 0.10) = 2/7 Cryptography Perfect secrecy Y b c A 0.25 0.15 0.20 B 0.10 0.25 0.05 Slide 11 Independent random variables • Definition: – Random variables X and Y are independent – if Pr (x | y) = Pr (x) for all x, y. • Equivalently, if Pr (x, y) = Pr (x) Pr (y) for all x, y. • Examples – X and Y on previous slide are not independent – # of heads in toss A,# in toss B: independent Cryptography Perfect secrecy Slide 12 Application to ciphers • Assume – PrP (x) • probability distribution on plaintext space P – PrK(k) • probability distribution on key space K – Choosing the key and selecting the plaintext are independent • These induce: – PrP,K (y) • probability distribution on ciphertext C Example and details on next slides. – PrP,K (x, y) • joint probability distribution of plaintext and ciphertext – PrP,K (x | y) • conditional distribution of plaintext given ciphertext Cryptography Perfect secrecy Slide 13 Example • Sets: Cipher a b 1 A B 2 B C 3 C D – Plaintext P = {a, b} – Ciphertext C = {A, B, C, D} – Key space K = {1, 2, 3} • Cipher: per table on right • Probabilitity distributions: – Prp(a) = ¼ – PrK(1) = ½ Prp(b) = ¾ PrK(2) = ¼ • Exercise: compute PrP,K (y) PrK(3) = ¼ – probability distribution on ciphertext C • Exercise: compute PrP,K (x | y) – conditional distribution of plaintext given ciphertext Cryptography Perfect secrecy Slide 14 Computation of the induced probability distributions • Given: PrP (x) PrK (k) • Probability that plaintext is x. Probability that key is k. • Assume choosing key and selecting plaintext are independent. • Then: PrP,K (y) PrP,K (x | y) PrP,K (y | x) are given by: • Probability PrP,K (y) that ciphertext is y • Probability PrP,K (y | x) that ciphertext is y given plaintext is x • Probability PrP,K (x | y) that plaintext is x given ciphertext is y – PrP,K (y) = [ PrP (x) PrK (k) ] • Where the sum is over all plaintext x and keys k such that ek(x) = y – PrP,K (y | x) = [ PrK (k) ] / PrP (x) • Where the sum is over all keys k such that ek(x) = y – PrP,K (x | y) = PrP,K (y | x) PrP (x) / PrP,K (y) by Bayes Theorem Cryptography Perfect secrecy Slide 15 So what is perfect secrecy? • Given: PrP (x) PrK (k) • Probability that plaintext is x. Probability that key is k. • Assume choosing key and selecting plaintext are independent. • Then that induces (per previous slide): • Probability PrP,K (y) that ciphertext is y • Probability PrP,K (y | x) that ciphertext is y given plaintext is x • Probability PrP,K (x | y) that plaintext is x given ciphertext is y • Informally: perfect secrecy means that the ciphertext generated does not contain enough information to determine uniquely the corresponding plaintext – Can you now give a precise definition of perfect secrecy, in terms of the above? Cryptography Perfect secrecy Slide 16 Perfect secrecy • Definition: A cryptosystem has perfect secrecy if: – For all x in plaintext space P and y in ciphertext space C – We have PrP,K (x | y) = PrP (x) • Theorem: – Suppose the 26 keys in the Shift cipher are used with equal probability. – Then for any plaintext probability distribution, – the Shift cipher has perfect secrecy. • Note that we are encrypting a single character with a single key • Another time: the (easy) proof! Cryptography Perfect secrecy Slide 17 What provides perfect secrecy? • Theorem: – Perfect secrecy requires |K| |C|. – Suppose as few keys as possible, i.e. |K| = |C| = |P|. • Note: Any cryptosystem has |C| |P|. – Then the cryptosystem has perfect secrecy iff • every key is used with equal probability, and • for every x in P and y in C, there is a unique key k such that ek (x) = y Cryptography Perfect secrecy Slide 18 Vernam’s one-time pad • Corollary to the theorem on the previous slide: – Vigenere’s cipher provides perfect secrecy, if: • each key is equally likely, and • you encrypt a single plaintext element (i.e., encrypt m characters using a key of length m) – Cannot have perfect secrecy with shorter keys – History: • 1917: Gilbert Vernam suggested Vigenere with a binary alphabet and a long keyword. Joseph Mauborgne suggested uing a one-time pad (key as long as the message, not reused). • Widely accepted as “unbreakable” but no proof until Shannon’s work 30 years later Cryptography Perfect secrecy Slide 19 What if keys are reused? • Summary: – We defined perfect secrecy. – We found cryptosystems that provide perfect secrecy. – But: perfect secrecy requires that we not reuse a key • Next: How secure is a cryptosystem when we reuse keys? – Entropy – Redundancy of a language – Spurious keys, unicity distance Cryptography Perfect secrecy Slide 20 Entropy: motivation • Background – – – – From information theory Introduced by Claude Shannon in 1948. A measure of information or uncertainty Computed as a function of a probability distribution • Example: – Toss a coin. How many bits required to represent the result? – Toss a coin n times. Now how many bits? • What if the coin is a biased coin? Cryptography Perfect secrecy Slide 21 Entropy: definition • Definition: – Suppose X is a random variable – with probability distribution p = p1, p2, ... pn – where pi is the probability X takes on its ith possible value. – Then the entropy of X, – written H(X), is n H ( X ) pi log2 pi i 1 Cryptography Perfect secrecy Slide 22 Entropy: example n • Definition of entropy: H ( X ) pi log2 pi i 1 • P = {a, b}. C = {1, 2, 3, 4}. – – – – pp: a => 1/4 b => 3/4 pc: 1 => 1/8 2 => 7/16 3 => 1/4 4 => 3/16 Exercise: what is H(P)? H(C)? H(P) = - [ ( 1/4 -2 ) + ( 3/4 (log2 3 - 2) ) ] 0.81 – H(C) 1.85. Cryptography Perfect secrecy Slide 23 Spurious keys • Exercise: – – – – – Suppose Oscar is doing a ciphertext-only attack on a string encoded using Vigenere’s cipher where m (key length) is modest (not a one-time pad). Oscar decrypts the message to a meaningful sentence. Why is Oscar not done? • Answer: – 1. There may be other keys that yield other meaningful sentences. – 2. We want the key, not just the meaningful sentence. Cryptography Perfect secrecy Slide 24 Spurious keys • Context: – Oscar is doing cipher-text only attack – Oscar has infinite computational resources – Oscar knows the plaintext is a “natural” language. • Result: – Oscar will be able to rule out certain keys. – Many “possible” keys remain. Only one key is correct. – The remaining possible, but incorrect, keys are called spurious keys. • Our goal: determine how many spurious keys. Cryptography Perfect secrecy Slide 25 Entropy & redundancy of a language • Definitions: – Let L be a natural language (like English). – Let Pn be a random variable whose probability distribution is that of all n-grams of plaintext in L. – The entropy HL of L is H (P n ) H L lim n n – The redundancy RL of L is HL RL 1 log2 | P | • HL measures entropy per letter. • RL measures fraction of “excess characters.” Cryptography Perfect secrecy Slide 26 Entropy & redundancy of a language • Experiments have shown that for English: H (P n ) H L lim n n HL RL 1 log2 | P | – H(P2) 7.80 – 1.0 HL 1.5 – So RL 0.75 • Exercise: does this mean you could keep only every 4th letter of a message and hope to read it? • Answer: No! This means you could hope to encode long strings of English to about 1/4 of their size, using a Huffman encoding. Cryptography Perfect secrecy Slide 27 Number of spurious keys • Theorem: – Suppose |C| = |P| and keys are equiprobable. – Given a ciphertext of length n (where n is large enough) – the expected number sn of spurious keys satisfies sn |K| | P | nRL 1 • So what can you say about long ciphertext messages? • Note: the expression goes to 0 quickly as n increases Cryptography Perfect secrecy Slide 28 Unicity distance • Definition: – – – – The unicity distance of a cyptosystem is the value of n (ciphertext length), denoted n0, at which the expected number of spurious keys becomes zero. log | K | • Theorem: n0 2 RL log2 | P | – Exercise: unicity distance of the Substitution cipher? – Answer: 88.4 / (0.75 4.7) 25 Cryptography Perfect secrecy Slide 29 Summary • Perfect secrecy. – Perfect. Provides clear sense of the ultimate: • What can be done. • How to do it (Vernam’s one-time pad). • If we reuse keys: – No longer perfect secrecy. – But the secret may not be utterly revealed, even against infinite computational resources: • Because of redundant keys – Clear answers, beautiful mathematics, but not much secrecy! • What if there are finite computational resources? Cryptography Perfect secrecy Slide 30