5

应该足够简单;我真的想将一个 int 发送到 SourceModule 内核声明,其中 C 函数

__global__......(int value,.....)

声明并调用该值...

value = 256
...
...
func(value,...)

但是我从 pycuda 得到了各种错误,我使用了错误的类型。

4

1 回答 1

9

标准的 PyCUDA 函数接口要求参数具有 numpy dtypes,因为它在内部确实映射到 C 类型。因此,对于按值传递的标量参数,您需要先“转换”为合适的 numpy dtype。就像是

value = 256
va = numpy.int32(value)

func(va)

应该管用。如果您要传递单精度浮点值或数组,请确保显式使用 np.float32 的 dtype,因为 numpy 默认使用双精度,您会遇到类似的错误。

于 2011-04-19T05:57:47.007 回答