Propositional Logic. Grammatical Complexity A natural language is complex. E.g. –The dog chased the cat. –The dog that ate the rat chased the cat. –The.

Slides:



Advertisements
Similar presentations
Artificial Intelligence
Advertisements

Completeness and Expressiveness
Computing Truth Value.
Artificial Intelligence Chapter 13 The Propositional Calculus Biointelligence Lab School of Computer Sci. & Eng. Seoul National University.
Introduction to Theorem Proving
Resolution.
1 Logic Logic in general is a subfield of philosophy and its development is credited to ancient Greeks. Symbolic or mathematical logic is used in AI. In.
Inference and Reasoning. Basic Idea Given a set of statements, does a new statement logically follow from this. For example If an animal has wings and.
Logic Use mathematical deduction to derive new knowledge.
Propositional Logic CMSC 471 Chapter , 7.7 and Chuck Dyer
Intelligent Systems Propositional Logic.
Deduction In addition to being able to represent facts, or real- world statements, as formulas, we want to be able to manipulate facts, e.g., derive new.
Logic.
Logic Concepts Lecture Module 11.
Outline Recap Knowledge Representation I Textbook: Chapters 6, 7, 9 and 10.
Computability and Complexity 9-1 Computability and Complexity Andrei Bulatov Logic Reminder (Cnt’d)
Formal Logic Proof Methods Direct Proof / Natural Deduction Conditional Proof (Implication Introduction) Reductio ad Absurdum Resolution Refutation.
CSE (c) S. Tanimoto, 2008 Propositional Logic
Logic in Computer Science Transparency No Chapter 3 Propositional Logic 3.6. Propositional Resolution.
Existential Graphs and Davis-Putnam April 3, 2002 Bram van Heuveln Department of Cognitive Science.
Today’s Topics n Review Logical Implication & Truth Table Tests for Validity n Truth Value Analysis n Short Form Validity Tests n Consistency and validity.
From Chapter 4 Formal Specification using Z David Lightfoot
Knoweldge Representation & Reasoning
Let remember from the previous lesson what is Knowledge representation
Chapter 3 Propositional Logic
Proof by Deduction. Deductions and Formal Proofs A deduction is a sequence of logic statements, each of which is known or assumed to be true A formal.
Copyright © Cengage Learning. All rights reserved.
Propositional Logic Reasoning correctly computationally Chapter 7 or 8.
Propositional Logic Review
Intro to Discrete Structures
Inference is a process of building a proof of a sentence, or put it differently inference is an implementation of the entailment relation between sentences.
Proof Systems KB |- Q iff there is a sequence of wffs D1,..., Dn such that Dn is Q and for each Di in the sequence: a) either Di is in KB or b) Di can.
Propositional Resolution Computational LogicLecture 4 Michael Genesereth Spring 2005.
1 Knowledge Based Systems (CM0377) Lecture 4 (Last modified 5th February 2001)
Pattern-directed inference systems
Advanced Topics in Propositional Logic Chapter 17 Language, Proof and Logic.
Logical Agents Logic Propositional Logic Summary
1 Knowledge Representation. 2 Definitions Knowledge Base Knowledge Base A set of representations of facts about the world. A set of representations of.
Of 33 lecture 12: propositional logic – part I. of 33 propositions and connectives … two-valued logic – every sentence is either true or false some sentences.
Propositional Logic Dr. Rogelio Dávila Pérez Profesor-Investigador División de Posgrado Universidad Autónoma Guadalajara
LECTURE LECTURE Propositional Logic Syntax 1 Source: MIT OpenCourseWare.
Propositional Logic. Propositions Any statement that is either True (T) or False (F) is a proposition Propositional variables: a variable that can assume.
Automated Reasoning Early AI explored how to automated several reasoning tasks – these were solved by what we might call weak problem solving methods as.
Section 1.2: Propositional Equivalences In the process of reasoning, we often replace a known statement with an equivalent statement that more closely.
Extra slides for Chapter 3: Propositional Calculus & Normal Forms Based on Prof. Lila Kari’s slides For CS2209A, 2009 By Dr. Charles Ling;
CS6133 Software Specification and Verification
Dr. Shazzad Hosain Department of EECS North South Universtiy Lecture 04 – Part B Propositional Logic.
Outline Logic Propositional Logic Well formed formula Truth table
Foundations of Discrete Mathematics Chapter 1 By Dr. Dalia M. Gil, Ph.D.
Metalogic Soundness and Completeness. Two Notions of Logical Consequence Validity: If the premises are true, then the conclusion must be true. Provability:
1 Propositional Proofs 1. Problem 2 Deduction In deduction, the conclusion is true whenever the premises are true.  Premise: p Conclusion: (p ∨ q) 
Discrete Mathematical Structures: Theory and Applications 1 Logic: Learning Objectives  Learn about statements (propositions)  Learn how to use logical.
March 3, 2016Introduction to Artificial Intelligence Lecture 12: Knowledge Representation & Reasoning I 1 Back to “Serious” Topics… Knowledge Representation.
© Copyright 2008 STI INNSBRUCK Intelligent Systems Lecture II – xx 2009 Propositional Logic Dieter Fensel and.
Chapter 1 Logic and proofs
Logical Agents. Outline Knowledge-based agents Logic in general - models and entailment Propositional (Boolean) logic Equivalence, validity, satisfiability.
Logic.
Chapter 7. Propositional and Predicate Logic
Knowledge Representation and Reasoning
The Propositional Calculus
Propositional Logic.
Propositional Resolution
Back to “Serious” Topics…
The Logic of Declarative Statements
Propositional Logic Computational Logic Lecture 2
Logical Entailment Computational Logic Lecture 3
CSNB234 ARTIFICIAL INTELLIGENCE
Foundations of Discrete Mathematics
Propositional Logic CMSC 471 Chapter , 7.7 and Chuck Dyer
Propositional Logic Computational Logic Lecture 2
Presentation transcript:

