# Boolean Logic and Truth Tables

**Computer programs use logic to control execution by comparing operands**. In the real world control and embedded systems frequently deal with individual bits in order to control specific operations or to determine the condition of part of a system. For example, a bit might be turned on to light a lamp or activate a relay, or a bit might be off to indicate a switch is on. Both systems are based on Boolean logic.

**Boolean logic**, developed by George Boole (1815-1864), is simply **a way of comparing operands or bits and determining their truth value**. It uses what are called **operators** to determine how the bits are compared. They simulate the **gates** that you will see in the hardware section you will read shortly.

**Think of operators as boxes with multiple inputs and one output**. Feed in various combinations of bit values, and the output will be high or low depending on the type of operation. The examples show 2 inputs, although gates can have more. Also, gates are often combined to form more complex logic. A modern microprocessor contains huge numbers of them with many inputs and many varying combinations. Please note that the terms **on**, **high** and **1** will be considered the same logical state, and **off**, **low** and **0** will be considered the same logical state in the discussions that follow. Typically **1 is used to indicate true and 0 is used to indicate false** and in the C programming language true is actually any value not equal to 0 and this can be used in powerful ways.

The Boolean operators used most often are **AND** and **OR and NOT**. The **AND** operation says if and only if **all** inputs are on, the output will be on. The output will be off if any of the inputs are off. The **OR** operation says if **any** input is on, the output will be on. The **NOT** operator negates the input (e.g. True  False and False  True). It's easy to see all of the combinations by using what are called **Truth Tables**, illustrated below. At the bottom of each table is shown the schematic symbol found in circuit diagrams.

# Basic Logic Gates

There are three basic logic gates each of which perform a basic logic function, they are called NOT, AND and OR. All other logic functions can ultimately be derived from combinations of these three. For each of the three basic logic gates a summary is given including the *logic symbol* , the corresponding *truth table* and the *Boolean expression*.

## The NOT gate

The NOT gate is unique in that it only has one input. It looks like

