Introduction
In the previous Propositional Logic Introduction chapter, we got an introduction to the most basic area of logic. We learnt what is propositional logic and its most fundamental concept — propositions.
Now in this chapter, we shall unravel the two categories of propositions: simple and compound.
Let's begin!
What are atomic propositions?
We'll start by answering the question: what exactly is an atomic proposition?
As the name clearly suggests:
It's the simplest of propositions.
For example here are a handful of atomic propositions:
- C++ is easy.
- JavaScript was created by Brendan Eich.
- CSS stands for Cascading Style Sheets.
- HTML is a web standard.
Why are they atomic? Simply because we can't divide them any further. They are the simplest they could be.
Atomic propositions, also known as primitive propositions, are the primitive, building blocks of propositional logic. They sit right at its foundation.
New propositions can be made by combining atomic propositions with connectives. These new propositions are formally called compound propositions.
Let's see what are they...
What are compound propositions?
Simply:
It is said to be composed of atomic propositions.
Compound propositions are also known as molecular propositions (analagous to the concept of a molecule in chemistry which is comprised of atoms).
But how do we combine simple propositions together to form a compound?
Well, we use something called connectives.
Following the most intuitive way to think about it, how can you combine the following two sentences (propositions) into one single sentence, just in plain English:
- Java is low-level.
- London is the capital of England.
Well, one way is to use the word 'and'.
Here's the compound sentence we could form by using 'and' and the two aforementioned sentences.
Notice how we can divide this sentence further into simpler sentences. There is room for extracting out simpler statements from this proposition. Hence, we say that it is a compound proposition.
Let's consider another example:
This time, we've used the word 'or' which is another common connective used in English. What we have is, clearly, a compound statement.
Now that we know this, let's make more compound propositions...
Long compound propositions
Let's say you are given the following atomic propositions:
- C is easy.
- Python is high-level.
- Java is challenging.
and have been asked to create a compound sentence using all of them and the word 'and'. What sentence would you get in the end?
Simple as it is, you'll get the following:
Easy, wasn't it?
Now, let's take it to the next level. Suppose you have the following ten sentences and have to do the same thing — create a compound sentence using all of them and the word 'and':
- C is easy.
- Java is challenging.
- Python is high-level.
- Maths is easy.
- Computers are intelligent.
- AI stands for Artificial Intelligence.
- Codeguage is a free learning platform.
- London is the capital of England.
- Ruby is a dynamically-typed language.
- Python is simple to use.
Let's form the sentence:
As you can realise, things start to become quite long. We are losing simplicity, yet what we have here is a really simple-to-understand sentence — it's a mere connection of simple statements using the connective 'and'.
Imagine, having 20 or 30 such propositions, or the same number of propositions but longer in length... Where would we end up?
In complete mess..
Any solutions? Well, yes — use propositional variables.
What are propositional variables?
A propositional variable is similar in idea to variables that we use in algebra in that it also holds on to something.
In algebra, the variables hold numbers or expressions, but in propositional logic, the variables hold propositions. So simple!
So, let's define the idea formally:
Conventionally, the symbols ::p, q, r, s, t, ...:: are used as propositional variables.
But there is absolutely no one stopping you from using ::a, b, c, ...::, or Greek symbols such as ::\phi, \delta, \sigma::, or even some abbreviations, or short phrases, such as ::\mathrm{PLEasy}::
for 'Propositional Logic is easy'.
Let's see how can we use propositional variables to simplify the last task that we had to do above, of joining the given ten statements.
We'll start by assigning each of the given propositions to a variable:
- ::\pmb{p}::: C is easy.
- ::\pmb{q}::: Java is challenging.
- ::\pmb{r}::: Python is high-level.
- ::\pmb{s}::: Maths is easy.
- ::\pmb{t}::: Computers are intelligent.
- ::\pmb{u}::: AI stands for Artificial Intelligence.
- ::\pmb{v}::: Codeguage is a free learning platform.
- ::\pmb{w}::: London is the capital of England.
- ::\pmb{x}::: Ruby is a dynamically-typed language.
- ::\pmb{y}::: Python is simple to use.
Next, we'll take each of these variables and combine them together using the word 'and':
See how simple the sentence now looks. It is still the same compound proposition as the one shown above; it's just that this time it's expressed in terms of variables.
And it's not just about working with these sentences in English that variables help us in — when we start to manipulate propositions algebraically, or represent the semantics (meaning) of operators using truth tables, having variables will prove to be extremely handy.
They can save us from having to rewrite given propositions again and again, thus making the whole process of working with propositions a lot more intuitive and easier.
Moving on...
In the next chapter, we would explore in detail the things that help in combining atomic propositions together into compound propositions; formally known as logical operators. Here we only saw two of them — 'and' and 'or' — and they too were not explored formally to the core.
All this discussion awaits us in the next chapter, so let's keep going!