Presentation is loading. Please wait.

Presentation is loading. Please wait.

مدار منطقی Logic Circuits

Similar presentations


Presentation on theme: "مدار منطقی Logic Circuits"— Presentation transcript:

1

2 مدار منطقی Logic Circuits
Combinational Logics

3 Combinational Circuits
Princess Sumaya University Digital Logic Design Combinational Circuits Output is a function of input only i.e. no feedback When input changes, output may change (after a delay) Combinational Circuits n inputs m outputs در مدارات ترکیبی خروجی مدار در هر لحظه فقط و فقط تابع ورودی های مدار در همان لحظه میباشد. مدارات ترکیبی از ترکیب گیت های منطقی به وجود میآیند. در مقابل مدارهای ترتیبی وجود دارند که در آنها علاوه بر گیتهای منطقی عناصر حافظه دار نیز وجود دارند و در نتیجه خروجی این مدارات به مقادری ورودی و حالت عناصر حافظه دار بستگی دارد و چون حالت عناصر حافظه دار از روی وردیهای قبلی به دست آمده بنابراین میتوان گفت خروجی مدار در هر لحظه به ورودیهای همان لحظه و ورودیهای لحظه های قبلی بستگی دارد و برای تحلیل این مدارات باید زمان بندی ورودیها را در نظر داشت. در این فصل در مورد مراحل تحلیل و طراحی مدارات ترکیبی بجث میشود و بعضی از مدارات مهم و کاربردی مانند جمع و تفریق کننده و مقایسه کننده، Decoder و Encoder و Multiplexer را بررسی می کنیم. مدارات این ادوات در رستة MSI(Medium scale integrated Circuits) قرار میگیرند. Dr. Bassam Kahhaleh

4 Combinational Circuits
Princess Sumaya University Digital Logic Design Combinational Circuits Analysis Given a circuit, find out its function Function may be expressed as: Boolean function Truth table Design Given a desired function, determine its circuit ? تحلیل مدار در مهندسی معکوس کاربرد دارد. ? Dr. Bassam Kahhaleh

5 Princess Sumaya University
Digital Logic Design Analysis Procedure Boolean Expression Approach T2=ABC T1=A+B+C T3=AB'C'+A'BC'+A'B'C F’2=(A’+B’)(A’+C’)(B’+C’) در اولین قدم باید مطمئن شد که مدار ترکیبی است. مدار ترکیبی فاقد فیدبک و یا عنصر حافظه دار است. مدار بالا Full Adder است. F2=AB+AC+BC F1=AB'C'+A'BC'+A'B'C+ABC F2=AB+AC+BC Dr. Bassam Kahhaleh

6 Princess Sumaya University
Analysis Procedure Digital Logic Design Truth Table Approach A B C F1 F2 = 0 1 Dr. Bassam Kahhaleh

7 Princess Sumaya University
Analysis Procedure Digital Logic Design Truth Table Approach A B C F1 F2 = 0 = 1 1 1 1 1 Dr. Bassam Kahhaleh

8 Princess Sumaya University
Analysis Procedure Digital Logic Design Truth Table Approach A B C F1 F2 1 = 0 = 1 1 1 1 1 Dr. Bassam Kahhaleh

9 Princess Sumaya University
Analysis Procedure Digital Logic Design Truth Table Approach A B C F1 F2 1 = 0 = 1 1 1 Dr. Bassam Kahhaleh

10 Princess Sumaya University
Analysis Procedure Digital Logic Design Truth Table Approach A B C F1 F2 1 = 1 = 0 1 1 1 1 Dr. Bassam Kahhaleh

11 Princess Sumaya University
Analysis Procedure Digital Logic Design Truth Table Approach A B C F1 F2 1 = 1 = 0 1 1 Dr. Bassam Kahhaleh

12 Princess Sumaya University
Analysis Procedure Digital Logic Design Truth Table Approach A B C F1 F2 1 = 1 = 0 1 1 Dr. Bassam Kahhaleh

13 Princess Sumaya University
Analysis Procedure Digital Logic Design Truth Table Approach A B C F1 F2 1 = 1 1 1 1 B 1 A C B 1 A C F1=AB'C'+A'BC'+A'B'C+ABC F2=AB+AC+BC Dr. Bassam Kahhaleh

14 Princess Sumaya University
Design Procedure Digital Logic Design Given a problem statement: Determine the number of inputs and outputs Derive the truth table Simplify the Boolean expression for each output Produce the required circuit Example: Design a circuit to convert a “BCD” code to “Excess 3” code ? 4-bits 0-9 values 4-bits Value+3 Dr. Bassam Kahhaleh

15 Princess Sumaya University
Design Procedure Digital Logic Design BCD-to-Excess 3 Converter C 1 B A x D C 1 B A x D A B C D w x y z x x x x w = A+BC+BD x = B’C+B’D+BC’D’ C 1 B A x D C 1 B A x D y = C’D’+CD z = D’ Dr. Bassam Kahhaleh

16 Princess Sumaya University
Design Procedure Digital Logic Design BCD-to-Excess 3 Converter A B C D w x y z x x x x برای کمتر شدن گیت ها باید توابع را تا می توانیم یکسان کنیم مثلاً در این مثال C+D همه جا وجود میآید و بنابراین میتوان با استفاده از یک گیت or آنرا تولید کرد و در سایر حاها استفاده کرد. در پباده سازی عملی باید ملاحظات متنوعی را در نظر گرفت: مثلا تعداد ورودیهای هر گیت، حداکثر تاخیر مجاز، Fan out گیتها و .... w = A + B(C+D) y = (C+D)’ + CD x = B’(C+D) + B(C+D)’ z = D’ Dr. Bassam Kahhaleh

17 Seven-Segment Decoder
Princess Sumaya University Digital Logic Design Seven-Segment Decoder a b c g e d f w x y z a b c d e f g x x x x x x x ? w x y z a b c d e f g BCD code y 1 x w z توضیج آند مشترک و کاتد مشترک. مقاومت محدود کننده جریان a = w + y + xz + x’z’ b = . . . c = . . . d = . . . Dr. Bassam Kahhaleh

18 Princess Sumaya University
Digital Logic Design Binary Adder Half Adder Adds 1-bit plus 1-bit Produces Sum and Carry HA x y S C x + y ─── C S x y C S 0 0 0 0 0 1 0 1 1 0 1 1 1 0 x y S C Dr. Bassam Kahhaleh

19 Princess Sumaya University
Digital Logic Design Binary Adder Full Adder Adds 1-bit plus 1-bit plus 1-bit Produces Sum and Carry FA x y z S C x + y + z ─── C S y 1 x z x y z C S 0 0 0 1 1 0 1 1 S = xy'z'+x'yz'+x'y'z+xyz = x  y  z y 1 x z C = xy + xz + yz Dr. Bassam Kahhaleh

20 Princess Sumaya University
Binary Adder Princess Sumaya University Digital Logic Design Full Adder S = xy'z'+x'yz'+x'y'z+xyz = x  y  z C = xy + xz + yz x y z S C S C x y z Dr. Bassam Kahhaleh

21 Princess Sumaya University
Binary Adder Digital Logic Design Full Adder HA HA x y z S C x y z S C Dr. Bassam Kahhaleh

22 Princess Sumaya University
Digital Logic Design Binary Adder Binary Adder x3x2x1x y3y2y1y0 S3S2S1S0 C0 Cy c3 c2 c + x3 x2 x1 x0 + y3 y2 y1 y0 ──────── Cy S3 S2 S1 S0 Carry Propagate Addition x x x x0 y y y y0 FA FA FA FA C C C C1 S S S S0 Dr. Bassam Kahhaleh

23 Princess Sumaya University
Digital Logic Design Binary Adder Carry Propagate Adder(Ripple Carry Adder) x7 x6 x5 x4 x3 x2 x1 x0 y7 y6 y5 y4 y3 y2 y1 y0 CPA A3 A2 A1 A0 B3 B2 B1 B0 S3 S2 S1 S0 C0 Cy CPA A3 A2 A1 A0 B3 B2 B1 B0 Cy C0 S3 S2 S1 S0 S7 S6 S5 S4 S3 S2 S1 S0 Dr. Bassam Kahhaleh

24 Carry Propagation When the correct outputs are available
The critical path counts (the worst case) (A1, B1, C1) → C2 → C3 → C4 → (C5, S4) When 4-bits full-adder → 8 gate levels (n-bits: 2n gate levels) سیگنالهای P(Carry Propagation) و G(Carry Generation) فقط و فقط به ورودیها بستگی دارند و بلافاصله بعد از اعمال ورودیها در کلیه طبقات بعد از تاخیر مربوط به گیت خود تولید میشوند و این تاخیر ثابت است و جمع شونده نیست. اما تاخیری که در مراحل مختلف مرتبا جمع میشود مربوط به Carry Propagation است، که همان گیت And و OR آخری است. چون در هر مرحله این گیتها با هم سری میشوند و تاخیر آنها با هم جمع می شود. بنابراین در هر مرحله 2 گیت تاخیر اضافه میشود. سیگنال Gi به معنی Carry Generation است یعنی سیگنال Carry در مرحلة i تولید میشود که شرط آن یک بودن Ai و Bi با هم است که با هم AND شده اند. سیگنال Pi به معنی Carry Propagation است که یعنی سیگنال Carry از مرحلة قبل آمده است و در این مرحله نیز به مرحلة بعد Propagate می کند که شرط آن یک بودن یکی از سیگنالهای Ai و یا Bi و همچنین یک یودن سیگنال Carry از مرحلة قبل است. که تاخیر اصلی نیز توسط همین Propagation تولید میشود. Full Adder with P and G Shown

