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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? marscpulib.cu

?? GPU實(shí)現(xiàn)的MapReduce framework,對于學(xué)習(xí)并行編程和cuda平臺的編程方面有著極好的參考價(jià)值
?? CU
?? 第 1 頁 / 共 2 頁
字號:

	//-----------------------------------------------
	//clean
	//-----------------------------------------------
CPU_MAP_EXIT:
	BenFree((char**)&keyValOffsets, sizeof(int2)*threadNum);
	BenFree((char**)&curIndex, sizeof(size_t)*threadNum);
	BenFree((char**)&g_map, sizeof(WorkerArg_t));

	BenFree((char**)&interKeySizePerThread, sizeof(size_t)*threadNum);
	BenFree((char**)&interValSizePerThread, sizeof(size_t)*threadNum);
	BenFree((char**)&interCountPerThread, sizeof(size_t)*threadNum);

	BenFree((char**)&g_mapcount, sizeof(CountArg_t));
	BenFree((char**)&tp, sizeof(BenThread_t)*threadNum);

	BenFree((char**)&psKeySizes, sizeof(size_t)*threadNum);
	BenFree((char**)&psValSizes, sizeof(size_t)*threadNum);
	BenFree((char**)&psCounts, sizeof(size_t)*threadNum);

	//LeaveFunc("StartCPUFunc");
}   

void StartCPUSort(Schedule_t *sched, char mode)
{
	if (mode & MAP_SORT || mode & MAP_SORT_REDUCE)
	{
		if (mode & USE_FILE)
			sched->outputSmallChunk.keyOffset = 0;
		QuickSortMem(&sched->outputSmallChunk);
		GroupByMem(&sched->outputSmallChunk);
		sched->outputSmallChunk.rangeSize = sched->outputSmallChunk.diffKeyCount*sizeof(int2);
	}      
}

void cpuEmitCount(size_t		keySize,
	  size_t		valSize,
	  size_t*		outputKeysSizePerTask,
	  size_t*		outputValsSizePerTask,
	  size_t*		outputCountPerTask,
	  int			index)
{
	outputKeysSizePerTask[index] += keySize;
	outputValsSizePerTask[index] += valSize;
	outputCountPerTask[index]++;
}

void cpuEmit  (char*		key, 
	   char*		val, 
	   size_t		keySize, 
	   size_t		valSize,
	   size_t*		psKeySizes, 
	   size_t*		psValSizes, 
	   size_t*		psCounts, 
	   int2*		keyValOffsets, 
	   char*		outputKeys,
	   char*		outputVals,
	   int4*		outputOffsetSizes,
	   size_t*		curIndex,
		int		index)
{ 
	char *pKeySet = (char*)(outputKeys +  psKeySizes[index]  + keyValOffsets[index].x);
	char *pValSet = (char*)(outputVals + psValSizes[index]   + keyValOffsets[index].y);
 
	BenMemcpy(pKeySet, (char*)key, keySize);
	BenMemcpy(pValSet, (char*)val, valSize);

	keyValOffsets[index].x += keySize;
	keyValOffsets[index].y += valSize;

	if (curIndex[index] != 0)
	{
	outputOffsetSizes[psCounts[index] + curIndex[index]].x = 
		(outputOffsetSizes[psCounts[index] + curIndex[index] - 1].x + 
		 outputOffsetSizes[psCounts[index] + curIndex[index] - 1].y);
	outputOffsetSizes[psCounts[index] + curIndex[index]].z = 
		(outputOffsetSizes[psCounts[index] +curIndex[index] - 1].z + 
		 outputOffsetSizes[psCounts[index] + curIndex[index] - 1].w);
	}
	
	outputOffsetSizes[psCounts[index] + curIndex[index]].y = keySize;
	
	outputOffsetSizes[psCounts[index] + curIndex[index]].w = valSize;

	curIndex[index]++;
}

