Навигация
Главная
Поиск
Форум
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
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Модуль Forms 65535
Реклама
Сейчас на сайте
Гостей: 3
На сайте нет зарегистрированных пользователей

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

Моделирование процесса обработки заданий на вычислительном центре на GP...
Движение шарика в эллиптическои параболоиде на Delphi [OpenGL] + Блок схемы
Моделирование круглосуточного интернет кафе на GPSS + Отчет

Реклама



Подписывайся на 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 Ноябрь 29 2009 23:18:42 · 0 Комментариев · 6719 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
Battle.Net - мони...
Пример создания W...
Заставка. Изображ...
Исправление проц...
Доступа к БД Fire...
DCMintry
Панель статистики...
База Allsubmitter...
Tank [Исходник на...
Учебник по создан...
IconCut [Исходник...
Экранная лупа
Delphi. Готовые а...
Ics
Gold Submitter II...
Программа "AutoRu...
3D Тетрис [Исходн...
Иллюстрированный ...
Усложнённый кальк...
Керниган Б.В., Ри...

Топ загрузок
Приложение Клие... 100634
Delphi 7 Enterp... 94495
Converter AMR<-... 20163
GPSS World Stud... 16363
Borland C++Buil... 13630
Borland Delphi ... 9590
Turbo Pascal fo... 7195
Калькулятор [Ис... 5424
Visual Studio 2... 5093
FreeSMS v1.3.1 3600
Случайные статьи
Сопутствующая инфо...
Упражнение 2: прое...
7.3. Ханойские башни
Вскрытие корпуса
Механизм наследова...
Механизм условных ...
Оптические дисководы
skip(X)
Фрикинг телефонных...
Работа с динамиче...
Технология NetFlow
Модуль CRT. Раблта...
Получение аннотаци...
Свойства цвета
Сердечная и несерд...
В то время как одн...
Goal,Rules. камеры...
Перемещение объект...
not(X)
сервера (всегда)]т...
— сервер приложени...
Игровые автоматы. ...
Числоформы (этот т...
Дверной доводчик d...
Вещественные типы
Статистика



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


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