Розробка схеми електричної принципової годинника-будильника-термометра з ІЧ ПК

МІНІСТЕРСТВО ОСВІТИ І НАУКИ УКРАЇНИ

РОМЕНСЬКИЙ КОЛЕДЖ

ДЕРЖАВНОГО ВИЩОГО НАВЧАЛЬНОГО ЗАКЛАДУ

«КИЇВСЬКИЙ НАЦІОНАЛЬНИЙ ЕКОНОМІЧНИЙ УНІВЕРСИТЕТ ІМЕНІ ВАДИМА ГЕТЬМАНА»

Спеціальність: 5.091504

«Обслуговування комп’ютерних та інтелектуальних систем та мереж»

Курсовий проект з предмету:

Мікропроцесорні системи

Тема: «Розробити схему електричну принципову годинника-будильника-термометра з ІЧ ПК»

РК КНЕУ. КП. 5.091504.

Виконав: студент гр. К 3-2

Катрич С. В.

Перевірив викладач

Шокота Т.А.

2007

Зміст

Вступ

1 Загальний розділ

1.1 Призначення проектуємого пристрою

1.2 Технічні характеристики

1.3 Розробка і обґрунтування схеми електричної структурної

2 Спеціальний розділ

2.1 Вибір і обґрунтування елементної бази

2.2 Принцип роботи окремих ВІС з використанням часових діаграм та алгоритмів роботи

2.3 Принцип роботи пристрою згідно схеми електричної принципової

3 Експлуатаційний розділ

3.1 Ініціалізація програмуємих ВІС

3.2 Тест перевірки окремих вузлів або пристроїв

3.3 Розрахунок надійності пристрою

4 Анотація

5 Література

Вступ

За сучасного розвитку науки і техніки, та постійного удосконалення електричних пристроїв ми все частіше і частіше стикаємося зі словами мікропроцесор та мікроконтролер. Ці пристрої дозволяють реалізувати досить складні закони керування електронними пристроями. Безперечною перевагою мікропроцесорних систем керування є їх гнучкість, оскільки систему, розроблену для виконання одного завдання, легко пристосувати для вирішення інших завдань шляхом зміни програмного забезпечення.

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

Мікропроцесор (МП) - програмно-управляючий пристрій, призначений для обробки цифрової інформації і керування процесом цієї обробки, виконано у виді однієї (або декількох) інтегральної схеми з високим ступенем інтеграції електронних елементів.

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

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

Надзвичайно важливим кроком у розвитку електроніки вцілому було створення мікроконтролерів (МК) - керуючих пристроїв, виконаних на одному чи декількох кристалах.

Мікроконтролери виконують функції логічного аналізу і керування (що дозволяє за рахунок виключення арифметичних операцій зменшити їхню апаратурну складність чи розвити функції логічного керування).

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

Загальний архітектурний тип мікросистеми містить такі компоненти:

    центральний процесор (ЦП);

    схеми синхронізації;

    пам’ять;

    підсистема введення-виведення;

    логіка управління шиною;

    системна шина.

В мікросистемі роль центрального процесора виконує МП. Він дешифрує команди і управляє всіма подіями в системі, а також виконує всі арифметичні і логічні операції.

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

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

Підсистема введення-виведення складається з різних пристроїв, призначених для взаємодії з зовнішнім середовищем та збереження великих об’ємів інформації.

Системну шину утворює сукупність провідників по яких передаються дані від ЦП до пам’яті та пристроїв введення-виведення. Звичайно провідники шини об’єднуються в три групи:

    лінії даних (для передачі інформації);

    лінії адреси (вказують звідки або куди передається інформація);

    лінії управління, (регулюють дії на шині).

Інтерфейс пам’яті утворює схеми для дешифрування адреси цільової комірки і буферизувати даних на шину (з шини), а також схеми виконання операцій зчитування і запису.

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

1 Загальний розділ

1.1 Призначення проектуємого пристрою

Визначення та поняття термінів, які використовуються у курсовому проекті:

АЛП – арифметико-логічний пристрій

ЕОМ – електронно-обчислювальна машина

МП – мікропроцесор

МПК – мікропроцесорний комплект

ВІС – великі інтегральні схеми

ЦП – центральний процесор

