Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
21 ошибка прогр... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
ТЕХНОЛОГИИ ДОСТ... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Имитационное мо... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Реклама
Сейчас на сайте
Гостей: 4
На сайте нет зарегистрированных пользователей

Пользователей: 13,372
новичок: vausoz
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Расчет обратной матрицы на Delphi + Пояснительная записка
Создание последовательности окон и передвижение окон по экрану на Turbo ...
Моделирование автовокзала + Отчет + Блок схема

Разработка микропроцессорного устройства управления технологическим процессом [на базе МК К1878ВЕ1]

Исходя из разностного уравнения, составим алгоритм работы цифровой вычислительной машины.
Алгоритм работы ЦВМ
Рис.10. Алгоритм работы ЦВМ
В алгоритме управления используются операции вычитания чисел, сложения и умножения на вещественные коэффициенты а0, а1 и а2. Для реализации вычитания следует использовать операцию сложения чисел с использованием дополнительного кода. Умножение целого числа на вещественное можно реализовать следующим образом:
1. Производится беззнаковое умножение модуля числа на целую часть коэффициента.
2. Производится беззнаковое умножение модуля числа на дробную часть коэффициента.
3. Сложение целой части результата с дробной.
Схема алгоритма подпрограммы умножения представлена на рис. 11.
В микроконтроллере в процессе умножения восьмиразрядных чисел получается шестнадцатиразрядный результат. Поэтому возникает необходимость сложения шестнадцатиразрядных чисел. Сложение таких чисел можно выполнить следующим образом :
1) отрицательные числа представляются в дополнительном коде;
2) складываются младшие байты операндов с помощью команды сложения;
3) к старшему байту одного из операндов добавляется перенос от предыдущей операции;
4) к результату прибавляется значение старшего байта другого операнда.
Схема алгоритма основной программы формирования управляющего кода представлена на рис 12.
Схема алгоритма подпрограммы умножения
Рис. 11. Схема алгоритма подпрограммы умножения
Схема алгоритма основной программы
Рис.12. Схема алгоритма основной программы

Текст программы
ldr #0, 060h ;A
ldr #1, 070h ;B
ldr #2, 080h ;C
ldr #3, 090h ;D

movl %A0, 01h ;целая часть коэффициента при х[n]
movl %A1, 05h ;дробная часть коэффициента при х[n]
movl %B0, 02h ;целая часть коэффициента при х[n-1]
movl %B1, 05h ;дробная часть коэффициента при х[n-1]
movl %C0, 01h ;целая часть коэффициента при х[n-2]
movl %C1, 01h ;дробная часть коэффициента при х[n-2]

movl %C4, 01h ;х[n-2]
movl %B4, 01h ;х[n-1]
movl %A4, 01h ;х[n]

movl %B6, 00h ;обнуление регистров
movl %B5, 00h
movl %B7, 00h
movl %C6, 00h
movl %C5, 00h
movl %C7, 00h

movl %D2, 01h ;маска
movl %D3, 07h ;счетчик цикла умножения

jsr reginitial ;переход к подпрограмме инициализации регистров
jsr multipl ;умножаем целую часть 1-го слагаемого
mov %C5, %A6 ;сохранение целой части 1-го слагаемого
mov %C6, %A7
mov %A0, %A1 ;пересылаем дробную часть 1-го слагаемого в А0
jsr reginitial ;переход к подпрограмме инициализации регистров
jsr multipl ;умножаем дробную часть 1-го слагаемого
mov %C7, %A7 ;сохраняем результат 1-го слагаемого
add %C6, %A6

mov %A0, %B0 ;пересылаем целую часть 2-го слагаемого в А0
mov %A1, %B1 ;пересылаем дробную часть 2-го слагаемого в А1
mov %A4, %B4 ;пересылаем 2-й множитель
jsr reginitial ;переход к подпрограмме инициализации регистров
jsr multipl ;умножаем целую часть 2-го слагаемого
mov %B5, %A6 ;сохранение целой части 2-го слагаемого
mov %B6, %A7
mov %A0, %A1 ;пересылаем дробную часть 2-го слагаемого в А0
jsr reginitial ;переход к подпрограмме инициализации регистров
jsr multipl ;умножаем дробную часть 2-го слагаемого
mov %B7, %A7 ;сохраняем результат 2-го слагаемого
add %B6, %A6

