亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? marsscan.cu

?? GPU實現的MapReduce framework,對于學習并行編程和cuda平臺的編程方面有著極好的參考價值
?? CU
?? 第 1 頁 / 共 2 頁
字號:
    unsigned int address = __mul24(blockIdx.x, (blockDim.x << 1)) + baseIndex + threadIdx.x; 

    __syncthreads();
    
    // note two adds per thread
    g_data[address]              += uni;
    g_data[address + blockDim.x] += (threadIdx.x + blockDim.x < n) * uni;
}


inline bool 
isPowerOfTwo(int n)
{
    return ((n&(n-1))==0) ;
}

inline int 
floorPow2(int n)
{
#ifdef WIN32
    // method 2
    return 1 << (int)logb((float)n);
#else
    // method 1
    // int nf = (int)n;
    // return 1 << (((*(int*)&nf) >> 23) - 127); 
    int exp;
    frexp((double)n, &exp);
    return 1 << (exp - 1);
#endif
}

#define BLOCK_SIZE 256

int** g_scanBlockSums;
unsigned int g_numEltsAllocated = 0;
unsigned int g_numLevelsAllocated = 0;



void preallocBlockSums(unsigned int maxNumElements)
{
//    assert(g_numEltsAllocated == 0); // shouldn't be called 

    g_numEltsAllocated = maxNumElements;

    unsigned int blockSize = BLOCK_SIZE; // max size of the thread blocks
    unsigned int numElts = maxNumElements;

    int level = 0;

    do
    {       
        unsigned int numBlocks = 
            max(1, (int)ceil((int)numElts / (2.f * blockSize)));
        if (numBlocks > 1)
        {
            level++;
        }
        numElts = numBlocks;
    } while (numElts > 1);

    g_scanBlockSums = (int**) malloc(level * sizeof(int*));
    g_numLevelsAllocated = level;
    
    numElts = maxNumElements;
    level = 0;
    
    do
    {       
        unsigned int numBlocks = 
            max(1, (int)ceil((int)numElts / (2.f * blockSize)));
        if (numBlocks > 1) 
        {
            CUDA_SAFE_CALL(cudaMalloc((void**) &g_scanBlockSums[level++],  
                                      numBlocks * sizeof(int)));
        }
        numElts = numBlocks;
    } while (numElts > 1);

    CUT_CHECK_ERROR("preallocBlockSums");
}

void deallocBlockSums()
{
    for (int i = 0; i < g_numLevelsAllocated; i++)
    {
        cudaFree(g_scanBlockSums[i]);
    }

    CUT_CHECK_ERROR("deallocBlockSums");
    
    free((void**)g_scanBlockSums);

    g_scanBlockSums = 0;
    g_numEltsAllocated = 0;
    g_numLevelsAllocated = 0;
}

void saven_initialPrefixSum(unsigned int maxNumElements)
{
	if(g_numEltsAllocated == 0)
		preallocBlockSums(maxNumElements);
	else
		if(g_numEltsAllocated>maxNumElements)
		{
			deallocBlockSums();
			preallocBlockSums(maxNumElements);
		}
	
}

