forked from abhusnurmath/592Notes
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy path11_BasicLogic.tex
240 lines (156 loc) · 9.78 KB
/
11_BasicLogic.tex
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
\documentclass[12pt]{article}
\usepackage{amsfonts,amssymb}
\usepackage{amsmath}
\usepackage{amsthm}
\usepackage{hyperref}
\usepackage{graphicx}
\usepackage{listings}
%\documentstyle[12pt,amsfonts]{article}
%\documentstyle{article}
\setlength{\topmargin}{-.5in}
\setlength{\oddsidemargin}{0 in}
\setlength{\evensidemargin}{0 in}
\setlength{\textwidth}{6.5truein}
\setlength{\textheight}{8.5truein}
%
%\input ../adgeomcs/lamacb.tex
%\input ../mac.tex
%\input ../mathmac.tex
%
\input xy
\xyoption{all}
\def\fseq#1#2{(#1_{#2})_{#2\geq 1}}
\def\fsseq#1#2#3{(#1_{#3(#2)})_{#2\geq 1}}
\def\qleq{\sqsubseteq}
\newtheorem{theorem}{Theorem}
%cis51109hw1
%
\begin{document}
\begin{center}
\fbox{{\Large\bf Basic Logic}}\\
\vspace{1cm}
\end{center}
\vspace{0.5cm}\noindent
\section*{Proposition}
A proposition is a statement that is either true or false. For instance `Philadelphia is the capital of Pennsylvania' is a proposition, since that is a false statement.
Things that do not have a true-false answer are not propositions. For instance, the most commonly asked `What is today's weather going to be like'.
Propositional variables such as p, q and r can be used to denote arbitrary propositions, as in "p: January has 31 days".
\section*{Boolean operators}
This section will be assumed knowledge. The only reason we go through this is to introduce the syntax we will use for our course.
Conjunction operator (AND) will be denoted by $\wedge$ - use $\text{\textbackslash wedge}$ in latex.
Disjunction operator (OR) will be denoted by $\vee$ - use $\text{\textbackslash vee}$ in latex.
Exclusive or (XOR) will be denoted by $\oplus$ - use $\text{\textbackslash oplus}$ in latex. Remember that $p \oplus q$ is true only when exactly one of the propositions is true.
NOT will be denoted by $\neg$ - use $\text{\textbackslash neg}$ in latex.
One of the first things to learn in logic is expressing English sentences in a more mathematical form using logical connectives.
As an example consider the statement - 'Dinner is eaten in our house at 7pm or at 8pm'. If we wanted to express this in terms of logical connectives, we can break this down into
\begin{align*}
p: & \text{I eat dinner at 7 pm} \\
q: & \text{I eat dinner at 8 pm}
\end{align*}
Then it seems like the most logical way of expressing the statement would be to write $p \vee q$. But if we pause for a moment we realize that one aspect of the English sentence is not really being captured. If we eat dinner at 7pm, can we say something about dinner being eaten at 8pm? Generally speaking, the English language uses the word or in the sense of exclusive or. So really if we wanted to capture the full meaning of our English sentence we should be saying $p \oplus q$.
This example might seem like an exaggeration of English ambiguities, but it is important to understand that if we want to make a computer work in a normal deterministic fashion, then the more clearly we can express thoughts and commands, the simpler it is to get the computer to do its job.
\textbf{The order of operations for Boolean algebra}. The normal order of operations for Boolean algebra is the following
\begin{enumerate}
\item $\neg$
\item $\wedge$
\item $\vee$
\end{enumerate}
\section*{Truth Tables}
Truth tables are definitely things that we assume you have seen by this point. Either as a past course or in CIT593 (Note: will be covered in class if someone says they have not seen them at all). If you do not know what a truth table is, please set up a 10-15 min meeting with a TA or the instructor. They are not hard!
\section*{De-Morgan}
For the simplification of Boolean expressions, the only rule that we need you to know is De-Morgan's law for booleans
\begin{itemize}
\item $\neg(p \vee q) = \neg p \wedge \neg q$
\item $\neg(p \wedge q) = \neg p \vee \neg q$
\end{itemize}
\section*{Conditional statements}
The "if-then" type of statement has specific rules when it comes to logic. Generally called an implication, it is expressed as $p \rightarrow q$ where $p$ and $q$ are propositions.
Very importantly, $p \rightarrow q$ is itself a proposition and it has a truth value which is determined from the following truth table.
\begin{tabular} {l c r}
p & q & $p \rightarrow q$ \\
T & T & T \\
T & F & F \\
F & T & T \\
F & F & T
\end{tabular}
The first part of a conditional is called the hypothesis and the second is called the conclusion. The hypothesis being false gives you no evidence for the truth value of the implication and the way that mathematical logic works, you go with the `innocent until proven guilty' idea.
We have been using this already when we have discussed whether or not the less-than relationship is anti-symmetric.
\subsubsection*{Expressing conditionals in English}
The following all express $p \rightarrow q$ in English
\begin{enumerate}
\item If p then q
\item If p, q
\item q if p
\item p only if q
\item p implies q
\item p is sufficient for q
\item q is necessary for p
\end{enumerate}
Also important to remember this
\begin{equation*}
p \rightarrow q \text{ is equivalent to } \neg p \vee q
\end{equation*}
This formula(or equivalence) can be verified by means of a truth table.
\subsubsection*{Contrapositive, Converse and Inverse}
There are 3 statements that are closely related to $p \rightarrow q$.
They are
\begin{itemize}
\item Contrapositive $\neg q \rightarrow \neg p$
\item Converse $q \rightarrow p$
\item Inverse $\neg p \rightarrow \neg q$
\end{itemize}
\section*{Predicates and Quantifiers}
Many mathematical statements contain variables. Statements that contain variables are different from propositions because their truth value depends on the value of the variable. A logical statement that is a function of variable(s) is called a predicate. A predicate always has an underlying domain associated with it. Variables are only allowed to take values from within the domain.
\medskip
\textbf{Universal quantifier}
Sometimes we want to assert that a predicate is true regardless of the value taken from the domain. This is a universally quantified predicate and is represented with the $\forall$.
\begin{align*}
\forall x \in \mathbb{R^+} \; \frac{1}{x+1} < 1
\end{align*}
Proving a universally quantified statement is \textbf{True} requires showing that it is true regardless of the value of any variables that are present in the statement.
\begin{align*}
\frac{1}{x+1} = 1 - \frac{x}{x+1} \\
x \in \mathbb{R^+} \rightarrow x + 1 \in \mathbb{R^+} \\
\text{Therefore } \frac{x}{x+1} \in \mathbb{R^+}\\
\text{Therefore } 1 - \frac{x}{x+1} < 1, \; \forall x \in \mathbb{R^+}
\end{align*}
Proving a universally quantified statement is \textbf{False} is easier. It just requires one counter example.
For example $\forall x \in \mathbb{R}, \, x^2 > x$ is a false statement because for $x = 0$, $x^2 = x$.
\medskip
\textbf{Existential quantifier}
If there is at least one value in the domain that causes the predicate to evalute to true, that is expressed using an existential quantifier $\exists$.
To prove an existentially quantified statement, you just need to show one single value that makes the statement true.
For instance, to prove the statement `There is a natural number n such that $2^n > n!$' all you have to do is say that for $n=2$, $2^2 > 2!$ because after all $4 > 2$.
What will proving an existential statement is False involve? That is the same as proving that no value in the domain will make the statement True.
For instance to prove that $\exists x \in \mathbb{R^+}, \, x + 1 < x$ is a false statement the following approach can be used.
\begin{align*}
& x + 1 < x
\\ & \implies 1 < 0 \tag{ by subtracting x from both sides}
\end{align*}
And $1 \not < 0$ therefore proved.
\subsection*{Writing English statements with quantifiers}
Now that we have seen quantifiers, we can express more English sentences using them.
\medskip
\emph{Every CIT592 student has taken the midterm.}
Assume $x$ is a variable that comes from the domain of all MCIT first year students.
Then this would be one way of writing the above statement.
Let P(x): x is a student in 592.
Let Q(x): x has taken the midterm.
$\forall x P(x) \rightarrow Q(x)$
\section*{Negating quantified statements}
It is important to be able to express the negation of a quantified statement.
Consider the statement `All birds fly'. To write this as a quantified statement you will probably consider $x$ to come from the domain of all birds and let $F(x)$ be a predicate that is true when $x$ can fly. $\forall x, \, F(x)$.
What if we wanted to negate that statement. In English we would simply say 'Not all birds fly'. Which actually can be equivalently stated as 'There is at least one bird that does not fly'. That brings us to more familiar territory as far as expressing things with quantifiers goes.
$\neg (\forall x \, F(x)) \equiv \exists x \; \neg F(x)$
The sign placed between the two quantified statements is the logical equivalence sign. That is saying that whenever the left statement is true, the right statement is true and whenever the left statement is false then the right statement is false.
Similarly consider the statement `There is some student that proved Fermat's last theorem'. Let us assume the domain is the set of all students. And let FLT(x) be true if the student proved Fermat's last theorem. Then the statement is saying $\exists x FLT(x)$.
What if we negate the statement. In English we might simply say there is no student that proved Fermat's last theorem. That is the equivalent to saying for every student, it is true that they have not proven Fermat's last theorem. Or in other words,
\begin{align*}
\neg (\exists x \text{ } FLT(x)) \equiv \forall x \text{ } \neg FLT(x)
\end{align*}
In general, here are the two rules to remember when it comes to negating a quantified statement
\begin{align*}
\neg \forall x \; P(x) &\equiv \exists \; \neg P(x) \\
\neg \exists x \; P(x) &\equiv \forall \; \neg P(x)
\end{align*}
\end{document}