МК – мікроконтролер

ОМК – однокристальний мікроконтролер

МПС – мікропроцесорна система

ОЗП – оперативно-запам’ятовучий пристрій

ДК – дистанційне керування

Місце та основні функції пристрою в архітектурі МПС.

Однокристальним мікроконтролером (ОМК) називають пристрій, виконаний конструктивно в одному корпусі ВІС, і містить усі компоненти МПС: процесор, пам'ять даних, пам'ять програм, програмовні інтерфейси.

Для однокристальних мікроконтролерів характерні:

    система команд, орієнтована на виконання завдань керування і регулювання;

    алгоритми, що реалізуються на ОМК, мають багато розгалужень залежно від зовнішніх сигналів;

    дані, якими оперують ОМК, не повинні мати велику розрядність;

    схемна реалізація систем керування на базі ОМК нескладна і має невисоку вартість;

    універсальність і можливість розширення функцій керування значно нижчі, ніж у системах із однокристальними МП.

Однокристальні мікроконтролери - зручний інструмент для створення сучасних вбудованих пристроїв керування різноманітним обладнанням, автомобільною електронікою, побутовою технікою, мобільними телефонами та ін.

В даній роботі описується МК приладу, що призначений для індикації поточного часу, подачі звукового сигналу у визначений час та індикації температури в двох точках (в приміщенні та на подвір’ї) на проміжку -55…+99 ºС з точністю ±1 ºС. Час та температура виводяться почергово. Встановлення значення часу, спрацювання будильника, спалахування та вимикання індикатора здійснюється з ІЧ пульта дистанційного керування (ДК). Будильник подає звуковий сигнал з паузою 10 с, спочатку два коротких (приблизно по 0,1 с) одиночних, потім стільки ж здвоєних (з паузою 0,1 с), а після них – два зтроєних (з такою ж паузою). На протязі хвилини зтроєні сигнали подаються кожну секунду до тих пір, поки будильник не буде відключений. Існує функція Snooze (повторення сигнала через певний час), що дозволяє ще трохи поспати після першого сигналу. Якщо індикатор погашено, в момент спрацювання будильника він вмикається і до відключення чи переходу в режим Snooze показує поточний час. Передбачено короткий звуковий сигнал при натисненні кнопок пульта, індикацію (світлодіодом) при проходженні команд з пульта, резервне живлення при зникненні напруги в мережі (в цьому випадку будильник буде подавати безперервний сигнал).

Принципова схема заснована на мікроконтролері DD2 АТ89С4051. 1.2 Технічні характеристики

При створенні схеми електричної принципової розроблюваного пристрою було використано такі елементи як мікроконтролер АТ89С4051, мікросхеми КР1171СП47, FCP8583, SAA3010, PCF8583, DS1621, MC34063.

Розрахунок надійності строю представлено в відповідному розділі курсового проекту.

Характеристики мікроконтролера АТ89С4051:

АТ89С4051 – низьковольтний швидкодіючий 8-ми розрядний мікроконтролер, що використовує енергонезалежну технологію пам’яті Atmel що характеризуються також високою щільністю, має 4 кілобайти перепрограмованої пам’яті з можливістю 1000 циклів запису/стирання, 15 портів вводу/виводу, 2 16-бітових таймери/лічильники, послідовний порт та систему переривань, п’ятивекторну дворівневу систему переривань, дуплексний послідовний порт, презиційний аналоговий компаратор. Даний мікроконтролер підтримує режим Power-down, який зберігає вміст пам’яті але зупиняє генератори до наступного перезапуску (/відновлення роботи) апаратних пристроїв, а також Idle mode – режим, під час якого він зупиняє ЦПП, і підтримує роботу пам’яті, таймерів/лічильників, послідовним портом та системою переривань, для продовження роботи пристрою.

На рисунку 1.2.1 зображено корпус мікроконтролера АТ89С4051.

Рисунок 1.2.1 – Зображення корпусу мікроконтролеру АТ89С4051

Структурна схема мікроконтролера АТ89С4051 зображена на рисунку 1.2.2.

Рисунок 1.2.2 – Структурна схема мікроконтролера АТ89С4051

