![]() |
Модераторы: PILOT, ManiaK, Mazzi |
![]() ![]() ![]() |
|
:)PROD[; |
|
|||
Новичок Профиль Группа: Участник Сообщений: 13 Регистрация: 4.4.2005 Где: Томск Россия Репутация: нет Всего: нет |
Здравствуйте.
Дали задание – написать на ассемблере программу для МК51 (эмулятор AVSim51). Задача: поместить в регистр B среднее арифметическое массива 8-ми разрядных двоичных чисел в адресах 20H-2FH. Все бы хорошо, но при сложении 16ти однобайтных чисел (если брать максимально-допустимое для них значение) может получиться 12ти разрядное число, и напрямую командой DIV AB его не разделить. Есть идея перевести сумму из двоичной в двоично-десятичную систему, записать в DPTR (тысячи и сотни в DPH,а десятки и единицы в DPL), потом их обратно в двоичную систему и уже потом делить по частям. Вот только программка получается уж больно здоровой. Нет ли более простого способа решить? Заранее спасибо |
|||
|
||||
LessNik |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 52 Регистрация: 20.2.2006 Репутация: 1 Всего: 1 |
Самый простой способ - написать на Cи, а потом в листинге посмотреть ассемблерный код и сказать, что мол типа сам написал
![]() Чё-то ты намудрил. |
|||
|
||||
maxim1000 |
|
|||
![]() Эксперт ![]() ![]() ![]() ![]() Профиль Группа: Участник Сообщений: 3334 Регистрация: 11.1.2003 Где: Киев Репутация: 1 Всего: 110 |
если деление нацело (а оно нацело), то массив из (к примеру) 2-ек даст среднее 0, что не очень хорошо в данном случае количество элементов 16, так что деление можно заменить сдвигом если есть возможность работать с 16-разрядным аккумулятором, и вытащить из него биты 4..11, то, пожалуй, это - оптимальный вариант если можно работать только с байтами, то подойдёт такое (модификация предложенного "поразрядного способа", только используется 16-ричная система - оптимальнее получается): отдельно усредняем старшие: сначала сдвигаем их на 4 вниз (это можно сделать без потерь, т.к. у старших четвёрок младшие 4 бита нулевые), а потом складываем отдельно усредняем младшие - просто складываем (переполнения не будет) и сдвигаем вниз на 4 (потери будут, но как раз от этих потерь никак не избавиться) ну и складываем результаты -------------------- qqq |
|||
|
||||
:)PROD[; |
|
|||
Новичок Профиль Группа: Участник Сообщений: 13 Регистрация: 4.4.2005 Где: Томск Россия Репутация: нет Всего: нет |
задача решена.
загоняем сумму 16ти элементов в DPTR и сдвигаем на 4 бита влево. либо обмениваем тетрады по принципу SWAP DPL ANL DPL,#00FF SWAP DPH ANL DPH,#FF00 ORL DPH,DPL идея LessNik возможно неплоха для Си, на асме либо будет давать большие погрешности, либо не будет работать вообще. Всем спасибо ![]() Это сообщение отредактировал(а) :)PROD[; - 5.12.2006, 06:29 |
|||
|
||||
![]() ![]() ![]() |
Правила форума "Микроконтроллеры (MCU) и микропроцессоры (MPU)" | |
|
На данный раздел помимо Правил форума распространяются текже следующие правила:
Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, PILOT, ManiaK, UniBomb, Mazzi. |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | Микроконтроллеры (MCU) и микропроцессоры (MPU) | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |