cse 505 programming languages lecture 12 the curry howard
play

CSE 505: Programming Languages Lecture 12 The Curry-Howard - PowerPoint PPT Presentation

CSE 505: Programming Languages Lecture 12 The Curry-Howard Isomorphism Zach Tatlock Fall 2013 We are Language Designers! What have we done? Define a programming language we were fairly formal still pretty close to OCaml if you


  1. CSE 505: Programming Languages Lecture 12 — The Curry-Howard Isomorphism Zach Tatlock Fall 2013

  2. We are Language Designers! What have we done? ◮ Define a programming language ◮ we were fairly formal ◮ still pretty close to OCaml if you squint real hard ◮ Define a type system ◮ outlaw bad programs that “get stuck” ◮ sound: no typable programs get stuck ◮ incomplete: knocked out some OK programs too, ohwell Zach Tatlock CSE 505 Fall 2013, Lecture 12 2

  3. Elsewhere in the Universe (or the other side of campus) What do logicians do? ◮ Define formal logics ◮ tools to precisely state propositions ◮ Define proof systems ◮ tools to figure out which propositions are true Turns out, we did that too! Zach Tatlock CSE 505 Fall 2013, Lecture 12 3

  4. Punchline We are accidental logicians! The Curry-Howard Isomorphism ◮ Proofs : Propositions :: Programs : Types ◮ proofs are to propositions as programs are to types Zach Tatlock CSE 505 Fall 2013, Lecture 12 4

  5. Punchline... wat. Zach Tatlock CSE 505 Fall 2013, Lecture 12 5

  6. Woah. Back up a second. Logic?! Let’s trim down our (explicitly typed) simply-typed λ -calculus to: ::= x | λx. e | e e e | ( e, e ) | e. 1 | e. 2 | A ( e ) | B ( e ) | match e with A x. e | B x. e τ ::= b | τ → τ | τ ∗ τ | τ + τ ◮ Lambdas, Pairs, and Sums ◮ Any number of base types b 1 , b 2 , . . . ◮ No constants (can add one or more if you want) ◮ No fix What good is this?! Well, even sans constants, plenty of terms type-check with Γ = · Zach Tatlock CSE 505 Fall 2013, Lecture 12 6

  7. λx : b. x has type b → b Zach Tatlock CSE 505 Fall 2013, Lecture 12 7

  8. λx : b 1 . λf : b 1 → b 2 . f x has type b 1 → ( b 1 → b 2 ) → b 2 Zach Tatlock CSE 505 Fall 2013, Lecture 12 8

  9. λx : b 1 → b 2 → b 3 . λy : b 2 . λz : b 1 . x z y has type ( b 1 → b 2 → b 3 ) → b 2 → b 1 → b 3 Zach Tatlock CSE 505 Fall 2013, Lecture 12 9

  10. λx : b 1 . ( A ( x ) , A ( x )) has type b 1 → (( b 1 + b 7 ) ∗ ( b 1 + b 4 )) Zach Tatlock CSE 505 Fall 2013, Lecture 12 10

  11. λf : b 1 → b 3 . λg : b 2 → b 3 . λz : b 1 + b 2 . ( match z with A x. f x | B x. g x ) has type ( b 1 → b 3 ) → ( b 2 → b 3 ) → ( b 1 + b 2 ) → b 3 Zach Tatlock CSE 505 Fall 2013, Lecture 12 11

  12. λx : b 1 ∗ b 2 . λy : b 3 . (( y, x. 1) , x. 2) has type ( b 1 ∗ b 2 ) → b 3 → (( b 3 ∗ b 1 ) ∗ b 2 ) Zach Tatlock CSE 505 Fall 2013, Lecture 12 12

  13. Empty and Nonempty Types Just saw a few “nonempty” types ◮ τ nonempy if closed term e has type τ ◮ τ empty otherwise Are there any empty types? b 1 b 1 → b 2 b 1 → ( b 2 → b 1 ) → b 2 Sure! What does this one mean? b 1 + ( b 1 → b 2 ) I wonder if there’s any way to distinguish empty vs. nonempty... Ohwell, now for a totally irrelevant tangent! Zach Tatlock CSE 505 Fall 2013, Lecture 12 13

  14. Totally irrelevant tangent. Zach Tatlock CSE 505 Fall 2013, Lecture 12 14

  15. Propositional Logic Suppose we have some set b of basic propositions b 1 , b 2 , . . . ◮ e.g. “ML is better than Haskell” Then, using standard operators ⊃ , ∧ , ∨ , we can define formulas: ::= b | p ⊃ p | p ∧ p | p ∨ p p ◮ e.g. “ML is better than Haskell” ∧ “Haskell is not pure” Some formulas are tautologies : by virtue of their structure, they are always true regardless of the truth of their constituent propositions. ◮ e.g. p 1 ⊃ p 1 Not too hard to build a proof system to establish tautologyhood. Zach Tatlock CSE 505 Fall 2013, Lecture 12 15

  16. Proof System Γ ::= · | Γ , p Γ ⊢ p Γ ⊢ p 1 Γ ⊢ p 2 Γ ⊢ p 1 ∧ p 2 Γ ⊢ p 1 ∧ p 2 Γ ⊢ p 1 ∧ p 2 Γ ⊢ p 1 Γ ⊢ p 2 Γ ⊢ p 1 Γ ⊢ p 2 Γ ⊢ p 1 ∨ p 2 Γ ⊢ p 1 ∨ p 2 Γ ⊢ p 1 ∨ p 2 Γ , p 1 ⊢ p 3 Γ , p 2 ⊢ p 3 Γ ⊢ p 3 p ∈ Γ Γ , p 1 ⊢ p 2 Γ ⊢ p 1 ⊃ p 2 Γ ⊢ p 1 Γ ⊢ p Γ ⊢ p 1 ⊃ p 2 Γ ⊢ p 2 Zach Tatlock CSE 505 Fall 2013, Lecture 12 16

  17. Wait a second... Zach Tatlock CSE 505 Fall 2013, Lecture 12 17

  18. Wait a second... ZOMG! That’s exactly our type system! Just erase terms, change each τ to a p , and translate → to ⊃ , ∗ to ∧ , + to ∨ . Γ ⊢ e : τ Γ ⊢ e 1 : τ 1 Γ ⊢ e 2 : τ 2 Γ ⊢ e : τ 1 ∗ τ 2 Γ ⊢ e : τ 1 ∗ τ 2 Γ ⊢ ( e 1 , e 2 ) : τ 1 ∗ τ 2 Γ ⊢ e. 1 : τ 1 Γ ⊢ e. 2 : τ 2 Γ ⊢ e : τ 1 Γ ⊢ e : τ 2 Γ ⊢ A ( e ) : τ 1 + τ 2 Γ ⊢ B ( e ) : τ 1 + τ 2 Γ ⊢ e : τ 1 + τ 2 Γ , x : τ 1 ⊢ e 1 : τ Γ , y : τ 2 ⊢ e 2 : τ Γ ⊢ match e with A x. e 1 | B y. e 2 : τ Γ( x ) = τ Γ , x : τ 1 ⊢ e : τ 2 Γ ⊢ e 1 : τ 2 → τ 1 Γ ⊢ e 2 : τ 2 Γ ⊢ x : τ Γ ⊢ λx. e : τ 1 → τ 2 Γ ⊢ e 1 e 2 : τ 1 Zach Tatlock CSE 505 Fall 2013, Lecture 12 18

  19. What does it all mean? The Curry-Howard Isomorphism. ◮ Given a well-typed closed term, take the typing derivation, erase the terms, and have a propositional-logic proof ◮ Given a propositional-logic proof, there exists a closed term with that type ◮ A term that type-checks is a proof — it tells you exactly how to derive the logic formula corresponding to its type ◮ Constructive (hold that thought) propositional logic and simply-typed lambda-calculus with pairs and sums are the same thing . ◮ Computation and logic are deeply connected ◮ λ is no more or less made up than implication ◮ Revisit our examples under the logical interpretation... Zach Tatlock CSE 505 Fall 2013, Lecture 12 19

  20. λx : b. x is a proof that b → b Zach Tatlock CSE 505 Fall 2013, Lecture 12 20

  21. λx : b 1 . λf : b 1 → b 2 . f x is a proof that b 1 → ( b 1 → b 2 ) → b 2 Zach Tatlock CSE 505 Fall 2013, Lecture 12 21

  22. λx : b 1 → b 2 → b 3 . λy : b 2 . λz : b 1 . x z y is a proof that ( b 1 → b 2 → b 3 ) → b 2 → b 1 → b 3 Zach Tatlock CSE 505 Fall 2013, Lecture 12 22

  23. λx : b 1 . ( A ( x ) , A ( x )) is a proof that b 1 → (( b 1 + b 7 ) ∗ ( b 1 + b 4 )) Zach Tatlock CSE 505 Fall 2013, Lecture 12 23

  24. λf : b 1 → b 3 . λg : b 2 → b 3 . λz : b 1 + b 2 . ( match z with A x. f x | B x. g x ) is a proof that ( b 1 → b 3 ) → ( b 2 → b 3 ) → ( b 1 + b 2 ) → b 3 Zach Tatlock CSE 505 Fall 2013, Lecture 12 24

  25. λx : b 1 ∗ b 2 . λy : b 3 . (( y, x. 1) , x. 2) is a proof that ( b 1 ∗ b 2 ) → b 3 → (( b 3 ∗ b 1 ) ∗ b 2 ) Zach Tatlock CSE 505 Fall 2013, Lecture 12 25

  26. So what? Because: ◮ This is just fascinating (glad I’m not a dog) ◮ Don’t think of logic and computing as distinct fields ◮ Thinking “the other way” can help you know what’s possible/impossible ◮ Can form the basis for theorem provers ◮ Type systems should not be ad hoc piles of rules! So, every typed λ -calculus is a proof system for some logic... Is STLC with pairs and sums a complete proof system for propositional logic? Almost... Zach Tatlock CSE 505 Fall 2013, Lecture 12 26

  27. Classical vs. Constructive Classical propositional logic has the “law of the excluded middle”: Γ ⊢ p 1 + ( p 1 → p 2 ) (Think “ p + ¬ p ” – also equivalent to double-negation ¬¬ p → p ) STLC does not support this law; for example, no closed expression has type b 1 + ( b 1 → b 2 ) Logics without this rule are called constructive . They’re useful because proofs “know how the world is” and “are executable” and “produce examples” Can still “branch on possibilities” by making the excluded middle an explicit assumption: (( p 1 + ( p 1 → p 2 )) ∗ ( p 1 → p 3 ) ∗ (( p 1 → p 2 ) → p 3 )) → p 3 Zach Tatlock CSE 505 Fall 2013, Lecture 12 27

  28. Classical vs. Constructive, an Example Theorem: There exist irrational numbers a and b such that a b is rational. Classical Proof: √ 2 . Either x x is rational or it is irrational. Let x = √ If x x is rational, let a = b = 2 , done. If x x is irrational, let a = x x and b = x . Since 2 � √ 2 � √ √ √ √ √ √ 2) = 2 = 2 , done. ( 2 · 2 = 2 2 Well, I guess we know there are some a and b satisfying the theorem... but which ones? LAME. Constructive Proof: √ Let a = 2 , b = log 2 9 . √ log 2 9 = 9 log 2 √ 2 = 9 log 2 (2 0 . 5 ) = 9 0 . 5 = 3 , done. 2 Since To prove that something exists, we actually had to produce it. SWEET. Zach Tatlock CSE 505 Fall 2013, Lecture 12 28

  29. Classical vs. Constructive, a Perspective Constructive logic allows us to distinguish between things that classical logic just crudely lumps together. Consider “ P is true.” vs. “It would be absurd if P were false.” ◮ P vs. ¬¬ P Those are different things, but classical logic is too clumsy to tell. Our friends G¨ odel and Gentzen gave us this nice result: P is provable in classical logic iff ¬¬ P is provable in constructive logic. Zach Tatlock CSE 505 Fall 2013, Lecture 12 29

  30. Fix A “non-terminating proof” is no proof at all. Remember the typing rule for fix : Γ ⊢ e : τ → τ Γ ⊢ fix e : τ That let’s us prove anything! Example: fix λx : b. x has type b So the “logic” is inconsistent (and therefore worthless) Related: In ML, a value of type ’a never terminates normally (raises an exception, infinite loop, etc.) let rec f x = f x let z = f 0 Zach Tatlock CSE 505 Fall 2013, Lecture 12 30

Download Presentation
Download Policy: The content available on the website is offered to you 'AS IS' for your personal information and use only. It cannot be commercialized, licensed, or distributed on other websites without prior consent from the author. To download a presentation, simply click this link. If you encounter any difficulties during the download process, it's possible that the publisher has removed the file from their server.

Recommend


More recommend