gpt4 book ai didi

c++ - Cuda thrust::device_vector 从特定范围获取指针

转载 作者:行者123 更新时间:2023-11-30 03:48:02 31 4
gpt4 key购买 nike

我有一个 vector 的 vector :

thrust::device_vector weights_;

这是一个连续的内存量,其中每 w 个项目,表示一个 vector 。

在我的一个函数中,我将该范围的开始和结束作为参数传递,如下所示:

 __host__ ann::d_vector ann::prop_layer (
unsigned int weights_begin,
unsigned int weights_end,
ann::d_vector & input
) const

然后,我去复制到一个新的 vector 范围内,然后得到一个我可以在内核中使用的原始指针:

thrust::device_vector<float> weights ( weights_.begin() + weights_begin,
weights_.begin() + weights_end );

float * weight_ptr = thrust::raw_pointer_cast( weights.data() );

some_kernel<<<numBlocks,numThreads>>>( weight_ptr, weight.size() );
  1. 我能否从该范围获取指针,而无需先将其复制到新 vector ?对我来说,这似乎是对复制重新分配的浪费。
  2. 如果我无法从该范围获取指针,我是否可以至少为该范围分配一个 vector ,而不复制实际值?

最佳答案

Can I get a pointer from that range, without first copying it to a new vector? That seems like a waste of copy-realloc to me.

是的,您可以获得指向该范围的指针。

float * weight_ptr = thrust::raw_pointer_cast( weights_.data() ) + weights_begin;

In case I can't get a pointer from that range, can I at least assign a vector to that range, without copying the actual values?

不,不能在现有数据的“顶部”实例化推力 vector 。

关于c++ - Cuda thrust::device_vector 从特定范围获取指针,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33398374/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com