Курсовая работа: Синтез керуючих автоматів

ВСТУП

Принцип мікропрограмного керування припускає, що цифровий пристрій складається з двох частин: операційний автомат (ОА) і керуючий автомат (КА). ОА виконує найпростіші операції (мікрооперації) типу зсув, алгебраїчне додавання, кон’юнкція, диз’юнкція і т.п. КА формує послідовність керуючих символів в ОА, під впливом яких ОА реалізує більш складні алгоритми. Такі послідовності операцій називаються мікропрограмами та, звичайно, записуються у вигляді граф-схеми алгоритму.

КА розділяються на дві великі групи: автомати з жорсткою логікою та автомати з програмованою логікою. У свою чергу автомати з жорсткою логікою підрозділяються на автомати, виконані за схемою Мілі (КА Мілі) і за схемою Мура (КА Мура), автомати з програмованою логікою – на автомати з примусовою адресацією та з природною адресацією.

В автоматах з жорсткою логікою схема автомата однозначно інтерпретує граф-схему мікропрограми. В автоматах із програмованою логікою граф-схема інтерпретується у вигляді програми, що зберігається в пам’яті автомата.


1. СИНТЕЗ ОПЕРАЦІЙНОГО АВТОМАТА

1.1 Аналіз вхідних даних

 

 Загальна формула для обчислювання результату S має такий вигляд:

Формулі ,  та  згідно з варіантом завдання:

             

Загальний алгоритм для обчислювання формули S приведений на рисунку 1.1.


Для обчислювання формули S використовується ІМp-модель (Individual Mutual with Parallel part - IMp).


Рис. 1.1 – Загальний алгоритм для обчислювання формули S

Схему взаємодії операційного та керуючої частин у цифровому просторі зображено на рисунку 1.2.


 

 

 


                    

                                          

Рис. 1.2 – Структура цифрового пристрою

Структурна схема ІМp - моделі зображена на рисунку 1.3


                                                                                             

 

 

 

 


Рис. 1.3 – Структура операційного пристрою

Пам’ять автомата складається з регістрів загального призначення R1, ... , Rn.

Локальні шини А1, А2, A3 призначені для прийому інформації з пам’яті та передачі її на комбінаційні схеми (КС).

В даному випадку використовуються КС двох типів: одномісні та двомісні.

Рис. 1.4 – Приклад комбінаційних схем

Однак, у даному ОА використовуються лише деякі з них.

 

1.2  Розробка функціонального алгоритму

Функціональна і структурна організація операційних пристроїв (ОУ) базується на принципі мікро програмного керування, сформульованому в 1951 році М. Уилксом.  Відповідно до цього принципу будь-яка машинна операція розділяється на послідовність елементарних дій по обробці інформації – мікро операцій (МО). Порядок проходження мікро операцій визначається спеціальними логічними умовами  (ЛУ), що у залежності від значень оброблюваної інформації приймають значення "істина" (1) або "неправда" (0). Алгоритм операцій в ОУ, записаний у термінах мікро операцій і логічних умов, що відбиває порядок проходження мікро операцій у часі, називається мікропрограмою.

Функція УА – це оперативна схема алгоритму, операторами якої є символи

, що ототожнюються з МО, виконуваними ОА, як логічні умови використовуються  булеві перемінні  . Найбільше часто операторна схема алгоритму представляється у виді граф-схеми алгоритму (ГСА).

 

Граф-схема алгоритму. Орієнтований зв'язаний граф – граф, що містить одну початкову вершину, одну кінцеву вершину, довільну безліч умовних і операторних вершин.

Будова ІМр автомата дозволяє паралельно виконувати одномісну та двумісну операції, тобто можливо виконувати за одне завантаження автомату завантаження двох операнд. Наприклад, у п’ятій вершині зроблено саме так.

Кожній дії, завантаженню автомата, відповідає Y[і].

Ідентичні дії відповідають однаковим командам, Y[і].

Логічні умови позначаються – XL, однаковим умовам відповідають однакові XL.

Функціональний алгоритм приведений на рисунку 1.5.


Рис. 1.5 – Функціональний алгоритм


1.3  Розробка структурної схеми автомата

 

1.3.1. Визначення набору регістрів пам’яті:

Rg : {RA, RB, RC, RS1, RS2, RS3}

 

1.3.2. Набір комбінаційних схем:

Одномісні: КС1 : {L1, L2, L3, R1, R2, R3}

На шину C повинні поступати всі аргументи одномісних операцій.

Двомісні: КС2: {Sum, Sub}

Припустимо, що операція відіймання виконується наступним чином:

Sub := B - A, тому від’ємне завжди повинно знаходитись на шині B, а від’ємник на шині А. В іншій двомісній операції Sum порядок операндів значення не має.  