Propositional Logic

Grammatical Complexity A natural language is complex. E.g. –The dog chased the cat. –The dog that ate the rat chased the cat. –The cherry blossoms in the spring … sank.

Ambiguity A natural language has ambiguity, e.g.: –There’s a girl in the room with a telescope. Which one of the figures the sentence intends to capture? In short we need to define a syntax.

Syntax

Propositional Constants Examples: –raining –r32aining –rAiNiNg –rainingorsnowing Non-Examples: – –raining.or.snowing

Compound Sentences Negations:  raining Conjunctions: (raining  snowing) The arguments of a conjunction are called conjuncts. Disjunctions: (raining  snowing) The arguments of a disjunction are called disjuncts.

Compound Sentences Implications: (raining  cloudy) The left argument of an implication is the antecedent. The right argument of an implication is the consequent. Reductions: (cloudy  raining) The left argument of a reduction is the consequent. The right argument of a reduction is the antecedent. Equivalences: (cloudy  raining) Notice that the constituent sentences within any compound sentence can be either simple sentences or compound sentences or a mixture of two.

Parenthesis Removal One disadvantage of our notation, as written, is that the parentheses tend to build up and need to be matched correctly. It would be nice if we could dispense with parentheses, e.g. simplifying ((p  q)  r) into p  q  r Unfortunately, we cannot do without parentheses entirely, since then we would be unable to render certain sentences unambiguously. For example, the sentence shown above could have resulted from dropping parentheses from either of the following sentences. ((p  q)  r ) (p  (q  r ))

Operator Precedence The solution to this problem is the use of operator precedence. The following table gives a hierarchy of precedences for our operators. The  operator has higher precedence than ,  has higher precedence than ,and  has higher precedence than , , and .    

Parenthesis Note that just because precedence allows us to delete parentheses in some cases, this doesn’t mean that we can dispense with parentheses entirely. E.g. (p  q)  s  r) Here, we cannot remove the parenthesis

Semantics

Algebra and Logic The semantics of logic is similar to the semantics of algebra. Algebra is unconcerned with the real-world meaning of variables like x and y. –What is interesting is the relationship between the variables expressed in the equations we write; and –algebraic methods are designed to respect these relationships, no matter what meanings or values are assigned to the constituent variables. In a similar way, logic itself is unconcerned with what sentences say about the world being described. –What is interesting is the relationship between the truth of simple sentences and the truth of compound sentences within which the simple sentences are contained. –Also, logical reasoning methods are designed to work no matter what meanings or values are assigned to the logical “variables” used in sentences.

