Реферат: Функціональний генератор інфранизької частоти на базі мікропроцесорної системи

Рис. 2. Структурна схема МК.

В даній роботі, ми використовуватимо внутрішній ПЗП МК, РЗП та ОЗП.

3.4. Підключення ЦАП

Для реалізації портів вводу-виводу будемо застосовувати вбудовані порти МК. Для підєднання ЦАП використовується порт P2, до якого безпосредньо підєднано ІМС ЦАП.

3.5. Підключення іникаторів

Для реалізації індикації застосуємо ІМС АЛС324Б, які являють собою семисегментний індикатор.

Таким чином для індикації нам необхідно використати вихідний восьмирозрядний порт. Для цієї мети використаємо порт Р1. Для керування індикацією використаємо порт Р0.

3.6. Розрахунок вихідного підсилювача

Амплітуда вихідної напруги складає 14В. На виході ЦАП при вхідному коді 255 та опорній напрузі 14В буде напруга 14В. Тому вихідне підсилення не потрібне.

3.7. Остаточна електрична принципова схема

При складанні електричної принципової схеми враховуючи усі схемні рішення вибрані у попередніх пунктах одержуємо схему зображену у додатку 2.

4. Розробка програмної частини

Програмна частина складається з головної програми ініціалізації та підпрограми обробки переривання від таймера-лічильника Т0.

4.1. Головна програма ініціалізації

В цій частині в РЗП заносяться початкові значення, задається режим роботи таймера-лічильника та заносяться початкові значення періоду переривань, а також задається дозвіл на переривання тільки від таймера.

4.2. Підпрограма обробки переривання

При переповненні таймера виникає переривання, яке викликає п.п. обробки переривання. В цій п.п. в ЦАП заноситься черговий відлік сигналу, переключається індикаторний пристрій та опитується стан клавіатури.

При реалізації підпрограми обробки нажаття першої клавіші застосовано алгоритм показаний на рис.3, для другої - рис.4.

Рис.3. Підпрограма обробки нажаття другої клавіші

Рис.4. Підпрограма обробки нажаття першої клавіші

4.4. Програма на мові асемблера

Згідно вище приведеного опису написано програму на мові асемблера для мікроконтролера Intel 8051. Лістинг програми приведений у додатку 3.

Після написання програми визначаємо, що в найгіршому випадку час виконання п.п. обробки переривання від таймера не перевищує 100 машинних циклів, тобто 100 мкс. Тому вибираємо цей час, як період дискретизації сигналу.

Враховуючи, що таймер в МК Intel 51 рахує машинні цикли шляхом інкрементування вираховуємо число, необхідне за забезпечення затримки в 50 мкс. Прийнятий час дискретизації займе 100 машинних циклів, тому для того, щоб за цей час відбулось переповнення необхідно в таймер занести число:

FFFF16 – 10010 = FFFF16 - 6416 ­ = FF9716

Крім того необхідно врахувати час ініціалізації таймерів при кожному перериванні (4 цикли):

FF9716 – 416 = FF9316

Результат такої дискретизації показаний на мал.1

Для часу дискретизації 2Т та 4Т це значення буде відповідно рівне:

FFFF16 – 20010 – 416 = FFFF16 – С816 ­ - 416 = FF3316

FFFF16 – 40010 - 416 = FFFF16 - 19016 ­ – 416 = FE6B16

Призначення використаних регістрів:

R1

Лічильник переривань для динамічної індикації

R2

К-во Просмотров: 297
Бесплатно скачать Реферат: Функціональний генератор інфранизької частоти на базі мікропроцесорної системи