реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> Разница между значениями, ищу алгоритм
king2
сообщение Nov 5 2006, 00:53
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 255
Регистрация: 17-08-06
Из: Москва
Пользователь №: 19 646



Есть некое значение, запомненное в регистре, есть новое значение. Необходимо определить, отличается ли новое значение от старого более или менее чем на 25% старого.

Пока что делаю так:

delta = T0 >> 2;
Tmin = T0 - delta;
Tmax = T0 + delta;

if ((T1>Tmax) || (T1<Tmax)) {
// ура, попали!
}

Можно ли как-то упростить? В голове вертится, что наверное можно как-то при помощи сдвигов и логических операций, но что-то туплю smile.gif

Спасиба! smile.gif
Go to the top of the page
 
+Quote Post
_artem_
сообщение Nov 5 2006, 01:56
Сообщение #2


учащийся
*****

Группа: Свой
Сообщений: 1 065
Регистрация: 29-10-05
Из: города контрастов
Пользователь №: 10 249



Код
if( !((OLD_VALUE^NEW_VALUE) & 0xC0) )
{
              uraaaaaaaaa!
}


--------------------
Зачем лаять на караван , когда на него можно плюнуть?

Go to the top of the page
 
+Quote Post
king2
сообщение Nov 5 2006, 02:33
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 255
Регистрация: 17-08-06
Из: Москва
Пользователь №: 19 646



Цитата(_artem_ @ Nov 5 2006, 04:56) *
[код скипнут]

Предположим, OLD_VALUE = 0x3F, NEW_VALUE = 0x40.
(0x3F^0x40) & 0xC0 = 0x40, !0x40 = FALSE, итого имеем нифига не ура.
А разница всего единица..

Сообщение отредактировал king2 - Nov 5 2006, 02:34
Go to the top of the page
 
+Quote Post
_artem_
сообщение Nov 5 2006, 03:26
Сообщение #4


учащийся
*****

Группа: Свой
Сообщений: 1 065
Регистрация: 29-10-05
Из: города контрастов
Пользователь №: 10 249



Верно, не ура)
Наверно логикой это не решить - Значение 25 процентов меняется. А вот Ваш метод тоже грешит - Если число Т1 = 18 а Т0 = 15 то при смешении Т0 вправо получится 3 для Т0 + 25 процентов = 18. Так как ишется меньше разбаланса по 25 то "ура" здесь тоже неуместно.
Лучше Вам делать так - цифры использовать двухбайтные а сами числа Т0 и Т1 умножать на четыре (сдвигать вправо два раза) перед сравнением а за 25 процентов использовать само несдвинутое число Т0. Тогда никакой потери по младшим разрядам не будет.
Наверно логического агоритма нет а если и есть то Вы наверно покажете его нам когда найдете.


--------------------
Зачем лаять на караван , когда на него можно плюнуть?

Go to the top of the page
 
+Quote Post
Gall
сообщение Nov 5 2006, 21:57
Сообщение #5


Участник
*

Группа: Новичок
Сообщений: 35
Регистрация: 4-07-06
Пользователь №: 18 578



Ускорить можно на некоторых процессорах за счет перестановки действий: взять разность T1-T0

if (abs(T1-T0)<(T0>>2))

Работает там, где abs не медленнее сложения. Эконосмим одно сравнение.

Впрочем, до этого может додуматься и компилятор.
Go to the top of the page
 
+Quote Post
EvgenyNik
сообщение Nov 24 2006, 10:23
Сообщение #6


Знающий
****

Группа: Свой
Сообщений: 597
Регистрация: 24-05-06
Из: г. Чебоксары
Пользователь №: 17 402



King2, напишите - скольки разрядные числа используете; могут ли значения T0, T1 быть отрицательными; есть ли максимальное/минимальное значения T0, T1, при которых код недоиспользуется?
Цитата
а за 25 процентов использовать само несдвинутое число Т0. Тогда никакой потери по младшим разрядам не будет.

Да, так и делается обычно. Лишь бы разрядности хватало и при переменном знаке есть свои тонкости.

Сообщение отредактировал Евгений Николаев - Nov 24 2006, 10:28


--------------------
Почему разработчики систем повышенной надёжности плохо справляются с простыми проектами? :)
Go to the top of the page
 
+Quote Post
otrog
сообщение Nov 24 2006, 10:53
Сообщение #7


Местный
***

Группа: Свой
Сообщений: 232
Регистрация: 22-02-06
Из: Воронеж
Пользователь №: 14 589



Для положительных чисел одинаковой разрядности:
Код
if( (old - new + err) < err*2)
{
  УРА!
}

где err = максимальное_значение_чисел / %_ошибки


--------------------
Истина рождается в спорах; но когда страсти кипят, истина испаряется.
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 13th July 2025 - 23:44
Рейтинг@Mail.ru


Страница сгенерированна за 0.014 секунд с 7
ELECTRONIX ©2004-2016