Interpretation Although the values assigned to variables are not crucial in the sense just described, in talking about logic itself, it is sometimes useful to make these assignments explicit and to consider various assignments or all assignments and so forth. Such an assignment is called an interpretation. A propositional logic interpretation (i) is an association between the propositional constants in a propositional language and the truth values T or F. p  i  T p i  T q  i  F can be written alsoq i  F r  i  T r i  T

Operator Semantics The notion of interpretation can be extended to all sentences by application of operator semantics. Negation:  T F F T For example, if the interpretation of p is F, then the interpretation of  p is T. For example, if the interpretation of  p is T, then the interpretation of  p is F.

Operator Semantics (continued) Conjunction:  T T T T F F F T F F F F Disjunction:  T T T T F T F T T F F F

Operator Semantics (continued) Implication:  T T T T F F F T T F F T Reduction:  T T T T F T F T F F F T

Evaluation We can easily determine for any given interpretation whether or not any sentence is true or false under that interpretation. The technique is simple. We substitute true and false values for the propositional constants and replace complex expressions with the corresponding values, working from the inside out. We say that an interpretation i satisfies a sentence if and only if it is true under that interpretation. As an example, consider the interpretation i show below. p i  true q i  false r i  true We can see that i satisfies (p  q)  (  q  r). (true  false)  (  false  true) true  (  false  true) true  (true  true) true  true true

Evaluation (continued) Now consider interpretation j defined as follows. p j  true q j  true r j  false In this case, j does not satisfy (p  q)  (  q  r). (true  true)  (  true  false) true  (  true  false) true  ( false  false) true  false false Using this technique, we can evaluate the truth of arbitrary sentences in our language. The cost is proportional to the size of the sentence.

Reverse Evaluation Reverse evaluation is the opposite of evaluation. We begin with one or more compound sentences and try to figure out which interpretations satisfy those sentences. –One way to do this is using a truth table for the language. A truth table for a propositional language is a table showing all of the possible interpretations for the propositional constants in the language. –The interpretations i and j correspond to the third and seventh rows of this table, respectively. Note that, for a propositional language with n logical constants, there are n columns in the truth tables 2 n rows. p q r T T T T T F T F T T F F F T T F T F F F T F F F

Validity, Satisfiability, Unsatisfiability A sentence is valid if and only if it is satisfied by every interpretation. –p  p is valid. A sentence is satisfiable if and only if it is satisfied by at least one interpretation. –We have already seen several examples of satisfiable sentences. A sentence is unsatisfiable if and only if it is not satisfied by any interpretation. –p  p is unsatisfiable. No matter what interpretation we take, the sentence is always false. In one sense, valid sentences and unsatisfiable sentences are useless. Valid sentences do not rule out any possible interpretations; unsatisfiable sentences rule out all interpretations; thus they say nothing about the world. On the other hand, from a logical perspective, they are extremely useful in that, as we shall see, they serve as the basis for legal transformations that we can perform on other logical sentences. Note that we can easily check the validity, satisfiability, or unsatisfiability of a sentence can easily by looking at the truth table for the propositional constants in the sentence. In one sense, valid sentences and unsatisfiable sentences are useless. Valid sentences do not rule out any possible interpretations; Unsatisfiable sentences rule out all interpretations; thus they say nothing about the world. On the other hand, they are very useful in that, they serve as the basis for legal transformations that we can perform on other logical sentences. Note that we can easily check the validity, satisfiability, or unsatisfiability of a sentence by looking at the truth table for the propositional constants in the sentence.

Entailment We would like to know, given some sentences, whether other sentences are or are not logical conclusions. This relative property is known as logical entailment. A set of sentences  logically entails a sentence   |=   iff every interpretation that satisfies  also satisfies . E.g. The sentence p logically entails the sentence (p  q). Since a disjunction is true whenever one of its disjuncts is true, then (p  q) must be true whenever p is true. On the other hand, the sentence p does not logically entail (p  q). A conjunction is true if and only if both of its conjuncts are true, and q may be false.

Semantic Reasoning Methods Several basic methods for determining whether a given set of premises propositionally entails a given conclusion.

Truth Table Method One way of determining whether or not a set of premises logically entails a possible conclusion is to check the truth table for the logical constants of the language. This is called the truth table method and can be formalized as follows. –Starting with a complete truth table for the propositional constants, iterate through all the premises of the problem, for each premise eliminating any row that does not satisfy the premise. –Do the same for the conclusion. –Finally, compare the two tables. If every row that remains in the premise table, i.e. is not eliminated, also remains in the conclusion table, i.e. is not eliminated, then the premises logically entail the conclusion.

