

## فصل دوم: جبر بول (Boolean Algebra)

- مدار دیجیتالی بصورت یک بلوک با ورودی ها و خروجی ها می تواند نمایش داده شود.



- سیگنالهای استفاده شده در مدارهای دیجیتالی بصورت گسسته/دیجیتال (discrete/digital) می باشند که دارای یکی از دو سطح ولتاژ Low یا High هستند. در حالیکه سیگنالهای استفاده شده در مدارهای آنالوگ بصورت پیوسته می باشند.

- مقایسه مدارهای دیجیتال نسبت به مدارهای آنالوگ:

- قابلیت اعتماد بالاتر(садگی) مدار- حساسیت کمتر به نویز)
- دقت قابل تعیین
- مدل ریاضی (جبر بول)
- اما : زمان پاسخ کنترل (زیر نمونه برداری)



## جبر بول

جبر چیست؟

مجموعه ای از عناصر (e.g. 0,1,2,...)

مجموعه ای از عملگرها (e.g. +, -, \*, ...)

مجموعه ای از اصول (e.g.  $0+x=x$ , ...)

جبر بول به خاطر George Boole نامگذاری شده است که برای بیان منطق انسان از آن استفاده نمود.

رویداد: true or false

$a \text{ OR } b$ ;  $a \text{ AND } b$ ,  $\text{NOT } a$ : عملگر ها:

| a | b | $a \text{ AND } b$ |
|---|---|--------------------|
| F | F | F                  |
| F | T | F                  |
| T | F | F                  |
| T | T | T                  |

| a | b | $a \text{ OR } b$ |
|---|---|-------------------|
| F | F | F                 |
| F | T | T                 |
| T | F | T                 |
| T | T | T                 |

| a | $\text{NOT } a$ |
|---|-----------------|
| F | T               |
| T | F               |

بعداً جبر کلیدی Shannon (Switching Algebra) را برای نمایش مدارهای کلیدی دو حالته معرفی کرد (جبر بول دو ارزشی).

## جبر بول دو ارزشی (Two-valued Boolean Algebra)

مجموعه‌ای از عناصر  $\{0,1\}$

مجموعه‌ای از عملگرهای  $\{., +, ', \cdot\}$

| x | y | $x \cdot y$ |
|---|---|-------------|
| 0 | 0 | 0           |
| 0 | 1 | 0           |
| 1 | 0 | 0           |
| 1 | 1 | 1           |

| x | y | $x + y$ |
|---|---|---------|
| 0 | 0 | 0       |
| 0 | 1 | 1       |
| 1 | 0 | 1       |
| 1 | 1 | 1       |

| x | $x'$ |
|---|------|
| 0 | 1    |
| 1 | 0    |



Signals: High = 5V = 1; Low = 0V = 0

## اصول جبر بول

### (Boolean Algebra Postulates)

جبر بول شامل مجموعه عناصر  $B$  همراه با دو عملگر باینری  $\{+, \cdot\}$  و یک عملگر یکتایی  $\{'\}$  است، طوریکه اصول زیر را بر آورده کند:

- **1- Closure:** For every  $x, y$  in  $B$ ,
  - ❖  $x + y$  is in  $B$
  - ❖  $x \cdot y$  is in  $B$
- **2- Identities (0 and 1):**
  - ❖  $0 + x = x + 0 = x$  for every  $x$  in  $B$
  - ❖  $1 \cdot x = x \cdot 1 = x$  for every  $x$  in  $B$
- **3- Commutative laws:** For every  $x, y$  in  $B$ ,
  - ❖  $x + y = y + x$
  - ❖  $x \cdot y = y \cdot x$
- **4- Distributive laws:** For every  $x, y, z$  in  $B$ ,
  - ❖  $x \cdot (y + z) = (x \cdot y) + (x \cdot z)$
  - ❖  $x + (y \cdot z) = (x + y) \cdot (x + z)$

## اصول جبر بول (Boolean Algebra Postulates)

- **5- Complement:** For every  $x$  in  $B$ , there exists an element  $x'$  in  $B$  such that
  - ❖  $x + x' = 1$
  - ❖  $x \cdot x' = 0$
- **6-**The set  $B$  contains at least two distinct elements  $x$  and  $y$ .

مجموعه  $\{0, 1\}$  و عملگر های منطقی  $B = \{0, 1\}$  ، AND ، OR و NOT تمام اصول جبر بول را بر آورده می سازد.

یک تابع بولی (Boolean function) یک جمله جبری است که شامل متغیر ها و عملگر های بولی است و تعدادی ورودی روی مجموعه  $\{0, 1\}$  را به مجموعه  $\{0, 1\}$  نگاشت می کند.

## تقدم عملگرها (Precedence of Operators)

■ به منظور کاهش تعداد پرانتز های استفاده شده در نمایش توابع بولی، می توان از تقدم عملگر ها استفاده کرد.

- Precedence (highest to lowest):  $()$  ,  $'$  ,  $\cdot$  ,  $+$

: مثال ■

$$a \cdot b + c = (a \cdot b) + c$$

$$b' + c = (b') + c$$

$$a + b' \cdot c = a + ((b') \cdot c)$$

: با استفاده از پرانتز می توان اولویت را تغییر داد ■

: مثال ■

$$a \cdot (b + c)$$

$$(a + b)' \cdot c$$