The input to the NOT gate is *inverted* i.e the binary input state of 0 gives an output of 1 and the binary input state of 1 gives an output of 0.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAASIAAABaCAYAAAAcuFuuAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAARJSURBVHhe7djtjqM4EAXQ3n3/d56VpUaTRXyUiQ1lc86flqYTOmNfLq7880NWf35/LuwV0xLuvNZFtLBnTOff35+MY6+gYFiernlFCsf+MQVBzqvm5GMfGZrRbA7GNYbmSZrX1XKxpwxHaPNaF9GyV9GCsrcMQ1jz2iuihUJiGr4jGle0YK6OeHAbT8u8zk5En5yOGJpg5lVTRAuFxJCMZnMpBdOysOAWimhO0TJSSKTgiJ7XldFsi3GN9IQvr1ZFtFBIpGU0e49owRjXuJ2nX16tT0SfnI5IRdDy6llEC4VECkazdysFEykZ4xpdKSKKaBkpJLpw5M7rjtFsi3GN2wlTXk8V0UIhcRujGXuiBWNc42ueZnk9fSL65HREV4KTV6YiWigkujCaUaMUTKRkjGtUUURcES0jhUSII3ReGUezLcY1viYceY1SRAuFxGVCkddoRVQoo7lE9/NIaK99R0RLJXSR4JWAtwg5k/BkymvEE9GaExIhTkT0VHNC4sWuFpGjNTWiZSRTY2m2Z1eOxOs/7Fjdx6zrHA2uXOXWNJ+KKK/Z17lXIe1dV07berSIbPJ9Zi+iomUZtbwWx5r3gC+reVIJbrRkjoomWkJFzWu5SU2DfW7g8r6tf6ON9Q3zhvWNlsTnWlwtFnm9pksPOBGRSQlxJMhn5bNcJ3o9HhbdpKPG+7oN2bS+2d62tmdls2dvnbauJ691uvVA9A3dPgC71jfOW9d2vQ5Hztao5lqz+iZH3Xog8obIH7j6IQQjrnpzJxPJytkaydv1HPXsAd8RMYy3F/HUIptb+xSpCYwnVJwb8TwvZ2skb9dz1LMHum1c9EMIRtzVAM2gJid767R1jTevaY3ePXD6ws8P0PK1nFtv/hvXtNUNsHUdGY3r3gNHL7xywUsfgk3rm+dt67n+/28paxJ53Rb5jLmlB3xZTTYlxNES+vxZQwkls7chV1pw8c17+Wt9M86+lpHyKSKZPSKTcbf1gBMRTyuBjZRICfNRoL/9PQ+yMXmtb84Z9ypSQIWcTs4G5zVzESkg/sdG5zVjESkgNvmOiLtESqgUkBJ6IUVEb6WAoiXES9n8vEYfzYxhhAlBXqMWkQKimtGMlpQQlwhEXiOdiBQQXxGMvEYoIgVEE0YzroqUUCkgJcQpRUStUkDREoIQYckr22hmDKMbockrSxEpILozmnFECXELAcrryRORAuJWgpTXE0WkgHiE0YxFpIRKASkhmlNElAKKlhB0IVx59R7NjGGkIWR59SoiBUQ6RrN3UUKkJHB5tTwRKSBSE7y8WhSRAmIIRrN5RUqoFJAS4nGKaD6lgKIlBCkIY161o5kxjGEJZV7RIlJADM9oNjYlxBQENK+jE5ECYiqCmtdWESkgpiSweUVL55P9ZEi+I5qHEmJYwpuXMYzXEOK8zorI3jENo9mYlBBTEei8tk5E9ospORGNQwkxqZ+f/wBvf8mD9EMMdAAAAABJRU5ErkJggg==)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAAWCAYAAAA1vze2AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAABrSURBVEhL7ZGLCoAwCACt///nIlCIUDsHNYMOxkDm45z8fJ5NT4lFb8K1OM5d9X4UOk20IpTfxuRsYe+9WEgLk2xibDPdhEyKbFqZEMJaZA0V3HqkSWZ7cPvWC1YaGGnOlI8fsTDC3BdMRHbsDBIXDeH93gAAAABJRU5ErkJggg==)

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAAWCAYAAAA1vze2AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAB1SURBVEhL7ZHBCgAhCESt///nXYKELdTGYstD7xKEmq9J1PLUc5Vmbq7n5RdKZu7c+uAt+uFw75bg0W20L4L6w5h8LbheulMJYWJtDNscN0E2hWxCmSCos5Bv8CDOQx6xbAvDWunS8wBj9hwJfsaCUXs3mBC9o4sTGisUAzYAAAAASUVORK5CYII=)is known as "NOT A" or alternatively as the *complement* of ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAAWCAYAAAA1vze2AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAABrSURBVEhL7ZGLCoAwCACt///nIlCIUDsHNYMOxkDm45z8fJ5NT4lFb8K1OM5d9X4UOk20IpTfxuRsYe+9WEgLk2xibDPdhEyKbFqZEMJaZA0V3HqkSWZ7cPvWC1YaGGnOlI8fsTDC3BdMRHbsDBIXDeH93gAAAABJRU5ErkJggg==). The truth table for the NOT gate appears as below

|  |  |
| --- | --- |
|  |  |
| 0 | 1 |
| 1 | 0 |

## The AND gate

The AND gate has two or more inputs. The output from the AND gate is 1 if and only if all of the inputs are 1, otherwise the output from the gate is 0. The AND gate is drawn as follows

