Навигация
Главная
Поиск
Форум
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
Реклама
Сейчас на сайте
Гостей: 8
На сайте нет зарегистрированных пользователей

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

Создание последовательности окон и передвижение окон по экрану на Turbo ...
Моделирование регулировочного участка цеха на GPSS + Пояснительная записка
Программа тестирования и обучающая программа по математике на Turbo Pasc...

Разработка микропроцессорного устройства управления технологическим процессом [на базе МК К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 Комментариев · 7213 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
VFW
Encrypt Decrypt
Советы от Даниилы...
Доступа к БД Fire...
Abbrevia
Delphi на примерах
Ehlib
32 урока по Delphi
Adapter (пример D...
VksButton
NotePad Pro [Исхо...
Win-Prolog 3.618
WinAmp
Библия хакера 2 К...
Работа с матрицами
CABfiles
MPTools
Основы программир...
Программирование ...
PHP/MySQL для нач...

Топ загрузок
Приложение Клие... 100772
Delphi 7 Enterp... 97809
Converter AMR<-... 20260
GPSS World Stud... 17014
Borland C++Buil... 14189
Borland Delphi ... 10267
Turbo Pascal fo... 7372
Калькулятор [Ис... 5972
Visual Studio 2... 5206
Microsoft SQL S... 3661
Случайные статьи
В качестве первого...
Фильтр "не(...)"
Драйвер seg_vn
Создание иконки пр...
Очистка кэша в Int...
Как быть, если ни ...
Реализация одноадр...
Разработка собстве...
Формат X PixMap
tab(X)
Содержание
Ограничение объясн...
С помощью сплит-те...
Файл HelloAndroidA...
Mostbet ставки на...
10.4. Принцип рез...
Официальный сайт В...
Вычислить среднее ...
Разборка приставки...
4.1. Двоичный поис...
Совмещение имен в IDL
Широкие потоки
Microsoft Word 2007
Футбольные ставки
внести параметры в...
Статистика



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


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