25 Parallel Adders Reduce the carry propagation delay Employ faster gates
Look-ahead carry (more complex mechanism, yet faster) Carry propagate: Pi = AiÅBi Carry generate: Gi = AiBi Sum: Si = PiÅCi Carry: Ci+1 = Gi+PiCi C0 = Input carry C1 = G0+P0C0 C2 = G1+P1C1 = G1+P1(G0+P0C0) = G1+P1G0+P1P0C0 C3 = G2+P2C2 = G2+P2G1+P2P1G0+P2P1P0C0 معنی مفهومی فرمول C3 یعنی اینکه سیگنال کری C3 به شرطی تولید میشود که یا در مرحلة دوم کری تولید شود(G2) و یا اینکه در مرحلة اول تولید شود و در مرحلة دوم انتشار یابد(P2G1) و یا اینکه در مرحلة صفرم تولید شود و در مراحل اول و دوم انتشار یابد(P2P1G0) و در نهایت یا اینکه در مرحلة صفرم کری وجود داشته باشد و در مراحل صفر و یک و دو انتشار یابد(P2P1P0C0)

26 Carry Look-ahead Adder (1/2)
Logic Diagram Logic Diagram of Carry Look-ahead Generator

27 Carry Look-ahead Adder (2/2)
4-bit carry-look ahead adder Propagation delay of C3, C2 and C1 are equal. البته برابر بودن تاخیرها به شرطی است که دارای گیتهای n ورودی باشیم و اگر دارای محدودیت در تعداد ورودیها داشته باشیم کریهای مراحل بالاتر با تاخیر بیشتری تولید خواهند شد ولی به هر حال از روش قبل سریعتر است. تاخیر کل مدار جمع کننده برابر با 4 تاخیر گیت است. دو تاخیر در تولید کری و دو تاخیر نیز در تولید سیگنال نهایی si 4-Bit Adder with Carry Look-ahead

28 Binary Adder

29 Princess Sumaya University
Digital Logic Design Binary Subtractor Use 2’s complement with binary adder x – y = x + (-y) = x + y’ + 1 Dr. Bassam Kahhaleh

30 Binary Adder/Subtractor
Princess Sumaya University Digital Logic Design Binary Adder/Subtractor M: Control Signal (Mode) M=0  F = x + y M=1  F = x – y Dr. Bassam Kahhaleh

31 Overflow Unsigned numbers Signed numbers
Addition  Carry means the result is n+1 Subtraction Carry = not(Borrow) C = 1  Result is correct and positive C = 0  Result is negative! (Take 2’s complement and place minus sign in front of it) Signed numbers Carry has no useful meaning We should check overflow and sign bit سرریز وقتی اتفاق می افتد که نتیجه جمع و یا تفریق دو عدد n رقمی برابر با عددی n+1 رقمی شود. 1- در جمع اعداد بدون علامت وقوع Carry همان معنای سرریز را دارد. 2- در تفریق اعداد بدون علامت چون تفریق با استفاده از جمع متمم دو انجام میشود Carry به معنای not قرض است. بنابراین اگر Carry یک شد یعنی قرضی لازم نبوده و حاصل درست است. اگر Carry صفر شد یعنی قرض نیاز داشته و حاصل عددی منفی است و باید از ان متمم دو گرفت و علامت منفی جلوی آن گذاشت. 3- در جمع و تفریق اعداد علامت دار بیت Carry مفهومی ندارد و باید به بیت Overflow نگاه کنیم.

32 Number wheel representation of 4-bit system
Possible Overflow

33 Overflow When the results of adding/subtracting two numbers of n digit occupies n + 1 digit If the carry in to the sign position is not equal to the carry out of the sign bit position an overflow is detected.

34 Princess Sumaya University
Digital Logic Design Overflow Unsigned Binary Numbers 2’s Complement Numbers FA x x x x0 y y y y0 S S S S0 C C C C1 Carry FA x x x x0 y y y y0 S S S S0 C C C C1 این مدار به طور کلی برای همه حالات استفاده میشود چه عدد علامت دار باشد چه بدون علامت. اگر بعد از انجام عمل سراغ بیت C رفتیم یعنی عدد بدون علامت در نظر گرفتیم. اگر بعد از انجام عمل سراغ بیت V رفتیم یعنی عدد علامت دار در نظر گرفتیم. Overflow Dr. Bassam Kahhaleh

