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

 
 
2 страниц V  < 1 2  
Reply to this topicStart new topic
xemul
сообщение Apr 1 2009, 05:18
Сообщение #16



*****

Группа: Свой
Сообщений: 1 928
Регистрация: 11-07-06
Пользователь №: 18 731



Цитата(777777 @ Apr 1 2009, 08:25) *
Если нужна именно фильтрация, то мажорирование не годится, потому что результат может оказатья неожиданным. Лучше уж отсортировать их и взять то, которое окажется посередине.

Если я правильно понял условие задачи singlskv: есть M (независимых) бинарных сигналов (которые, н-р, принимает N-разрядный порт контроллера); нужно по N отсчетам установить мажоритарное состояние каждого сигнала.
Go to the top of the page
 
+Quote Post
_Pasha
сообщение Apr 1 2009, 12:13
Сообщение #17


;
******

Группа: Участник
Сообщений: 5 646
Регистрация: 1-08-07
Пользователь №: 29 509



Чисто по-эстонски подумал, спустя год: а почему N*(log(N)+1) ?

1.Берем маску  0x5555 и 0xAAAA

2. Каждый элемент проредили, сложили 

Получили N*4 операций. И оно не растет.

Всех с днем Дурака, а меня особенно, потому что я думаю, что самый умный smile.gif
Go to the top of the page
 
+Quote Post
singlskv
сообщение Apr 1 2009, 12:58
Сообщение #18


дятел
*****

Группа: Свой
Сообщений: 1 681
Регистрация: 13-05-06
Из: Питер
Пользователь №: 17 065



Цитата(_Pasha @ Apr 1 2009, 16:13) *
1.Берем маску  0x5555 и 0xAAAA

Для байтовых чисел A,B,C это будет так:
((((A&0x55)+(B&0x55)+(C&0x55))>>1)&0x55) | ((((A&0xAA)>>1)+((B&0xAA)>>1)+((С&0xAA)>>1))&0xAA)

но это сложнее конъюнкций/дизъюнкций
и для 5 чисел наверное так же сложнее
а вот для 7 чисел по маске 001001001 такой вариант видимо уже быстрее
Go to the top of the page
 
+Quote Post
singlskv
сообщение Apr 1 2009, 18:09
Сообщение #19


дятел
*****

Группа: Свой
Сообщений: 1 681
Регистрация: 13-05-06
Из: Питер
Пользователь №: 17 065



для 3 чисел есть такое решение:
Код
R=((((A|B|C)^A^B)&B)^((A|B|C)^A^B)^C) | (((A|B|C)^A^B)&B);

что трансформируется в:
Код
tmp1=(A|B|C)^A^B;
tmp2=tmp1&B;
R=(tmp2^tmp1^C)|tmp2;

оно конечно длиннее для 3 чисел чем конъюнкции/дизъюнкции

но видимо на 7 числах станет уже лучше
Go to the top of the page
 
+Quote Post
xemul
сообщение Apr 1 2009, 21:11
Сообщение #20



*****

Группа: Свой
Сообщений: 1 928
Регистрация: 11-07-06
Пользователь №: 18 731



А я про баню...smile.gif
Код
ushort VCntA, VCntB;

void vcounter_2t(ushort x) // count in seq 0, 1, 2, 2...
{
   VCntA |= (VCntB & x);
   VCntB |= x;
}

ushort major_3(ushort *x)
{
   VCntA = VCntB = 0;
   vcounter_2t(*x);
   vcounter_2t(*(x+1));
   vcounter_2t(*(x+2));
   return VCntA;
}

Не проверял, но вроде бы похоже.

major_5, major_7 (нужно добавить VCntС) строятся аналогично.
Go to the top of the page
 
+Quote Post
SM
сообщение Apr 1 2009, 22:46
Сообщение #21


Гуру
******

Группа: Свой
Сообщений: 7 946
Регистрация: 25-02-05
Из: Moscow, Russia
Пользователь №: 2 881



Если экономим все же время, то переделать схему так, чтобы биты приходили последовательно, в виде A0 B0 ... x0 A1 B1 ... x1 - и потом это слово перекодируем по таблице, в которой записано соответствие выходных битов (пар битов, троек, смотря какая длина чего) входным данным.
Go to the top of the page
 
+Quote Post

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

 


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


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