## جدول درستی (Truth Table)

- جدول درستی لیستی از تمام ترکیبات ممکن در ورودی و خروجی متناظر با هر حالت را نمایش می دهد.

| INPUTS | OUTPUTS |
|--------|---------|
| ...    | ...     |
| ...    | ...     |

| x | y | $x \cdot y$ | $x + y$ |
|---|---|-------------|---------|
| 0 | 0 | 0           | 0       |
| 0 | 1 | 0           | 1       |
| 1 | 0 | 0           | 1       |
| 1 | 1 | 1           | 1       |

- مثال: دو ورودی- دو خروجی

## اثبات با استفاده از جدول درستی

- مثال: ثابت کنید  $x \cdot (y + z) = (x \cdot y) + (x \cdot z)$  (i) جدول درستی را برای سمت راست(RHS) و چپ(LHS) معادله تشکیل دهید:

| x | y | z | $y + z$ | $x \cdot (y + z)$ | $x \cdot y$ | $x \cdot z$ | $(x \cdot y) + (x \cdot z)$ |
|---|---|---|---------|-------------------|-------------|-------------|-----------------------------|
| 0 | 0 | 0 | 0       | 0                 | 0           | 0           | 0                           |
| 0 | 0 | 1 | 1       | 0                 | 0           | 0           | 0                           |
| 0 | 1 | 0 | 1       | 0                 | 0           | 0           | 0                           |
| 0 | 1 | 1 | 1       | 0                 | 0           | 0           | 0                           |
| 1 | 0 | 0 | 0       | 0                 | 0           | 0           | 0                           |
| 1 | 0 | 1 | 1       | 1                 | 0           | 1           | 1                           |
| 1 | 1 | 0 | 1       | 1                 | 1           | 0           | 1                           |
| 1 | 1 | 1 | 1       | 1                 | 1           | 1           | 1                           |

- ii) بررسی کنید آیا  $RHS=LHS$ ? چون ستون خروجی ۲ و ۵ با هم برابرند. پس رابطه برای تمام حالت‌های ورودی صحیح بوده و درستی آن اثبات می شود.

## ٢-١ تمرین

Q. Use truth table to prove the following.

- (a)  $A' \cdot B' + A \cdot B' + A \cdot B = A + B'$
- (b)  $A \cdot B \cdot C + A' \cdot B \cdot C + A' \cdot B \cdot C' = B \cdot C + A' \cdot B$

## دوگانی (Duality)

اصل درگانی: هر عبارت معتبر بولی (معادله) با تغییر زیر معتبر باقی خواهد ماند:

$$+ \leftrightarrow \cdot$$

$$1 \leftrightarrow 0$$

مثال: با داشتن عبارت معتبر زیر:

$$a + (b \cdot c) = (a + b) \cdot (a + c)$$

دوگان آن یعنی رابطه زیر نیز معتبر خواهد بود:

$$a \cdot (b + c) = (a \cdot b) + (a \cdot c)$$

دوگانی یک قضیه را درگان بدست می دهد "two for the price of one" .  
شما یک رابطه معتبر را اثبات می کنید و رابطه دیگر نیز اثبات می گردد.

اگر رابطه  $(x + y + z)' = x' \cdot y' \cdot z'$  معتبر باشد، دوگان آن نیز معتبر خواهد بود. یعنی  $(x \cdot y \cdot z)' = x' + y' + z'$

اگر رابطه  $x \cdot 0 = 0$  معتبر باشد، دوگان آن نیز معتبر خواهد بود. یعنی  $0 \cdot 1 = 1$

## قضایای اصلی جبربول

علاوه بر اصول، قضایای مفیدی نیز می تواند استفاده گردد:

### 1. Idempotency.

$$(a) x + x = x \quad (b) x \cdot x = x$$

Proof of (a):