Рис. 1.6 – Структурна схема автомата

 

1.3.3. Зв'язки між регістрами та локальними шинами

Наша схема має три шини: А та B – двомісні, та шина C – одномісна.

A {RA, RB, RC, RS1, RS2, RS3}

B {RA, RB, RC, RS1, RS2, RS3}

C {RA, RB, RC, RS1, RS2, RS3}

1.3.4.  Зворотні зв'язки шин Z1 та Z2 з регістрами пам’яті

Шини, що є результативними:

Z1 – результати одномісних операцій, а Z2 – двомісних операцій.

Z1 {RA, RB, RC, RS1, RS2, RS3}

Z2 {RA, RB, RC, RS1, RS2, RS3}

Кожний елемент, котрий діє у схемі може виконуватись тільки при наявності відповідного керуючого сигналу y[n].

у1, у2, у3 – завантаження початкових даних на шини.

у4 – у15 – завантаження даних  у регістри пам'яті.

у16–у33 – завантаження з пам'яті на локальні шини А, B, C.

у34, у39 – завантаження результатів одномісних операцій на шину Z1.

y40–у41 – завантаження результатів двомісних операцій на шину Z2.

Отримані таким чином дані заносимо до таблиці 1.1

Табл. 1.1 –Таблиця мікрооперацій

Мікрооперація A B C

Z1

Z2

Result
Y формула регістр y регістр y регістр y форм. y форм. y регістр y
1

RA := <A>

RB := <B>

<B>

y2

<A>

y1

RA:=Z2

RB:=Z1

y4

y7

2 RC := <C> <C>

y3

RC:=Z2

y8

3

RS3 := RA + RB

RA

y17

RB

y21

RA+RB

y40

RS3:=Z2

y14

4

RS2 := RA – RB

RB

y20

RA

y18

RA-RB

y41

RS2:=Z2

y12

5

RS1 := L3(RS2)

RS2

y28

L3(RS2)

y36

RS1:=Z1

y11

6

RS1 := RS1 – RS2

RS2

y29

RS1

y27

RS1-RS2

y41

RS1:=Z2

y10

7

RS2 := L2(RA)

RA

y16

L2(RA)

y35

RS2:=Z1

y13

8

RS3 := L1(RB)

RB

y19

L1(RB)

y34

RS3:=Z1

y15

9

RS1 := RS2 – RS3

RS3

y32

RS2

y30

RS2-RS3

y41

RS1:=Z2

y10

10

RS1 := L2(RA)

RA

y16

L2(RA)

y35

RS1:=Z1

y11

11

RS1 := RS1 – RA

RA

y17

RS1

y27

RS1-RA

y41

RS1:=Z2

y10

12

RS1 := R1(RS1)

RS1

y25

R1(RS1)

y37

RS1:=Z1

y11

13

RS1 := RS1 – RB

RB

y20

RS1

y27

RS1-RB

y41

RS1:=Z2

y10

14

RS3 := RB – RA

RA

y17

RB

y21

RB-RA

y41

RS3:=Z2

y14

15

RS3 := R1(RB)

RB

y19

R1(RB)

y37

RS3:=Z1

y15

16

RS2 := RA – RS3

RS3

y32

RA

y18

RA-RS3

y41

RS2:=Z2

y12

17

RS2 := RA + RB

RS3 := L1(RC)

RA

y17

RB

y21

RC

y22

L1(RC)

y34

RA+RB

y40

RS2:=Z2

RS3:=Z1

y12 y15

18

RS2 := RS2 – RS3

RS3

y32

RS2

y30

RS2-RS3

y41

RS2:=Z2

y12

19

RS2 := RS2 – RC

RC

y23

RS2

y30

RS2-RC

y41

RS2:=Z2

y12

20

RS3 := L1(RB)

RB

y19

L1(RB)

y34

RS3:=Z1

y15

21

RS3 := RA – RS3

RS3

y32

RA

y18

RA-RS3

y41

RS3:=Z2

y14

22

RS2 := L3(RS3)

RS3

y31

L3(RS3)

y36

RS2:=Z1

y13

23

RS2 := RS2 – RS3

RS3

y32

RS2

y30

RS2-RS3

y41

RS2:=Z2

y12

24

RS2 := R3(RS2)

RS2

y28

R3(RS2)

y39

RS2:=Z1

y13

25

RS3 := RC + RB

RB

y20

RC

y24

RB+RC

y40

RS3:=Z2

y14

26

RS3 := L1(RS3)

RS3

y31

L1(RS3)

y34

RS3:=Z1

y15

27

RS3 := RS3 + RC

RS3

y32

RC

y24

RS3+RC

y40

RS3:=Z2

