Python内存错误np.诊断()

2024-05-14 16:03:39 发布

您现在位置:Python中文网/ 问答频道 /正文

我想实现以下方程(Horn-Schunck方法的精确解):

Exact solution of the Horn-Schunck Method

我的代码:

def HS_exact(Ix, Iy, It, u, v, lamda):
  M = u.shape[0]
  N = u.shape[1]
  nabla = np.zeros((M,N))
  nabla = spnabla(M,N)
  transpose = np.transpose(nabla)
  u_0 = u
  v_0 = v
  Ix = Ix.flatten()
  Iy = Iy.flatten()
  diag_Ix_squared = np.diag(Ix*Ix)
  diag_Ix_Iy = np.diag(Ix*Iy)
  diag_Iy_squared = np.diag(Iy*Iy)
  tmp = lamda*diag_Ix_squared
  A11 = transpose*nabla + tmp 
  A12 = lamda*diag_Ix_Iy
  A21 = lamda*diag_Ix_Iy
  A22 = transpose*nabla + lamda*diag_Iy_squared

当我试图创建diag_Ix_squared时,错误出现了。我是python新手,不知道如何处理大数组。在


Tags: 方法nptmpdiagix方程transposeshape
1条回答
网友
1楼 · 发布于 2024-05-14 16:03:39

现在我知道问题出在哪里了。我用密集矩阵代替稀疏矩阵。在

 Ix_flat = Ix.flatten()
 Iy_flat = Iy.flatten()
 diag_Ix_squared = sp.spdiags(Ix_flat*Ix_flat, 0, M*N, M*N)

这解决了我的问题。谢谢你们的帮助。在

相关问题 更多 >

    热门问题