$$\begin{aligned} x + x &= (x + x) \cdot 1 && \text{(identity)} \\ &= (x + x) \cdot (x + x') && \text{(complementarity)} \\ &= x + x \cdot x' && \text{(distributivity)} \\ &= x + 0 && \text{(complementarity)} \\ &= x && \text{(identity)} \end{aligned}$$

## قضایای اصلی جبربول

### 2. Null elements for + and . operators.

$$(a) x + 1 = 1 \quad (b) x \cdot 0 = 0$$

### 3. Involution. $(x')' = x$

### 4. Associative laws:

$$\begin{aligned} (a) (x + y) + z &= x + (y + z) = x + y + z \\ (b) (x \cdot y) \cdot z &= (x \cdot y) \cdot z = x \cdot y \cdot z \end{aligned}$$

### 5. DeMorgan.

$$\begin{aligned} (a) (x + y)' &= x' \cdot y' \\ (b) (x \cdot y)' &= x' + y' \end{aligned}$$

### 6. Absorption.

$$(a) x + x \cdot y = x \quad (b) x \cdot (x + y) = x$$

■ قضایا را می توان با جدول درستی اثبات نمود.  
تمرین: قضیه De-Morgan را با جدول درستی اثبات کنید.

■ همچنین می توان آنها را با عملیات جبری (Algebraic Manipulation) و با استفاده از اصول و قضایای دیگر اثبات نمود

## قضایای اصلی جبربول

: ۴a (absorption) ■ اثبات قضیه

$$x + x.y = x.1 + x.y \quad (\text{identity})$$

$$= x.(1 + y) \quad (\text{distributivity})$$

$$= x.(y + 1) \quad (\text{commutativity})$$

$$= x.1 \quad (\text{Theorem 2a})$$

$$= x \quad (\text{identity})$$

با دوگانی قضیه ۴b اثبات می گردد. (عنوان تمرین اثبات شود)

$$x.(x+y) = x$$

## توابع بولی(منطقی) (Boolean Functions)

تابع بولی عبارتی است شامل متغیر های باینری، عملگر های AND، OR و NOT و پارانتز و علامت مساوی.

نتیجه آن نیز مقدار باینری خواهد بود.

معمولًا برای AND ، + برای OR و ' برای NOT استفاده می گردد. اغلب اگر ابهامی پیش نیاید."نوشته نمی شود.

مثال: ■

$$F1 = xyz'$$

$$F2 = x + y'z$$

$$F3 = (x'y'z) + (x'yz) + (xy')$$

$$F4 = xy' + x'z$$

| x | y | z | F1 | F2 | F3 | F4 |
|---|---|---|----|----|----|----|
| 0 | 0 | 0 | 0  | 0  | 0  | 0  |
| 0 | 0 | 1 | 0  | 1  | 1  | 1  |
| 0 | 1 | 0 | 0  | 0  | 0  | 0  |
| 0 | 1 | 1 | 0  | 0  | 1  | 1  |
| 1 | 0 | 0 | 0  | 1  | 1  | 1  |
| 1 | 0 | 1 | 0  | 1  | 1  | 1  |
| 1 | 1 | 0 | 1  | 1  | 0  | 0  |
| 1 | 1 | 1 | 0  | 1  | 0  | 0  |

از روی جدول مشاهده می شود که  $F3 = F4$  است. با عملیات جبری تساوی را ثابت کنید.

## مکمل تابع (Complement of Functions)

- با داشتن جدول تابع  $F$  مکمل آن یعنی  $F'$  با جایگزینی 0 و 1 بدست می آید. با داشتن عبارت منطقی از قضیه دمورگان می توان استفاده کرد.

مثال :  
مکمل تابع :

$$\begin{aligned} F' &= (xyz)' \\ &= x' + y' + (z')' \quad \text{DeMorgan} \\ &= x' + y' + z \quad \text{Involution} \end{aligned}$$

فرم کلی قضیه دمورگان :

$$(A + B + C + \dots + Z)' = A' \cdot B' \cdot C' \cdot \dots \cdot Z'$$

$$(A \cdot B \cdot C \cdot \dots \cdot Z)' = A' + B' + C' + \dots + Z'$$

| x | y | z | <b>F1</b> | <b>F1'</b> |
|---|---|---|-----------|------------|
| 0 | 0 | 0 | <b>0</b>  | <b>1</b>   |
| 0 | 0 | 1 | <b>0</b>  | <b>1</b>   |
| 0 | 1 | 0 | <b>0</b>  | <b>1</b>   |
| 0 | 1 | 1 | <b>0</b>  | <b>1</b>   |
| 1 | 0 | 0 | <b>0</b>  | <b>1</b>   |
| 1 | 0 | 1 | <b>0</b>  | <b>1</b>   |
| 1 | 1 | 0 | <b>1</b>  | <b>0</b>   |
| 1 | 1 | 1 | <b>0</b>  | <b>1</b>   |

## مکمل تابع (Complement of Functions)

- روش دوم: ابتدا دوگان تابع را بدست آورده و با مکمل کردن تمام متغیر های آن مکمل تابع بدست می آید. معمولاً برای توابعی که تعداد متغیر ها و جملات آن زیاد باشد، این روش مفید تر خواهد بود.

مثال :

$$F = x + yz'$$

دوگان تابع:

$$F_D = x \cdot (y + z')$$

مکمل تابع :  
 $F' = x' (y' + z)$

## فرم‌های استاندارد (Standard Forms)

از نقطه نظر پیاده سازی (implementation) بعضی از فرم‌های توابع بولی مناسب‌تر هستند.

دو فرم استاندارد:

### Sum-of-Products and Product-of-Sums

به یک متغیر در فرم خود یا بفرم مکمل گفته می‌شود. مثال  $x, x', y, y'$ :

جمله ضربی (Product Term): یک لیترال یا AND چند لیترال مثال:  $x, xyz', A'B, AB$

جمله جمعی (Sum Term): یک لیترال یا OR چند لیترال مثال:  $x, x+y+z', A'+B, A+B$

## فرم‌های استاندارد

فرم جمع حاصل ضرب (SOP): یک جمله ضربی یا OR چند جمله ضربی . مثال:  $x, x+yz', xy'+x'yz, AB+A'B'$

فرم ضرب حاصل جمع (POS): یک جمله جمعی یا AND چند جمله جمعی . مثال:  $x, x(y+z'), (x+y')(x'+y+z), (A+B)(A'+B')$

هر عبارت بولی می‌تواند بفرم SOP و POS نوشته شود.

Examples:

SOP:  $x'y + xy' + xyz$

POS:  $(x + y')(x' + y)(x' + z')$

both:  $x' + y + z$  or  $xyz'$

neither:  $x(w' + yz)$  or  $z' + wx'y + v(xz + w')$

## Minterm & Maxterm

- مینترم عبارتست از AND روی n متغیر ، طوریکه متغیر با مقدار 0 پریم دار و با مقدار 1 بدون پریم می باشد
- ماکسterm عبارتست از OR روی n متغیر ، طوریکه متغیر با مقدار 1 پریم دار و با مقدار 0 بدون پریم می باشد
- مثال : مینترم و ماکسtermهای دو متغیره :

| Minterms |   |        | Maxterms |         |          |
|----------|---|--------|----------|---------|----------|
| x        | y | term   | notation | term    | notation |
| 0        | 0 | $x'y'$ | $m_0$    | $x+y$   | $M_0$    |
| 0        | 1 | $x'y$  | $m_1$    | $x+y'$  | $M_1$    |
| 1        | 0 | $xy'$  | $m_2$    | $x'+y$  | $M_2$    |
| 1        | 1 | $xy$   | $m_3$    | $x'+y'$ | $M_3$    |

هر مینترم مکمل ماکسterm متناظرش می باشد.  
مثال:

$$\begin{aligned} m_2 &= xy' \\ m_2' &= (xy')' = x' + (y')' = x'+y = M_2 \end{aligned}$$

## Canonical Form: Sum of Minterms

- فرم کانوئیک(نرمال) چیست؟
- ❖ یک فرم یکه برای نمایش یک عبارت
- ❖ مینترم جمله ضربی می باشد و می توان تابع بولی را بفرم Sum-of-Minterms نمایش داد.

مراحل:

الف- جدول درستی را بدست آورید:

ب- فرم جمع مینترم را با جمع کردن مینترمهایی که تابع در آنها یک است بدست آورید.

مثال:

$$\begin{aligned} F_1 &= xyz' = \Sigma m(6) \\ F_2 &= x'y'z+xy'z'+xy'z+xyz'+xyz \\ &= m_1+m_4+m_5+m_6+m_7 \\ &= \Sigma m(1,4,5,6,7) \\ F_3 &= x'y'z+x'yz+xy'z'+xy'z \\ &= \Sigma m(1,3,4,5) \end{aligned}$$

## Canonical Form: Product of Maxterms

- ماکسٹرمها جملات جمعی (Sum Terms) می باشند.
- ماکسٹرمها یک تابع بولی ترمہایی هستند که تابع در آنها صفر است.
- توابع بولی را می توان بفرم ضرب ماکسٹرمها (Products-of- Maxterms) نمایش داد.

$$E.g.: F2 = \prod M(0,2,3) = (x+y+z)(x+y'+z)(x+y'+z')$$

$$F3 = \prod M(0,2,6,7) = (x+y+z)(x+y'+z)(x'+y'+z)(x'+y'+z')$$

| x | y | z | F1 | F2 | F3 |
|---|---|---|----|----|----|
| 0 | 0 | 0 | 0  | 0  | 0  |
| 0 | 0 | 1 | 0  | 1  | 1  |
| 0 | 1 | 0 | 0  | 0  | 0  |
| 0 | 1 | 1 | 0  | 0  | 1  |
| 1 | 0 | 0 | 0  | 1  | 1  |
| 1 | 0 | 1 | 0  | 1  | 1  |
| 1 | 1 | 0 | 1  | 1  | 0  |
| 1 | 1 | 1 | 0  | 1  | 0  |

## Canonical Form: Product of Maxterms

می توان درستی این نمایش را بصورت زیر اثبات کرد:

$$F2 = \sum m(1,4,5,6,7)$$

$$\begin{aligned} F2' &= \sum m(0,2,3) \\ &= m0 + m2 + m3 \end{aligned}$$

$$\begin{aligned} F2 &= (m0 + m2 + m3)' \\ &= m0' \cdot m2' \cdot m3' && \text{DeMorgan} \\ &= M0 \cdot M2 \cdot M3 && (m_j)' = M_j \\ &= \prod M(0,2,3) \end{aligned}$$

| x | y | z | F2 | F2' |
|---|---|---|----|-----|
| 0 | 0 | 0 | 0  | 1   |
| 0 | 0 | 1 | 1  | 0   |
| 0 | 1 | 0 | 0  | 1   |
| 0 | 1 | 1 | 0  | 1   |
| 1 | 0 | 0 | 1  | 0   |
| 1 | 0 | 1 | 1  | 0   |
| 1 | 1 | 0 | 1  | 0   |
| 1 | 1 | 1 | 1  | 0   |

• هر تابع بولی را می توان به هر دوform کانونیک تبدیل کرد.

## تمرين ٢-٢

1. A Boolean function of 5 variables can have up to \_\_\_\_ minterms.
2. Given a Boolean function  $F(A,B,C) = \Sigma m(0, 5, 7)$ .  
Which of the following is correct?
  - a)  $F'(A,B,C) = \Sigma m(0,5,7)$
  - b)  $F(A,B,C) = \Pi M(1,2,3,4,6)$
  - c)  $F(A,B,C) = \Pi M(0,5,7)$
  - d)  $F'(A,B,C) = \Sigma m(1,2,3)$
  - e) None above
3. Given a Boolean function  $F(x,y,z) = y' \cdot (x + z') + x' \cdot z$ .  
Which of the following is correct?
  - a)  $F(x,y,z) = \Sigma m(0,1)$
  - b)  $F(x,y,z) = \Sigma m(0,1,4,5)$
  - c)  $F(x,y,z) = \Sigma m(0,1,2,3,4)$
  - d)  $F(x,y,z) = \Sigma m(0,1,3,4,5)$
  - e)  $F(x,y,z) = \Sigma m(1,2,3,4,5)$

