Clear as the sun explanation of De Morgan’s laws
Sometimes, novice developers struggle with basic logic expressions, especially De Morgan’s laws. To help with this, I have prepared a simple explanation.
The following examples were made using a small React app that I created for this article. You can choose to download and play with it or not 😀️. The following text doesn’t require the app installation.
Step 1. Where are we from
Ok. Let start with the basics. How looks a&&b
result? I think everybody knows:
data:image/s3,"s3://crabby-images/4bd83/4bd837fb737789663676b35f9046f27f32c05052" alt=""
Step 2. Let’s play with it
What if we negate b
in this expression? Just imagine the column where b
was true
will changed to false
, and vice versa. The matrix will be flipped horizontally, like reflection in a mirror!
data:image/s3,"s3://crabby-images/a5f65/a5f65e70dc57af8c9627c297446ecf304a087895" alt=""
And if we negate a
, it will be flipped vertically:
data:image/s3,"s3://crabby-images/043e2/043e2aefcc79c0ea026c4c4dbcc4a5307c2cb745" alt=""
Step 3. Try a little bit harder
What if we negate both a
and b
the same time? Right! The matrix will be flipped in both directions – horizontally and vertically:
data:image/s3,"s3://crabby-images/cd7f6/cd7f609578ed1e03c00ce8f42fb8d5b5877a3f85" alt=""
Step 4. The Final
Nice, and what if we negate the entire expression after negating a
and b
? In that case the values in the matrix will change from true
to false
, and vice versa:
data:image/s3,"s3://crabby-images/e9426/e942664b700247d321f8b86f6929b6762bd715e6" alt=""
But wait! It looks like matrix for a||b
!
data:image/s3,"s3://crabby-images/5fd6f/5fd6feaad2a0e5a0d68d0f0a577d4804d91c860b" alt=""
Actually that’s the de Morgan’s Law
!(!a&&!b) === a||b or !a&&!b === !(a||b)
I hope this article was helpful.
Leave a Reply