The output from the AND gate is written as (the dot can be written half way up the line as here or on the line. Note that some textbooks omit the dot completely).

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAUEAAABYCAYAAABroEXWAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAQ8SURBVHhe7dqLbuM2EAXQtP//zy3UjQuZlvjQgxY55wBBgKxsLTjDy1Gcv37o7Z/f77TTr1xOU/UnBK+lhzlFA/UnBO+lp2miYfoTgv3ob4o0SX9pCKpBnTOHhzVml+boTwheqyUcrTUfNEV/QvA+tYFozfmfZuhPCPZRE4jWHk3wBUKwL2FIluL3JwS/JxeI6hDU37/fIYJc0C0BWTM1MhkhSDRLEJbCkECEIFHlwlAQBiIEiU4QBicEQRCG1hqCS1NoDGa093is3yfXEoLrZtAYzEoQBuNxGD4JwkBqQ3CrATQFMxOEQZgEYZ8gDKAmBNdFX5pi3RgagtkJwsmZBIHQSiGYToEvpkEiMQ1OzCQIdQThpLYK+7I3Ba7VXJPSOO9q143v2+pd9RucSRDqbQWeQ31wuVOstbgmwWNMEuNJe1gNB7Y3CR4JKuFGVHp/YHsn2LqopVOu5Vo+N4w1G5M6TmJrEmwNtfU1aWMAPJoPRuCYdEAwAAwqV8jW8f7MayNJN4u1Gpda1nmt05Xrk659ye69TYLAndZh1RpcV9q9t5Orv7QYajA29cy7a33W75t7z+L9TYLAXdIAWmz97E7F0BWCQGhCELhD+ri6nsh6T4NZQhDOSR+3HrXB+QjjD8XnZS6XbhI1GJ+avssFTzGUfr2u27smXfOS3XtFL9Y32DDzad2Qoyv1bC7ocv/2UrNHjqz55v08DgNXKoXc+mdHgmzL8p57X2ub9xOCwNOswysNslbF15+9Ae1qRn3GctVEM4pcz7auxdH+X9+n5j12r7cB+xOC81HTP1oD8OXIel0Wgh6HgTssQZP7egwhCFyhdTJbX3N0gqyV/b8JQWBmxYB91FgaRFoUNRjb1iaLVtPspFVw9LXFcNuw+f4mQbiWQ+15lprs1kXB+jMJzkU9B2cSBEITgkBoQhCO8yg8ASEIhLZ1crV+9Oz0a2N6mIdaTuCKSbA1NGEG+n4SpUkwd7I5BY+xbnNQx0mcmQQVnahMgRPxwQicZyAYmBCENqbAyWydYOsi50642utSmuidKWIsaf+q3+BKIVijtQmE4DubaBxbvat+g/MnMnCcAJxAaRLMFTkNv9qGEJrvbKQxmAIndSYEFy3X8sfRw4PvEYATO/s4vG6ErUYBeDR/IgN5psDJCUHYJwADOBuC6ybRHMxEAAZxJgT9DpBZ6e1Atk62Iw3ghKyXrq+1e5a9/lenSV3x6bDmYBYCMCDF7c8k+EwCMCifDoMADE0IEtkSfgIwOCFIVHvhtxCAgQhBIspNfwIwGCFIJB5/+SAEiSAXfgsBGJji95duRjW4Ty74FtYekyBTKk1+CwHIfzRCfybBe5RC78V680ZD9CcEr1Ebei/WmU0aoz8h2K418NasL1kapL8zG5o6+ppqmqU/IXgPvcwhGqc/IXgd/ctpmqg/IdhOn3KTn59/AdR1so9EvWQEAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADIAAAASCAYAAAAZk42HAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADPSURBVEhL1ZXBDsMgDEPZ/v+fu0UqUpo6boxgGu/CJXGCjcSraRznqfYxumYVOPt9nhX8QHX4TOBsxdkoMCsVr8s06fxqIsgF6MxCqHHK0/prKheJ0Xtnfp1Kyk6JREMv0Hf3hTVTYUevy2rUVKHO6kT8kurCGVCn4qRRcRPVxKFPNdV9jEvt6kT8MLZkBdqvOPDE6KLVRDqwPktEvYQx0jONzAHFJdXRiNoP61EiqrCv8b0rSHfb9UO8ER1X0/CM9o6keNPfKRHDLgBMau0DZo8pGSEgpGYAAAAASUVORK5CYII=)

The truth table for a two-input AND gate looks like

|  |  |  |
| --- | --- | --- |
|  |  |  |
| 0 | 0 | 0 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

It is also possible to represent an AND gate with a simple analogue circuit.

**Short Circuit Evaluation**

We and the computer always strive for efficiency. Have a look at the above truth table. Is there any condition where we can evaluate just a single operand (input) to determine the result thereby saving the computation time to evaluate the 2nd operand in conjunction with the 1st operand?

Note the AND operator is also known as logical conjunction and is also represented by ^

## The OR gate

The OR gate has two or more inputs. The output from the OR gate is 1 if any of the inputs is 1. The gate output is 0 if and only if all inputs are 0. The OR gate is drawn as follows

The output from the OR gate is written as