void prescanArrayRecursive(int *outArray, 
                           const int *inArray, 
                           int numElements, 
                           int level)
{
    unsigned int blockSize = BLOCK_SIZE; // max size of the thread blocks
    unsigned int numBlocks = 
        max(1, (int)ceil((int)numElements / (2.f * blockSize)));
    unsigned int numThreads;

    if (numBlocks > 1)
        numThreads = blockSize;
    else if (isPowerOfTwo(numElements))
        numThreads = numElements / 2;
    else
        numThreads = floorPow2(numElements);

    unsigned int numEltsPerBlock = numThreads * 2;

    // if this is a non-power-of-2 array, the last block will be non-full
    // compute the smallest power of 2 able to compute its scan.
    unsigned int numEltsLastBlock = 
        numElements - (numBlocks-1) * numEltsPerBlock;
    unsigned int numThreadsLastBlock = max(1, numEltsLastBlock / 2);
    unsigned int np2LastBlock = 0;
    unsigned int sharedMemLastBlock = 0;
    
    if (numEltsLastBlock != numEltsPerBlock)
    {
        np2LastBlock = 1;

        if(!isPowerOfTwo(numEltsLastBlock))
            numThreadsLastBlock = floorPow2(numEltsLastBlock);    
        
        unsigned int extraSpace = (2 * numThreadsLastBlock) / NUM_BANKS;
        sharedMemLastBlock = 
            sizeof(int) * (2 * numThreadsLastBlock + extraSpace);
    }

    // padding space is used to avoid shared memory bank conflicts
    unsigned int extraSpace = numEltsPerBlock / NUM_BANKS;
    unsigned int sharedMemSize = 
        sizeof(int) * (numEltsPerBlock + extraSpace);

#ifdef DEBUG
    if (numBlocks > 1)
    {
        assert(g_numEltsAllocated >= numElements);
    }
#endif

    // setup execution parameters
    // if NP2, we process the last block separately
    dim3  grid(max(1, numBlocks - np2LastBlock), 1, 1); 
    dim3  threads(numThreads, 1, 1);

    // make sure there are no CUDA errors before we start
    CUT_CHECK_ERROR("prescanArrayRecursive before kernels");

    // execute the scan
    if (numBlocks > 1)
    {
        prescan<true, false><<< grid, threads, sharedMemSize >>>(outArray, 
                                                                 inArray, 
                                                                 g_scanBlockSums[level],
                                                                 numThreads * 2, 0, 0);
        CUT_CHECK_ERROR("prescanWithBlockSums");
        if (np2LastBlock)
        {
            prescan<true, true><<< 1, numThreadsLastBlock, sharedMemLastBlock >>>
                (outArray, inArray, g_scanBlockSums[level], numEltsLastBlock, 
                 numBlocks - 1, numElements - numEltsLastBlock);
            CUT_CHECK_ERROR("prescanNP2WithBlockSums");
        }

        // After scanning all the sub-blocks, we are mostly done.  But now we 
        // need to take all of the last values of the sub-blocks and scan those.  
        // This will give us a new value that must be sdded to each block to 
        // get the final results.
        // recursive (CPU) call
        prescanArrayRecursive(g_scanBlockSums[level], 
                              g_scanBlockSums[level], 
                              numBlocks, 
                              level+1);

        uniformAdd<<< grid, threads >>>(outArray, 
                                        g_scanBlockSums[level], 
                                        numElements - numEltsLastBlock, 
                                        0, 0);
        CUT_CHECK_ERROR("uniformAdd");
        if (np2LastBlock)
        {
            uniformAdd<<< 1, numThreadsLastBlock >>>(outArray, 
                                                     g_scanBlockSums[level], 
                                                     numEltsLastBlock, 
                                                     numBlocks - 1, 
                                                     numElements - numEltsLastBlock);
            CUT_CHECK_ERROR("uniformAdd");
        }
    }
    else if (isPowerOfTwo(numElements))
    {
        prescan<false, false><<< grid, threads, sharedMemSize >>>(outArray, inArray,
                                                                  0, numThreads * 2, 0, 0);
        CUT_CHECK_ERROR("prescan");
    }
    else
    {
         prescan<false, true><<< grid, threads, sharedMemSize >>>(outArray, inArray, 
                                                                  0, numElements, 0, 0);
         CUT_CHECK_ERROR("prescanNP2");
    }
}

void prescanArray(int *outArray, int *inArray, int numElements)
{
    prescanArrayRecursive(outArray, inArray, numElements, 0);
}