y14

28

RC := L2(RB)

RS3 := RA – RB

RB

y20

RA

y18

RB

y19

L2(RB)

y35

RA-RB

y41

RC:=Z1

RS3:=Z2

y9 y14

29

RS3 := RS3 – RC

RC

y23

RS3

y33

RS3-RC

y41

RS3:=Z2

y14

30

RS3 := RC – RA

RA

y17

RC

y24

RC-RA

y41

RS3:=Z2

y14

31

RS3 := R2(RS3)

RS3

y31

R2(RS3)

y38

RS3:=Z1

y15

32

RS1 := L1(RS1)

RS1

y25

L1(RS1)

y34

RS1:=Z1

y11

33

RS1 := RS2 + RS1

RS1

y26

RS2

y30

RS1+RS2

y40

RS1:=Z2

y10

34

RS1 := RS2 – RS1

RS1

y26

RS2

y30

RS2-RS1

y41

RS1:=Z2

y10

35

RS1 := L2(RS3)

RS3

y31

L2(RS3)

y35

RS1:=Z1

y11

36

RS1 := RS2 + RS1

RS1

y26

RS2

y30

RS1+RS2

y40

RS1:=Z2

y10


Рис. 1.7 – Структурна граф-схема операційного автомата


2. СИНТЕЗ КЕРУЮЧИХ АВТОМАТІВ З ЖОРСТКОЮ ЛОГІКОЮ

На практиці використовуються дві моделі МПА - автомат Милі й автомат Мура, розходження між якими полягає у функції виходу. В автоматі Милі вихідний сигнал залежить від поточного стану і вхідного сигналу, а в автоматі Мура‑  тільки від стану. Незалежно від типу МПА для їхнього синтезу використовується однакова методика, що включає наступні етапи:

1. Оцінка станів автомата на ГСА.

2. Побудова таблиці переходів.

3. Кодування станів УА.

4. Побудова прямої структурної таблиці.

5. Формування системи булевських функцій (СБФ) для вихідних сигналів і функцій збудження елементів пам'яті

6. Синтез схеми в заданому елементному базисі.

 

2.1  Методика синтезу автомата Мура

 

На першому етапі початкова і кінцева вершини відзначаються окремим станом.

Побудова таблиці переходів зводиться, до формувань по відзначеної ГСА таблиці, що містить стовпці: am - вихідний стан; as - стан переходу; X(am, as) - кон’юнкція вхідних перемінних, визначальний перехід (am, as) і відповідна функції переходу  іj, де Yі відзначений станом am, Y – стан  As, Y(am) - вихідні сигнали; h=1, H - номер переходу.

При кодуванні станів необхідно прагнути до такого кодування, що зменшує кількість функцій збудження, що приймають одиничне значення, і, отже, складність схеми УА.

Для цих цілей рекомендується використовувати алгоритми кодування.

Структурна схема автомата Мура (див. рис. 2.1):

1.  Пам'ять – зберігає код стану (Q);

2. Дешифратор (ДС) – виконує перетворення коду в унітарний код, вказує на поточний стан.

На базі вектора станів А схема вихідних сигналів (СФВС) формує вихідні сигнали керуючого автомата y.

Автомат Мура має свою відмінність - вихідний сигнал y залежить не від вхідного Х, а від стану.

Автомат Мура, як і кожний інший автомат складається з двох частин: комбінаційна схема та пам'ять (тригер).

Для синтезу автомата Мура потрібно позначити кожну операторну вершину через a[i], починаючи з “початок” -  і закінчуючи “кінець” - , так як це зроблено на рисунку 2.2.

Записуємо до таблиці 2.2 отримані результати: поточний стан (мітка вершини та номер її значення в двійковій системі вираховування), наступний стан (мітка вершини та номер її значення в двійковій системі вираховування), вхідний сигнал Х, вихідний сигнал Y та функції збудження пам'яті у заданому тригері (згідно варіанта - у тригері RS).


Рис. 2.2 – Граф-схема автомата Мура


Табл. 2.1  – Структура переходів для автомата Мура

п/п

Поточний

стан

Наступний

стан

Вхідний сигнал

Х

Вихідний сигнал

y

S входи тригерів R входи тригерів

Am

код

As

код
1

a0

000000

a1

000001 1 -

S6

2

a1

000001

a2

000010 1

у1 у2 y4 y7

S5

R6

3

a2

000010

a3

000011 1

y3 у8

S6

4

a3

000011

a4

a7

a10

000100

000111

001010

X3

nX3 X4

nX3 nX4

у14 у17 у21 y40

S4

S4

S3

R5 R6

R6

5

a4

000100

a5

000101 1

y12 у18 у20 y41

S6

6

a5

