Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Умножение
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > AVR
Ich
Подскажите пожалуйста как правильно на асемблере умножить регистровую пару на константу, поиском ничего доступного не нашел (может и плохо искал). Заранее спасибо!
dimka76
Цитата(Ich @ Dec 12 2006, 01:05) *
Подскажите пожалуйста как правильно на асемблере умножить регистровую пару на константу, поиском ничего доступного не нашел (может и плохо искал). Заранее спасибо!


Это смотря какие числа умножать и для каких контроллеров (имеется ли на борту аппаратный умножитель или нет).
А вообще посмотри AVR200 и AVR201 на
http://www.atmel.com/dyn/products/app_note...p?family_id=607
Ich
Контроллер Mega 16, надо умножить результат от преобразования АЦП на константу, в моем случае на 7.
kalinka16
Цитата(Ich @ Dec 12 2006, 10:33) *
Контроллер Mega 16, надо умножить результат от преобразования АЦП на константу, в моем случае на 7.


Результат АЦП сдвинуть влево на три бита (эквивалентно умножению на 8) и вычесть результат АЦП (будет 7)
Wild007
Цитата(Ich @ Dec 12 2006, 09:33) *
Контроллер Mega 16, надо умножить результат от преобразования АЦП на константу, в моем случае на 7.

Исползовать команду:
MULSU Rd, Rr Multiply Signed with Unsigned R1:R0 ← Rd x Rr
Смотри DS
ValeraK
Цитата(Ich @ Dec 12 2006, 03:05) *
Подскажите пожалуйста как правильно на асемблере умножить регистровую пару на константу


При умножении 16 на 16 результат 32, делаю так:

clr Temp1000
clr Temp0100
ldi Cnt,16 ;bit counter
M16x16: lsr MnozhimoeH
ror MnozhimoeL
brcc NoAdd
add Temp0100,MnozhitelL
adc Temp1000,MnozhitelH
NoAdd: ror Temp1000 ;Result >>
ror Temp0100
ror Temp0010
ror Temp0001
dec Cnt
brne M16x16

Результат будет в четырёх регистрах Temp*
xemul
(high(a)*256 + low(a)) * b = (high(a) *b ) * 256 + low(a) * b
Осталось только реализовать это на ассемблере с использованием поминавшейся команды mulsu (mul, muls - по вкусуsmile.gif).
_Bill
Цитата(Ich @ Dec 12 2006, 10:33) *
Контроллер Mega 16, надо умножить результат от преобразования АЦП на константу, в моем случае на 7.

"Умножение без умножения"
=GM=
Цитата(ValeraK @ Dec 12 2006, 08:07) *
Цитата(Ich @ Dec 12 2006, 03:05) *

Подскажите пожалуйста как правильно на асемблере умножить регистровую пару на константу


При умножении 16 на 16 результат 32, делаю так:

clr Temp1000
clr Temp0100
ldi Cnt,16 ;bit counter
M16x16: lsr MnozhimoeH
ror MnozhimoeL
brcc NoAdd
add Temp0100,MnozhitelL
adc Temp1000,MnozhitelH
NoAdd: ror Temp1000 ;Result >>
ror Temp0100
ror Temp0010
ror Temp0001
dec Cnt
brne M16x16

Результат будет в четырёх регистрах Temp*

Будет чуток побыстрее (на 32 такта), если совместить регистры MnozhimoeH и MnozhimoeH с регистрами Temp0010 и Temp0001. К тому же нужно будет не 8 регистров, а 6. Ну и lsr сменить на ror.
OlegIvanov
умножение 2 байта на байт правильно понял? [A:B] * C = [B*C] + [A*C] если скорость не критична Есть алгоритмы побыстрее - умножение определенным способом на константу, вроде как говорили выше, не разбирался
ValeraK
Цитата(=GM= @ Dec 12 2006, 20:35) *
Цитата(ValeraK @ Dec 12 2006, 08:07) *

Цитата(Ich @ Dec 12 2006, 03:05) *

Подскажите пожалуйста как правильно на асемблере умножить регистровую пару на константу

При умножении 16 на 16 результат 32, делаю так:

Будет чуток побыстрее (на 32 такта), если совместить регистры MnozhimoeH и MnozhimoeH с регистрами Temp0010 и Temp0001. К тому же нужно будет не 8 регистров, а 6. Ну и lsr сменить на ror.


Полностью согласен, только ещё нужно убрать пару лишних сдвигов снизу.
Делалось давно, да и я стараюсь следовать: работает - не трогай.

P.S. Нет пределов совершенству; лучшее враг хорошего.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.