int prefexSum( int* d_inArr, int* d_outArr, int numRecords )
{	
	preallocBlockSums(numRecords);
	prescanArray( d_outArr, d_inArr, numRecords );
	deallocBlockSums();	

	int* h_outLast = ( int* )malloc( sizeof( int ) );
	CUDA_SAFE_CALL( cudaMemcpy( h_outLast, d_outArr+numRecords-1, sizeof(int),
                                cudaMemcpyDeviceToHost) );
	int* h_inLast = ( int* )malloc( sizeof( int ) );
	CUDA_SAFE_CALL( cudaMemcpy( h_inLast, d_inArr+numRecords-1, sizeof(int),
                                cudaMemcpyDeviceToHost) );

	unsigned int sum = *h_outLast + *h_inLast;

	free( h_outLast );
	free( h_inLast );
	
	return sum;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产一区二区三区免费播放| 欧美无砖砖区免费| 高清日韩电视剧大全免费| 国产在线播放一区二区三区| 麻豆91精品91久久久的内涵| 另类的小说在线视频另类成人小视频在线 | 亚洲色图色小说| 国产精品午夜免费| 亚洲国产成人在线| 亚洲视频在线一区二区| 一区二区三区欧美激情| 亚洲第一福利一区| 日韩电影在线观看一区| 美脚の诱脚舐め脚责91| 国产美女精品一区二区三区| 国产精品一区在线| 92精品国产成人观看免费| 色久优优欧美色久优优| 欧美乱妇15p| 26uuu精品一区二区| 亚洲国产激情av| 久久www免费人成看片高清| 麻豆精品一区二区综合av| 国内精品伊人久久久久av影院 | 日本高清不卡一区| 欧美美女网站色| 337p日本欧洲亚洲大胆精品| 亚洲国产电影在线观看| 一区二区三区四区在线免费观看| 视频精品一区二区| 国产乱码精品1区2区3区| 99re在线精品| 91麻豆精品国产自产在线观看一区| 精品日本一线二线三线不卡| 欧美激情一区二区在线| 一区二区三区91| 久久99精品久久久久婷婷| 不卡av电影在线播放| 欧美日韩免费观看一区二区三区| 日韩一区二区三区免费看| 国产精品女主播在线观看| 一区二区高清视频在线观看| 久久激情五月激情| 91小视频在线观看| 日韩精品一区二区三区蜜臀 | 中文字幕亚洲区| 首页综合国产亚洲丝袜| 国产成人精品一区二区三区四区| 欧洲精品在线观看| 国产亚洲精品中文字幕| 亚洲一区二区黄色| 成人综合在线视频| 91精品国产色综合久久ai换脸 | 日韩精品久久久久久| 国产精品三级久久久久三级| 亚洲大片精品永久免费| 国产乱码精品一区二区三区五月婷 | 色欧美日韩亚洲| 日韩免费观看高清完整版| 亚洲免费av网站| 国产激情一区二区三区四区| 欧美酷刑日本凌虐凌虐| 亚洲少妇屁股交4| 精品一区二区av| 欧美精品 日韩| 亚洲乱码国产乱码精品精小说| 黄页网站大全一区二区| 欧美日韩国产系列| 国产精品传媒入口麻豆| 国内精品久久久久影院一蜜桃| 欧美日韩另类一区| 亚洲欧洲成人精品av97| 国产一区二区女| 日韩一级大片在线观看| 亚洲国产人成综合网站| 色婷婷国产精品| 亚洲国产高清aⅴ视频| 国产做a爰片久久毛片| 91精品国产综合久久久久久久久久| 亚洲欧洲在线观看av| 大陆成人av片| 久久精品免视看| 久久av资源网| 日韩精品自拍偷拍| 日韩精品久久理论片| 欧美日韩亚洲丝袜制服| 亚洲欧美日韩在线| 99视频一区二区| 中文字幕一区三区| 成人av动漫在线| 1区2区3区国产精品| 丰满少妇在线播放bd日韩电影| 欧美精品一区二区三| 久久激五月天综合精品| 欧美xxxxx裸体时装秀| 视频一区二区欧美| 欧美一区二区三区视频免费 | 91视频免费观看| 国产精品久久久久久久久图文区 | 一本大道久久a久久综合| 国产精品久久久久桃色tv| 国产91对白在线观看九色| 国产日韩欧美综合一区| 国产乱子轮精品视频| 精品国产一区二区三区av性色 | 91浏览器打开| 亚洲人午夜精品天堂一二香蕉| 99在线精品免费| 一区二区三区四区高清精品免费观看| 99精品久久免费看蜜臀剧情介绍| 中文字幕一区二区5566日韩| 91在线观看污| 一区二区三区不卡视频| 欧美日韩国产综合草草| 天堂成人免费av电影一区| 欧美精品tushy高清| 久久精品噜噜噜成人av农村| 精品日韩在线观看| 丁香另类激情小说| 尤物视频一区二区| 欧美久久一二区| 国产一区二区主播在线| 欧美—级在线免费片| 91麻豆国产在线观看| 婷婷综合五月天| 精品国产区一区| 成人av免费在线观看| 亚洲一区二区三区视频在线播放| 欧美日韩在线播放| 精品一区二区在线视频| 国产精品国产三级国产aⅴ入口 | 91久久一区二区| 久久精品欧美日韩| a4yy欧美一区二区三区| 一区二区三区蜜桃网| 制服丝袜中文字幕一区| 国产成人免费视频网站高清观看视频 | 欧美成人一区二区三区片免费| 精品系列免费在线观看| 国产精品国产三级国产a| 欧美日韩一级视频| 国产原创一区二区三区| 亚洲精品综合在线| 日韩你懂的在线播放| 91视频在线观看| 奇米精品一区二区三区四区| 国产欧美一区二区精品性| 欧美性大战久久久久久久蜜臀| 精品影视av免费| 亚洲综合清纯丝袜自拍| 日韩精品中午字幕| 91在线视频播放地址| 美女在线一区二区| 亚洲精品欧美激情| 久久先锋资源网| 欧美日韩精品电影| 国产高清亚洲一区| 日日欢夜夜爽一区| 中文字幕在线观看不卡| 欧美岛国在线观看| 91国产成人在线| 国产成人av自拍| 免费观看日韩电影| 一区二区三区国产精华| 久久久91精品国产一区二区精品| 欧美日本一区二区在线观看| 国产精品一二一区| 日本中文字幕一区二区视频| 一区二区中文视频| 久久久国产午夜精品| 91精品国产入口| 欧美色图一区二区三区| 岛国精品在线观看| 国产综合久久久久久鬼色| 天天综合色天天| 一区二区三区鲁丝不卡| 国产欧美日韩视频在线观看| 日韩欧美国产高清| 欧美精品久久天天躁| 91福利视频久久久久| 成人av网站在线观看| 国产一区二区三区最好精华液| 天天综合日日夜夜精品| 亚洲视频资源在线| 国产精品久久99| 国产欧美日韩中文久久| 亚洲精品一区二区三区蜜桃下载| 欧美人妇做爰xxxⅹ性高电影| 一本一道综合狠狠老| www.av亚洲| 成人黄页在线观看| 懂色av噜噜一区二区三区av| 国产综合久久久久影院| 韩国午夜理伦三级不卡影院| 麻豆国产一区二区| 久久成人免费网| 韩国三级中文字幕hd久久精品| 韩国女主播一区二区三区| 久久综合五月天婷婷伊人| 日韩欧美在线综合网|