000101

a6

000110 1

y11 y28 y36

S5

R6

7

a6

000110

a14

001110 1

y10 y27 y29 y41

S3

8

a7

000111

a8

001000 1

y13 y16 y35

S3

R4 R5 R6

9

a8

001000

a9

001001 1

y15 y19 y34

S6

10

a9

001001

a14

001110 1

y10 y30 y32 y41

S4 S5

R6

11

a10

001010

a11

001011 1

y11 y16 y35

S6

12

a11

001011

a12

001100 1

y10 y17 y27 y41

S4

R5 R6

13

a12

001100

a13

001101 1

y11 y25 y37

S6

14

a13

001101

a14

001110 1

y10 y20 y27 y41

S5

R6

15

a14

001110

a15

a17

a20

001111

010001

010100

X3

nX3 X4

nX3 nX4

y14 y17 y21 y41

S6

S2 S6

S2

R3 R4 R5

R3 R5

16

a15

001111

a16

010000 1

y15 y19 y37

S2

R3 R4 R5 R6

17

a16

010000

a25

011001 1

y12 y18 y32 y41

S3 S6

18

a17

010001

a18

010010 1

y12 y15 y17

y21 y22 y34 y40

S5

R6

19

a18

010010

a19

010011 1

y12 y30 y32 y41

S6

20

a19

010011

a25

011001 1

y12 y23 y30 y41

S3

R5

21

a20

010100

a21

010101 1

y15 y19 y34

S6

22

a21

010101

a22

010110 1

y14 y18 y32 y41

S5

R6

23

a22

010110

a23

010111 1

y13 y31 y36

S6

24

a23

010111

a24

011000 1

y12 y30 y32 y41

S3

R4 R5 R6

25

a24

011000

a25

011001 1

y13 y28 y39

S6

26

a25

011001

a26

a28

a30

011010

011100

011110

X3

nX3 X4

nX3 nX4

y14 y20 y24 y40

S5

S4

S4 S5

R6

R6

R6

27

a26

011010

a27

011011 1

y15 y31 y34

S6

28

a27

011011

a32

a34

a35

100000

100010

100011

X2

nX2 X1

nX2 nX1

y14 y24 y32 y40

S1

S1

S1

R2 R3 R5 R6

R2 R3 R6

R2 R3

29

a28

011100

a29

011101 1

y9 y14 y18

y19 y20 y35 y41

S6

30

a29

011101

a32

a34

a35

100000

100010

100011

X2

nX2 X1

nX2 nX1

y14 y23 y33 y41

S1

S1 S5

S1 S5

R2 R3 R4 R6

R2 R3 R4 R6

R2 R3 R4

31

a30

011110

a31

011111 1

y14 y17 y24 y41

S6

32

a31

011111

a32

a34

a35

X2

nX2 X1

nX2 nX1

y15 y31 y38

S1

S1

S1

R2 R3 R4 R5 R6

R2 R3 R4 R6

R2 R3 R4

33

a32

100000

a33

100001 1

y11 y25 y34

S6

34

a33

100001

a0

000000 1

y10 y26 y30 y40

R1 R6

35

a34

100010

a0

000000 1

y10 y26 y30 y41

R1 R5

36

a35

100011

a36

100100 1

y11 y31 y35

S4

R5 R6

37

a36

100100

a0

000000 1

y10 y26 y30 y40

R1 R4

2.2 Формування схеми автомата Мура

 

2.2.1 Функції збудження пам'яті та їх синтез у заданий базис:

2.2.2 Синтез дешифратора та його синтез у заданий базис:

Синтез дешифратора для автомата Мура розробляється так само, як і синтез для автомата Мілі(див. далі).

 

2.2.3 Рівняння вихідних сигналів та їх синтез у заданий базис:

    

    

        

 

    


2.3   Методика синтезу автомата Мілі

Структурна схема автомата Мілі (зображена на рис. 2.3) включає ті ж етапи, що і синтез КА Мура. Відрізняється від схеми автомата Мура тим, що вихідні сигнали Y залежать від вхідних Х.

Порядок синтезу автомата Мілі:

1. Позначаємо вхід початкових та кінцевих станів;

2. Позначаємо вихід операторних вершин у паралельних гілках одним станом (див. рис. 2.4). Кожна операторна вершина відзначається окремим станом. Таблиця переходів автомата має наступні стовпці: am, as - вихідний стан і стан переходу.

Х (am,as) - кон’юнкція вхідних перемінних, визначальний перехід (am, as),

Yh - вихідний сигнал на переході (am, as).

Для синтезу логічної схеми в заданому базисі необхідно перетворити СБФ  за правилами Де-Моргана з урахуванням обмежень елементного базису - числа входів і навантажувальної здатності.