## تمرين ٢-٣

4. Given a Boolean function with 6 variables  $a, b, c, d, e, f$ .  
What is maxterm  $M60$ ?
  - a)  $a' \cdot b' \cdot c' \cdot d' \cdot e \cdot f$
  - b)  $a' + b' + c' + d'$
  - c)  $a' + b' + c' + d' + e + f$
  - d)  $a \cdot b \cdot c \cdot d \cdot e \cdot f'$
  - e)  $a + b + c + d + e' + f'$
5. Given a Boolean function  $F(a,b,c) = \Sigma m(0, 2, 5, 6, 7)$ .  
If  $a=0, b=c=1$ , what is the value of  $F$ ?
  - a) 0
  - b) 1
  - c)  $b \cdot c$
  - d)  $a'$
  - e) Unknown
6. Which of the following is NOT a minterm of the Boolean function:  $F(w,x,y,z) = w \cdot x \cdot z' + x \cdot y' \cdot z + x \cdot z$ 
  - a)  $w \cdot x \cdot y \cdot z'$
  - b)  $w' \cdot x \cdot y' \cdot z$
  - c)  $w \cdot x \cdot y \cdot z$
  - d)  $w \cdot x \cdot y' \cdot z'$
  - e)  $w \cdot x' \cdot y \cdot z$

