PETSc Matrix副本引发异常:为什么?

时间:2017-06-30 19:38:38

标签: python petsc

我正在使用petsc4py,并获得一个我不明白的例外。我定义了以下函数:

def tsIJacobian(self, ts, t, u, udot, shift, A, B):
    self.setup_problem()
    psol = fe.as_backend_type(self.sol.vector()).vec()
    pA = fe.as_backend_type(self.A).mat()
    u.copy(psol)
    JU = fe.assemble(fe.derivative(ksdg.U_terms, ksdg.U))
    Jrho = fe.assemble(fe.derivative(ksdg.rho_terms, ksdg.rho))
    pJU = fe.as_backend_type(JU).mat()
    pJrho = fe.as_backend_type(Jrho).mat()
    pA.copy(A)
    A.scale(shift)
    A.axpy(1.0, pJU)
    A.axpy(1.0, pJrho)
    A.assemble()
    if not (A is B):
        A.copy(B)
        B.assemble()

然后尝试以下方法。 (pA已被定义为48x48 PETSc.Mat在其他地方,并已组装.ksdg是我正在研究的类的一个实例,如果我可以使它工作,它最终将成为一个成员函数):< / p>

J = pA.duplicate()
B = pA.duplicate()
tsIJacobian(ksdg, ts, 0, psol, pdsol, 0.1, J, B)

这会引发以下异常:

---------------------------------------------------------------------------
Error                                     Traceback (most recent call last)
<ipython-input-24-2a71f7ccf0af> in <module>()
----> 1 tsIJacobian(ksdg, ts, 0, psol, pdsol, 0.1, J, B)

<ipython-input-22-14579c08d6ae> in tsIJacobian(self, ts, t, u, udot, shift, A, B)
     15     A.assemble()
     16     if not (A is B):
---> 17         A.copy(B)
     18         B.assemble()

PETSc/Mat.pyx in petsc4py.PETSc.Mat.copy (src/petsc4py.PETSc.c:118071)()

Error: error code 63

查看petscerror.h.html,63为PETSC_ERR_ARG_OUTOFRANGE 63 /* input argument, out of range */

如果有人理解为什么PETSc不允许我将矩阵A复制到B,我会很感激解释。感谢。

1 个答案:

答案 0 :(得分:0)

好的,我有点想通了。当一个人试图在稀疏矩阵中创建一个新的非零元素时,如果选项

,则引发错误63异常
PETSc.Mat.Option.NEW_NONZERO_ALLOCATION_ERR

True。因此,如果我执行

B.setOption(PETSc.Mat.Option.NEW_NONZERO_ALLOCATION_ERR, False)

创建B后,tsIJacobian没有异常。我不明白的是为什么我没有得到J的相同例外。