【发布时间】:2019-09-21 09:16:44
【问题描述】:
我有以下代码:
magma_int_t *h_ipiv;
magma_imalloc_cpu( &h_ipiv, k);
for (i=0;i<k;i++){
h_ipiv[i] = i;
}
magma_dgemm(MagmaTrans, MagmaNoTrans, N, n, m, 1.0, d_G2, m, d_A2, m, 0.0, d_QA, N, queue);
magma_dgemm(MagmaTrans, MagmaNoTrans, N, n, m, 1.0, d_G1, m, d_A1, m, -1.0, d_QA, N, queue);
magma_int_t info_getrs;
magma_dgetrs_gpu(MagmaTrans, Ngaps, n, d_M, N, h_ipiv, d_QA, N, &info_getrs);
在最后一行我收到一个错误double free or corruption (out): 0x000000001dd18540。我检查了来自magma_dgemm 的数组,它们似乎是正确的。尺寸也是正确的,因为我在 cpu lapack 版本上有这个代码,它们是一样的。所以错误似乎在h_ipiv 上,但我不知道h_ipiv 有什么问题。
有什么想法吗?
【问题讨论】:
-
为什么你在
h_ipiv的长度为k的元素上做一个malloc,而k在你对magma_dgetrs_gpu的调用中没有出现在任何地方?h_ipiv的长度的预期值是Ngaps,与 used in the 2nd parameter 对magma_dgetrs_gpu调用的Ngaps相同。如果kNgaps,那可能就是问题所在。您应该在矩阵中的每一行都有一个枢轴条目。 -
嗨@RobertCrovella,感谢您的回答。这里没有写,但 k 与 Ngaps 的值相同。所以这不是问题。