На схемі зображено: регістр адрес пам’яті, пам’ять RAM, Flash-пам’ять, регістр В, Арифметико-логічний пристрій (АЛП), буфер даних, вказівник стеку, програмний регістр адрес, програмний лічильник, інкрементор, порти драйверів, аналоговий компаратор, схеми управління і синхронізації, регістр інструкцій, блок переривання, серійний порт і блоки таймеру.

1.3 Розробка і обґрунтування схеми електричної структурної

Структурна схема пристрою зображена на рисунку 1.3.

Рисунок 1.3 – Структурна схема розроблюваного пристрою

На структурній схемі пристрою (див. рисунок 1.3) зображено наступні функціональні блоки: мікроконтролер, який забезпечує керування роботою всіх пристроїв схеми; блок живлення що забезпечує безперебійне живлення всіх компонентів схеми; індикатори, які відображають час та температуру; блок датчиків який призначений для знімання показників температури та синхронізації пристрою з блоком керування до якого входить пульт ДК; блок управління часом що забезпечує організацію управління часом.

2 Спеціальний розділ

2.1 Вибір і обґрунтування елементної бази

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

Рисунок 2.1.1 – Схема електрична принципова годинника-будильника-термометра

Основою створюваного пристрою є мікроконтролер DD2 AT89C4051, який керує роботою всіх вузлів. До його складу входить енергозалежна пам’ять програм (4кб), ОЗП (128 байт), 2 таймери, система переривань та ін. (див. пункт 1.2). Для надійного запуску та захисту мікроконтролера від збоїв по напрузі використано мікросхему КР1171СП47 (DA1), яка забезпечує затримку на своєму виході низький рівень при напрузі живлення менше 4.7 В.

Табло пристрою складається з п’яти світлодіодних цифрових індикаторів типу SA08-11GWA. Індикація статична. Для зниження яскравості свічення в коло живлення індикаторів включено діоди VD5 і VD6.

Для керування вузлом індикації використано три виводи мікроконтролера: P1.2, (14); P1.3, (15); P1.4, (16).

МС 74HC595 являє собою 8-бітгний регістр з послідовним входом і паралельним виходом.

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

Для подачі звукових сигналів застосовано електромагнітний випромінювач НСМ1606Х з вбудованим генератором, що працює на частоті 2200 Гц.

Батарея GB1 служить для живлення мікросхеми годинника та звуковипромінювача при відсутності живлення в мережі.

Для прийому сигналів керування пульта ДК використано інтегральний приймач ІЧ-діапазону SFH 506-36. Ця мікросхема дуже чутлива до перешкод в колі живлення, тому до неї включено фільтр VD4C8C9.

Живиться пристрій від стабілізованого перетворювача напруги на основі мікросхеми MC 34063. Принципову схему ІЧ пульту ДК зображено на рисунку 2.1.2.

Рисунок 2.1.2 – Схема електрична принципова годинника-будильника-термометра

Пульт керування виконано на базі малогабаритного калькулятора. В якості передавача використано мікросхему SAA 3010 яка працює в системі ІЧ ДК RC5. В режимі очікування SAA 3010 спожива незначний струм що робить експлуатацію пульту дуже зручною.

В якості виносних датчиків апаратури застосовано мікросхеми DS1621

2.2 Принцип роботи окремих ВІС з використанням часових діаграм та алгоритмів роботи

Часові діаграми машинних циклів читання зовнішньої пам’яті програм показано на рисунку 2.2.1.

Рисунок 2.2.1 – діаграми машинних циклів читання зовнішньої пам’яті програм

При виконанні команди MOVX, сигнал ALE формується у другому машинному циклі лише один раз.

2.3 Принцип роботи пристрою згідно схеми електричної принципової

Схема електрична принципова зображена на рисунку 2.1.1 пункту 2.1.

Описуваний пристрій призначений для індикації поточного часу, подачі звукових сигналів в заданий час та індикації температури в двох точках в інтервалі від -55˚ до +99˚ С з точністю ˚ С. Час і температура відображаються по черзі на протязі 10, 1 та 2 секунд відповідно. Встановлення показань годинника, часу спрацювання будильника, відключення будильника, ввімкнення і вимкнення індикатора проводяться з ІЧ пульта ДК.

