Я думаю, что это будет постепенное обновление разреженной матрицы, а не условное условие, основанное на цикле, которое будет замедлять процесс.
Когда вы добавляете новую запись в разреженную матрицу через что-то вроде A(i,j) = 1
, обычно требуется, чтобы вся структура данных матрицы была переупакована. Это дорогая операция. Если вам интересно, MATLAB использует внутреннюю структуру данных CCS
(хранилище сжатых столбцов), которая описана в разделе Структура данных здесь . Обратите внимание на утверждение:
Эта схема неэффективна для манипулирования матрицами одним элементом в
время
Как правило, гораздо лучше (быстрее) накапливать ненулевые записи в матрице в виде набора триплетов, а затем сделать один вызов sparse
. Например (предупреждение - скомпилированный мозгом код !!):
% Inputs:
% N
% prev_array and next_array
% n_labels_prev and n_labels_next
% mapping
% allocate space for matrix entries as a set of "triplets"
ii = zeros(N,1);
jj = zeros(N,1);
xx = zeros(N,1);
nn = 0;
for next_label_ix = 1:n_labels_next
prev_label = mapping(next_label_ix);
if prev_label <= n_labels_prev
prev_global_label = prev_array(prev_label);
next_global_label = next_array(next_label_ix);
% reallocate triplets on demand
if (nn + 1 > length(ii))
ii = [ii; zeros(N,1)];
jj = [jj; zeros(N,1)];
xx = [xx; zeros(N,1)];
end
% append a new triplet and increment counter
ii(nn + 1) = next_global_label; % row index
jj(nn + 1) = prev_global_label; % col index
xx(nn + 1) = 1.0; % coefficient
nn = nn + 1;
end
end
% we may have over-alloacted our triplets, so trim the arrays
% based on our final counter
ii = ii(1:nn);
jj = jj(1:nn);
xx = xx(1:nn);
% just make a single call to "sparse" to pack the triplet data
% as a sparse matrix object
sp_graph_adj_global = sparse(ii,jj,xx,N,N);
Я размещаю порциями N
записей одновременно. Предполагая, что вы много знаете о структуре вашей матрицы, вы можете использовать лучшее значение здесь.
Надеюсь, это поможет.