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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? marsscan.cu

?? GPU實(shí)現(xiàn)的MapReduce framework,對(duì)于學(xué)習(xí)并行編程和cuda平臺(tái)的編程方面有著極好的參考價(jià)值
?? CU
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
    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;
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品网站在线观看| 亚洲成人精品一区| 欧美videossexotv100| 99精品视频在线观看免费| 久久99国产精品麻豆| 日韩成人午夜精品| 蜜桃视频第一区免费观看| 日韩精品一卡二卡三卡四卡无卡| 国产精品美女久久久久久久久 | 日韩在线观看一区二区| 亚洲午夜久久久久中文字幕久| 日韩理论电影院| 中文字幕精品—区二区四季| 久久久不卡网国产精品二区 | 日一区二区三区| 亚洲成人免费影院| 一区二区三区四区亚洲| 亚洲人吸女人奶水| 亚洲色图在线播放| 亚洲一区二区影院| 亚洲一区二区欧美日韩| 亚洲成人激情综合网| 亚洲成人一区在线| 蜜桃av一区二区三区电影| 伦理电影国产精品| 久久99国产精品久久| 精品在线播放午夜| 国产精品亚洲а∨天堂免在线| 国产精品一区在线| 国产91精品精华液一区二区三区| 成人免费观看视频| 一本色道a无线码一区v| 色欧美日韩亚洲| 欧美系列一区二区| 69久久99精品久久久久婷婷| 在线不卡a资源高清| 日韩欧美中文一区二区| 2023国产精华国产精品| 国产欧美一区二区精品秋霞影院| 久久综合资源网| 亚洲欧美国产77777| 亚洲国产精品久久不卡毛片 | 一区二区三区色| 亚洲国产毛片aaaaa无费看| 日韩av中文字幕一区二区 | 国产一区二区三区| 成人精品免费看| 91在线精品秘密一区二区| 欧洲av一区二区嗯嗯嗯啊| 欧美一区二区三区成人| 国产午夜亚洲精品午夜鲁丝片| 亚洲视频一区在线观看| 日韩av一区二区三区四区| 日本在线观看不卡视频| 国产剧情一区二区三区| 91老司机福利 在线| 91麻豆精品国产91久久久久久 | 99在线精品视频| 日本韩国欧美一区二区三区| 91精品国产色综合久久| 国产午夜精品久久久久久免费视 | 一区二区三区四区蜜桃| 免费黄网站欧美| 粉嫩13p一区二区三区| 91精品国产日韩91久久久久久| 国产欧美日韩在线观看| 亚洲一区日韩精品中文字幕| 久久se精品一区二区| 91久久精品国产91性色tv| 日韩欧美在线不卡| 亚洲欧美日韩系列| 日韩成人一级大片| 国产精品一二二区| 欧美一区三区四区| 亚洲日本va午夜在线影院| 美女爽到高潮91| 欧美老年两性高潮| 亚洲欧洲日产国码二区| 麻豆精品一区二区| 色婷婷综合在线| 精品久久久久久久人人人人传媒| 亚洲黄色小说网站| 国产精品99久久久久久久vr| 欧美视频一二三区| 自拍偷拍亚洲综合| 国产精品一区二区在线观看不卡| 欧美系列日韩一区| 中文字幕av一区二区三区高 | 亚洲观看高清完整版在线观看| 国产精一区二区三区| 欧美丰满一区二区免费视频 | 国产精品色眯眯| 蜜桃传媒麻豆第一区在线观看| 91福利社在线观看| 亚洲精品国产a久久久久久| 国产精品亚洲午夜一区二区三区 | 亚洲国产婷婷综合在线精品| 白白色亚洲国产精品| 久久夜色精品国产欧美乱极品| 日本欧美大码aⅴ在线播放| 欧美亚洲尤物久久| 亚洲视频一区在线观看| 岛国一区二区三区| 日韩视频一区在线观看| 日av在线不卡| 欧美日韩大陆一区二区| 一区二区三区资源| 国产揄拍国内精品对白| 日韩精品一区二区三区在线观看| 蜜桃视频一区二区| 久久五月婷婷丁香社区| 国产激情精品久久久第一区二区 | 欧美国产综合一区二区| 成人午夜视频福利| 亚洲免费观看在线视频| 欧美在线综合视频| 日韩av中文在线观看| 精品久久国产字幕高潮| 国产成人精品aa毛片| 综合久久给合久久狠狠狠97色| 91免费看`日韩一区二区| 亚洲国产wwwccc36天堂| 欧美电影免费观看高清完整版| 国产一区二区三区四| 国产精品国产三级国产普通话三级| 94-欧美-setu| 偷拍自拍另类欧美| 日韩美女天天操| 成人手机电影网| 亚洲一区在线播放| 精品精品国产高清a毛片牛牛| 国产精品亚洲午夜一区二区三区| 亚洲婷婷综合久久一本伊一区| 色狠狠桃花综合| 午夜激情一区二区| 久久久久久久久久久黄色| heyzo一本久久综合| 亚洲成a人片综合在线| 精品久久久久久无| 色综合一个色综合亚洲| 免费在线看一区| 亚洲欧洲成人精品av97| 欧美日本一区二区在线观看| 韩国毛片一区二区三区| 亚洲欧洲综合另类| 欧美大片日本大片免费观看| www.在线欧美| 日本免费新一区视频| 中文乱码免费一区二区| 欧美精品一二三四| 成人黄色av网站在线| 日韩制服丝袜av| 欧美国产精品劲爆| 91精品国产综合久久久蜜臀粉嫩| 丁香婷婷综合色啪| 日韩av电影天堂| 国产精品免费免费| 日韩欧美一区二区不卡| 色综合久久久久综合| 久久91精品久久久久久秒播| 一区二区三区中文字幕电影| 久久久综合激的五月天| 在线电影一区二区三区| thepron国产精品| 狠狠色丁香九九婷婷综合五月| 亚洲综合小说图片| 国产精品欧美综合在线| 欧美变态tickle挠乳网站| 在线视频国内自拍亚洲视频| 成人影视亚洲图片在线| 免费观看30秒视频久久| 亚洲永久精品大片| 亚洲欧洲99久久| 久久久久亚洲蜜桃| 欧美一区二区三区视频在线观看| 97久久超碰国产精品电影| 黄页网站大全一区二区| 午夜视频在线观看一区二区三区| 国产精品国产a级| 国产日韩欧美一区二区三区乱码 | 日韩午夜电影在线观看| 欧美性xxxxx极品少妇| 91亚洲精华国产精华精华液| 国产一区二区不卡| 久久99国内精品| 麻豆精品视频在线| 日韩av中文字幕一区二区| 亚洲电影你懂得| 一区二区三区av电影| 亚洲视频一二区| 国产日韩欧美激情| 久久亚洲私人国产精品va媚药| 欧美一区二区三区婷婷月色| 欧美日本一区二区三区四区| 精品视频1区2区| 欧美中文字幕一二三区视频| 在线看不卡av| 色婷婷精品久久二区二区蜜臂av| 99精品久久99久久久久| av中文字幕亚洲|