Навигация
Главная
Поиск
Форум
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
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Содержание сайт... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Создание отчето... 65420
Модуль Forms 65184
Пример работы с... 64332
ТЕХНОЛОГИИ ДОСТ... 61830
Имитационное мо... 57751
Реклама
Сейчас на сайте
Гостей: 9
На сайте нет зарегистрированных пользователей

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

Моделирование процесса передачи данных по магистрали с основным и резерв...
Обработка задач на ЭВМ на GPSS + Пояснительная записка
Калькулятор на Delphi с переводом в другую систему исчисления + Блок схемы

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
Разработка микропроцессорного устройства управления технологическим процессом [на базе МК К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 23:18:42 · 0 Комментариев · 6355 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
AJAX и PHP. разра...
ЯЗЫК ПРОГРАММИРОВ...
Strawberry Prolog...
База Allsubmitter...
Allsubmitter 4.7 ...
Мод "register.php...
Форма в форме
около 291 статьи ...
GamesBase 3.0
CLR via C#
RxLIB
DFileDeleter
PRNDbgrid
PHP 5
Анекдоты с ostrie.ru
Дарахвелидзе П., ...
Delphi 6 программ...
Просмотр файлов и...
Основы Delphi. Пр...
ADVstatusbar

Топ загрузок
Приложение Клие... 100469
Delphi 7 Enterp... 87040
Converter AMR<-... 20078
GPSS World Stud... 12816
Borland C++Buil... 11830
Borland Delphi ... 8602
Turbo Pascal fo... 7039
Visual Studio 2... 4999
Калькулятор [Ис... 4798
FreeSMS v1.3.1 3542
Случайные статьи
меню команду RunAs
Печать русских бук...
Частотная манипуляция
Онлайн-понтон на р...
Это разрешение буд...
Как расколоть орешек
Обработка текста в...
Создание справки [...
Маршруты
atom(X)
DMZ).• Сервер DNS.
вание цифровой под...
Как купить мед спр...
Создание пользоват...
ДЕЙСТВИТЕЛЬНО ЛИ Н...
Комбинирование CSS...
Не можете найти фа...
Определяя переменн...
Рекурсивные методы...
Интернет-магазины ...
ЭТАП 4. ПРИМЕР РЕА...
Процессы и потоки
Определение шаблон...
DTABLE (РАЗНОСТНАЯ...
Эффективное исполь...
Статистика



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


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