Будильник подає звукові сигнали з паузою 10 с: спочатку – два коротких одиночних, потім – стільки ж здвоєних, а після них – два строєних. По закінченні хвилини вбудовані сигнали подаються в кожну секунду до тих пір, доки будильник не буде вимкнено. Якщо індикатор вимкнено, в момент спрацювання будильника він вмикається і до відключення або переходу в режим Snooze показує поточний час. Передбачений короткий звуковий відклик у відповідь на натиснення кнопок пульту.

Мікроконтролер DD2 AT89C4051 керує роботою всіх вузлів. До його складу входить енергозалежна пам’ять програм, ОЗП, 2 таймери, система переривань та ін. Для надійного запуску та захисту мікроконтролера від збоїв по напрузі використано мікросхему КР1171СП47 (DA1), яка забезпечує затримку на своєму виході низький рівень при напрузі живлення менше 4.7 В.

Табло пристрою складається з п’яти світлодіодних цифрових індикаторів типу SA08-11GWA. Індикація статична. Для зниження яскравості свічення в коло живлення індикаторів включено діоди VD5 і VD6.

Для керування вузлом індикації використано три виводи мікроконтролера: P1.2, (14); P1.3, (15); P1.4, (16).

МС 74HC595 являє собою 8-бітгний регістр з послідовним входом і паралельним виходом.

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

Для подачі звукових сигналів застосовано електромагнітний випромінювач НСМ1606Х з вбудованим генератором, що працює на частоті 2200 Гц.

Батарея GB1 служить для живлення мікросхеми годинника та звуковипромінювача при відсутності живлення в мережі.

Для прийому сигналів керування пульта ДК використано інтегральний приймач ІЧ-діапазону SFH 506-36. Ця мікросхема дуже чутлива до перешкод в колі живлення, тому до неї включено фільтр VD4C8C9.

3 Експлуатаційний розділ

3.1 Ініціалізація програмуємих ВІС

Програма ініціалізації мікросхем виконує налагодження портів вводу-виводу мікросхем та встановлює параметри дільника та входів мікросхеми по яким буде виконуватися переривання. Також налагоджуються переривання по таймеру. Всі інші переривання забороняються.

Програма ініціалізації і програма тестування пристрою наведена в пункті 3.2.

3.2 Тест перевірки окремих вузлів або пристроїв

Програма за якою працює мікропроцесор мовою асемблера АТ89С4051 має наступний вигляд:

__CONFIG _CP_OFF & _WDT_OFF & _PWRTE_ON & _XT_OSC

ORG 0

Goto PROGRAM

sec equ H'11' ; секунди

sec10 equ H'12' ; Десятки секунд

min equ H'13' ; минути

min10 equ H'14' ; Десятки минут

hour equ H'15' ; години

hour10 equ H'16' ; Десятки годин

Indicator equ H'17' ; 7-сегментний код для загрузки в регістр DD2

Bit_counter equ H'18' ; лічильник бітів, загруженних в регістр DD2

FLAGS equ H'19' ; різні прапорці

FLAGS_2 equ H'1F'

Fig_pointer equ H'1B' ; показник виведеної цифри

TEMP equ H'1C' ; для тимчасового збереження вмісту порту A

Ind_start equ H'1D' ; адреса комірки, яка першою виводиться на індикатор

SB_delay equ H'1E' ; часова затримка

STATUS_copy equ H'21' ; копії вмісту регістрів

W_copy equ H'22'

FSR_copy equ H'23'

min_al_1 equ H'24' ; регістри першого будильника

min10_al_1 equ H'25'

hour_al_1 equ H'26'

hour10_al_1 equ H'27'

min_al_2 equ H'28' ; регістри другого будильника

min10_al_2 equ H'29'

hour_al_2 equ H'2A'

hour10_al_2 equ H'2B'

EEP_Ind_4 equ H'2C' ; регістри для індикації

EEP_Ind_3 equ H'2D' ; режиму роботи з EEPROM

EEP_Ind_2 equ H'2E'

EEP_Ind_1 equ H'2F'

Alarm_count equ H'30' ; лічильник будильника

SB4_count equ H'31' ; лічильник часу натискання на кнопку SB2

IntCount_H equ H'32' ; лічильник переповнення таймеру номер 1