.

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAUoAAABbCAYAAAAV1MyPAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAUOSURBVHhe7dqBbuwmEAXQtP//z61os3qOgzFgwNicI0V5yvNuNjPD9USbLwDS/vr+zDX/fH9ekRni9Qx5GysHZS6zxmMZ3jYEZT0zyPQMaRuCsi1zyVQMZB9nwfmmuo+6SZhVbmP4+kqFyGq1bx2oZpdhDNsYRyGh/m0CVB3pyoCNIyzzXQlP9aQ5QzWWsKxXE57qShMGaTxh2UZpcKov1WqH5zOkhq9O7JCrZb2S0FRnitUMzX4oDV4dYdlHbmiqNdkE5b2EZV85oanenCodkqPBM2z13Hj6E5hcIijvF6upevZzFppqzy8lQ7EdsM/jYl+j3P7wqmV/ApNsf39/5l77Q3l2iLku1DwVhqEH+sB/coNyOzDb4dr+21DxRDmByeJslPPYH1YHdKxUYIZe6MfCcoJyOyCxQdp+zTC1pZ7jHYVloB+LSg3Fx1lQBjnXbBm4fDn1pI+jOdWTxfQINUHZlkN5L2HJabNrA63X867KobxfbGb1ZRElgdbrWs45kHM4mlv9eblUg0uC76PmMfy2P5BqOQ9huSB/HgRlBOKCjpp+ZTO0VbZhq5xbbLPUo5eyUUKdWCge/VrOw7kDzstG+Qw2ywXYKJ/DtjInm+UCBOW8bCXPoVcvp8Fz8+v3c/gVPN+nViPqU7rdR1+TjRLaEIp5tsFVGmIjRF+T5s5t3zT9mp+epY2uz/b7pb5X8nXZKIFR9mEUxL52h2RgC8pnmWWoOLY/cHrWR6jr56M7QTm33r+W0Ie+/bYNtFCfbY2mv5kISujjUUHAryD/wZ1vfvtDpmfPkjyAi0jVoLY+uY/bn58z0eeyUcI44dCWHlz+96ldrIap/ysVffyqd7gn2TdOz57n6uGdXe5Gd3Rd6TVnts+R89zB/vl/XGujhP5SB5Q8oYbbj63U/+VKPk5QQn8l29CbhTrEPmaxDcsfr0tQQl8zBcFoNT/7lPWqXVMZZz84evYssYO/Sg+3P/vZz1xybZB7fZPntVHCOOHg5RzWNygNqO0128ce+dSyZT0PX7OghH5yDjxzSPaqZRrTx76BevYchxvKy135uVvXLBmAB359Xxsl9FFzQLlXCMhoOOckdmnDW9wF+GNff/V9Bn17kR4bpTtpOw7bMzkDL1O6Uaaud6jbU9Nn0reXablRGgawTb6SN3OgLwvECwhKaMc2+VItg3I7JO6i4By8Rk4jS++ShqMdbwo8R+yc6NdL9AjK4Ox5a55zdQ7dvITky5UGZer6/bCUXMs5B29eJbPPA/nzILjGTX8Brd/13oalAeLtYjNuYXihnKZuh6HH9cSp49yE5EL8HeWcYoeQeQjJxbQOSlsQbyckF9TrD86pt6+jQzgPIbmonCbXBKDhqSco5yQkF9bjXW/Dw5uEgBSSi9Psudgm5xILyEBfFuNdb/jtaIsMhOSCNH0etsk5HAVkoCeL0vh5CMp7CUgOGYA5xA6p3oyRCshAHzAEk7BN3sMWSRbDcD/b5Hi2SIoYiHsJyXHOwjFQe6IMxr32h1c/2hOQXGZA7mOb7EtA0oxBuYeQ7CMnHAO1poiBGU9ItpUbjoE6U8XgjCcorxOODGWIxhKSdUqC8UNdacYwjXF00NU/riYYA/WkC4PVn5BMqw3FD3WkO0PWl5D842ogbplbhjJwfaRC4Y01bxmCMeaUWxnANnoHxWrMJVMxkG0IynpmkOkZ0jYE5TmzxmMZ3jZWD0pzBADr+vr6F39j6W07s+sPAAAAAElFTkSuQmCC)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADcAAAASCAYAAAD/ukbDAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADdSURBVFhH3ZXhDoMwCITr3v+dZy7RBFs4oCvO7Usaf1jgODBuLc77eGZiZjlrRVE1vY6nhyyWLXwHqqboFPrg6unJeqwW1RWZnOaK6tQXoCZH13IVMOU85XjNSRFwSTr1lOmZ3D251fTmX2A7ywJpUkI0LrsVaq7q5jIiZZ5sc2DQYQmLiM/e8bCas3KDPv/lbvU3h2LySNi7KDTOeplxHETFzUwkklu9r00u2xiYiSnHW0u4wM6j6QVm1wHMxHhkcpp3/+knPiA7/WQCq6dHRRsMdX99cgBNKYa2tgNmPysmZklmCwAAAABJRU5ErkJggg==)