void *cpuReduceCount(void *i)
{
	int index = (int)i;

	size_t keyOffset = g_reducecount->keyOffset;
	size_t valOffset = g_reducecount->valOffset;

	for (int i = 0; i <= g_reducecount->recPerThread; i++)
	{
		int cindex = i*g_reducecount->threadNum+index;
		if (cindex >= g_reducecount->recCount) return 0;
	
		int valStartIndex = g_reducecount->inKeyListRange[cindex].x;
		int valCount = g_reducecount->inKeyListRange[cindex].y - g_reducecount->inKeyListRange[cindex].x;

		size_t keySize = g_reducecount->inIndex[valStartIndex].y;

		char *key = cpuGetRecordFromBuf(g_reducecount->inKeys, 
			g_reducecount->inIndex, valStartIndex, 0, keyOffset, valOffset);
		char *vals = cpuGetRecordFromBuf(g_reducecount->inVals, 
			g_reducecount->inIndex, valStartIndex, 1, keyOffset, valOffset);

		cpu_reduce_count(key,
				vals,
				keySize,
				valCount,
				g_reducecount->inIndex,
				g_reducecount->interKeySizePerThread,
				g_reducecount->interValSizePerThread,
				g_reducecount->interCountPerThread,
				index,
				valStartIndex);
	}
	return 0;
}