## تمرین ۲-۲

7. Identify the following function  $F(x,y,z)$ .

- a)  $x.y'.z' + x'.y.z + x.z'$
- b)  $x'.y.z + x.y' + x'.y'.z$
- c)  $x.y'.z + x'.y'.z + x.y$
- d)  $x.y.z + x'.y'.z' + x.y'$
- e) None above

| $x$ | $y$ | $z$ | $F$ |
|-----|-----|-----|-----|
| 0   | 0   | 0   | 0   |
| 0   | 0   | 1   | 1   |
| 0   | 1   | 0   | 0   |
| 0   | 1   | 1   | 1   |
| 1   | 0   | 0   | 1   |
| 1   | 0   | 1   | 1   |
| 1   | 1   | 0   | 0   |
| 1   | 1   | 1   | 0   |

## تبديل فرم‌های کانوئیک

### ▪ Sum-of-Minterms $\Rightarrow$ Product-of-Maxterms

❖ اندیس هایی که در یک فرم نیست در فرم دیگر نوشته می شود

$$\text{Eg: } F1(A,B,C) = \sum m(3,4,5,6,7) = \prod M(0,1,2)$$

### ▪ Product-of-Maxterms $\Rightarrow$ Sum-of-Minterms

❖ اندیس هایی که در یک فرم نیست در فرم دیگر نوشته می شود

$$\text{Eg: } F2(A,B,C) = \prod M(0,3,5,6) = \sum m(1,2,4,7)$$

## Conversion of Canonical Forms

### ▪ Sum-of-Minterms of $F \Rightarrow$ Sum-of-Minterms of $F'$

❖ اندیس هایی که در یک فرم نیست در فرم دیگر نوشته می شود

$$Eg: F1(A,B,C) = \sum m(3,4,5,6,7)$$

$$F1'(A,B,C) = \sum m(0,1,2)$$

### ▪ Product-of-Maxterms of $F \Rightarrow$ Prod-of-Maxterms of $F'$

❖ اندیس هایی که در یک فرم نیست در فرم دیگر نوشته می شود

$$Eg: F1(A,B,C) = \prod M(0,1,2)$$

$$F1'(A,B,C) = \prod M(3,4,5,6,7)$$

## Conversion of Canonical Forms

### ▪ Sum-of-Minterms of $F \Rightarrow$ Product-of-Maxterms of $F'$

❖ همان اندیس ها تکرار می شود.

$$Eg: F1(A,B,C) = \sum m(3,4,5,6,7)$$

$$F1'(A,B,C) = \prod M(3,4,5,6,7)$$

### ▪ Product-of-Maxterms of $F \Rightarrow$ Sum-of-Minterms of $F'$

❖ همان اندیس ها تکرار می شود.

$$Eg: F1(A,B,C) = \prod M(0,1,2)$$

$$F1'(A,B,C) = \sum m(0,1,2)$$

## تمرین ۲-۳

Q. Consider the function

$$f(A,B,Y,Z) = \sum m(0, 2, 5, 6, 8, 11, 15).$$

- a) Write this as a Boolean expression in canonical SOP form.
- b) Rewrite the expression in canonical POS form.
- c) Write the complement of  $f$  in “little m” notation and in canonical SOP form.
- d) Write the complement of  $f$  in “big M” notation and in canonical POS form.

## تابع باینری

- برای  $n$  متغیر  $2^n$  مینترم وجود خواهد داشت.
- چون هر تابع را می توان بفرم جمع مینترم نمایش داد ، پس  $2^{2^n}$  تابع مختلف خواهیم داشت.
- برای دو متغیر  $4=2^2$  مینترم و  $16=2^4$  تابع مختلف خواهیم داشت.
- تابع باینری ممکن در جدول زیر نمایش داده شده اند:

