Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Перемножить два двоичных вектора С=A^B
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > ARM
sergvks
Стоит задача перемножить в GF(2) два двоичных вектора, которые хранятся в двух массивах 32-битных слов. Вопрос заключается в том, как оптимизировать код под ARM7,ARM9 и CORTEX M3 с учётом их особенностей, возможно, с использованием ассемблера.

Пока в голову пришло вот это:

unsigned int multAB(unsigned int *A,unsigned int *B, unsigned int size)
{
unsigned int y=0;
for (i=0; i<size; i++)y^=A[i]^B[i];
y=y^(y>>1);
y=y^(y>>2);
y=y^(y>>4);
y=y^(y>>8);
y=y^(y>>16);
return y;
}
sergvks
Увидел пару неточностей smile.gif
Вот так правильно:
unsigned int multAB(unsigned int *A,unsigned int *B, unsigned int size)
{
unsigned int y=0,n;
for (i=0; i<size; i++)y^=A[i]&B[i];
y=y^(y>>1);
y=y^(y>>2);
y=y^(y>>4);
y=y^(y>>8);
y=y^(y>>16);
return y&1;
}
zltigo
Цитата(sergvks @ Jul 27 2008, 10:57) *
Увидел пару неточностей smile.gif

И еще одна осталась sad.gif
unsigned int y=0,n;
надо:
unsigned int y=0;
unsigned int i;

А оптимизировать в перемножении векторов произвольного размера особо нечего sad.gif. Едиственно, написать цикл по человечески - практически наверняка будет покороче и в цикле, и при инициализации цикла:
Код
    do{
        y ^= *A++ & *B++;
    }
    while( --size );
Alex03
Цитата(zltigo @ Jul 27 2008, 15:44) *
Едиственно, написать цикл по человечески - практически наверняка будет покороче и в цикле, и при инициализации цикла: ....

А не факт... Зависит от возможностей адресации проца... Проверять надо, плюс у sergvks предварительная проверка есть на size==0.

sergvks Я людь тёмный, GF(2) двоичных вектороф не знаю, что в результате то надо, признак нечётного количества попарно единичных битов в исходных массивах?
zltigo
Цитата(Alex03 @ Jul 28 2008, 11:26) *
А не факт...

Слова "практически наверняка" видели?
Цитата
Зависит от возможностей адресации проца...

Речь идет про АРМ, а зависит в данном случае в первую очередь от способностей компилятора к оптимизации. Но в общем случае написание "по-сишному", без явного указания лишних переменных и лишних (зачем перемножать два отсутствующих вектора) проверок в if() благотворно скажется на результате.
Цитата
Проверять надо...

Проверьте, если интересно, на все про все минут 15 smile.gif работы. Думаю, что одну команду в цикле и 3-4 вне цикла сэкономить реально.
sergvks
Цитата(Alex03 @ Jul 28 2008, 13:26) *
sergvks Я людь тёмный, GF(2) двоичных вектороф не знаю, что в результате то надо, признак нечётного количества попарно единичных битов в исходных массивах?

Ага, возможно и так сказать.

Я поэкспериментировал с асмом, но лучше чем у кейла у меня не получилось, так что наверно оставлю всё в таком виде.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.