И снова про округление......
(«Телесистемы»: Конференция «Микроконтроллеры и их применение»)

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

Отправлено SimplyMe 26 августа 2004 г. 13:22

Вот есть процедурка:
int DataConvert (int Data, int _MinIn, int _MaxIn, int _MinOut, int _MaxOut)
{
int tmp = ((long)Data - _MinIn) *
((long)_MaxOut - _MinOut)/
((long)_MaxIn - _MinIn) + _MinOut;

return (tmp);
}
В общем она переводит переменные из одного масштаба в другой, например
DataConvert(2048, 0, 4095, 0, 180) == 90 (2048 => 90)и наоборот
DataConvert(90, 0, 180, 0, 4095) == 2048 (90 => 2048).
Так вот, очевидно что эти равенства выполняются не всегда т.к. происходит отбрасывание дробной части при вычислении. А отсюда и вопрос: как бы это значение покорректнее округлить чтобы преобразования как в одну сторону, так и в другую давали один и тот же результат? Заранее сенкс!!

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

Ответы



Перейти к списку ответов  |||  Конференция  |||  Архив  |||  Главная страница  |||  Содержание  |||  Без кадра

E-mail: info@telesys.ru