IntCount_L equ H'33' ; лічильник переповнення таймеру номер 2

MaxInt_H equ H'34' ; верхня границя лічильника переривань

MaxInt_L equ H'35' ; визначає секундну затримку

TIME_SET equ H'36' ; коефіцієнт корекції часу

; ------------- Підпрограма яка добавляє хвилини ---------------

INC_MIN macro Reg1_min,Reg2_min

movfw Reg1_min ; якщо кількість менут = 9 то

xorlw 9 ; обнуляємо менути і прибавляємо десятки менут

BZ $+3 ; інакше прибавляємо менути та виходимо з підпрограми

incf Reg1_min, f

goto Main_loop

clrf Reg1_min

movfw Reg2_min

xorlw 5 ; якщо кількість десятків менут = 5,

BZ $+3 ; обнуляємо менути та взагалі та виходимо з підпрограми

incf Reg2_min, f ; інакше прибавляємо десятки менут

goto Main_loop

clrf Reg1_min

clrf Reg2_min

goto Main_loop

endm

; ------------- Підпрограма яка прибавляє години ---------------

INC_HOUR macro Reg1_hour,Reg2_hour

movfw Reg1_hour ; якщо кількість годин = 3, то перевіряємо чи

xorlw 3 ; число десятків годин = 2, якщо так то

btfss STATUS, Z ; обнуляємо години взагалі (перехід із 23 годин в 00)

goto $+5

movfw Reg2_hour

xorlw 2

BZ $+D'14'

movfw Reg1_hour ; якщо число годин = 10, прибавляєм

xorlw 9 ; десятки годин і скидаємо одениці

BZ $+3 ; інакше прибавляєм одениці годин та виходимо із підпрограми

incf Reg1_hour, f

goto Main_loop

clrf Reg1_hour

movfw Reg2_hour

xorlw 2

BZ $+3

incf Reg2_hour, f

goto Main_loop

clrf Reg1_hour

clrf Reg2_hour

goto Main_loop

endm

; ------------- Підпрограма зменшення хвилин ---------------

DEC_MIN macro Reg1_min,Reg2_min

local DEC_min10,Clr

movfw Reg1_min ; зменшуєм хвилини

xorlw 0

BZ DEC_min10

decf Reg1_min,f

goto Main_loop

DEC_min10 movlw 9 ; установлюєм число хвилин = 9

movwf Reg1_min ; і зменшуєм десятки хвилин

movfw Reg2_min

xorlw 0

BZ Clr

decf Reg2_min, f

goto Main_loop

movlw 5

movwf Reg2_min

goto Main_loop

endm

; ------------- Підпрограма зменшення годин ---------------

DEC_HOUR macro Reg1_hour,Reg2_hour

local Set_hour,Clr,If_hour10_1,If_hour10_2,Dec_hour10

movfw Reg1_hour ; зменшуєм години

xorlw 0

BZ Set_hour

decf Reg1_hour, f

goto Main_loop

movfw Reg2_hour ; якщо десятки годин = 0,

xorlw 0 ; установлюємо години рівні 3

btfss STATUS, Z

goto If_hour10_1

movlw 3

movwf Reg1_hour

goto Dec_hour10

If_hour10_1 movfw Reg2_hour ; якщо десятки годин = 1,

xorlw 1 ; установлюєм число годин = 9

btfss STATUS, Z

goto If_hour10_2

movlw 9

movwf Reg1_hour

goto Dec_hour10

If_hour10_2 movlw 9 ; якщо десятки годин = 2,

movwf Reg1_hour ; установлюємо години рівні 9

Dec_hour10 movfw Reg2_hour ; зменшуєм десятки годин

xorlw 0

BZ Clr

decf Reg2_hour, f

goto Main_loop

Clr movlw 2

movwf Reg2_hour

goto Main_loop

endm

; ------------- Підпрограма запису в EEPROM ---------------

EE_write macro Adress,Data

movlw Adress

movwf EEADR

movfw Data

movwf EEDATA

call Write_to_EEPROM

endm

; ------------- Підпрограма читання EEPROM ---------------

EE_read macro Adress,Destination

movlw Adress

movwf EEADR

call Read_from_EEPROM

movfw EEDATA

movwf Destination

endm