The truth table for a two-input OR gate looks like

|  |  |  |
| --- | --- | --- |
|  |  | **A + B** |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 1 |

**Short Circuit Evaluation**

Have a look at the above truth table. Is there any condition where we can evaluate just a single operand (input) to determine the result thereby saving the computation time to evaluate the 2nd operand in conjunction with the 1st operand?

Note the OR operator is also known as logical disjunction and is also represented by v

**Desk Check Example**

**Set A equal to 7**

**Set B equal to 6**

**Set C equal to 13**

**Set D equal to 4**

**What is the truth value? Hint, link up the parenthesis, create memory locations as you would do in a desk check and work left to right adhering to mathematical precedence. The answer has been whited out so you may change the font of the whitespace to black to reveal the answer**

**If (NOT ( (B < A) AND ( (C > D) OR (D == A) ) ) )**

**Answer: False**

1. **< A) => True**
2. **> D) => True so we don’t need to evaluate OR (D == A) - Short Circuit Evaluation**

**Now True AND True is True**

**Not True => False**

**Now this one which has some bad programming practices but is good for demonstration. There are several interpretations or uses of the following code:**

**In Boolean Algebra, 1 is true and 0 is false**

**In Linux Scripting an exit code of 0 is a successful exit whereas anything else is an exit with errors.**

**If ( (B == ( A – ( C > D ) ) ) AND ( NOT ( ( ( A + B) == C) OR ( NOT ( True == False) ) ) ) )**

**Answer: False**

(C > D) => True

1. – True which is 1) => 6
2. == 6) => True

( A + B) => 13

(13 == C) => True – no need to continue OR evaluation due to Short Circuit Evaluation Not True => False

True AND False => False

**Optional**

**Other Logic Gates**

The three basic logic gates can be combined to provide more complex logical functions. Four important logical functions are described here, namely NAND, NOR, XOR and XNOR. In each case a summary is given including the *logic symbol* for that function, the corresponding *truth table* and the *Boolean expression*.

### The NAND gate

