-1

我正在尝试找到数组的最大值。我从CUDA Maximum Reduction Algorithm Not Working获得了帮助。并做一些自己的修改。但是我正在为 16 个数据运行它。我发现在内核代码共享内存中只复制第一个 4data。休息丢失。我把两个 cuPrintf..1st printf 显示的数据是它们在共享内存中的。但是第二个 cuPrintf 就在 __syncthreads 之后.. 并且从线程 id 显示 0 4 onwords .. 请帮助 #include #include #include #include #include #include "cuPrintf.cu" #include "cuPrintf.cuh"

__device__ float MaxOf2(float a, float b)
{
    if(a > b)   return a;
    else            return b;
}

__global__ void findMax(int size,float *array_device , float *outPut)
{
    extern __shared__ float sdata[];
    int tid =  threadIdx.x;
    int i = blockIdx.x*blockDim.x + threadIdx.x;

   if(i< size)
   {
    sdata[tid] = array_device[i];
    cuPrintf(" array_d[%d]===%f, sdata[%d]===%f\n ",i,array_device[i],tid,sdata[tid]);
    __threadfence();

    }
    __syncthreads();

    if(tid<size) 
        cuPrintf(" array_d[%d]===%f, sdata[%d]===%f\n ",i,array_device[i],tid,sdata[tid]);

    for ( int s=blockDim.x/2; s>0; s=s>>1)//s=blockDim.x/2
    {   
        if (tid < s) 
        {   
            sdata[tid]= MaxOf2(sdata[tid],sdata[tid+s]);

        }

        __syncthreads();
   }
   if (tid == 0) outPut[blockIdx.x] = sdata[0];

}

 int main()
{
    long double M = pow(2,20);
    long double N = 2;
    int noThreadsPerBlock = 512 ;
    printf("\n Provide the array Size N.(array will be of size N * 2^20 ) :-");
    scanf("%Lf",&N);
    long int size = 16;
    int numOfBlock = (int)size /noThreadsPerBlock + 1;
    printf("\n num of blocks==%ld",numOfBlock);

    float *array_device , *outPut;
    float array_host[]={221,100,2,340,47,36,500,1,33,4460,5,6,7,8,9,11};
    cudaMalloc((void **)&array_device, size*sizeof(float));
    cudaMalloc((void **)&outPut, size*sizeof(float));
    cudaError_t error0 = cudaGetLastError();
    printf("\n 0CUDA error: %s\n", cudaGetErrorString(error0));
    printf("size===%ld",size);

    cudaMemcpy(array_device, array_host, size*sizeof(float), cudaMemcpyHostToDevice);
    cudaError_t error1 = cudaGetLastError();
    printf("\n1CUDA error: %s\n", cudaGetErrorString(error1));


    while(size>1 )
    {
        cudaPrintfInit();
        findMax<<< numOfBlock,noThreadsPerBlock>>>(size,array_device, outPut);cudaPrintfDisplay(stdout, true);
       cudaPrintfEnd();
       cudaError_t error2 = cudaGetLastError();
       printf("   2CUDA error: %s\n", cudaGetErrorString(error2));
       cudaMemcpy(array_device, outPut, size*sizeof(float), cudaMemcpyDeviceToDevice);
       size = numOfBlock;
       printf("\n ****size==%ld\n",size);
       numOfBlock = (int)size /noThreadsPerBlock + 1;
   }

     cudaMemcpy(array_host, outPut, size*sizeof(float), cudaMemcpyDeviceToHost);
     cudaError_t error3 = cudaGetLastError();
    printf("\n3CUDA error: %s\n", cudaGetErrorString(error3));
    for(int i=0;i<size;i++)
          printf("\n index==%d ;data=%f ",i,array_host[i]);
    return 0;
 }
4

1 回答 1

3

我正在按要求发布我的评论作为答案。

首先,您没有在内核启动时指定共享内存的动态大小。它应该看起来像: findMax<<< numOfBlock,noThreadsPerBlock,sizeof(float)*noThreadsPerBlock>>>

if(tid<size)其次,第二个条件背后的概念是什么cuPrintf?提供程序的输出也会有所帮助。

于 2013-08-30T12:50:11.753 回答