亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
国产日产欧美一区二区三区| 精品国产精品网麻豆系列| 懂色av一区二区在线播放| 国内精品国产成人| 久久国产精品露脸对白| 亚洲综合网站在线观看| 一区二区三区四区高清精品免费观看 | 99久久免费视频.com| 99视频一区二区| 91浏览器打开| 精品视频全国免费看| 欧美日韩国产综合久久| 91精品国产黑色紧身裤美女| 欧美一区二区精品| 精品剧情v国产在线观看在线| 日韩欧美高清在线| 国产亚洲欧美激情| 中文字幕亚洲区| 亚洲国产视频直播| 奇米精品一区二区三区在线观看一| 日韩成人免费电影| 精品一区二区成人精品| 成人午夜电影小说| 日本久久一区二区三区| 欧美日韩高清一区二区不卡| 日韩欧美三级在线| 国产精品日韩成人| 一区二区三区四区高清精品免费观看| 偷窥少妇高潮呻吟av久久免费| 偷拍与自拍一区| 精品一区二区精品| 91在线视频免费观看| 欧美另类久久久品| 久久精品水蜜桃av综合天堂| 亚洲色图在线看| 三级在线观看一区二区| 国产一区二区三区av电影| 99久久99精品久久久久久| 欧美另类高清zo欧美| 国产亚洲精品aa| 亚洲自拍偷拍图区| 国产一区二区三区四区五区入口| 粉嫩aⅴ一区二区三区四区五区| 在线观看日韩av先锋影音电影院| 在线91免费看| 久久精品一二三| 亚洲中国最大av网站| 精品一区在线看| 91免费小视频| 欧美变态tickling挠脚心| 日韩理论电影院| 国产最新精品免费| 欧美综合色免费| www亚洲一区| 亚洲自拍欧美精品| 国产一区二区三区免费播放| 欧美自拍丝袜亚洲| 日韩一本二本av| 日韩美女视频19| 热久久免费视频| 91亚洲精品久久久蜜桃| 精品奇米国产一区二区三区| 亚洲一区中文日韩| 成人99免费视频| 欧美成人免费网站| 香蕉成人啪国产精品视频综合网| 高清免费成人av| 日韩欧美一二三区| 亚洲精品美腿丝袜| 成人高清免费观看| 2024国产精品视频| 天天色综合天天| 一本色道综合亚洲| 亚洲国产精品99久久久久久久久| 男女男精品视频网| 欧美日韩中文一区| 一区二区中文视频| 成人午夜av在线| 欧美精品一区二区在线观看| 亚洲无人区一区| 91一区一区三区| 国产精品网站在线播放| 久久97超碰国产精品超碰| 欧美最猛性xxxxx直播| 亚洲色图另类专区| 成人夜色视频网站在线观看| 精品久久久久久久一区二区蜜臀| 午夜激情一区二区三区| 在线看不卡av| 亚洲理论在线观看| 91麻豆免费观看| 亚洲同性gay激情无套| jvid福利写真一区二区三区| 欧美国产欧美综合| 国产成人在线观看免费网站| 26uuu成人网一区二区三区| 久久精品国产亚洲一区二区三区| 666欧美在线视频| 丝袜亚洲另类丝袜在线| 欧美三级在线播放| 天天综合网 天天综合色| 欧美日韩综合色| 午夜视频在线观看一区| 欧美在线短视频| 午夜免费欧美电影| 欧美精品xxxxbbbb| 日韩精品亚洲专区| 日韩三级免费观看| 美女视频黄免费的久久| 欧美刺激脚交jootjob| 国产伦精品一区二区三区免费迷| 精品国产免费久久| 国产.欧美.日韩| 成人欧美一区二区三区小说| 99久久国产综合色|国产精品| 亚洲色图视频网| 欧美人与禽zozo性伦| 日本亚洲三级在线| 2017欧美狠狠色| 成人免费观看男女羞羞视频| 亚洲欧洲av色图| 欧洲在线/亚洲| 日韩av成人高清| 精品国产乱码久久久久久蜜臀 | 久久99国产精品尤物| 2020国产精品自拍| 不卡影院免费观看| 亚洲一区二区三区中文字幕 | 91精品国模一区二区三区| 久久99精品久久只有精品| 国产亚洲一区二区三区在线观看 | 91视频免费看| 视频一区二区三区在线| 精品国产一区二区亚洲人成毛片| 丁香婷婷综合色啪| 亚洲一二三区在线观看| 欧美va在线播放| 99久久综合狠狠综合久久| 婷婷综合五月天| 国产欧美一区二区精品忘忧草| 色婷婷久久久久swag精品| 美女网站一区二区| 国产精品久久久久久久久久久免费看| 在线亚洲一区二区| 久草在线在线精品观看| 中文字幕在线不卡一区二区三区| 欧美日韩专区在线| 国产91精品一区二区| 亚洲一区二区四区蜜桃| 久久精品人人做人人爽97| 欧美性受xxxx黑人xyx性爽| 久久99久久久欧美国产| 亚洲欧美在线视频| 日韩欧美黄色影院| 97se亚洲国产综合自在线| 日韩中文字幕一区二区三区| 国产三级精品视频| 91精品国产入口| va亚洲va日韩不卡在线观看| 蜜桃在线一区二区三区| 国产精品无遮挡| 日韩精品综合一本久道在线视频| 99久久精品免费看| 国产一区二区不卡| 爽好久久久欧美精品| 亚洲欧美日韩在线不卡| 久久蜜桃av一区精品变态类天堂| 欧美视频日韩视频| 成人免费毛片嘿嘿连载视频| 久久激情综合网| 亚洲午夜视频在线| 中文字幕视频一区二区三区久| 日韩欧美国产1| 欧美老女人在线| 一本久久a久久精品亚洲| 国产成人午夜视频| 久久99精品国产.久久久久久| 亚洲在线中文字幕| 国产精品久久久久久久第一福利| 精品国产一二三| 日韩一区二区视频在线观看| 色老综合老女人久久久| www.av亚洲| 成人美女视频在线看| 国产一区二区免费看| 蜜桃在线一区二区三区| 丝袜脚交一区二区| 亚洲成人高清在线| 亚洲在线视频一区| 最新日韩av在线| 国产精品久久久久久妇女6080| 久久―日本道色综合久久 | 亚洲成在人线免费| 成人免费在线观看入口| 国产亚洲一区字幕| 久久久www成人免费毛片麻豆 | 美女视频第一区二区三区免费观看网站 | 午夜精品在线看| 亚洲高清视频在线| 亚洲国产成人av|