Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2008.12.07;
Скачать: CL | DM;

Вниз

Алгоритм сравнения матриц   Найти похожие ветки 

 
JetuS   (2008-02-12 15:07) [0]

Есть большой массив двухмерных битовых матриц 64х64:
A: array of array[1..64, 1..64]: Boolean;
И есть одна контрольная матрица 64х64.

Как быстро сравнить масив А с контрольной матрицей и определить, какая матрица из масива А имеет наибольше "совпадений" с контрольной?

Совпадение - это когда A[x][i, j]=Contr[i, j]
Простым перебором for работает очень долго, а хотелось бы побыстрее.


 
ketmar ©   (2008-02-12 15:11) [1]

для начала — выкидываем boolean"ы и берём longword"ы.

---
Understanding is not required. Only obedience.


 
MBo ©   (2008-02-12 15:20) [2]

Можно попробовать задавать матрицу как array[0..63] of Int64
тогда сравнение строки с контрольной - один xor, затем подсчет количества единичных битов


 
ketmar ©   (2008-02-12 15:24) [3]

>[2] MBo © (2008-02-12 15:20:00)
он умный, он поймёт и так.

---
Understanding is not required. Only obedience.


 
JetuS   (2008-02-12 15:25) [4]


> для начала — выкидываем boolean"ы и берём longword"ы.

И что дальше?


> Можно попробовать задавать матрицу как array[0..63] of Int64

Не совсем я понял как из 64х64 сделать одномерную матрицу 0..63


 
ketmar ©   (2008-02-12 15:32) [5]

>[4] JetuS (2008-02-12 15:25:00)
Джетус, а с чего она одномерной стала? байты — они состоят из битов. в каждом байте — 8 битов. в int64 4 байта. бит принимает значения 0 и 1. Boolean принимает значения true и false. нсходство не улавливаешь?

правда, с битами придётся работать руками. зато сравнение — один xor и одна асм-команда подсчёта единичных битов (вроде была такая, искать лень %-).

преобразуется примерно так:
установить значение в [ i, j ]: arr[ i ] := arr[ i ] or (1 shl j);
дальше по аналогии.

---
Understanding is not required. Only obedience.


 
Palladin ©   (2008-02-12 15:34) [6]


> в int64 4 байта

8 там байт... восемь...


 
ketmar ©   (2008-02-12 15:35) [7]

>[6] Palladin © (2008-02-12 15:34:00)
тьфу. и в [1] ту же ошибку сделал. точно, пора спать. вот пиво допью, пожру — и…

---
Understanding is not required. Only obedience.


 
MBo ©   (2008-02-12 15:37) [8]

>вроде была такая, искать лень
увы, команды такой нет, но способов посчитать биты - море.



Страницы: 1 вся ветка

Текущий архив: 2008.12.07;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.012 c
15-1223026601
int64
2008-10-03 13:36
2008.12.07
Перескок счетчиков.


6-1195957359
ZzZzZzZ
2007-11-25 05:22
2008.12.07
отправка принятых данных =)) (TClientSocket & TServerSocket)


2-1225118500
НовичОК89
2008-10-27 17:41
2008.12.07
получить Коды символов-разделителй


2-1225395211
batya-x
2008-10-30 22:33
2008.12.07
Работа с чужими окнами


2-1225432186
Uno-84
2008-10-31 08:49
2008.12.07
Как выделить дату в MonthCalendar?