| <b>x</b> | <b>y</b> | <b>F<sub>0</sub></b> | <b>F<sub>1</sub></b> | <b>F<sub>2</sub></b> | <b>F<sub>3</sub></b> | <b>F<sub>4</sub></b> | <b>F<sub>5</sub></b> | <b>F<sub>6</sub></b> | <b>F<sub>7</sub></b> |
|----------|----------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|
| 0        | 0        | 0                    | 0                    | 0                    | 0                    | 0                    | 0                    | 0                    | 0                    |
| 0        | 1        | 0                    | 0                    | 0                    | 0                    | 1                    | 1                    | 1                    | 1                    |
| 1        | 0        | 0                    | 0                    | 1                    | 1                    | 0                    | 0                    | 1                    | 1                    |
| 1        | 1        | 0                    | 1                    | 0                    | 1                    | 0                    | 1                    | 0                    | 1                    |
| Symbol   |          | .                    | /                    | /                    |                      |                      | $\oplus$             | $+$                  |                      |
| Name     |          | AND                  |                      |                      | XOR                  | OR                   |                      |                      |                      |

| <b>x</b> | <b>y</b> | <b>F<sub>8</sub></b> | <b>F<sub>9</sub></b> | <b>F<sub>10</sub></b> | <b>F<sub>11</sub></b> | <b>F<sub>12</sub></b> | <b>F<sub>13</sub></b> | <b>F<sub>14</sub></b> | <b>F<sub>15</sub></b> |
|----------|----------|----------------------|----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|
| 0        | 0        | 1                    | 1                    | 1                     | 1                     | 1                     | 1                     | 1                     | 1                     |
| 0        | 1        | 0                    | 0                    | 0                     | 0                     | 1                     | 1                     | 1                     | 1                     |
| 1        | 0        | 0                    | 0                    | 1                     | 1                     | 0                     | 0                     | 1                     | 1                     |
| 1        | 1        | 0                    | 1                    | 0                     | 1                     | 0                     | 1                     | 0                     | 1                     |
| Symbol   |          | $\downarrow$         | $\odot$              | '                     | $\subset$             | '                     | $\supset$             | $\uparrow$            |                       |
| Name     |          | NOR                  | XNOR                 |                       |                       | NAND                  |                       |                       |                       |

- **Inhibition** :  $x / y : x.y'$  ,  $y / x : x'.y$
- **Transfer** :  $F_3=x$  ,  $F_5=y$
- **Complement** :  $F_{10}=y'$  ,  $F_{12}=x'$
- **Implication** :  $x \subset y : x+y'$   
IF  $y$  THEN  $x$   
 $x \supset y : x'+y$   
IF  $x$  THEN  $y$
- **NULL** :  $F_0=0$
- **Identity** :  $F_{15}=1$

## گیت های منطقی Logic Gates

### ▪ Gate Symbols

|        | Symbol set 1 | Symbol set 2<br>(ANSI/IEEE Standard 91-1984) |
|--------|--------------|----------------------------------------------|
| AND    |              |                                              |
| OR     |              |                                              |
| NOT    |              |                                              |
| BUFFER |              |                                              |
| NAND   |              |                                              |
| NOR    |              |                                              |
| XOR    |              |                                              |
| XNOR   |              |                                              |

Digital Design-Introduction to  
Logic Gates

Seyedarabi

۲۱

## Logic Gates: The Inverter

### ▪ The Inverter



| A | A' |
|---|----|
| 0 | 1  |
| 1 | 0  |

### ▪ Application of the inverter: complement.



Digital Design-Introduction to  
Logic Gates

Seyedarabi

۲۲

# Logic Gates: The BUFFER

- The **BUFFER**



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

کاربردها:

- تقویت سیگنال و گرفتن انشعاب
- ایجاد تأخیر در سیگنال ورودی

# Logic Gates: The AND Gate

- The **AND** Gate



|   |   |       |
|---|---|-------|
| A | B | A . B |
| 0 | 0 | 0     |
| 0 | 1 | 0     |
| 1 | 0 | 0     |
| 1 | 1 | 1     |

# Logic Gates: The AND Gate

- Application of the AND Gate



# Logic Gates: The OR Gate

- The OR Gate



| A | B | $A + B$ |
|---|---|---------|
| 0 | 0 | 0       |
| 0 | 1 | 1       |
| 1 | 0 | 1       |
| 1 | 1 | 1       |

## Logic Gates: The NAND Gate

- The **NAND** Gate



| A | B | $(A \cdot B)'$ |
|---|---|----------------|
| 0 | 0 | 1              |
| 0 | 1 | 1              |
| 1 | 0 | 1              |
| 1 | 1 | 0              |



## Logic Gates: The NOR Gate

- The **NOR** Gate



| A | B | $(A+B)'$ |
|---|---|----------|
| 0 | 0 | 1        |
| 0 | 1 | 0        |
| 1 | 0 | 0        |
| 1 | 1 | 0        |



# Logic Gates: The XOR Gate

- The **XOR** Gate



| A | B | $A \oplus B$ |
|---|---|--------------|
| 0 | 0 | 0            |
| 0 | 1 | 1            |
| 1 | 0 | 1            |
| 1 | 1 | 0            |

# Logic Gates: The XNOR Gate

- The **XNOR** Gate



| A | B | $A \odot B$ |
|---|---|-------------|
| 0 | 0 | 1           |
| 0 | 1 | 0           |
| 1 | 0 | 0           |
| 1 | 1 | 1           |