Simple sentences: Amy loves Pat. loves(amy, pat) Since we don’t have vars but only constants, it the same as saying lovesAmyPat. Amy loves Quincy. loves(amy, quincy) Same as lovesAmyQuincy It is Monday. ismonday Amy’s … Premises: If Amy loves Pat, Amy loves Quincy. lovesAmyPat  lovesAmyQuincy If it Monday, Amy loves Pat or Quincy. ismonday  lovesAmyPat  lovesAmyQuincy Question: If it is Monday, does Amy love Quincy? I.e. is ismonday  lovesAmyQuincy entailed by the premises?

Truth table for the premises lovesAmyPat lovesAmyQuincyismonday lovesAmyPat  lovesAmyQuincy ismonday  lovesAmyPat  lovesAmyQuincy T TTTT T T F TT T F T FT TF F FT FT T TT FT F TT FF T TF FF F TT

Crossing out non-sat interpretations lovesAmyPat lovesAmyQuincyismonday lovesAmyPat  lovesAmyQuincy ismonday  lovesAmyPat  lovesAmyQuincy T TTTT T T F TT T F T FT TF F FT FT T TT FT F TT FF T TF FF F TT

Truth table for the conclusion lovesAmyPat lovesAmyQuincyismonday ismonday  lovesAmyQuincy T TTT T T F T T F T F TF F T FT T T FT F T FF T F FF F T

Crossing out non-sat interpretations lovesAmyPat lovesAmyQuincyismonday ismonday  lovesAmyQuincy T TTT T T F T T F T F TF F T FT T T FT F T FF T F FF F T

Comparing tables Finally, in order to make the determination of logical entailment, we compare the two rightmost tables and notice that every row remaining in the premise table also remains in the conclusion table. –In other words, the premises logically entail the conclusion. The truth table method has the merit that it is easy to understand. It is a direct implementation of the definition of logical entailment. In practice, it is awkward to manage two tables, especially since there are simpler approaches in which only one table needs to be manipulated.

Validity checking One of these approaches is the validity checking method. It goes as follows. To determine whether a set of sentences {  1,…,  n } logically entails a sentence , we form the sentence (  1  …  n  ) and check that it is valid. To see how this method works, consider the problem of Amy and Pat and Quincy once again. In this case, we write the tentative conclusion as shown below. (lovesAmyPat  lovesAmyQuincy)  (ismonday  lovesAmyPat  lovesAmyQuincy)   ismonday  lovesAmyQuincy) We then form a truth table for our language with an added column for this sentence and check its satisfaction under each of the possible interpretations for our logical constants.

Unsatisfability Checking The satisfiability checking method is another single table approach. It is almost exactly the same as the validity checking method, except that it works negatively instead of positively. To determine whether a finite set of sentences {  1,…,  n } logically entails a sentence , we form the sentence (  1  …  n  ) and check that it is unsatisfiable. Both the validity checking method and the satisfiability checking method require about the same amount of work as the truth table method, but they have the merit of manipulating only one table.

A truth table… p qr p  qp  rp  r  q(p  q)  (p  r)  (p  r  q) p  r  q(p  q)  (p  r)  (p  r  q) T TTTTTTTT T T F TFTTFT T F T FTTTFT TF F FFFTFT FT T TTTTTT FT F TTTTTT FF T TTTTTT FF F TTTTTT

Proofs

Intro Semantic methods for checking logical entailment have the merit of being conceptually simple; they directly manipulate interpretations of sentences. Unfortunately, the number of interpretations of a language grows exponentially with the number of logical constants. –When the number of logical constants in a propositional language is large, the number of interpretations may be impossible to manipulate. Proof methods provide an alternative way of checking and communicating logical entailment that addresses this problem. –In many cases, it is possible to create a “proof” of a conclusion from a set of premises that is much smaller than the truth table for the language; –moreover, it is often possible to find such proofs with less work than is necessary to check the entire truth table.

Schemata An important component in the treatment of proofs is the notion of a schema. A schema is an expression satisfying the grammatical rules of our language except for the occurrence of metavariables in place of various subparts of the expression. For example, the following expression is a pattern with metavariables  and .  (  ) An instance of a sentence schema is the expression obtained by substituting expressions for the metavariables. For example, the following is an instance of the preceding schema. p  (q  p)