; ------------------- ІНІЦІАЛІЗАЦІЯ ----------------------

PROGRAM

bsf STATUS,RP0 ; банк 1

clrf TRISA ; порт А на вихід

movlw B'11110000' ; RB7..RB4 - на вхід, RB3..RB0 - на вихід

movwf TRISB

movlw B'00001000' ; відключений від таймеру

movwf OPTION_REG

bcf STATUS, RP0 ; банк 0

clrf TIME_SET

clrf FLAGS

clrf FLAGS_2

clrf sec

clrf sec10

clrf min

clrf min10

clrf hour

clrf hour10

clrf SB_delay

clrf Bit_counter

clrf Alarm_count

clrf PORTB

clrf SB4_count

clrf IntCount_H

clrf IntCount_L

movlw B'00010001'

movwf PORTA

movlw H'16' ; починаєм індикацію з десятків годин

movwf Ind_start

movfw Ind_start

movwf Fig_pointer

bsf FLAGS,PT ; ввімкнення крапок на індикаторі

bsf FLAGS_2, HL1

movlw D'16' ; запускаємо таймер номер 0

movwf TMR0

EE_read 1, TIME_SET ; читаємо значення коэфіціэнту

movwf TIME_SET ; корекції часу

EE_read 2, min_al_1 ; читаєм показпоказники обох

EE_read 3, min10_al_1 ; будильників з EEPROM

EE_read 4, hour_al_1

EE_read 5, hour10_al_1

EE_read 6, min_al_2

EE_read 7, min10_al_2

EE_read 8, hour_al_2

EE_read 9, hour10_al_2

movfw min_al_1 ; якщо в регістрах будильника

xorlw H'11' ; були числа 0х11, тоді,

btfss STATUS,Z ; він був вімкнений при останньому

bsf FLAGS, Al_on ; записі в EEPROM

movfw min_al_2

xorlw H'11'

btfss STATUS, Z

bsf FLAGS_2, Al_on2

bsf PORTB, 3 ; вмикаєм світлодіод

btfsc FLAGS, Al_on

bcf PORTB, 3

btfsc FLAGS_2, Al_on2

bcf PORTB, 3

bsf INTCON, T0IE ; дозволяєм переривання

bsf INTCON, GIE

movlw H'E' ; ініціалізація регістрів для правельної індикації

movwf EEP_Ind_1 ; режим роботи EEPROM

movlw H'E'

movwf EEP_Ind_2

movfw TIME_SET ; розбиваємо змінну TIME_SET

andlw B'00001111' ; на 16-розрядні десятки та одениці

movwf EEP_Ind_4 ; одениці

movfw TIME_SET

movwf EEP_Ind_3 ; десятки

swapf EEP_Ind_3, f

movlw B'00001111'

andwf EEP_Ind_3, f

;******************************************************************

; ГОЛОВНИЙ ЦИКЛ ПРОГРАМИ

******************************************************************

movlw H'21' ; задаємо верхню границю

movwf MaxInt_L ; лічби переривань = 3873

movlw H'F'

movwf MaxInt_H

movfw TIME_SET ; добавляєм TIME_SET до границі

bcf STATUS, C ; лічби переповнення таймера

addwf MaxInt_L, f

btfsc STATUS, C

incf MaxInt_H, f

movfw IntCount_H ; порівнюєм старший байт

xorwf MaxInt_H, w

btfss STATUS, Z

goto Main_loop

movfw IntCount_L ; порівнюєм молотший байт

xorwf MaxInt_L, w

btfss STATUS, Z

goto Main_loop

goto ADD1s ; секунда пройшла

; ------- Процедура перекодування числа в семисегментний код --------

Table

addwf PCL,f

retlw B'00000010' ; цифра 0

retlw B'10011110' ; цифра 1

retlw B'00100100' ; цифра 2

retlw B'00001100' ; цифра 3

retlw B'10011000' ; цифра 4

retlw B'01001000' ; цифра 5

retlw B'01000000' ; цифра 6

retlw B'00011110' ; цифра 7

retlw B'00000000' ; цифра 8

retlw B'00001000' ; цифра 9

retlw B'11111110' ; пусте місце (код 10h)

retlw B'11111100' ; тире (код 11h)

;********************* Режим індикації секунд ***********************