The NAND gate has two or more inputs. The output from the NAND gate is 0 if and only if all of the inputs are 1 otherwise the output is 1. Therefore the output from the NAND gate is the NOT of A AND B (also known as the *complement* or *inversion* of **.** ). The NAND gate is drawn as follows

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAAWCAYAAAA1vze2AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAABrSURBVEhL7ZGLCoAwCACt///nIlCIUDsHNYMOxkDm45z8fJ5NT4lFb8K1OM5d9X4UOk20IpTfxuRsYe+9WEgLk2xibDPdhEyKbFqZEMJaZA0V3HqkSWZ7cPvWC1YaGGnOlI8fsTDC3BdMRHbsDBIXDeH93gAAAABJRU5ErkJggg==)![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAAWCAYAAAA1vze2AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAABwSURBVEhL7ZLBCgAhCETd/v+fW9gUQnJ2QA8FvYuXcnQcuWzHo9XTtbJEfT6a1ixwKGYTNKVvvnyb3QTaZFTZBTlChLodc3gGeJsbYQPaZFTYNQstbTsiwhQVIr8hyYrA6BpROqjPjjBpFSJh84HICwelDh5pipWhAAAAAElFTkSuQmCC)

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAU4AAABYCAYAAACaqx5bAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAASISURBVHhe7dqBbts6DAXQbv//z+/B3bKpniSLjqxa1jlAMaBzkoKkr+kkPz4Y5b/f/xJnTrkVAzmO4OzL7PJtDN84gvNaZplhDNs4gnMcc82lDNg4++BU+zbvXHDUmEsYrHEEZ1+RQFVrujJQ4wjO67SGqJrThUEaR3CO0RKias9bDNA4gnMsAcplDM44gvP71EJUHwj7+fvfiG0IW67mcBe1cDTPhEWDMx0ww8ZMtvA8ClBocmbjhJnVAlR40iQSnLmhMmjMSnhymo2TlQlPTmkNznSQ9rc6hoyZ7ef5xVxTZOOEX4QnzVqCc79tvtg6eRrhSRMbJ3wlPDmUG5JUadtMtRzzYgD/OqoV3ys3q3rGJxsn5OVC0oWfT703RBtnO9vL/dk6yaptnGdCTjDyJLZOsmpXz3RAIpukK3Le/oRTp3nkwlL/FlbaOKNBmB6TGzKAxyiF4pkN8sxjVrK/oKjRXHILgR62mXGZqvY2t3GeDcD02BkLBTVCkj9yw3A2ODfvPPbp9hcT9ZlPbiHQxwVp+jiC8xn0EV+AB4gSnBCz3zBzt+88nOAECPL+zDjeG3sOvezvVdOetYzeDTS/toaP42R7llI/SyerfpdddW5Eg3PT9NqaOY7gfJYzJ+VG3/81Ijhrzxl+fe9xwlhnA/epcvUYXaNwUAtOGE94Tk5wwjm1LWX7v/SHvPQCsq/VrS8ughP6ygVl7ne2zvvYB/ihpoPoYn+iqP38oj1dKSwjtdgf2xpkr+NKx0TrffQ3/2HjBGaUhmI0IEuan0dwAqOlAZXb8tLf9QrF7TlLP6mm1xOcwIzSwNuHX1T48e++IO32VzK1n19uOyn1NXLs00W3yLN1Sl+n5Tmaj7dxQl+5UBCaf0VDc3PmMZdatXnfYd98tZ/fOye04DyuQeTYnOjjm4+3ccJ4QrOtBukx6WOvEPrbBCecc/ZEXjU07yzcS00cZ98ctZ9bqZ+lk3D1fqd1idbi7GNLvahpen4bJ/S1nXi5H+4t1CcNHae0oTAn/VxYrdnRNdfg1DnRnkU/F9bzVj0atDArobm41o2z9biNIcpTp+fQy8X12DgNDbAUn6pDzH7bZEGCE97jjmtBPYKz9b1QmJ1tk0+1oIsOidCs84HC/PSQTz2Dc9P7+Z7MSTeX3Pzq4aJagy4SiKVjBedXTrq5tM45C/B1JDjmos8XvT5VT8PTkPF0loXF1QYgDcCWQYkevxq3enPKLQJ6tzjf44QyoUlWr+C0bQLL6P0FeHgK2yZFtUE4E4gGq2xfT7W6L6FJVc9P1Q0WTyA0OWQgxrFx3l/pLkuv+MKn6vCL0KSZ4AShSZDgZHVCkzDBycqEJqcITla0BabQ5DTByWpKgbkRmjQRnKyktmUKTZoJTlbg1pyuBCdPVgvMjdDkFIMzzv4EVvvr1MJyo/a8xcbJkxxtmBuhydsM0Tg2zmscBeWLetONYRpHcPbRGpQv6kx3hmocwRkXDcmU+nIZwzXOOyFAG/PMEAZtHMF5DTPMcIZuHMHZj7nlWxnAcQRnnPnkhj4+/gcKQMOQtBEvdQAAAABJRU5ErkJggg==)

where the small circle immediately to the right of the gate on the output line is known as an *invert bubble*.