void *cpuReduce(void *args)
{
	int index = (int)args;

	g_reduce->outIndex[g_reduce->psCounts[index]].x = g_reduce->psKeySizes[index];
	g_reduce->outIndex[g_reduce->psCounts[index]].z = g_reduce->psValSizes[index];

	for (int i = 0; i <= g_reduce->recPerThread; i++)
	{
		int cindex = i*g_reduce->threadNum+index;
		if (cindex >= g_reduce->recCount) return 0;
	
		int valStartIndex = g_reduce->inKeyListRange[cindex].x;
		int valCount = g_reduce->inKeyListRange[cindex].y - g_reduce->inKeyListRange[cindex].x;

		size_t keySize = g_reduce->inIndex[g_reduce->inKeyListRange[cindex].x].y;

		char *key = cpuGetRecordFromBuf(g_reduce->inKeys, 
			g_reduce->inIndex, valStartIndex, 0, g_reducecount->keyOffset, g_reducecount->valOffset);
		char *vals = cpuGetRecordFromBuf(g_reduce->inVals, 
			g_reduce->inIndex, valStartIndex, 1,
			g_reducecount->keyOffset, g_reducecount->valOffset);

		cpu_reduce(key,
			   vals,
			   keySize,
			   valCount,
			   g_reduce->psKeySizes,
			   g_reduce->psValSizes,
			   g_reduce->psCounts,
			   g_reduce->keyValOffsets,
			   g_reduce->inIndex,
			   g_reduce->outKeys,
			   g_reduce->outVals,
			   g_reduce->outIndex,
			   g_reduce->curIndex, 
				index,
				valStartIndex);
	}
	return 0;
}
//-------------------------------------------------
//main cpu reduce procedure
//-------------------------------------------------
void StartCPUReduce(Schedule_t *sched, char mode)
{
	BEN_ASSERT(sched != NULL);

	//-------------------------------------------------------
	//get reduce input data
	//-------------------------------------------------------
	//!!!
	size_t	interRecCount = sched->inputSmallChunk.diffKeyCount;
	//!!!

	if (interRecCount <= 0) return;

	//!!!
	char *interKeys = sched->inputSmallChunk.keys;
	char *interVals = sched->inputSmallChunk.vals;
	int4 *interIndex = sched->inputSmallChunk.index;
	int2 *interKeyListRange = sched->inputSmallChunk.keyListRange;
	//!!!

	//----------------------------------------------
	//determine the number of threads to run
	//----------------------------------------------
	size_t threadNum = sched->cpuReduceThreadNum;
	size_t recPerThread = interRecCount / threadNum;
	if (0 == recPerThread)
		recPerThread = 1;

	//----------------------------------------------
	//calculate intermediate data keys'buf size 
	//	 and values' buf size
	//----------------------------------------------
	size_t*	outputKeySizePerThread = (size_t*)BenMalloc(sizeof(size_t)*threadNum);
	size_t*	outputValSizePerThread = (size_t*)BenMalloc(sizeof(size_t)*threadNum);
	size_t*	outputCountPerThread = (size_t*)BenMalloc(sizeof(size_t)*threadNum);

	g_reducecount = (CountArg_t*)BenMalloc(sizeof(CountArg_t));
	g_reducecount->inKeys = interKeys;
	g_reducecount->inVals = interVals;
	g_reducecount->inIndex = interIndex;
	g_reducecount->inKeyListRange = interKeyListRange;
	g_reducecount->interKeySizePerThread = outputKeySizePerThread;
	g_reducecount->interValSizePerThread = outputValSizePerThread;
	g_reducecount->interCountPerThread = outputCountPerThread;
	g_reducecount->recCount = interRecCount; 
	g_reducecount->recPerThread = recPerThread;
	g_reducecount->threadNum = threadNum;
	g_reducecount->keyOffset = 0;//!!!sched->inputSmallChunk.keyOffset;
	g_reducecount->valOffset = 0;//!!!sched->inputSmallChunk.valOffset;

	BenThread_t *tp = (BenThread_t*)BenMalloc(sizeof(BenThread_t)*threadNum);
	for (int i = 0; i < threadNum; i++)
	{
		tp[i] = BenNewThread(cpuReduceCount, (void*)i);
		//cpuReduceCount((void*)i);
	}
	BenWaitForMul(tp, threadNum);
 
	//-----------------------------------------------
	//prefix sum
	//-----------------------------------------------
	size_t allKeySize = outputKeySizePerThread[0];
	size_t allValSize = outputValSizePerThread[0];
	size_t allCounts = outputCountPerThread[0];

	size_t *psKeySizes = (size_t*)BenMalloc(sizeof(size_t)*threadNum);
	size_t *psValSizes = (size_t*)BenMalloc(sizeof(size_t)*threadNum);
	size_t *psCounts = (size_t*)BenMalloc(sizeof(size_t)*threadNum);

	for (int i = 1; i < threadNum; i++)
	{
		psKeySizes[i] += (outputKeySizePerThread[i-1] + psKeySizes[i-1]);
		psValSizes[i] += (outputValSizePerThread[i-1] + psValSizes[i-1]);
		psCounts[i] += (outputCountPerThread[i-1] + psCounts[i-1]);
	}

	allKeySize = (outputKeySizePerThread[threadNum-1]+psKeySizes[threadNum-1]);
	allValSize = outputValSizePerThread[threadNum-1]+psValSizes[threadNum-1];
	allCounts = outputCountPerThread[threadNum-1]+psCounts[threadNum-1];

	//-----------------------------------------------
	//allocate intermediate memory
	//-----------------------------------------------
	char*	outputKeys = (char*)BenMalloc(allKeySize);
	char*	outputVals = (char*)BenMalloc(allValSize);
	int4*	outputIndex = (int4*)BenMalloc(sizeof(int4)*allCounts);

	int2*	keyValOffsets = (int2*)BenMalloc(sizeof(int2)*threadNum);
	size_t*	curIndex = (size_t*)BenMalloc(sizeof(size_t)*threadNum);
	//!!!size_t cur = sched->outputSmallCurCount;

	if (allCounts <= 0)
		goto CPU_REDUCE_EXIT;

	g_reduce = (WorkerArg_t*)BenMalloc(sizeof(WorkerArg_t));

	g_reduce->inKeys = interKeys;
	g_reduce->inVals = interVals;
	g_reduce->inIndex = interIndex;
	g_reduce->inKeyListRange = interKeyListRange;
	g_reduce->psKeySizes = psKeySizes;
	g_reduce->psValSizes = psValSizes;
	g_reduce->psCounts = psCounts;
	g_reduce->keyValOffsets = keyValOffsets;
	g_reduce->outKeys = outputKeys;
	g_reduce->outVals = outputVals;
	g_reduce->outIndex = outputIndex;
	g_reduce->curIndex = curIndex;
	g_reduce->recCount = interRecCount;
	g_reduce->recPerThread = recPerThread;
	g_reduce->threadNum = threadNum;

	for (int i = 0; i < threadNum; i++)
	{
		tp[i] = BenNewThread(cpuReduce, (void*)i);
		//cpuReduce((void*)i);
	}
	BenWaitForMul(tp, threadNum);

	//-----------------------------------------------
	//output
	//-----------------------------------------------

	sched->outputSmallChunk.keys = outputKeys;
	sched->outputSmallChunk.vals = outputVals;
	sched->outputSmallChunk.index = outputIndex;
	sched->outputSmallChunk.keySize = allKeySize;
	sched->outputSmallChunk.valSize = allValSize;
	sched->outputSmallChunk.indexSize = allCounts*sizeof(int4);
	sched->outputSmallChunk.recCount = allCounts;
 
	//-----------------------------------------------
	//clean
	//-----------------------------------------------
CPU_REDUCE_EXIT:
	BenFree((char**)&keyValOffsets, sizeof(int2)*threadNum);
	BenFree((char**)&curIndex, sizeof(size_t)*threadNum);
	BenFree((char**)&g_reduce, sizeof(WorkerArg_t));

	BenFree((char**)&outputKeySizePerThread, sizeof(size_t)*threadNum);
	BenFree((char**)&outputValSizePerThread, sizeof(size_t)*threadNum);
	BenFree((char**)&outputCountPerThread, sizeof(size_t)*threadNum);

	BenFree((char**)&g_reducecount, sizeof(CountArg_t));
	BenFree((char**)&tp, sizeof(BenThread_t)*threadNum);

	BenFree((char**)&psKeySizes, sizeof(size_t)*threadNum);
	BenFree((char**)&psValSizes, sizeof(size_t)*threadNum);
	BenFree((char**)&psCounts, sizeof(size_t)*threadNum);
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
丁香亚洲综合激情啪啪综合| 国产精品天干天干在观线| 亚洲一区二区欧美激情| 欧美综合欧美视频| 日日摸夜夜添夜夜添国产精品| 欧美疯狂性受xxxxx喷水图片| 视频一区在线播放| 久久老女人爱爱| jlzzjlzz亚洲日本少妇| 亚洲精品成人悠悠色影视| 欧美日韩午夜在线| 精品影院一区二区久久久| 国产日韩欧美综合一区| 色婷婷久久久综合中文字幕| 午夜精品免费在线| 久久久久综合网| 99久久伊人久久99| 日韩精品欧美成人高清一区二区| 精品国产成人在线影院| 91在线观看美女| 日本美女一区二区三区| 欧美激情综合在线| 欧美日本视频在线| 成人午夜在线免费| 日韩一区精品字幕| 中文字幕制服丝袜一区二区三区 | 亚洲一区二区精品视频| 欧美一卡二卡在线观看| 高清国产一区二区三区| 肉肉av福利一精品导航| 欧美国产精品v| 欧美日韩1234| 丰满亚洲少妇av| 日韩精品福利网| 国产精品高潮呻吟久久| 欧美xxxxxxxx| 在线免费观看不卡av| 国产精品一品二品| 日韩va欧美va亚洲va久久| 亚洲视频每日更新| 精品对白一区国产伦| 在线免费亚洲电影| 粉嫩绯色av一区二区在线观看| 亚洲va天堂va国产va久| 国产精品理伦片| 久久这里只精品最新地址| 欧美三级蜜桃2在线观看| 丁香天五香天堂综合| 日韩中文字幕麻豆| 一区二区国产视频| 一区二区中文字幕在线| www久久精品| 日韩小视频在线观看专区| 色女孩综合影院| jiyouzz国产精品久久| 激情丁香综合五月| 麻豆精品一区二区| 日韩专区欧美专区| 亚洲bdsm女犯bdsm网站| 亚洲自拍偷拍图区| 亚洲精品乱码久久久久久久久| 国产精品丝袜91| 国产女人aaa级久久久级| 精品国产免费一区二区三区香蕉| 欧美日韩视频在线观看一区二区三区 | 国产黄人亚洲片| 久久国产婷婷国产香蕉| 日韩激情一区二区| 三级久久三级久久| 五月天激情综合| 日韩国产在线一| 婷婷久久综合九色综合绿巨人 | 国产视频在线观看一区二区三区| 日韩午夜中文字幕| 日韩欧美一级特黄在线播放| 欧美日韩国产综合草草| 欧美日本在线一区| 777亚洲妇女| 日韩精品一区二区三区中文精品| 在线不卡中文字幕播放| 制服.丝袜.亚洲.中文.综合| 欧美三级在线视频| 欧美高清www午色夜在线视频| 777奇米成人网| 91精品国产综合久久精品性色| 欧美猛男超大videosgay| 欧美日韩日日夜夜| 欧美久久久久久久久久| 5858s免费视频成人| 91精品国产色综合久久不卡电影| 欧美一区三区二区| 精品日韩一区二区三区免费视频| 久久综合色综合88| 日本一区二区视频在线观看| 中文字幕高清一区| 亚洲精品水蜜桃| 五月婷婷综合在线| 精品夜夜嗨av一区二区三区| 国产东北露脸精品视频| av毛片久久久久**hd| 欧美色综合影院| 日韩欧美高清dvd碟片| 久久久精品免费观看| 亚洲三级电影全部在线观看高清| 依依成人精品视频| 美日韩一区二区三区| 成人一级片网址| 欧美系列在线观看| 欧美大片在线观看| 国产精品卡一卡二| 五月激情综合色| 国产盗摄视频一区二区三区| 日本福利一区二区| 久久女同精品一区二区| 亚洲女同一区二区| 麻豆精品在线看| 91极品美女在线| 2020国产精品自拍| 亚洲一区二区视频| 国产剧情在线观看一区二区| 色婷婷精品久久二区二区蜜臂av | 成人黄色一级视频| 91麻豆swag| 日韩午夜精品视频| 亚洲婷婷综合色高清在线| 丝袜a∨在线一区二区三区不卡| 国产精品1区2区| 欧美久久久一区| 日韩久久一区二区| 国模套图日韩精品一区二区| 色婷婷亚洲一区二区三区| 久久五月婷婷丁香社区| 亚洲一区二区免费视频| 99久久久无码国产精品| 亚洲精品在线免费播放| 日韩极品在线观看| 日本韩国精品在线| 中文字幕视频一区二区三区久| 久久99精品久久久久久动态图| 欧洲av在线精品| 亚洲国产精品v| 精品一区二区精品| 91精品国产综合久久国产大片| 亚洲欧美日韩久久精品| 国产suv精品一区二区三区| 日韩欧美一级片| 天天影视色香欲综合网老头| 91视频国产资源| 亚洲国产高清aⅴ视频| 久久精品噜噜噜成人av农村| 欧美日韩国产另类不卡| 一区二区三区在线视频免费 | 亚洲色图另类专区| 粉嫩av一区二区三区在线播放| 日韩一区二区三区观看| 亚洲第一福利一区| 色女孩综合影院| 亚洲精品免费在线| 99国产精品一区| 国产精品久久久久久久久免费樱桃 | 色先锋资源久久综合| 国产女人18毛片水真多成人如厕| 欧美高清视频不卡网| 综合电影一区二区三区| 国产盗摄一区二区| 久久精品人人做人人综合| 国内精品视频一区二区三区八戒| 日韩欧美123| 韩国女主播成人在线观看| 26uuu精品一区二区三区四区在线| 美腿丝袜亚洲色图| 精品乱人伦一区二区三区| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美肥妇毛茸茸| 蜜臀av性久久久久av蜜臀妖精 | 国产精品影音先锋| 久久精品在这里| 成人aaaa免费全部观看| 国产精品久久久久久久久快鸭| 99久久精品免费看| 亚洲精品免费看| 5566中文字幕一区二区电影| 蜜桃av噜噜一区| 国产欧美日韩亚州综合 | 国产精品自拍av| 久久精品亚洲精品国产欧美| 福利一区二区在线| 亚洲女同一区二区| 欧美一级理论性理论a| 国产毛片一区二区| 国产精品视频一二三| 欧美四级电影网| 久久99精品久久久| 17c精品麻豆一区二区免费| 欧美最新大片在线看| 蜜臀av在线播放一区二区三区| 日本一区二区三区dvd视频在线| 色综合婷婷久久| 美女性感视频久久| 日韩一区有码在线|