Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Подпрограмма деления для AT89S4051 (AT89C....)
Форум разработчиков электроники ELECTRONIX.ru > Сайт и форум > В помощь начинающему > Программирование
POMOR
Юзаю AT89S2051 (ставлю вместо него и AT89C2051, AT89C4051, AT89S4051). В проекте сделал транслятор протокола с подменой некоторых данных в передаваемом пакете.

Вот возникла необходимость пересчитать км/час в узлы. Имею изначально 3 регистра X1 X2 X3, с содержимым к примеру 31h 32h 33h, это 123 км/час. Для перевода в узлы (мили в час) надо поделить на 1,852 (или же умножить на ~0.54). Регистров всегда 3, в них скорость от 000 до 999. При маленькой скорости нули есть всегда.

Поделить можно и на 1,85 или даже 1,8 округлив 1,852.

Результат надо положить в эти же регистры, (3) остаток в принципе не нужен, хотя и пригодился бы. Плавающая точка тоже не помешает. То есть, к этим 3-м регистрам есть возможность добавить несколько для точки и остатка.

Нет ли у кого готового примера такого деления или умножения? Был бы очень признателен smile.gif
ukpyr
ну например умножить на (0.54 * 256)~138, потом разделить на 256 (сдвинуть вправо на 8 бит, или просто взять старший байт), на больших скоростях будет небольшая ошибка.
POMOR
Здорово, достаточно короткий вариант. Но на маленьких пешеходных скоростях тоже погрешность получается. Хотя намного меньшая, чем если на 2 делить, а не на 1,852.
_pv
Цитата(POMOR @ Jan 2 2009, 06:11) *
Здорово, достаточно короткий вариант. Но на маленьких пешеходных скоростях тоже погрешность получается. Хотя намного меньшая, чем если на 2 делить, а не на 1,852.


256/138 = 1.85507
65536/35387 = 1.85198
_Pasha
Цитата(POMOR @ Jan 1 2009, 19:22) *
Имею изначально 3 регистра X1 X2 X3, с содержимым к примеру 31h 32h 33h, это 123 км/час.


Цитата(_pv @ Jan 2 2009, 11:03) *
65536/35387 = 1.85198


Код
unsigned char X[3];
unsigned int R16_bit;
unsigned long R32_bit;
//1. Приводите к 16-битному целому
R16_bit = (X[1]-0x30)*100 + (X[2]-0x30)*10 + (X[3]-0x30);
//2. Умножаете 32бит*32бит
// или 16*16, но надо написать на ассемблере
R32_bit = (unsigned long) (R16_bit * 35387)>>16;
POMOR
[quote name='_Pasha' date='Jan 2 2009, 13:59' post='525312']
//1. Приводите к 16-битному целому
R16_bit = (X[1]-0x30)*100 + (X[2]-0x30)*10 + (X[3]-0x30);

Ну это понятно, так и делаю smile.gif Получаю 2 байта 01 23, могу в 7Bh перевести.

А вот тут не догоняю:

//2. Умножаете 32бит*32бит
// или 16*16, но надо написать на ассемблере
R32_bit = (unsigned long) (R16_bit * 35387)>>16;
Herz
Цитата
А вот тут не догоняю:

//2. Умножаете 32бит*32бит
// или 16*16, но надо написать на ассемблере
R32_bit = (unsigned long) (R16_bit * 35387)>>16;

Что же именно тут непонятного? Целочисленное умножение и сдвиг, эквивалентный делению.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.