Рис. 2.5 – Граф-схема автомата Мілі


Табл. 2.2  – Структура переходів для автомата Мілі

п/п

Поточний

стан

Наступний

стан

Вхідний сигнал

Х

Вихідний сигнал

y

S входи тригерів R входи тригерів

Am

код

As

код
1

a0

00000

a1

00001 1

у1 у2 y4 y7

S5

2

a1

00001

a2

00010 1

y3 у8

S4

R5

3

a2

00010

a3

00011 1

у14 у17 у21 y40

S5

4

a3

00011

a4

a6

a8

00100

00110

01000

X3

nX3 X4

nX3 nX4

y12 у18 у20 y41

y13 y16 y35

y11 y16 y35

S3

S3

S2

R4 R5

R5

R4 R5

5

a4

00100

a5

00101 1

y11 y28 y36

S5

6

a5

00101

a11

01011 1

y10 y27 y29 y41

S2 S4

R3

7

a6

00110

a7

00111 1

y15 y19 y34

S5

8

a7

00111

a11

01011 1

y10 y30 y32 y41

S2

R3

9

a8

01000

a9

01001 1

y10 y17 y27 y41

S5

10

a9

01001

a10

01010 1

y11 y25 y37

S4

R5

11

a10

01010

a11

01011 1

y10 y20 y27 y41

S5

12

a11

01011

a12

01100 1

y14 y17 y21 y41

S3

R4 R5

13

a12

01100

a13

a14

a16

01101

01110

10000

X3

nX3 X4

nX3 nX4

y15 y19 y37

y12 y15 y17

y21 y22 y34 y40

y15 y19 y34

S5

S4

S1

R2 R3

14

a13

01101

a20

10100 1

y12 y18 y32 y41

S1

R2 R5

15

a14

01110

a15

01111 1

y12 y30 y32 y41

S5

16

a15

01111

a20

10100 1

y12 y23 y30 y41

S1

R2 R4 R5

17

a16

10000

a17

10001 1

y14 y18 y32 y41

S5

18

a17

10001

a18

10010 1

y13 y31 y36

S4

R5

19

a18

10010

a19

10011 1

y12 y30 y32 y41

S5

20

a19

10011

a20

10100 1

y13 y28 y39

S3

R4 R5

21

a20

10100

a21

10101 1

y14 y20 y24 y40

S5

22

a21

10101

a22

a23

a24

10110

10111

11000

X3

nX3 X4

nX3 nX4

y15 y31 y34

y9 y14 y18

y19 y20 y35 y41

y14 y17 y24 y41

S4

S4

S2

R5

R3 R5

23

a22

10110

a25

11001 1

y14 y24 y32 y40

S2 S5

R3 R4

24

a23

10111

a25

11001 1

y14 y23 y33 y41

S2

R3 R4

25

a24

11000

a25

11001 1

y15 y31 y38

S5

26

a25

11001

a26

a0

a27

11010

00000

11011

X2

nX2 X1

nX2 nX1

y11 y25 y34

y10 y26 y30 y41

y11 y31 y35

S4

S4

R5

R1 R2 R5

27

a26

11010

a0

00000 1

y10 y26 y30 y40

R1 R2 R4

28

a27

11011

a0

00000 1

y10 y26 y30 y40

R1 R2 R4 R5

2.4 Формування схеми автомата Мілі

 

2.4.1 Функції збудження пам'яті та їх синтез у заданий базис:

2.4.2 Синтез дешифратора та його синтез у заданий базис.

Методика синтезу дешифратора до автомата Мілі:

-   таблиця істинності (Карта Карно);

-   Карта Карно для одержання мінімізованої функції збудження;

-   запис формул функцій збудження;

-   побудова схеми.

Оскільки на кожнім наборі вхідних перемінних активний тільки один біт, то Карту Карно можна зобразити одну загальну для усіх вихідних сигналів. При цьому в осередках Карти Карно записуються не одиниці, а імена відповідних функцій.

Табл. 2.3  – Карта Карно до дешифратора автомата Мілі

000         001         011         010         110         111         101         100

00

01

11

10

а0

а1

а3

а2

а6

а7

а5

а4

а8

а9

а11

а10

а14

а15

а13

а12

а24

а25

а27

а26

* * * *

а16

а17

а19

а18

а22

а23

а21

а20

...

...

...

Електрична схема дешифратора зображена на рисунку 2.6.


Рис. 2.6 – Дешифратор. Функціональна схема.

2.4.3 Рівняння вихідних сигналів та їх синтез у заданий базис:

                                         

      


3. Синтез автоматів з програмованою логікою

 

3.1 Синтез автомата з примусовою адресацією команд

