亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
精品国精品国产尤物美女| 成人国产精品免费观看视频| 在线不卡a资源高清| 亚洲国产日韩在线一区模特| 欧美日韩国产不卡| 蜜乳av一区二区三区| 日韩午夜三级在线| 韩国欧美一区二区| 久久精品视频在线免费观看| 成人深夜视频在线观看| ㊣最新国产の精品bt伙计久久| 色悠悠久久综合| 日韩精品视频网站| 2017欧美狠狠色| 99热在这里有精品免费| 洋洋av久久久久久久一区| 欧美精品日韩一区| 久久91精品国产91久久小草| 中文字幕 久热精品 视频在线| 91麻豆国产在线观看| 日日嗨av一区二区三区四区| 国产三级一区二区三区| 一本一道久久a久久精品| 日韩二区在线观看| 欧美国产精品专区| 欧美在线免费播放| 国产精品中文字幕欧美| 亚洲情趣在线观看| 欧美一二三四区在线| 成人综合婷婷国产精品久久蜜臀| 一级做a爱片久久| 欧美草草影院在线视频| 99国产精品一区| 国内成人自拍视频| 亚洲精品水蜜桃| 欧美精品在线观看一区二区| 成人免费视频国产在线观看| 亚洲123区在线观看| www久久精品| 欧美视频在线播放| 国产91色综合久久免费分享| 亚洲成人自拍网| 中文字幕不卡一区| 日韩精品中午字幕| 欧美专区日韩专区| 波多野结衣中文字幕一区| 日韩成人午夜电影| 亚洲欧美一区二区三区国产精品 | 欧美国产成人在线| 欧美疯狂做受xxxx富婆| 91丨九色丨黑人外教| 看片网站欧美日韩| 一区二区三区四区亚洲| 欧美极品aⅴ影院| 欧美电视剧在线看免费| 在线观看亚洲成人| 99精品在线免费| 懂色av一区二区在线播放| 久久se这里有精品| 日本欧美一区二区三区乱码| 亚洲国产综合人成综合网站| 亚洲天堂网中文字| 中文字幕av一区二区三区高 | 亚洲一级片在线观看| 国产精品久久久久久久久动漫 | 国产精品色在线| 欧美成人欧美edvon| 欧美日韩免费高清一区色橹橹 | 欧美α欧美αv大片| 在线观看91av| 欧美老人xxxx18| 欧美午夜精品一区二区三区| 色视频一区二区| 色哟哟一区二区在线观看| eeuss鲁片一区二区三区在线看| 国产成人av一区二区三区在线观看| 裸体一区二区三区| 免费精品99久久国产综合精品| 亚洲综合在线电影| 亚洲主播在线观看| 亚洲精品综合在线| 一区二区欧美国产| 亚洲国产精品久久久久婷婷884| 亚洲国产sm捆绑调教视频| 一区二区三区.www| 午夜欧美一区二区三区在线播放 | 首页综合国产亚洲丝袜| 日韩高清欧美激情| 久久激五月天综合精品| 久久国内精品自在自线400部| 日本美女视频一区二区| 午夜亚洲国产au精品一区二区| 天天av天天翘天天综合网 | 久久久五月婷婷| 中文字幕第一区| 亚洲蜜臀av乱码久久精品 | 日本中文字幕一区二区有限公司| 日本欧美在线看| 国产精品99久久久| caoporn国产精品| 在线看不卡av| 日韩精品自拍偷拍| 欧美国产日韩亚洲一区| 亚洲一区二区三区中文字幕 | 国产精品77777| 99热在这里有精品免费| 欧美久久久久免费| 久久综合视频网| 国产精品久久一级| 午夜国产精品一区| 国产一区二区电影| 色av成人天堂桃色av| 日韩欧美久久一区| 亚洲免费av在线| 精品一区二区av| 91色综合久久久久婷婷| 欧美一区二区日韩一区二区| 欧美国产日韩一二三区| 日日夜夜精品视频免费| 北条麻妃国产九九精品视频| 在线电影一区二区三区| 国产精品蜜臀av| 青青青伊人色综合久久| 成人深夜在线观看| 欧美一区二区久久| 亚洲品质自拍视频| 国产老肥熟一区二区三区| 欧美日韩国产综合一区二区| 国产精品久久久久久久第一福利 | 国产精品色呦呦| 久久不见久久见免费视频7| 色狠狠av一区二区三区| 久久综合色8888| 日韩精品91亚洲二区在线观看| av高清久久久| 久久理论电影网| 日一区二区三区| 欧美午夜电影在线播放| 国产精品萝li| 激情综合色综合久久综合| 欧美日韩国产一级二级| 日韩理论片网站| 国产伦精品一区二区三区视频青涩| 欧美日韩一区不卡| 亚洲欧美福利一区二区| 国产91精品在线观看| 精品久久五月天| 视频在线观看一区二区三区| 欧美在线观看视频一区二区 | 91精品福利视频| 国产精品麻豆一区二区| 国产乱对白刺激视频不卡| 日韩欧美一卡二卡| 奇米影视7777精品一区二区| 欧美日韩性生活| 一级日本不卡的影视| 91网站在线播放| 亚洲欧洲www| 不卡高清视频专区| 国产精品久久久久久户外露出| 粉嫩一区二区三区在线看| 欧美电影免费观看高清完整版在 | 日韩欧美国产系列| 视频一区视频二区中文字幕| 欧美日韩一区二区在线视频| 亚洲电影视频在线| 91美女片黄在线观看| 国产精品久久午夜夜伦鲁鲁| av日韩在线网站| 国产精品美女久久久久久2018 | 337p日本欧洲亚洲大胆精品| 久久精品国产精品亚洲精品| 欧美一区日韩一区| 蜜桃视频在线观看一区二区| 欧美一区二区久久| 黄色日韩网站视频| 久久久久久久久一| 国产成人8x视频一区二区| 国产精品午夜在线| 91麻豆精品视频| 香蕉成人啪国产精品视频综合网| 欧美蜜桃一区二区三区 | 精品一区二区免费看| 久久久亚洲精华液精华液精华液 | 精品亚洲porn| 久久久亚洲高清| 91小宝寻花一区二区三区| 亚洲综合精品自拍| 911精品产国品一二三产区| 久久成人麻豆午夜电影| 国产嫩草影院久久久久| 91视频观看免费| 日本aⅴ免费视频一区二区三区| 精品捆绑美女sm三区| 99视频在线精品| 日韩黄色片在线观看| 久久精品人人做人人综合| 在线亚洲高清视频| 免费观看久久久4p| 国产精品全国免费观看高清|