Rules of Inference The basis for proof methods is the use of correct rules of inference that can be applied directly to sentences to derive conclusions that are guaranteed to be correct under all interpretations. –Since the interpretations are not enumerated, time and space can often be saved. A rule of inference is a pattern of reasoning consisting of: –one set of sentence schemata, called premises, and –a second set of sentence schemata, called conclusions. A rule of inference is sound if and only if, for every instance, the premises logically entail the conclusions.

E.g. Modus Ponens    raining  wet raining wet wet  slippery wet slippery p  (q  r) p q  r (p  q)  r p  q r I.e. we can substitute for the metavariables complex sentences Note that, by stringing together applications of rules of inference, it is possible to derive conclusions that cannot be derived in a single step. This idea of stringing together rule applications leads to the notion of a proof.

Axiom schemata The implication introduction schema (II), together with Modus Ponens, allows us to infer implications.  (  ) The implication distribution schema (ID) allows us to distribute one implication over another. (  (  ))  ((  )  (  )) The contradiction realization schemata (CR) permit us to infer a sentence if the negation of that sentence implies some sentence and its negation. (  )  ((  )  ) (  )  ((  )  ) The equivalence schemata (EQ) capture the meaning of the  operator. (  )  (  ) (  )  (  ) (  )  ((  )  (  )) The meaning of the other operators in propositional logic is captured in the following axiom schemata. (  )  (  ) (  )  (  ) (  )  (  ) The axiom schemata in this section are jointly called the standard axiom schemata for Propositional Logic. They all are valid.

Proofs A proof of a conclusion from a set of premises is a sequence of sentences terminating in the conclusion in which each item is either (1) a premise, (2) an instance of an axiom schema, or (3) the result of applying a rule of inference to earlier items in sequence. 1. p  q Premise 2. q  r Premise 3. (q  r)  (p  (q  r)) II 4. p  (q  r) MP : 3,2 5. (p  (q  r))  (( p  q)  (p  r)) ID 6. (p  q)  (p  r ) MP : 5,4 7. p  r MP : 6,1

Proofs (continued) If there exists a proof of a sentence  from a set  of premises and the standard axiom schemata using Modus Ponens, then  is said to be provable from  (written as  |-  ) and is called a theorem of . Earlier, it was suggested that there is a close connection between provability and logical entailment. In fact, they are equivalent. A set of sentences  logically entails a sentence  if and only if  is provable from . Soundness Theorem: If  is provable from , then  logically entails . Completeness Theorem: If  logically entails , then  is provable from . The concept of provability is important because it suggests how we can automate the determination of logical entailment. –Starting from a set of premises , we enumerate conclusions from this set. –If a sentence  appears, then it is provable from  and is, therefore, a logical consequence. –If the negation of  appears, then  is a logical consequence of  and  is not logically entailed (unless  is inconsistent). –Note that it is possible that neither  nor  will appear.

Resolution

Intro Propositional resolution is an extremely powerful rule of inference for Propositional Logic. Using propositional resolution (without axiom schemata or other rules of inference), it is possible to build a theorem prover that is sound and complete for all of Propositional Logic. What's more, the search space using propositional resolution is much smaller than for standard propositional logic.

Clausal Form Propositional resolution works only on expressions in clausal form. Before the rule can be applied, the premises and conclusions must be converted to this form. A literal is either an atomic sentence or a negation of an atomic sentence. For example, if p is a logical constant, the following sentences are both literals: p,  p A clause expression is either a literal or a disjunction of literals. If p and q are logical constants, then the following are clause expressions p,  p, p  q A clause is the set of literals in a clause expression. For example, the following sets are the corresponding clauses: {p}, {  p}, {p,q} Note that the empty set {} is also a clause. It is equivalent to an empty disjunction and, therefore, is unsatisfiable.

Converting to clausal form 1. Implications (I):  1  2  1  2  1  2  1  2  1  2  (  1  2 )  (  1  2 ) 2. Negations (N):   (  1  2 )  1  2  (  1  2 )  1  2 3. Distribution (D):  1  (  2  3 )  (  1  2 )  (  1  3 ) (  1  2 )  3  (  1  3 )  (  2  3 ) (  1  2 )  3  1  (  2  3 ) (  1  2 )  3  1  (  2  3 ) 4. Operators (O):  1 ...  n  {  1,...,  n }  1 ...  n  {  1 }...{  n }