ПЗУ – зберігаємий набір команд, кожна з котрих несе інформацію про набір вихідного сигналу, про поточний такт та адресу мікрокоманд, котрі повинні бути виконані у наступному такті.


Рис. 3.1 - Формат МК


Рис. 3.2 - Структурна схема АПЛ з примусовою адресацією мікрокоманд

Аналіз рисунка 3.2:

-   СФВС - дозволяє декодувати інформацію, що утримується в полі Y.

-   САХ - являє собою мультиплексор на інформаційні входи якого подаються вхідні сигнали, а на адресні, код з поля Nх при цьому на А0 завжди подається сигнал "0", у такий спосіб формується сигнал Z, що забезпечує передачу на адресний вхід пам'яті А або А0, або А1.

Для того щоб сформувати вміст ROM по граф-схемі мікрокоманд необхідно:

-   відзначити номера мікрокоманд;

-   закодувати вихідні сигнали і сформувати мікрокоманди по заданому форматі;

-   сформувати таблицю вмісту ROM.


Рис. 3.3 – Граф-схема автомата з примусовою адресацією команд

Для скорочення довжини слова ROM будемо використовувати принцип максимального кодування вихідних сигналів.


Табл. 3.1 – Максимальне кодування вихідних сигналів

№ п/п Макрокоманда Мікрооперації Код
1

Y0

- 000000
2

Y1

y1 y2 y4 y7

000001
3

Y2

y3 y8

000010
4

Y3

y14 y17 y21 y40

000011
5

Y4

y11 y16 y35

000100
6

Y5

y10 y17 y27 y41

000101
7

Y6

y11 y25 y37

000110
8

Y7

y10 y20 y27 y41

000111
9

Y8

y13 y16 y35

001000
10

Y9

y15 y19 y34

001001
11

Y10

y10 y30 y32 y41

001010
12

Y11

y12 y18 y20 y41

001011
13

Y12

y11 y28 y36

001100
14

Y13

y10 y27 y29 y41

001101
15

Y14

y14 y17 y21 y41

001110
16

Y15

y15 y19 y34

001111
17

Y16

y14 y18 y32 y41

010000
18

Y17

y13 y31 y36

010001
19

Y18

y12 y30 y32 y41

010010
20

Y19

y13 y28 y39

010011
21

Y20

y12 y15 y17 y21 y22 y34 y40

010100
22

Y21

y12 y30 y32 y41

010101
23

Y22

y12 y23 y30 y41

010110
24

Y23

y15 y19 y37

010111
25

Y24

y12 y18 y32 y41

011000
26

Y25

y14 y20 y24 y40

011001
27

Y26

y14 y17 y24 y41

011010
28

Y27

y15 y31 y38

011011
29

Y28

y9 y14 y18 y19 y20 y35 y41

011100
30

Y29

y14 y23 y33 y41

011101
31

Y30

y15 y31 y34

011110
32

Y31

y14 y24 y32 y40

011111
33

Y32

y11 y31 y35

100000
34

Y33

y10 y26 y30 y40 y0

100001
35

Y34

y10 y26 y30 y41 y0

100010
36

Y35

y11 y25 y34

100011

Табл. 3.2  – Структура переходів для автомата з примусовою адресацією команд

Адреса

а1а2а3а4а5а6

Y

0..5

X

6..8

FA0

9..14

FA1

15..20

Перехід
000000 000001 000 000001 *

b0 → b1

000001 000010 000 000010 *

b1 → b2

000010 000011 011 000011 001011

b2

000011 000000 100 000100 001000

b3

000100 000100 000 000101 *

b4 → b5

000101 000101 000 000110 *

b5 → b6

000110 000110 000 000111 *

b6 → b7

000111 000111 000 001110 *

b7 → b14

001000 001000 000 001001 *

b8 → b9

001001 001001 000 001010 *

b9 → b10

001010 001010 000 001110 *

b10 → b14

001011 001011 000 001100 *

b11 → b12

001100 001100 000 001101 *

b12 → b13

001101 001101 000 001110 *

b13 → b14

001110 001110 011 001111 011000

b14

001111 000000 100 010000 010101

b15

010000 001111 000 010001 *

b16 → b17

010001 010000 000 010010 *

b17 → b18

010010 010001 000 010011 *

b18 → b19

010011 010010 000 010100 *

b19 → b20

010100 010011 000 011010 *

b20 → b26

010101 010100 000 010110 *

b21 → b22

010110 010101 000 010111 *

b22 → b23

010111 010110 000 011010 *

b23 → b26

011000 010111 000 011001 *

b24 → b25

011001 011000 000 011010 *

b25 → b26

011010 011001 011 011011 100000

b26

011011 000000 100 011100 011110

b27

011100 011010 000 011101 *

b28 → b29

011101 011011 010 100010 100110

b29

011110 011100 000 011111 *

b30 → b31

011111 011101 010 100010 100110

b31

100000 011110 000 100001 *

b32 → b33

100001 011111 010 100010 100110

b33

100010 000000 001 100011 100101

b34

100011 100000 000 100100 *

b35 → b36

100100 100001 000 000000 *

b36 → кінець

100101 100010 000 000000 *

b37 → кінець

100110 100011 000 100111 *

b38 → b39

100111 100001 000 000000 *

b39 → кінець


Табл. 3.3 – Таблиця кодів станів автомата з примусовою адресацією команд    

№ п/п Стан Код
1

b0

000000
2

b1

000001
3

b2

000010
4

b3

000011
5

b4

000100
6

b5

000101
7

b6

000110
8

b7

000111
9

b8

001000
10

b9

001001
11

b10

001010
12

b11

001011
13

b12

001100
14

b13

001101
15

b14

001110
16

b15

001111
17

b16

010000
18

b17

010001
19

b18

010010
20

b19

010011
21

b20

010100
22

b21

010101
23

b22

010110
24

b23

010111
25

b24

011000
26

b25

011001
27

b26

011010
28

b27

011011
29

b28

011100
30

b29

011101
31

b30

011110
32

b31

011111
33

b32

100000
34

b33

100001
35

b34

100010
36

b35

100011
37

b36

100100
38

b37

100101
39

b38

100110
40

b39

100111

 

Табл. 3.4 – Таблиця вхідних сигналів автомата з примусовою адресацією команд

№ п/п Вхідний стан Код
1

Х0

000
2

Х1

001
3

Х2

010
4

Х3

011
5

X4

100

Рівняння вихідних сигналів та їх
 синтез у заданий базис:



3.2  Синтез автомата з природною адресацією команд

У реальних мікропрограмах часто зустрічаються ситуації, коли маються досить довгі сплетіння операторних вершин. У цьому випадку можлива організація схеми, коли безумовний перехід не задається, а виконується нарощуванням адреси мікрокоманди. Таким чином вдається зменшити довжину мікрокоманди за рахунок формування вихідних сигналів і аналізу вхідних сигналів у різні моменти часу. Для цього в автоматах із природною адресацією використовується два формати мікрокоманд:



-   операторна 


-   умовна  

                      А

ROM

D

 
                   

С

 



РГМК

 

СТ

 
            

Х

 

                                              

+1

 

                                             

                                                            

Рис. 3.4 – Структурна схема автомата з природною адресацією

Аналіз схеми:

У регістрі мікрокоманд зберігатися поточне МК, якщо це операторна МК, то працює схема формування вихідних сигналів і в операційний автомат попадає y.

При цьому схема аналізу Х формує Z, що змушує адресу, що зберігається в лічильнику збільшитися на одиницю.

Якщо в регістрі МК умовна МК, то вихідний сигнал не формується, а схема аналізу Х формує Z, у залежності від значення Z:

якщо Z=1, то до значення лічильника команд додається 1,

якщо Z=0, то в лічильник попадає адреса мікрокоманди з поля b.

Порядок формування змісту ROM такий же як в автоматі з примусовою адресацією мікрокоманд.

Рис. 3.5 – Граф-схема автомата з природною адресацією команд


Табл. 3.5  – Структура переходів для автомата з природною адресацією команд

№ п/п

Адреса b

b1  b2  b3  b4  b5  b6

0 1     .  .  .     6 Перехід
1 1 ... 3 4 . . . 9
1 000000 0 000001

b0 → b1

2 000001 0 000010

b1 → b2

3 000010 0 000011

b2 → b3

4 000011 1 011 010010

b2

5 000100 0 001011

b4 → b5

6 000101 0 001100

b5 → b6

7 000110 0 001101

b6 → b7

8 000111 0 001110

b7 → b14

9 001000 1 011 011100

b8

10 001001 0 010111

b9 → b10

11 001010 0 011000

b10 → b11

12 001011 0 011001

b11 → b12

13 001100 1 011 100111

b12

14 001101 0 011110

b13 → b14

15 001110 0 011111

b14 → b15

16 001111 1 010 101110

b15

17 010000 0 100011

b16 → b17

18 010001 0 100001

b17 → кінець

19 010010 1 100 010111

b18

20 010011 0 001000

b19 → b20

21 010100 0 001001

b20 → b21

22 010101 0 001010

b21 → b22

23 010110 1 000 000111

b22 → БП b7

24 010111 0 000100

b23 → b24

25 011000 0 000101

b24 → b25

26 011001 0 000110

b25 → b26

27 011010 0 000111

b26 → b27

