[an error occurred while processing this directive]
[an error occurred while processing this directive]
|
Честно говоря, я тоже этим не занимался. Гораздо легче пользоваться библиотечными функциями.
Хотя приходилось пользоваться этим как-то раз. Мне досталась в наследство плата, на которой память была подключена как-то не так: позволяла 16-битный доступ, но не 8-битный. Поэтому нельзя было использовать библиотеку. Вот и пришлось применить эту идею. Но там было проще: в C166 есть аппаратный умножитель 16x16=32 бит и делитель 32/16=32 бит, так что запас точности был хороший.
А идея не нова. По-моему, так же работает и арифметика с плавающей точкой: умножения и деления целочисленные, хитрость в том, что аргументы нормированные, и результат нормируется битовыми сдвигами. В результате полностью используется разрядность умножителя или делителя (аппаратного или программного), а точка "плавает". Я не могу посоветовать ссылки, но уверен, что многие в этой конференции могут.
Удачи!
E-mail: info@telesys.ru