mov %A0, %C0 ;пересылаем целую часть 3-го слагаемого в А0
mov %A1, %C1 ;пересылаем дробную часть 3-го слагаемого в А1
mov %A4, %C4 ;пересылаем 3-й множитель
jsr reginitial ;переход к подпрограмме инициализации регистров
jsr multipl ;умножаем целую часть 3-го слагаемого
mov %C0, %A6 ;сохранение целой части 3-го слагаемого
mov %C1, %A7
mov %A0, %A1 ;пересылаем дробную часть 3-го слагаемого в А0
jsr reginitial ;переход к подпрограмме инициализации регистров
jsr multipl ;умножаем дробную часть 3-го слагаемого
add %A6, %C1 ;сохраняем результат 3-го слагаемого
mov %A5, %C0

;переводим 2-е слагаемое в дополнительный код
cmpl %b6, 00h
jz .+6
not %B7
not %B6
not %B5
addl %B6, 01h
jnc .+1
addl %B5, 01h

;складываем 1-е и 2-е слагаемое
add %C6, %b6
jnc .+1
addl %C5, 01h
add %C5, %b5
jnc .+1
addl %C4, 01h

;складываем результат и 3-е слагаемое
add %C6, %a6
jnc .+1
addl %C5, 01h
add %C5, %a5
jnc .+1
addl %C4, 01h

;переводим результат в прямой код
cmpl %C5, 00h
jz .+4
subl %C6, 01h
js .+1
subl %C5, 01h
not %C6

jmp end


;подпрограмма инициализации регистров
reginitial:
mov %A3, %A4 ;пересылаем множимое
mov %D0, %D3 ;пересылаем счетчик
movl %A6, 00h
movl %A7, 00h
movl %D5, 00h
rts ;возврат из подпрограммы


;подпрограмма умножения
multipl:
mov %D1, %A3 ;пересылаем множитель
and %D1, %D2 ;выделяем младший бит множителя
jeq .+10 ;переход если младший бит равен 0
add %A6, %D5
movl %D5, 00h
shl %A6 ;логический сдвиг влево второго байта результата
add %A7, %A0 ;если младший бит=1,то прибавляем к первому байту результата множимое
shl %A0 ;логический сдвиг влево множимого
jc .+2 ;переход если бит С равен 1
addl %A6, 00h ;прибаляем ко второму байту результата 0
jmp .+1 ;безусловный переход через одну команду
addl %D5, 01h ;прибаляем к регистру %D5 1
jmp .+1
shl %A0 ;логический сдвиг влево множимого
shr %A3 ;логический сдвиг вправо множителя
subl %D0, 01h ;уменьшаем значение счетчика
jnz multipl
rts ;возврат из подпрограммы


;конец программы
end:
nop


Опубликовал Kest November 29 2009 20:18:42 · 0 Комментариев · 7648 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
Советы от Даниилы...
Паскаль и Дельфи....
Borland Delphi 6....
Архив программ
HtmlLerz PRO
DelTrayIcon [Исхо...
Delphi 7: Для про...
Экспорт базы данн...
БД сеть компьютер...
Факториал [Исходн...
ComboBox97
Cooltray
TrayComp
PCXReader. Програ...
Последние загруж...
Turbo Pascal for ...
Генетический алго...
Gold Submitter II...
3D Тетрис [Исходн...
Создание оригинал...

Топ загрузок
Приложение Клие... 100800
Delphi 7 Enterp... 98063
Converter AMR<-... 20302
GPSS World Stud... 17068
Borland C++Buil... 14261
Borland Delphi ... 10388
Turbo Pascal fo... 7398
Калькулятор [Ис... 6093
Visual Studio 2... 5241
Microsoft SQL S... 3676
Случайные статьи
Функция date() - в...
• Открыть в службе...
Как создать новый ...
Онлайн казино. Игр...
Коды стран
Специализированные...
Типы данных
Символы, используе...
ТЕХНОЛОГИИ ДОСТУПА...
Мода и покер: самы...
Программирвоание: ...
Сотрудник службы б...
Установка модулей ...
Машинное представл...
Направления дальне...
Особенности Страда...
Описание полей в т...
Установление подли...
Блоки работы с лог...
Имейте достаточно ...
Программа преобраз...
файлов
Структура распрост...
File not open for ...
Это позволит повто...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?