推力/CUDA将一个阵列与另一个阵列的值进行多次复制
假设我有两个数组推力/CUDA将一个阵列与另一个阵列的值进行多次复制,cuda,thrust,Cuda,Thrust,假设我有两个数组 A={1,2,3} 及 B={10,20,30,40,50} 我想生成一个大小为的新数组 sizeof(A)*sizeof(B) 我想复制B sizeof(A)次,在每次重复I时,结果数组应该添加A[I]。所以结果会是这样的 {11,21,31,41,51,12,22,32,42,52,13,23,33,43,53}此任务可以解释为一个二维问题,其中输出数组可以被视为维度矩阵sizeof(a)乘以sizeof(B)。通过这种方式,我们可以使用2D CUDA索引来实现所需的功能。
A={1,2,3}
及
B={10,20,30,40,50}
我想生成一个大小为的新数组
sizeof(A)*sizeof(B)
我想复制B sizeof(A)次,在每次重复I
时,结果数组应该添加A[I]
。所以结果会是这样的
{11,21,31,41,51,12,22,32,42,52,13,23,33,43,53}
此任务可以解释为一个二维问题,其中输出数组可以被视为维度矩阵sizeof(a)
乘以sizeof(B)
。通过这种方式,我们可以使用2D CUDA索引来实现所需的功能。这个2D实现的一个示例CUDA C++代码如下:
#include <iostream>
#include <cuda_runtime.h>
#include <cassert>
using namespace std;
__global__ void kernel_replicate(int* a, int* b, int* c, int alen, int blen, int clen)
{
const int ai = blockIdx.x * blockDim.x + threadIdx.x;
const int bi = blockIdx.y * blockDim.y + threadIdx.y;
if(ai<alen && bi<blen)
{
const int ci = ai * blen + bi;
c[ci] = a[ai] + b[bi];
}
}
void replicate_device(int* a, int* b, int* c, int alen, int blen, int clen)
{
dim3 block(16,16);
dim3 grid;
grid.x = (alen + block.x - 1) / block.x;
grid.y = (blen + block.y - 1) / block.y;
kernel_replicate<<<grid, block>>>(a,b,c,alen,blen,clen);
assert(cudaSuccess == cudaDeviceSynchronize());
}
void replicate(int* a, int* b, int* c, int alen, int blen, int clen)
{
int *ad, *bd, *cd;
size_t abytes = alen * sizeof(int);
size_t bbytes = blen * sizeof(int);
size_t cbytes = clen * sizeof(int);
cudaMalloc(&ad, abytes);
cudaMalloc(&bd, bbytes);
cudaMalloc(&cd, cbytes);
cudaMemcpy(ad,a, abytes, cudaMemcpyHostToDevice);
cudaMemcpy(bd,b, bbytes, cudaMemcpyHostToDevice);
replicate_device(ad,bd,cd, alen,blen,clen);
cudaMemcpy(c,cd, cbytes, cudaMemcpyDeviceToHost);
cudaFree(ad);
cudaFree(bd);
cudaFree(cd);
}
int main()
{
const int alen = 3;
const int blen = 5;
const int clen = alen * blen;
int A[alen] = {1,2,3};
int B[blen] = {10,20,30,40,50};
int C[clen] = {0};
replicate(A,B,C,alen, blen, clen);
for(int i=0; i<alen; i++)
{
cout<<A[i]<<" ";
}
cout<<endl;
for(int i=0; i<blen; i++)
{
cout<<B[i]<<" ";
}
cout<<endl;
for(int i=0; i<clen; i++)
{
cout<<C[i]<<" ";
}
cout<<endl;
return 0;
}
#包括
#包括
#包括
使用名称空间std;
__全局无效内核复制(int*a、int*b、int*c、int-alen、int-blen、int-clen)
{
const int ai=blockIdx.x*blockDim.x+threadIdx.x;
const int bi=blockIdx.y*blockDim.y+threadIdx.y;
如果(ai