在pyopincl中写入索引数组



hi我在pyopincl中写了这段代码来获得稀疏随机向量,但问题是我不能将任何值写入索引数组。问题是什么?输出始终为零!!

这是我的代码

import pyopencl as cl
import numpy as np
from pyopencl import array 
from pyopencl import clrandom
ctx = cl.create_some_context()
queue = cl.CommandQueue(ctx,
        properties=cl.command_queue_properties.PROFILING_ENABLE)
x=array.zeros(queue, 512, dtype=np.float32 )
indices = clrandom.rand(queue, 17 , dtype=np.int32 ,luxury=2, a=1 , b=512)
clrandom.RanluxGenerator(queue,luxury=0).fill_normal(x[indices], mu=0, sigma=1)
print x

似乎x[indices]返回的是副本而不是视图。

>>> import pyopencl as cl
>>> import numpy as np
>>> from pyopencl import array 
>>> from pyopencl import clrandom
>>> 
>>> ctx = cl.create_some_context()
>>> queue = cl.CommandQueue(ctx,
...         properties=cl.command_queue_properties.PROFILING_ENABLE)
>>> 
>>> x=array.zeros(queue, 512, dtype=np.float32 )
>>> 
>>> indices = clrandom.rand(queue, 17 , dtype=np.int32 ,luxury=2, a=1 , b=512)
>>> x_cp = x[indices]
>>> x_cp
array([ 0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,
        0.,  0.,  0.,  0.], dtype=float32)
>>> clrandom.RanluxGenerator(queue,luxury=0).fill_normal(x_cp, mu=0, sigma=1)
>>> x_cp
array([ 1.16633689,  0.65845662,  1.97530341, -0.53728914,  1.38982224,
        1.47071588, -0.73042828,  1.29367638,  1.2390343 ,  2.89497447,
       -0.75589401,  0.04600764, -4.28992653,  0.50232059,  0.4881362 ,
        0.01112503, -0.46737072], dtype=float32)
>>> x[indices]
array([ 0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,  0.,
        0.,  0.,  0.,  0.], dtype=float32)

您可以尝试以下操作:

  1. 创建一个float32数组,该数组与indices数组具有相同的维度,我们将其称为tmp_random
  2. 生成随机数并将其存储在tmp_random
  3. 编写一个以indicestmp_randomx为参数的内核。每个线程从indices中读取一个索引,从tmp_random中读取相应的随机数,并将其存储在x中的正确位置

最新更新