35 Princess Sumaya University
Digital Logic Design BCD Adder 4-bits plus 4-bits Operands and Result: 0 to 9 + x3 x2 x1 x0 + y3 y2 y1 y0 ──────── Cy S3 S2 S1 S0 X +Y x3 x2 x1 x0 y3 y2 y1 y0 Sum Cy S3 S2 S1 S0 0 + 0 = 0 0 + 1 = 1 0 + 2 = 2 0 + 9 = 9 1 + 0 = 1 1 + 1 = 2 1 + 8 = 9 1 + 9 = A Invalid Code 2 + 0 = 2 9 + 9 = 18 1 Wrong BCD Value Dr. Bassam Kahhaleh

36 Princess Sumaya University
BCD Adder Digital Logic Design X +Y x3 x2 x1 x0 y3 y2 y1 y0 Sum Cy S3 S2 S1 S0 Required BCD Output Value 9 + 0 = 9 9 + 1 = 10 = 16 9 + 2 = 11 = 17 9 + 3 = 12 = 18 9 + 4 = 13 = 19 9 + 5 = 14 = 20 9 + 6 = 15 = 21 9 + 7 1 = 22 9 + 8 = 23 9 + 9 = 24 بنابراین میبینبم در جمع اعداد BCD به روش باینری اگر حاصل دارای کری بود و یا عددی بین A تا F است نیاز به تصحیح دارد. + 6 Dr. Bassam Kahhaleh

37 Princess Sumaya University
BCD Adder Digital Logic Design Correct Binary Adder’s Output (+6) If the result is between ‘A’ and ‘F’ Or if Cy = 1 S3 S2 S1 S0 Err 1 S1 S2 S3 1 S0 بدون جدول کارنو نیز می توان به راحتی تشخیص داد معادله به چه صورت است. وقتی نتیجه بین A تا F است که S3 یک باشد و S1 و یا S2 نیز یک باشند. Err = S3 S2 + S3 S1 + Cy Dr. Bassam Kahhaleh

38 Princess Sumaya University
Digital Logic Design BCD Adder Err میتوان این مدار را بلوک دیاگرام کرد و با اتصال سری ان به یکدیگر اعداد BCD چند رقمی را با هم جمع کرد. Dr. Bassam Kahhaleh

39 Binary Multiplier The multiplicand is multiplied by each bit of the multiplier, starting from the least significant bit. Each such multiplication forms a partial product. Successive partial products are shifted one position to the left. The final product is obtained from the sum of the partial products. Multiplicand Multiplier

40 Binary Multiplier در اینجا توانستیم جمع ها را با HA انجام دهیم ولی در حالت کلی به FA نیاز داریم.

41 Binary Multiplier J multiplier bits, and K multiplicand bits
Result  J+K Bits J×K AND Gates (J-1) Adders K bit Adders Multiplicand(K-Bit) Multiplier(J-Bit)

42 Binary Multiplier B3B2B1B0  K = 4 A2A1A0  J = 3
این در واقع یکی از تکنیک های ضرب است. برای ضرب تکنبکهای متنوع و سریع تری وجود دارد. تمرین با نمره اضافی

43 Princess Sumaya University
Magnitude Comparator Digital Logic Design Compare 4-bit number to 4-bit number 3 Outputs: < , = , > Expandable to more number of bits A3A2A1A0 B3B2B1B0 Magnitude Comparator جدول حالت برای مقایسه دو عدد n بیتی دارای 22n سطر است که خیلی بزرگ است. در این مسائل الگوریتم حل مسئاله را باید بیابیم. به طور حسی حل کردن این مسائل بسیار ساده تر از راه حل سیتماتیک جدول کارنو است. ما در اینجا نیاز به جدول کارنو 8 متغییره داریم. حل حسی 1- تشخیص مساوی بودن : باید تمام بیتها با هم برابر باشند. تابع XNOR 2- بزرگ تر بودن A از B : باید بیت MSB A یک باشد و بیت MSB B صفر باشد و یا این دوبیت باهم برابر باشند و بیت رتبة بعدی در A یک و در B صفر باشد و الی آخر. سئوال: مداری که دو عدد علامت دار را مقایسه کند. مداری که یک عدد علامت دار و بدون علامت را مقایسه کند. مداری که دو عدد با طول متفاوت را مقایسه کند. A<B A=B A>B Dr. Bassam Kahhaleh

44 Princess Sumaya University
Magnitude Comparator Digital Logic Design Dr. Bassam Kahhaleh

45 Princess Sumaya University
Digital Logic Design Magnitude Comparator x7 x6 x5 x4 x3 x2 x1 x0 y7 y6 y5 y4 y3 y2 y1 y0 Magnitude Comparator A3 A2 A1 A0 B3 B2 B1 B0 A<B A=B A>B I(A>B) I(A=B) I(A<B) Magnitude Comparator A3 A2 A1 A0 B3 B2 B1 B0 1 I(A>B) I(A=B) I(A<B) A<B A=B A>B فرض کنید مدار دارای ورودیهای مقایسه است که مربوط به مراحل بالاتر است. طراحی کنید A<B A=B A>B Dr. Bassam Kahhaleh

