Lecture Slides
Total Page:16
File Type:pdf, Size:1020Kb
CPSC 121: Models of Computation Module 7: Predicate Logic and Inferences Module 7: Predicate Logic and Inferences By the start of class, you should be able to: Determine the negation of any quantified statement. Given a quantified statement and an equivalence rule, apply the rule to create an equivalent statement (particularly the De Morgan’s and contrapositive rules). Prove and disprove quantified statements using the “challenge” method (Epp, 4th edition, page 119). Apply universal instantiation, universal modus ponens, and universal modus tollens to predicate logic statements that correspond to the rules’ premises to infer statements implied by the premises. CPSC 121 – 2019W T2 2 Module 7: Predicate Logic and Inferences Quiz 7 feedback: Once again well done overall. One question seemed more difficult (next slide). Not much to say about the open-ended question: most people gave correct strategies. Great! CPSC 121 – 2019W T2 3 Module 7: Predicate Logic and Inferences Which of the following could be the result of applying one of the negation equivalence laws to the statement: ∀x∈ D, Q(x)→[( ∃ y ∈ D, P(x, y)) ∧~( ∀ y ∈ D, P(x, y))] a) ∀x ∈ D, Q(x) → F b) F c) None: we can not apply the law to just the right side of the statement. d) None: the law doesn't match the right side of the statement. ▷ CPSC 121 – 2019W T2 6 Module 7: Predicate Logic and Inferences CPSC 121: the BIG questions: How can we? convince ourselves? that an algorithm? does what it's supposed to do? ? ? We continue discussing how to prove various types of predicate logic statements that arise when we discuss algorithm correctness.? ? ? ? ? ? ? ? ? ? ? CPSC 121 – 2019W T2 8 Module 7: Predicate Logic and Inferences By the end of this module, you should be able to: Explore alternate forms of predicate logic statements using the logical equivalences you have already learned plus negation of quantifiers (a generalized form of De Morgan’s Law). CPSC 121 – 2019W T2 9 Module 7: Predicate Logic and Inferences Pre-class quiz #8 is due Thursday February 27th at 19:00. Assigned reading for the quiz: Epp, 5th or 4th edition: 4.1, 4.6, 4.7, Theorem 4.4.1 Epp, 3rd edition: 3.1, 3.6, Theorem 3.4.1. Rosen, 6th edition: 1.6, 1.7. 3.4 (theorem 2 only). Rosen 7th edition: 1.7, 1.8, 4.1 (theorem 2 only). Assignment #3 is also due Thursday February 27th at 19:00. CPSC 121 – 2019W T2 10 Module 7: Predicate Logic and Inferences Pre-class quiz #9 is tentatively due Sunday March 8th at 19:00 Epp, 5th or 4th edition: 12.2, pages 791 to 795. Epp, 3rd edition: 12.2, pages 745 to 747, 752 to 754 Rosen, 6th edition: 12.2 pages 796 to 798, 12.3 Rosen, 7th edition: 13.2 pages 858 to 861, 13.3 CPSC 121 – 2019W T2 11 Module 7: Predicate Logic and Inferences Summary Thinking of quantifiers differently. Transformations: allowed or forbidden? The challenge method. CPSC 121 – 2019W T2 12 Module 7.1: Thinking of quantifiers differently Suppose D contains values x1, x2, ..., xn What does ∀x ∈ D, P(x) really mean? It's the same as P(x1) ^ P(x2) ^ ... ^ P(xn). Similarly, ∃x ∈ D, P(x) ≡ P(x1) v P(x2) v ... v P(xn) Thinking of quantifiers this way explains Generalized De Morgan's laws. Universal instantiation Universal Modus Ponens, Tollens CPSC 121 – 2019W T2 13 Module 7.1: Thinking of quantifiers differently Generalized De Morgan's laws: ~∀ x ∈ D, P(x) ≡ ~(P(x ) ^ P(x ) ^ ... ^ P(x )) 1 2 n ≡ ~P(x ) v ~P(x ) v ... v ~P(x ) 1 2 n ≡ ∃x ∈ D, ~P(x) ~∃ x ∈ D, P(x) ≡ ~(P(x ) v P(x ) v ... v P(x )) 1 2 n ≡ ~P(x ) ^ ~P(x ) ^ ... ^ ~P(x ) 1 2 n ≡ ∀x ∈ D, ~P(x) CPSC 121 – 2019W T2 14 Module 7.1: Thinking of quantifiers differently Exercise: rewrite the following definition to eliminate the negation sign: ~ ∃c ∈ R+ ∃n ∈ N ∀n ∈ N, n ≥ n → f(n) ≤ cg(n) 0 0 CPSC 121 – 2019W T2 15 Module 7: Predicate Logic and Inferences Summary Thinking of quantifiers differently. Transformations: allowed or forbidden? The challenge method. CPSC 121 – 2019W T2 19 Module 7.2: Transformations (allowed or forbidden?) Universal instantiation: (∀ x ∈ D, P(x)) ^ (a ∈ D) → P(a) Proving it is a valid inference: Suppose ∀x ∈ D, P(x) is true. Hence P(x ) ^ P(x ) ^ ... ^ P(x ) holds. 1 2 n If a = x is an element of D, then by specialization i we have P(x ). i CPSC 121 – 2019W T2 20 Module 7.2: Transformations (allowed or forbidden?) Universal modus ponens: Suppose ∀x ∈ D, P(x) → Q(x) is true. P(x ) holds where x is an element of D. i i Hence (P(x ) → Q(x )) ^ ... ^ (P(x )→ Q(x )). 1 1 n n By specialization P(x ) → Q(x) holds. i i By modus ponens, we deduce Q(x ). i The same reasoning explains why universal modus tollens is valid. CPSC 121 – 2019W T2 21 Module 7.2: Transformations (allowed or forbidden?) Consider existential instantiation: ∃x ∈ D, P(x) a ∈ D \P(a) a) This argument is valid: P(a) is true. b) This argument is invalid: P(a) is false. c) This argument is invalid: P(a) might be false. d) This argument is invalid for another reason. ▷ CPSC 121 – 2019W T2 22 Module 7.2: Transformations (allowed or forbidden?) Applying logical equivalences to predicate logic: Suppose we have ∀x ∈ D, P(x) → Q(x) We know that P(x) → Q(x) ≡ ~P(x) v Q(x) We might want to write ∀x ∈ D, ~P(x) v Q(x) Is this valid? CPSC 121 – 2019W T2 26 Module 7.2: Transformations (allowed or forbidden?) Which propositional logic equivalences apply to predicate logic? a) Double negative, Identity, and De Morgan's (not all equivalences!) b) ~(P(x) → Q(x)) ≡ P(x) ∧ ~Q(x) c) Commutative, Associative, and the “definition of conditional” d) All propositional logic equivalences apply to predicate logic. e) None of the above. ▷ CPSC 121 – 2019W T2 27 Module 7.2: Transformations (allowed or forbidden?) Applying rules of inference to predicate logic: Suppose we have ∀x ∈ D, P(x) → Q(x) We know that ∀x ∈ D, P(x) We might want to write ∀x ∈ D, Q(x) Is this valid? CPSC 121 – 2019W T2 29 Module 7.2: Transformations (allowed or forbidden?) Which rules of inference apply to predicate logic? a) Modus ponens, modus tollens and elimination only. b) All rules apply, but only if they follow universal quantifiers, not existential quantifiers. c) All rules apply, but only if they follow existential quantifiers, not universal quantifiers. d) All rules apply, no matter what quantifiers are used. e) None of the above. ▷ CPSC 121 – 2019W T2 30 Module 7.2: Transformations (allowed or forbidden?) The only rules we really need: Universal Instantiation: for any a in D ∀x ∈ D, P(x) P(a) Universal Generalization: P(x) for an arbitrary element x of D ∀x ∈ D, P(x) CPSC 121 – 2019W T2 32 Module 7.2: Transformations (allowed or forbidden?) The only rules we really need (continued) Existential Instantiation: ∃x ∈ D, P(x) P(w) for an unspecified (new) witness w in D Existential Generalization: P(a) for a given element a of D ∃x ∈ D, P(x) CPSC 121 – 2019W T2 33 Module 7: Predicate Logic and Inferences Summary Thinking of quantifiers differently. Transformations: allowed or forbidden? The challenge method. CPSC 121 – 2019W T2 34 Module 7.3: The challenge method The Challenge method: A predicate logic statement is like a game with two players. you (trying to prove the statement true) your adversary (trying to prove it false). The two of you pick values for the quantified variables working from the left to right (i.e. inwards). You pick the values of existentially quantified variables. Your adversary picks the values of universally quantified variables CPSC 121 – 2019W T2 35 Module 7.3: The challenge method The Challenge method (continued): If there is a strategy that allows you to always win, then the statement is true. If there is a strategy for your adversary that allows him/her to always win, then the statement is false. What does it mean to have a winning strategy at Nim? CPSC 121 – 2019W T2 36 Module 7.3: The challenge method Example 1: ∃x ∈ Z, ∀n ∈ Z+, 2x < n How would we say this in English? How would we prove this theorem? Example 2: ∀n ∈ N, ∃x ∈ N, n < 2x How would we say this in English? How would we prove this theorem? CPSC 121 – 2019W T2 37 Module 7.3: The challenge method Example 3: ∃x ∈ N, ∀n ∈ N, n < 2x How would we say this in English? How would we prove this theorem? How do we prove a statement is false? CPSC 121 – 2019W T2 38.