Разработка, производство и продажа радиоэлектронной аппаратуры
|
Требуется программист в Зеленограде - обработка данных с датчиков; ColdFire; 40 тыс.
e-mail: jobsmp@pochta.ru
|
Классический алгоритм деления даёт ошибку. Что я делаю неправильно?
Отправлено
RRR 06 августа 2009, г. 13:33
Классический алгоритм деления без восстановления остатка реализован на 8-разрядном контроллере PIC16F690 (код написан на ассемблере). Делится 32-разрядное число на 16-разрядное. При некоторых значениях аргументов программа выдаёт неправильные результаты. Проверил на бумажке - получаю то же самое.
Например, деление 0x8000 на 0x1AAE даёт результат 5, а должно получаться 4.
Что я делал (и, соответственно, делает проверяемая программа):
1. Нормализуем делимое и делитель, т.е. сдвигаем влево до получения 1 в старшем разряде. При этом счётчик сдвигов инкрементируется при сдвиге делимого и декрементируется при сдвиге делителя.
В итоге делимое - 0x80000000, делитель - 0xD570 счётчик сдвигов - ZZ=0x0D.
2. Вычитаем делитель из старших разрядов делимого и инкрементируем счётчик сдвигов:
0x8000-0xВ570=0xAA90, ZZ=0x0E, C=0 => следующая операция - сложение делимого и удвоенного остатка (как я понимаю, старший бит при сдвиге делимого влево не учитывается? или именно тут я и ошибаюсь?)
2*0xAA90=0x5520, 0x5520+0xD570=0x2A90, ZZ=0x0F, C=1 => следующая операция - вычитание делимого из удвоенного остатка.
2*0x2A90=0x5520, 0x5520-D570=0x7FB0, ZZ=0x10, C=0 => следующая операция - сложение делимого и удвоенного остатка.
2*0x7FB0=0xFF60, 0xFF60+0xD570=0xD4D0, ZZ=0x11 (признак окончания деления), C=1.
Итак, получается результат 0x0101. А виндовый калькулятор и простая логика даёт результат 0x0100.
Где тут грабли?
Составить ответ | Вернуться на конференцию.
Ответы
- Я, может быть, во что-то не въезжаю... Но, какой-то у Вас странный "классический" алгоритм... - Палыч (06.08.2009, 15:12:2 192.168.21.15,87.117.3.81, 377 байт)
- ошибка в переполнении (+): - argus98 (06.08.2009, 14:04:6 81.22.205.230, 258 байт)
- В старинных Аппликухах у мелкочипа есть все примеры деления чего угодно на что угодно. - Крок (06.08.2009, 13:53:42 62.118.59.14, пустое)
- Может поможет... - POV (06.08.2009, 13:49:13 213.137.239.62, 6681 байт)
- 32768 / 6830=4.79 - misyachniy (06.08.2009, 13:46:1 194.187.111.110, пустое)