28 011011 1 000 000111

b27 → БП b7

29 011100 1 100 100001

b28

30 011101 0 010100

b29 → b30

31 011110 0 010101

b30 → b31

32 011111 0 010110

b31 → b32

33 100000 1 000 001011

b32 → БП b11

34 100001 0 001111

b33 → b34

35 100010 0 010000

b34 → b35

36 100011 0 010001

b35 → b36

37 100100 0 010010

b36 → b37

38 100101 0 010011

b37 → b38

39 100110 1 000 001011

b38 → БП b11

40 100111 1 100 101011

b39

41 101000 0 011100

b40 → b41

42 101001 0 011101

b41 → b42

43 101010 1 000 001111

b42 → БП b15

44 101011 0 011010

b43 → b44

45 101100 0 011011

b44 → b45

46 101101 1 000 001111

b45 → БП b15

47 101110 1 001 110000

b46

48 101111 0 100010

b47 → кінець

49 110000 0 100000

b48 → b49

50 100001 0 100001

b49 → кінець

Табл. 3.6 – Таблиця кодів станів автомата з природною адресацією команд

№ п/п Стан Код
1

b0

000000
2

b1

000001
3

b2

000010
4

b3

000011
5

b4

000100
6

b5

000101
7

b6

000110
8

b7

000111
9

b8

001000
10

b9

001001
11

b10

001010
12

b11

001011
13

b12

001100
14

b13

001101
15

b14

001110
16

b15

001111
17

b16

010000
18

b17

010001
19

b18

010010
20

b19

010011
21

b20

010100
22

b21

010101
23

b22

010110
24

b23

010111
25

b24

011000
26

b25

011001
27

b26

011010
28

b27

011011
29

b28

011100
30

b29

011101
31

b30

011110
32

b31

011111
33

b32

100000
34

b33

100001
35

b34

100010
36

b35

100011
37

b36

100100
38

b37

100101
39

b38

100110
40

b39

100111
41

b40

101000
42

b41

101001
43

b42

101010
44

b43

101011
45

b44

101100
46

b45

101101
47

b46

101110
48

b47

101111
49

b48

110000
50

b49

110001

Табл. 3.7 – Таблиця вхідних сигналів автомата з природною адресацією команд

№ п/п Вхідний стан Код
1

Х0

000
2

Х1

001
3

Х2

010
4

Х3

011
5

X4

100

 

Рівняння вихідних сигналів та їх синтез у заданий базис:



Синтез мультиплексора

Табл. 3.8  – Карта Карно до мультиплексора

00 01 11 10

0

1

x0

x1

x3

x2

x4

* * *


4. ПОРІВНЯЛЬНА ХАРАКТЕРИСТИКА АВТОМАТІВ

 

4.1 Порівняльна характеристика автоматів з жорсткою логікою

Розрахуємо усі дані по формулам:

N - кількість великих елементів.

Nвх – кількість входів на великі елементи.

n – кількість малих елементів.

nвх - кількість входів на малі елементи.

Nтр – кількість тригерів у схемі

 

 

 

Табл. 4.1  – Таблиця обліку апаратурних витрат автоматів з жорсткою логікою

R схеми Тригер DC
Мура
Мілі

З таблиці 4.1 видно, що R схеми у Мура менше, але входів на DC більше.

Тригерів однакова кількість.


4.2 Порівняльна характеристика автоматів з програмованою логікою

 

                        

Табл.4.2 Таблиця обліку апаратурних витрат автоматів з програмованою логікою

ПЗУ Регістр лічильник Комбінаційна частина DC
Примусова
Природна

 

У автомата з природною адресацією МК більш мінімальні апаратні витрати (корпусів), ніж у автомата з примусовою адресацією.

Тригерів однакова кількість. Кількість входів на DC однакова.

Комбінаційна частина у АПЛ з природною адресацією більша,
ніж у примусової.


ВИСНОВОК

операційний керуючий автомат програмований логіка

Виконано курсовий проект з дисципліни „Прикладна теорія цифрових автоматів” на тему „Синтез керуючих автоматів”.

Були синтезовані основні типи автоматів з жорсткою та програмованою логікою. Хоча всі приведені автомати справилися з поставленою задачею і в достатній мірі реалізували схему керуючого автомата, але є деякі позитивні і негативні особливості синтезу кожного з автоматів. Наприклад, автомати з жорсткою логікою мають досить велику комбінаційну частину, але вони не потребують елементів ROM, це робить ці автомати дуже оптимальними за ціною затрат.

Автомати з програмованою логікою виявились досить складними в розрахунках  і реалізації, але це повністю компенсувалось універсальністю та гнучкістю програмування, чого не можна було досягнути на автоматах з жорсткою логікою.