[an error occurred while processing this directive]
Я для этой цели широко пользуюсь рациональными двоичными дробями
(«Телесистемы»: Конференция «Микроконтроллеры и их применение»)

миниатюрный аудио-видеорекордер mAVR

Отправлено =AVR= 06 июня 2006 г. 17:23
В ответ на: long - вполне нормальный вариант. отправлено _Bill 06 июня 2006 г. 16:52

x*0.9876 = x*9876/10000 ~~ x*64723/65536 = (x*9876) >> 16 или просто x=LSW(x*9876). Десятичную точку в результате ставлю куда надо, а при масштабировании выбираю такую пару числитель/знаменатель, чтобы промежуточный результат был как можно ближе к наибольшему int (65536), но не переполнял бы его. Точность практически не теряется, просто получается передискретизация

Составить ответ  |||  Конференция  |||  Архив

Ответы


Отправка ответа

Имя (обязательно): 
Пароль: 
E-mail: 
NoIX ключ Запомнить

Тема (обязательно):
Сообщение:

Ссылка на URL: 
Название ссылки: 

URL изображения: 


Rambler's Top100 Рейтинг@Mail.ru
Перейти к списку ответов  |||  Конференция  |||  Архив  |||  Главная страница  |||  Содержание

E-mail: info@telesys.ru