Я хочу распараллелить мой код Python и пытаюсь использовать PyCuda.До сих пор я видел, что вы должны написать «Ядро» в C в своем коде Python.Это Ядро - это то, что будет распараллелено.Я прав?Пример (удвоение массива случайных чисел из https://documen.tician.de/pycuda/tutorial.html):
import pycuda.driver as cuda
import pycuda.autoinit
from pycuda.compiler import SourceModule
import numpy
a = numpy.random.randn(4, 4)
a = a.astype(numpy.float32)
a_gpu = cuda.mem_alloc(a.nbytes)
cuda.memcpy_htod(a_gpu, a)
# Kernel:
mod = SourceModule("""
__global__ void doublify(float *a)
{
int idx = threadIdx.x + threadIdx.y*4;
a[idx] *= 2;
}
""")
func = mod.get_function("doublify")
func(a_gpu, block=(4, 4, 1))
a_doubled = numpy.empty_like(a)
cuda.memcpy_dtoh(a_doubled, a_gpu)
print(a_doubled)
print(a)
Дело в том, что в моем коде Python есть классы и другие вещи, подходящие для Python и не подходящие для C (т.е. непереводимые для C).
Позвольте мне уточнить: у my есть 256 независимых циклов for, которые я хочу распараллелить. Эти циклы содержат код Python, который нельзя преобразовать в C.
Как я могу распараллелить фактический код Pythonс PyCuda без перевода моего кода на C?