46 Princess Sumaya University
Digital Logic Design Decoders Extract “Information” from the code Binary Decoder Example: 2-bit Binary Number Only one lamp will turn on 1 2 3 minterms The decoders presented here are called n-to-m-line decoders, where m<= 2n. Their purpose is to generate the 2n (or fewer) minterms of n input variables. Binary Decoder x1 x0 1 Dr. Bassam Kahhaleh

47 Decoders 2-to-4 Line Decoder Binary Decoder I1 I0 y3 y2 y1 y0 I1 I0
اگر گیت های خروجی گیت NAND باشد مدار Active Low میشود. I1 I0 Y3 Y2 Y1 Y0 0 0 0 1 1 0 1 1

48 Decoders 3-to-8 Line Decoder Y7 Y6 Y5 Binary Decoder Y4 Y3 Y2 I2 Y1 I1

49 Decoders “Enable” Control Binary Decoder I1 I0 E Y3 Y2 Y1 Y0 E I1 I0
x x 1 0 0 0 1 1 0 1 1 سیگنال Enable نیز میتواند Active High و یا Active Low باشد. همچنین ممکن است چند ورودی Enable وجود داشته باشد. Decoder با ورودی Enable میتواند به عنوان Demultiplexer نیز عمل کند و دقیقا مدار آنها نیز یکسان است. در حالت Demultiplex ورودی E ورودی دیتا خواهد بود و ورودی I1 و I0 ورودی های Select هستند و دیتایی که برروی E قرار میگیرد فقط برروی خروجی که توسط I0 و I1 انتخاب شده اند قرار میگیرد.

50 Decoders Expansion I2 I1 I0 I2 I1 I0 Y7 Y6 Y5 Y4 Y3 Y2 Y1 Y0 0 0 0
Binary Decoder I0 I1 E Y3 Y2 Y1 Y0 Y7 Y6 Y5 Y4 در کتاب مثالی که حل کرده با فرض Active Low بودن سیگنال Enable است.

51 Decoders Active-High / Active-Low I1 I0 Y3 Y2 Y1 Y0 0 0 0 0 0 1 0 1
0 0 0 1 1 0 1 1 I1 I0 Y3 Y2 Y1 Y0 0 0 0 1 1 0 1 1 Binary Decoder I1 I0 Y3 Y2 Y1 Y0 Binary Decoder I1 I0 Y3 Y2 Y1 Y0

52 Implementation Using Decoders
Each output is a minterm All minterms are produced Sum the required minterms Example: Full Adder S(x, y, z) = ∑(1, 2, 4, 7) C(x, y, z) = ∑(3, 5, 6, 7) I2 I1 I0 Y7 Y6 Y5 Y4 Y3 Y2 Y1 Y0 Binary Decoder x y z S C البته این پیاده سازی ساده ترین نوع پیاده سازی نیست و یک نوع پیاده سازی هزینه بر است. این روش وقتی کارا است که بخواهیم چندین تابع را با هم پیاده کنیم نکته: اگر تابعی دارای مینمم ترم های زیادی باشد آنگاه در این روش گیت Or استفاده شده باید دارای ورودیهای زیادی باشد.(به ازای هر مینمم ترم یک ورودی نیاز است.) در این مواقع میتوان تابع F′ که دارای مینمم ترم های کمتری است را در نظر گرفت و در نهایت به جای گیت OR از گیت NOR استفاده کرد تا پریم آن خنثی و تابع F بدست آید. در این صورت گیت NOR مورد استفاده دارای ورودیهای کمتری خواهد بود.

53 Implementation Using Decoders
Y7 Y6 Y5 Y4 Y3 Y2 Y1 Y0 Binary Decoder x y z S C I2 I1 I0 Y7 Y6 Y5 Y4 Y3 Y2 Y1 Y0 Binary Decoder x y z S C

54 Only one switch should be activated at a time
Encoders Put “Information” into code Binary Encoder Example: 4-to-2 Binary Encoder Only one switch should be activated at a time 1 2 3 Binary Encoder y1 y0 x1 x2 x3 x3 x2 x1 y1 y0 0 0 0 1 1 0 1 1 وقتی هیچ کلیدی فشار داده نشده است کد صفر است. یا می تواند صفر به عنوان یک ورودی نیز در نظر گرفت

55 Encoders Octal-to-Binary Encoder (8-to-3) Binary Encoder Y2 Y1 Y0 I7
I4 I3 I2 I1 I0 I7 I6 I5 I4 I3 I2 I1 I0 Y2 Y1 Y0 این Encoder دارای دو محدودیت است اولا فرض بر این است که فقط یکی از ورودی ها در هر لحظه فعال است و اگر دو وردی در یک زمان فعال باشد خروجی اشتباه می شود. و ثانیا هنگامی که هیچ ورودی فعال نباشد نیز خروجی صفر فعال است که دقیقا شبیه حالتی است که ورودی صفر فعال است. برای رفع عیب اول باید از Encoder اولویت استفاده کرد و برای رفع مشکل دوم باید یک خروجی اضافی در نظر گرفت که نشان دهد حداقل یک ورودی فعال شده است.