The output from the NAND gate is written as ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADMAAAAaCAYAAAAaAmTUAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADlSURBVFhH7ZbBDsMgDEPZ/v+fNyFBlaWOwahlouJduCQO2BU0PYlXWSufsq7EcYZ3WTebzWZt/NXcQ72+R3oj1CcBzlavZjv0n28SnK2660WuSsfqMk06X0kGuQEduhFq3qP+AHoP4z8D69DsdEJWS8ab+gP9BgtMgIobal1Uo6YLdWYkYzeqbjoC6rSSsU09rqIaP7hVw/ZEtWYkYweyjfZA+1vi3okWo5vtTaYC61ky6kEyIz2XwVxQ3FKd9aj9sD5KRhW3Nbb3DsK9rfxonkCuq6lYRntH0jzpr5ZMJh8CGJXSFyyOKhxa4FEHAAAAAElFTkSuQmCC)(the same rules apply regarding the placement and appearance of the dot as for the AND gate - see the section on basic logic gates). The Boolean expression ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADMAAAAaCAYAAAAaAmTUAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADlSURBVFhH7ZbBDsMgDEPZ/v+fNyFBlaWOwahlouJduCQO2BU0PYlXWSufsq7EcYZ3WTebzWZt/NXcQ72+R3oj1CcBzlavZjv0n28SnK2660WuSsfqMk06X0kGuQEduhFq3qP+AHoP4z8D69DsdEJWS8ab+gP9BgtMgIobal1Uo6YLdWYkYzeqbjoC6rSSsU09rqIaP7hVw/ZEtWYkYweyjfZA+1vi3okWo5vtTaYC61ky6kEyIz2XwVxQ3FKd9aj9sD5KRhW3Nbb3DsK9rfxonkCuq6lYRntH0jzpr5ZMJh8CGJXSFyyOKhxa4FEHAAAAAElFTkSuQmCC)reads as "A NAND B".

The truth table for a two-input NAND gate looks like

|  |  |  |
| --- | --- | --- |
|  |  |  |
| 0 | 0 | 1 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

### The NOR gate

The NOR gate has two or more inputs. The output from the NOR gate is 1 if and only if all of the inputs are 0, otherwise the output is 0. This output behaviour is the NOT of A OR B. The NOR gate is drawn as follows

![](data:image/png;base64,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)

The output from the NOR gate is written as ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADkAAAAYCAYAAABA6FUWAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADuSURBVFhH7ZaBCsMgDETd/v+fV1JaiBrPnKtWxAfSwUy85Kz1E2J+13MVzvq+58/NZrMZSHq6erhP4JZYFva0NzWxp6tedMbPjamJdSNN0ttNvR5aC+pinLS6ZHbuBWCz37oMSHPu0R1vkVqMdE13bhY3i6xyrUtNiIB7+QIlgMkB3jh2l5i5RhXJiNV52CKFTEetSE8R7JwapSKR1jR/NHfUOymL6qFB/3mBcbWkjAOCV2SLQ57c5nzkJFug0BLTHe92la6gMTUlgew2EVpiajA5i3NXvAxkWN35x5Gn3YTiC2TrruKkIMUZjQ3hAHuxLCl52ArBAAAAAElFTkSuQmCC)which reads "A NOR B".

The truth table for a two-input NOR gate looks like

|  |  |  |
| --- | --- | --- |
|  |  |  |
| 0 | 0 | 1 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 0 |

### The eXclusive-OR (XOR) gate

The exclusive-OR or XOR gate has two or more inputs. For a two-input XOR the output is similar to that from the OR gate except it is 0 when both inputs are 1. This cannot be extended to XOR gates comprising 3 or more inputs however.

In general, an XOR gate gives an output value of 1 when there are an odd number of 1's on the inputs to the gate. The truth table for a 3-input XOR gate below illustrates this point. The XOR gate is drawn as

![](data:image/png;base64,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)

The output from the XOR gate is written as ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADgAAAATCAYAAADF7c7rAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAD8SURBVFhH3ZXhDsMgCITd3v+dt5KooSjHMTVL+v0xKQccmLbl6bzqGfGpJ6vfRevLMvhjDNsm2SE9k7/0ZrjVPTkgaw7V0zVYndC1kVnPZCbP0+7SNKbadz134pmS5yh2BDSgNZM1pPUejGaJ3TfYBs8Yb9qVW7SX0fGMuAkXTIw1bXWoF4PNP/IO/pNhIcPEF1o0iwvRxlHdTIzxImid0LVPuUF3eLRNBpRvY9nngvYyi1sGvb1BLWBAeqZWtl8ab5tCtDGkZers0mgGvU7KFhNQjo4hUK+Mp6n25EdGmiBTUTyDu8zWILMpy0puhGsccPPwpB+9DGYWXMoXLCc+HH33tc0AAAAASUVORK5CYII=)which reads "A XOR B".

The truth table for a two-input XOR gate looks like

|  |  |  |
| --- | --- | --- |
|  |  |  |
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |