Почему сборка разреженной матрицы выполняется медленнее, чем сборка плотной (полной) матрицы?Python

Программы на Python
Ответить Пред. темаСлед. тема
Anonymous
 Почему сборка разреженной матрицы выполняется медленнее, чем сборка плотной (полной) матрицы?

Сообщение Anonymous »

У меня есть две функции (i) getKglobal и (ii) getKglobal_Sp. Однако время для разреженной функции примерно в 5 раз медленнее, чем для полноматричной формулировки. Я понимаю, что добиться производительности от разреженности может быть непросто. Но замедление в 5 раз кажется слишком плохим. Какую «большую и очевидную» ошибку я упускаю?
def getKglobal(geom,mat,nel,tdof):
k_global = np.zeros((tdof, tdof))
for i in range(0,nel):
dof_idx = geom.dof_idx
coord = geom.coord
kloc=getkelement(coord,mat)
k_global[np.ix_(dof_idx, dof_idx)]+=kloc
return k_global

def getKglobal_Sp(geom,mat,nel,tdof):
from scipy.sparse import lil_matrix
k_global = lil_matrix((tdof, tdof))
for i in range(0,nel):
dof_idx = geom.dof_idx
coord = geom.coord
kloc=getkelement(coord,mat)
for a, global_a in enumerate(dof_idx):
for b, global_b in enumerate(dof_idx):
k_global[global_a, global_b] += kloc[a, b]
return k_global.tocsr()


Подробнее здесь: https://stackoverflow.com/questions/793 ... x-assembly
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «Python»