## رسم(پیاده سازی) مدار های منطقی

■ مثال

$$(i) F1 = xyz'$$

دقت: از گیت AND سه ورودی استفاده شده است.



$$(ii) F2 = x + y'z$$

می توان فرض کرد که متغیر و مکمل آن مستقیماً قابل دسترسی هستند.



$$(iii) F3 = xy' + x'z$$



## تمرین ۲-۴

Q1. Draw a logic circuit for BD + BE + D'F

Q2. Draw a logic circuit for

$$A'BC + B'CD + BC'D + ABD'$$

## تحلیل مدارهای منطقی Analysing Logic Circuit

- Example: What is the Boolean expression of F4?



$$F4 = (A'B'+C)' = (A+B).C'$$

## تمرین ۵-۲

- What is Boolean expression of F5?



# Universal Gates: NAND and NOR

■ گیت های AND/OR/NOT برای طراحی تمام توابع منطقی کافی هستند.

■ با این وجود گیت های دیگر نیز بدلاًیل زیر استفاده می گردد:

- (i) usefulness
- (ii) economical on transistors
- (iii) self-sufficient

NAND/NOR: economical, self-sufficient

XOR: useful (e.g. parity bit generation)

## NAND Gate

■ گیت NAND حالت self-sufficient دارد یعنی می توان هر مدار منطقی را فقط با آن طراحی کرد (گیت یونیورسال)

■ می توان گیتهای AND/OR/NOT را با آن ساخت.

■ پیاده سازی گیت NOT با NAND :



$$(x \cdot x)' = x' \quad (\text{T1: idempotency})$$



■ پیاده سازی گیت AND با NAND :