56 Priority Encoders 4-Input Priority Encoder Priority Encoder V Y1 Y0 I3
I3 I2 I1 I0 Y1 Y0 V 0 0 1 x 0 1 x x 1 0 1 x x x 1 1 V Valid bit indicator Y1 I1 1 I2 I3 I0

57 Encoder / Decoder Pairs
Binary Encoder Binary Decoder Y7 Y6 Y5 Y4 Y3 Y2 Y1 Y0 7 7 I7 I6 I5 I4 I3 I2 I1 I0 6 6 5 5 Y2 Y1 Y0 I2 I1 I0 4 4 3 3 2 2 1 1

58 Multiplexers S1 S0 Y 0 0 I0 0 1 I1 1 0 I2 1 1 I3 MUX Y I0 I1 I2 I3
0 0 I0 0 1 I1 1 0 I2 1 1 I3 MUX Y I0 I1 I2 I3 S1 S0

59 Multiplexers 2-to-1 MUX 4-to-1 MUX I0 MUX I1 Y S I0 I1 MUX I2 I3 Y
قسمت انتخاب شده بسیار شبیه مدار دیکودر 2 به 4 است که برای هر گیت AND یک ورودی اطلاعات نیز اضافه شده است. به سادگی می توان با یک دیکدر 2 به 4 و چهار عدد گیت AND یک MUX 4 به 1 ساخت. MUX Y I0 I1 I2 I3 S1 S0

60 Multiplexers Quad 2-to-1 MUX x3 y3 x2 y2 x1 y1 x0 y0 I0 MUX I1 Y S S
S E Y3 Y2 Y1 Y0 B3 B2 B1 B0 مسئالة Fan out برای سیگنالهای S و E وجود دارد. چون ممکن است از بیرون به چند جای دیگر نیز بروند و اصولا نباید یک گیت و IC اینقدر برروی یک سیگنال Fan out ایجاد کند. S

61 Multiplexers Quad 2-to-1 MUX A3 A2 A1 A0 MUX Y3 Y2 Y1 Y0 B3 B2 B1 B0
S E Y3 Y2 Y1 Y0 B3 B2 B1 B0 Extra Buffers

62 Implementation Using Multiplexers
Example F(x, y) = ∑(0, 1, 3) x y F 0 0 1 0 1 1 0 1 1 MUX Y I0 I1 I2 I3 S1 S0 1 F در قسمت قبل دیدیم که می توان به کمک Decoder و OR خارجی توابع را پیاده سازی کرد. در مدار MUX دیدیم که تشکیل شده از یک دیکودر به همراه یک OR بنابراین میتوان از MUX نیز برای پیاده سازی توابع استفاده کرد و هیچ المان خارجی نیز نیاز نداریم. x y

63 Implementation Using Multiplexers
Example F(x, y, z) = ∑(1, 2, 6, 7) MUX Y I0 I1 I2 I3 I4 I5 I6 I7 S2 S1 S0 1 x y z F 1 F x y z

64 Implementation Using Multiplexers
Example F(x, y, z) = ∑(1, 2, 6, 7) x y z F 1 MUX Y I0 I1 I2 I3 S1 S0 z F = z z F F = z 1 به طور کلی می توان برای پیاده سازی یک تابع n متغیره از یک Mux 2n-1 به یک استفاده کرد و متغییر n ام را در وردی MUX درگیر کرد. به هر ترتیبی نیز که بخواهیم می توانیم متغییر درگبر در ورودی و n-1 متغییر برای Select را انتخاب کنیم. چون برای هر ترکیب متغییرهای انتخاب شده برای Select در جدول صحت دو حالت وجود دارد. اگر این دو حالت یک باشد ورودی یک و اگر صفر باشد ورودی صقر و در غیر این صورت یا برابر با متغییر انتخاب نشده و یا برابر با not آن است و گزینة دیگری وجود ندارد. F = 0 x y F = 1

65 Implementation Using Multiplexers
Example F(x, y, z) = ∑(1, 2, 6, 7) x y z F 1 F = 0 MUX Y I0 I1 I2 I3 S1 S0 F = x x F 1 F = 1 x F = x F = 0 y z F = x F = 1 F = x

66 Implementation Using Multiplexers
Example F(A, B, C, D) = ∑(1, 3, 4, 11, 12, 13, 14, 15) A B C D F 1 MUX Y I0 I1 I2 I3 I4 I5 I6 I7 S2 S1 S0 D F = D D F = D D F = D F F = 0 D F = 0 1 F = D 1 F = 1 F = 1 A B C