Examples g  (r  f ) I g  (  r  f ) N g  (  r  f ) D g  (  r  f ) O {g} {  r, f}  (g  (r  f )) I  (g  (  r  f )) N  g  (  r  f ))  g  (  r  f )  g  (r  f ) D (  g  r)  (  g  f ) O {  g,r} {  g,  f}

Propositional Resolution {  1,..., ,...,  m } {  1,..., ,...,  n } {  1,...,  m,  1,...,  n } E.g. {p,q} {  p,r} {q,r} The idea of resolution is simple. Suppose we know that p is true or q is true, and suppose we also know that p is false or r is true. One clause contains p, and the other contains  p. If p is false, then by the first clause q must be true. If p is true, then, by the second clause, r must be true. Since p must be either true or false, then it must be the case that q is true or r is true. In other words, we can cancel the p literals.

Example 1. {p,q} Premise 2. {  p, q} Premise 3. {p,  q} Premise 4. {  p,  q} Premise 5. {q} 1,2 6. {  q} 3,4 7. {} 5,6

Two finger (or pointer) method We keep two pointers (the slow and the fast); On each step we compare the sentences under the pointers. If we can resolve, we add the new derived sentence at the end of the list. At the start of the inference we initialize slow and fast at the top of the list. As long as the two pointers point to different positions, we leave the slow where it is and advance the fast. When they meet, we move the fast at the top of the list and we move the slow one position down the list.

Example (two finger method) 1. {p,q} Premise 2. {  p,r} Premise 3. {  q, r} Premise 4. {  r} Premise 5. {q,r} 1,2 6. {p,r} 1,3 7. {  p} 2,4 8. {  q} 3,4 9. {r} 3,5 10. {q} 4,5 11. {r} 2,6 12. {p} 4,6 13. {q} 1,7 14. {r} 6,7 15. {p} 1,8 16. {r} 5,8 17. {} 4,9

TFM With Identical Clause Elimination 1. {p,q} Premise 2. {  p,r} Premise 3. {  q, r} Premise 4. {  r} Premise 5. {q,r} 1,2 6. {p,r} 1,3 7. {  p} 2,4 8. {  q} 3,4 9. {r} 3,5 10. {q} 4,5 11. {p} 4,6 12. {} 4,9

Another TFM example 1. {p,q} 2. {p,  q} 3. {  p,q} 4. {  p,  q} 5. {p} 1,2 6. {q} 1,3 7. {  q, q} 2,3 8. {p,  p} 2,3 9. {q,  q} 1,4 9.5 {p,  p} 1,4 10. {  q} 2,4 11. {  p} 3, {q} 3,5 13. {  q} 4,5 14. {p} 2,6 15. {  p} 4,6 16. {p,q} 1,7 17. {  q, p} 2,7 18. {  p,q} 3,7 19. {  q,  p} 4,7 20. {q} 6,7

continued 21. {  q, q} 7, {  q, q} 7, {q, p} 1,8 24. {  q, p} 2,8 25. {  p,q} 3,8 26. {  p,  q} 4,8 27. {p} 5,8 28. {  p, p} 8,8 29. {  p, p} 8,8 30. {p,q} 1,9 31. {  q, p} 2,9 32. {  p, q} 3,9 33. {  q,  p} 4, {q} 6,9 35. {  q,q} 7,9 36. {q,  q} 9,9 37. {q,  q} 9,9 38. {p} 1, {  p} 3, {} 6,10

Proof With Identical Clause Elimination 1. {p,q} 2. {p,  q} 3. {  p,q} 4. {  p,  q} 5. {p} 1,2 6. {q} 1,3 7. {  q, q} 2,3 8. {p,  p} 2,3 9. {q,  q} 1,4 10. {  q} 2,4 11. {  p} 3,4 12. {} 6,10

Motivation for Tautology Elimination A tautology is a clause with a complementary pair of literals. 1. {p,q} Premise 2. {p,  p} Premise 3. {p,q} 1,2

Proof with TE and ICE 1. {p, q} 2. {p,  q} 3. {  p, q} 4. {  p,  q} 5. {p} 1,2 6. {q} 1,3 7. {  q} 2, 4 8. {  p} 3,4 9. {} 6,7