$$((xy)'(xy))' = ((xy)')' \quad \text{idempotency} \\ = (xy) \quad \text{involution}$$



■ پیاده سازی گیت OR با NAND :

$$((xx)'(yy))' = (x'y')' \quad \text{idempotency} \\ = x''+y'' \quad \text{DeMorgan} \\ = x+y \quad \text{involution}$$

## NOR Gate

گیت NOR نیز حالت self-sufficient دارد (گیت یونیورسال)

می توان گیتهای AND/OR/NOT را با آن ساخت.

پیاده سازی گیت NOT با NOR :



$$(x+x)' = x' \quad (\text{T1: idempotency})$$



پیاده سازی گیت AND با NOR :

$$\begin{aligned} ((x+x)'+(y+y))' &= (x'+y')' && \text{idempotency} \\ &= x'' . y'' && \text{DeMorgan} \\ &= x . y && \text{involution} \end{aligned}$$

پیاده سازی OR با NOR :



$$\begin{aligned} ((x+y)'+(x+y))' &= ((x+y)')' && \text{idempotency} \\ &= (x+y) && \text{involution} \end{aligned}$$

## پیاده سازی با استفاده از گیت NAND

می توان هر تابع بولی را با استفاده از گیت NAND پیاده سازی کرد:

مراحل:

(i) فرم SOP را بدست آورید:

$$\text{e.g. } F3 = xy' + x'z$$

(ii) با استفاده از قضیه DeMorgan فرمی را بدست آورید که بصورت دوطبقه پیاده سازی شود.

$$\begin{aligned} \text{e.g. } F3 &= xy' + x'z \\ &= (xy' + x'z)' && \text{involution} \\ &= ((xy')' . (x'z)') && \text{DeMorgan} \end{aligned}$$



## پیاده سازی با استفاده از گیت NOR

■ می توان هرتابع بولی را با استفاده از گیت NOR پیاده سازی کرد:

مراحل:

(i) فرم POS را بدست آورید:

$$\text{e.g. } F_6 = (x+y').(x'+z)$$

(ii) با استفاده از قضیه DeMorgan فرمی را بدست آورید که بصورت NOR دوطبقه پیاده سازی شود.

$$\text{e.g. } F_6 = (x+y').(x'+z)$$

= ((x+y').(x'+z))' \quad \text{involution}

= ((x+y')' + (x'+z)')' \quad \text{DeMorgan}



## پیاده سازی های دوطبقه فرم SOP

■ فرم SOP می تواند به چهارحالت دوطبقه پیاده سازی گردد:

- ❖ 2-level AND-OR logic circuits
- ❖ 2-level NAND-NAND logic circuits
- ❖ 2-level NOR-OR logic circuits
- ❖ 2-level OR-NAND logic circuits

### ■ AND-OR logic circuit



## پیاده سازی های دو طبقه فرم SOP

### NAND-NAND circuit ■

- الف- در هر مسیر دو عدد NOT قرار دهد.
- ب- گیت OR با ورودی های NOT شده را با گیت NAND جایگزین کنید.
- برای متغیر های ورودی با مکمل آن جایگزین می شود.



## پیاده سازی های دو طبقه فرم SOP

### NOR-OR circuit ■

- الف- در هر مسیر دو عدد NOT قرار دهد.
- ب- گیت AND با ورودی های NOT شده را با گیت NOR جایگزین کنید.
- برای متغیر های ورودی با مکمل آن جایگزین می شود.



## پیاده سازی های دو طبقه فرم SOP

### OR-NAND circuit ■

- الف- در هر مسیر دو عدد NOT قرار دهد.
- ب- گیت OR با ورودی های NOT شده را با گیت NAND جایگزین کنید.
- ج- گیت NAND با ورودی های NOT شده را با گیت OR جایگزین کنید.
- د- NOT برای متغیر های ورودی با مکمل آن جایگزین می شود.



## پیاده سازی های دو طبقه فرم POS

■ فرم POS نیز می تواند به جهار حالت دو طبقه پیاده سازی گردد:

- ❖ 2-level OR-AND logic circuits
- ❖ 2-level NOR-NOR logic circuits
- ❖ 2-level NAND-AND logic circuits
- ❖ 2-level AND-NOR logic circuits
- OR-AND logic circuit



## پیاده سازی های دو طبقه فرم POS

### NOR-NOR circuit ■

الف- در هر مسیر دو عدد NOT قرار دهید.

ب- گیت AND با ورودی های NOT شده را با گیت NOR جایگزین کنید.

برای متغیر های ورودی با NOT مکمل آن جایگزین می شود



## پیاده سازی های دو طبقه فرم POS

### NAND-AND circuit ■

الف- در هر مسیر دو عدد NOT قرار دهید.

ب- گیت OR با ورودی های NOT شده را با گیت NAND جایگزین کنید.

برای متغیر های ورودی با مکمل آن جایگزین می شود



## پیاده سازی های دو طبقه فرم POS

### AND-NOR circuit ■

- الف- در هر مسیر دو عدد NOT قرار دهد.
- ب- گیت AND با ورودی های NOT شده را با گیت NOR جایگزین کنید.
- ج- گیت NOR با ورودی های NOT شده را با گیت AND جایگزین کنید.
- د- برای متغیر های ورودی با مکمل آن جایگزین می شود



## ۲-۶ تمرین

Q1. Draw a logic circuit for  $BD + BE + D'F$  using only NAND gates. Use both DeMorgan method and SOP method.

Q2. Transform the following AND-OR Circuit to NAND circuit.



Q3. Using only NOR gates, draw a logic circuit using POS method for  $(A+B+C')(B'+C'+D)$

## منطق مثبت و منفی Positive & Negative Logic

- معمولاً در گیت های منطقی داریم:
  - ❖ H (high voltage, 5V) = 1
  - ❖ L (low voltage, 0V) = 0
- این قرداد منطق مثبت می باشد.
- با این وجود قرار داد معکوس یعنی منطق مثبت نیز می تواند استفاده گردد.
  - ❖ H (high voltage) = 0
  - ❖ L (low voltage) = 1
- بسته به نوع منطق استفاده شده یک گیت ممکن است عبارت بولی متفاوتی را نمایش دهد.

## منطق مثبت و منفی Positive & Negative Logic

Positive logic:



Negative logic:



## خانواده مدار های مجتمع (IC) دیجیتالی Integrated Circuit Logic Families

بعضی خانواده های مدار های منطقی دیجیتالی: TTL, CMOS, ECL

### ■ TTL: Transistor-Transistor Logic.

- ❖ از ترانزیستور های (bipolar junction transistors ) BJT استفاده می کند.
- ❖ شامل مدار های زیر است: standard TTL, low-power TTL, Schottky TTL, etc.

### ■ CMOS: Complementary Metal-Oxide Semiconductor.

- ❖ از ترانزیستور های (field-effect transistors) FET استفاده می کند.

### ■ ECL: Emitter Coupled Logic.

- ❖ از تکنولوژی مدار های دوقطبی (bipolar circuit technology) استفاده می کند.
- ❖ دارای سرعت سویچینگ بالایی هستند ولی مصرف توان آنها بالاست.

## خانواده مدار های مجتمع (IC) دیجیتالی Integrated Circuit Logic Families

| TTL Series             | Prefix Designation | Example of Device        |
|------------------------|--------------------|--------------------------|
| Standard TTL           | 54 or 74           | 7400 (quad NAND gates)   |
| Low-power TTL          | 54L or 74L         | 74L00 (quad NAND gates)  |
| Schottky TTL           | 54S or 74S         | 74S00 (quad NAND gates)  |
| Low-power Schottky TTL | 54LS or 74LS       | 74LS00 (quad NAND gates) |

## خانواده مدار های مجتمع (IC) دیجیتالی

### مشخصات ویژه:

یا گنجایش خروجی: حدکثر انشعباب هایی که می توان از خروجی گیت گرفت، بدون اینکه تاثیر نامطلوب در عملکرد آن داشته باشد. برای گرفتن انشعباب بیش از مقدار- Fan-Out می توان از بافر استفاده کرد.

یا تاخیر انتشار: زمانی که طول می کشد بعد از اعمال ورودی به گیت اثر آن در خروجی ظاهر گردد.

تاخیر انتشار کل یک مدار منطقی برابر تعداد طبقات آن ضریب تاخیر یک طبقه(یک گیت) است. از این لحاظ پیاده سازی های دو طبقه، سرعت بالاتری خواهند داشت و از نقطه نظر پیاده سازی اهمیت زیادی دارند.

یا مصرف توان: مصرف توان هر گیت را مشخص می کند.

حاصلضرب تاخیر انتشار در مصرف توان می باشد.

یا محدوده نویز: حد اکثر ولتاژ نویزی را که گیت می تواند بدون تغییر نا مطلوب تحمل کند نشان می دهد.