67 Multiplexer Expansion
8-to-1 MUX using Dual 4-to-1 MUX Y I0 I1 I2 I3 I4 I5 I6 I7 S2 S1 S0 MUX Y I0 I1 I2 I3 S1 S0 MUX Y I0 I1 S MUX Y I0 I1 I2 I3 S1 S0 1 0 0

68 DeMultiplexers DeMUX I Y3 Y2 Y1 Y0 S1 S0 S1 S0 Y3 Y2 Y1 Y0 0 0 I 0 1
0 0 I 0 1 1 0 1 1 همان دیکودر با ورودی enable است

69 Multiplexer / DeMultiplexer Pairs
MUX DeMUX Y7 Y6 Y5 Y4 Y3 Y2 Y1 Y0 7 7 I7 I6 I5 I4 I3 I2 I1 I0 6 6 5 5 4 4 Y I 3 3 2 2 1 1 S2 S1 S0 S2 S1 S0 Synchronize x2 x1 x0 y2 y1 y0

70 DeMultiplexers / Decoders
DeMUX I Y3 Y2 Y1 Y0 S1 S0 Binary Decoder I1 I0 E Y3 Y2 Y1 Y0 E I1 I0 Y3 Y2 Y1 Y0 x x 1 0 0 0 1 1 0 1 1 S1 S0 Y3 Y2 Y1 Y0 0 0 I 0 1 1 0 1 1 به راحتی می توان Decoder با ورودی Enable را به عنوان Demultiplexer استفاده کرد به شرطی که از ورودی E به عنوان خط دیتا و از ورودیهای I0 و I1 به عنوان ورودی انتخاب استفاده شود. عکس قضیه نیز صادق است. می توان Demultiplexer را به عنوان Decoder استفاده کرد. به شرطی که از ورودی I به عنوان ورودی Enable و از ورودیهای S0 و S1 به عنوان ورودیهای I0 و I1 استفاده شود.

71 Three-State Gates Tri-State Buffer Tri-State Inverter C A Y 0 x Hi-Z
1 0 1 1 1 A Y C A Y C

72 Three-State Gates C D Y 0 0 Hi-Z 0 1 B 1 0 A 1 1 ? A Y C B Not Allowed
0 0 Hi-Z 0 1 B 1 0 A 1 1 ? A Y C B Not Allowed D A C B ساخت MUX 2 به یک توسط بافر سه حالته A if C = 1 B if C = 0 Y=

73 Three-State Gates I3 I2 Y I1 I0 Y3 Binary Decoder Y2 S1 I1 Y1 I0 Y0 E
ساخت Multiplexer از MUX و یا بافرهای سه حالته برای ساخت Bus استفاده میشود. I0 Binary Decoder Y3 Y2 Y1 Y0 S1 I1 I0 E S0 E

74 HDL Model of compinational circuits
The module is the basic building block for modeling hardware with the Verilog HDL The logic of a module can be described in any one (or a combination) of the following modeling styles: 1. Gate-level modeling using instantiations of predefined and user-defined primitive gates. 2. Dataflow modeling using continuous assignment statements with the keyword assign. 3. Behavioral modeling using procedural assignment statements with the keyword always. هرچه به سمت بالاتر حرکت میکنیم توصیف برای ما راحت تر خواهد بود و بیشتر عملکرد مدار توصیف میشود و پیاده سازی مدار بر عهده ابزار سنتز خواهد بود. Gate-level (structural) modeling describes a circuit by specifying its gates and how they are connected with each other. Dataflow modeling is used mostly for describing the Boolean equations of combinational logic. Behavioral modeling that is used to describe combinational and sequential circuits at a higher level of abstraction.

75 Gate level modeling Gate level modeling provides a textual description of a schematic diagram. 12 basic gates. (four of them tree state gates) lowercase keywords and, nand, or, nor, xor, xnor, not, and buf. The buf and not primitives are n-output primitives. Others are n-input primitives. four valued system, 0, 1, x, z x  unknown z  high impedance In this type of representation, a circuit is specified by its logic gates and their interconnections. Gate level modeling provides a textual description of a schematic diagram. When a primitive gate is listed in a module, we say that it is instantiated in the module.

76 Truth tables

77 Vectors The first (leftmost) number (array index) listed is always the most significant bit of the vector. The individual bits are specified within square brackets, so D[2] specifies bit 2 of D. It is also possible to address parts (contiguous bits) of vectors. For example, SUM[2: 0] specifies the three least significant bits of vector SUM.

78 2-4 decoder

79 Design methodology Two or more modules can be combined to build a hierarchical description of a design. There are two basic types of design methodologies: top down and bottom up. In a top-down design, the top-level block is defined and then the sub-blocks necessary to build the top-level block are identified. In a bottom-up design, the building blocks are first identified and then combined to build the top-level block. روش اول در طراحی و لایه مدیریتی روش دوم در پیاده سازی و لایة مهندسی

