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

 
 
> Перемножить два двоичных вектора С=A^B, Как это эффективно сделать для ARM
sergvks
сообщение Jul 26 2008, 05:30
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 251
Регистрация: 26-07-05
Пользователь №: 7 117



Стоит задача перемножить в 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;
}
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Alex03
сообщение Jul 28 2008, 09:26
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 359
Регистрация: 9-12-05
Пользователь №: 12 034



Цитата(zltigo @ Jul 27 2008, 15:44) *
Едиственно, написать цикл по человечески - практически наверняка будет покороче и в цикле, и при инициализации цикла: ....

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

sergvks Я людь тёмный, GF(2) двоичных вектороф не знаю, что в результате то надо, признак нечётного количества попарно единичных битов в исходных массивах?
Go to the top of the page
 
+Quote Post



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

 


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


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