Show_seconds

clrf SB4_count

btfsc FLAGS,Sec ; якщо на індикаторі показані секунди

goto Show_hour ; повертаємся до нормального вигляду

movlw H'14'

movwf Ind_start

bsf FLAGS, Sec

movwf SB_delay

goto Main_loop

Show_hour

movlw H'16'

movwf Ind_start

bcf FLAGS,Sec

movwf SB_delay

goto Main_loop

;***************** Добавляєм менути реального часу ******************

ADDmin_button

clrf sec

clrf sec10

INC_MIN min, min10

goto Main_loop

;******************Добавляєм години реального часу ******************

ADDh_button

clrf sec

clrf sec10

INC_HOUR hour, hour10

goto Main_loop

END ; кінець програми

Рисунок 3.2.1 - Блок-схема роботи пристрою

3.3 Розрахунок надійності пристрою

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

Показники надійності:

    Безвідмовність.

    Довговічність.

    Ремонтопридатність.

    Збереження.

Безвідмовність – властивість безупинно зберігати працездатність до граничного стану, після настання, якого подальша експлуатація виробу економічно недоцільна.

Ремонтопридатність – пристосованість пристрою до попередження відмовлень, до можливості виявлення та усунення несправностей шляхом проведення ремонту і технічного обслуговування.

До термінів ремонтопридатності відносяться: відмовлення, збереження.

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

Відмовлення бувають:

Раптові (катастрофічні) – стрибкоподібна зміна параметрів робочого виробу.

Поступові (параметричні) – постійна зміна одного або декількох параметрів з часом, що виходять за припустимі межі.

Збереження – термін, протягом якого при дотриманні режимів збереження виріб зберігає працездатний стан.

Розрахунок надійності поділяється на три розділи:

    Визначення значення інтенсивності відмовлення всіх елементів за принциповою схемою вузла пристрою.

    Визначення значення імовірності безвідмовної роботи всієї схеми.

Визначення середнього наробітку до першого відмовлення.

Виконання розрахунків проходить наступним чином:

1. Інтенсивність відмовлення всіх елементів визначається за формулою:

(3.3.1)

де:

n>i>> >– кількість елементів у схемі;

>i>> >– інтенсивність відмовлень і-го елемента;

m – кількість типів елементів.

При розрахунку також потрібно враховувати інтенсивність відмовлень через пайки радіоелементів на друкованій платі.

Інтенсивність відмовлень елементів розраховуємо за формулою:

(3.3.2)

де:

>о> – інтенсивність відмовлень елементів у режимі номінального навантаження;

К>e> – експлуатаційний коефіцієнт;

К>р> – коефіцієнт навантаження.

Усі ці параметри беруться з довідника з розрахунку надійності.

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

Ймовірність безвідмовної роботи визначається за формулою:

(3.3.3)

де:

- інтенсивність відмов всіх елементів;

t – час, (год).

За результатами розрахунків складається таблиця і графік.

3. Середній наробіток до першого відмовлення – це час роботи пристрою до першої відмови.

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

(3.3.4)

Розрахунок надійності пристрою приведено далі.

Анотація

Завданням даної курсової роботи є створення схеми електричної принципової годинника-будильника-термометра з ІЧ ПК. В ході виконання курсової роботи розроблено структурну та електричну принципову схему пристрою та програму тестування роботи пристрою, та проведено розрахунок надійності його роботи.

Виконання даної курсової роботи змусило повторити та закріпити вивчений протягом навчального року матеріал з предмету «Мікропроцесорні системи», а також звернутися до додаткової літератури та вивчити багато нового.

Література

    Бороволоков Э.П. Фролов В.В. «Радиолюбительские схемы» // К.: Кондор – 1995 – 6 с.

    Якименко Ю.І. Терещенко Т.О. Сокол Є.І. «Мікропроцесорна техніка» // К.: Кондор – 2004 – 24 с.

    Методичні вказівки щодо виконання курсової роботи.

    Вершинин О.Е. «Применение микропроцессоров для автоматизации технологических процессов» // Л.: Энергоатомиздат, 1986.

    Самофалов К.Г., Викторов О.В., Кузняк А.К. «Микропроцессоры» // К.: Техника, 1986.