80 4 bit ripple-carry adder
Half adder A description of a module is said to be a structural description if it is composed of instantiations of other modules. Instantiating modules within other modules creates a hierarchical decomposition of a design.

81 4 bit ripple-carry adder
one bit Full adder

82 4 bit ripple-carry adder
instance names must be specified when defined modules are instantiated (such as FA0 for the first full adder in the third module), but using a name is optional when instantiating primitive gates.

83 Three-State gates The outputs of three-state gates can be connected together to form a common output line. To identify such a connection, Verilog HDL uses the keyword tri (for tristate) to indicate that the output has multiple drivers.

84 Mux with three-state output
Keywords wire and tri are examples of a set of data types called nets, which represent connections between hardware elements. The word net is not a keyword, but represents a class of data types, such as wire, wor, wand, tri, supply1, and supply0.

85 Data flow modeling Dataflow modeling of combinational logic uses a number of operators that act on binary operands to produce a binary result. Continuous assignments using the keyword assign. It should be noted that a bitwise operator (e.g., ~) and its corresponding logical operator (e.g., ! ) may produce different results, depending on their operand. If the operands are scalar the results will be identical; if the operands are vectors the result will not necessarily match. For example, ~ (1010) is (0101), and !(1010) is 0. A binary value is considered to be logically true if it is not 0. In general, use the bitwise operators to describe arithmetic operations and the logical operators to describe logical operations.

86 Four-bit adder Dataflow HDL models describe combinational circuits by their function rather than by their gate structure. The target output is the concatenation of the output carry C_out and the four bits of Sum. Concatenation of operands is expressed within braces and a comma separating the operands. Thus, {C_out, Sum} represents the five-bit result of the addition operation.

87 Four bit comparator

88 2-1 multiplexer

89 Behavioral modeling Behavioral modeling represents digital circuits at a functional and algorithmic level. It is used mostly to describe sequential circuits, but can also be used to describe combinational circuits. Behavioral descriptions use the keyword always. The target output of a procedural assignment statement must be of the reg data type. The procedural assignment statements inside the always block are executed every time there is a change in any of the variables listed after symbol. Contrary to the wire data type, whereby the target output of an assignment may be continuously updated, a reg data type retains its value until a new value is assigned.

90 2-1 multiplexer

91 4-1 multiplexer always @* for combinational circuit description
بهتر است عبارت آخر با default نوشته شود. نحوه نمایش اعداد؟ If the base of the number is not specified, its interpretation defaults to decimal. If the size of the number is not specified, the system assumes that the size of the number is at least 32 bits; if a host simulator has a larger word length—say, 64 bits—the language will use that value to store unsized numbers. The integer data type (keyword integer) is stored in a 32-bit representation. The underscore (_) may be inserted in a number to improve readability of the code (e.g., 16’b0101_1110_0101_0011 ). It has no other effect.

92 Number representation
[size]’[base][value] b, B  Binary, h, H  Hex, d, D  Decimal, o, O  Octal Default base is 10 The underscore (_) may be inserted in a number to improve readability of the code. 16’b0101_1110_0101_0011 16’h5_E_5_3

93 Test bench A test bench is an HDL program used for describing and applying a stimulus to an HDL model of a circuit in order to test it and observe its response during simulation. Test benches can be quite complex and lengthy and may take longer to develop than the design that is tested. Using always statement loosely The always statement executes repeatedly in a loop. The initial statement executes only once, starting from simulation time 0. The block is enclosed between the keywords begin and end. # for delay. repeat specifies a looping statement.

94 Test bench

95 Test bench

96 Test bench A test module is written like any other module, but it typically has no inputs or outputs. The signals that are applied as inputs to the design module for simulation are declared in the stimulus module as local reg data type. The outputs of the design module that are displayed for testing are declared in the stimulus module as local wire data type. The module under test is then instantiated, using the local identifiers in its port list.

97 Test bench Verilog system tasks are built-in system functions that are recognized by keywords that begin with the symbol $ The base may be binary, decimal, hexadecimal, or octal, identified with the symbols %b, %d, %h, and %o, respectively (%B, %D, %H, and %O are valid too). It is better to use the format %0d instead of %d. This provides a display of the significant digits without the leading spaces that %d will include. (%d will display about 10 leading spaces because time is calculated as a 32-bit number.)

98 Example Mux 2-1s

99 Example Test bench

100 Output Log

101 Home works 4.5, 4.6, 4.15, 4.17, 4.23, 4.25, 4.27, 4.28, 4.32, 4.33, 4.36, 4.37, 4.40, 4.41, 4.43, 4.45


Download ppt "مدار منطقی Logic Circuits"

Similar presentations


Ads by Google