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

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

?? marsgpuemit.cu

?? GPU實現(xiàn)的MapReduce framework,對于學習并行編程和cuda平臺的編程方面有著極好的參考價值
?? CU
字號:
/**
 *This is the source code for Mars, a MapReduce framework on graphics
 *processors.
 *Author: Wenbin Fang (HKUST), Bingsheng He (HKUST)
 *Mentor: Naga K. Govindaraju (Microsoft Corp.), Qiong Luo (HKUST), Tuyong
 *Wang (Sina.com).
 *If you have any question on the code, please contact us at {saven,
 *wenbin, luo}@cse.ust.hk.
 *The copyright is held by HKUST. Mars is provided "as is" without any 
 *guarantees of any kind.
 */

//---------------------------------------------------------------------------------------------------------------------
//float type
//----------------------------------------------------------------------------------------------------------------------
__device__ void gpuEmitKeyFloat(float		key, 
				 size_t		keySize, 
				 size_t*	psKeySizes,
				 size_t*	psCounts,
				 int2*		keyValOffsets,
				 char*		interKeys,
				 int4*		interOffsetSizes,
				 size_t*	curIndex)
{
	size_t index = (blockIdx.x * blockDim.x + threadIdx.x);
	float *pKeySet = (float*)(interKeys + psKeySizes[index] + keyValOffsets[index].x);
	pKeySet[0] = key;
	keyValOffsets[index].x += keySize;
	if (curIndex[index] != 0)
	{
	interOffsetSizes[psCounts[index] + curIndex[index]].x = 
		(interOffsetSizes[psCounts[index] + curIndex[index] - 1].x + 
		 interOffsetSizes[psCounts[index] + curIndex[index] - 1].y);
	}
	interOffsetSizes[psCounts[index] + curIndex[index]].y = keySize;
}

__device__ void gpuEmitValFloat(float		val, 
				 size_t		valSize,
				 size_t*	psValSizes,
				 size_t*	psCounts,
				 int2*		keyValOffsets,
				 char*		interVals,
				 int4*		interOffsetSizes,
				 size_t*	curIndex)
{
	size_t index = (blockIdx.x * blockDim.x + threadIdx.x);

	float *pValSet = (float*)(interVals + psValSizes[index] + keyValOffsets[index].y);
	pValSet[0] = val;
	keyValOffsets[index].y += valSize;
	if (curIndex[index] != 0)
	{
	interOffsetSizes[psCounts[index] + curIndex[index]].z = 
		(interOffsetSizes[psCounts[index] + curIndex[index] - 1].z + 
		 interOffsetSizes[psCounts[index] + curIndex[index] - 1].w);
	}
	interOffsetSizes[psCounts[index] + curIndex[index]].w = valSize;
}

//---------------------------------------------------------------------------------------------------------------------
//float2 type
//----------------------------------------------------------------------------------------------------------------------
__device__ void gpuEmitKeyFloat2(float2		key, 
				 size_t		keySize, 
				 size_t*	psKeySizes,
				 size_t*	psCounts,
				 int2*		keyValOffsets,
				 char*		interKeys,
				 int4*		interOffsetSizes,
				 size_t*	curIndex)
{ 
	size_t index = (blockIdx.x * blockDim.x + threadIdx.x);
	float2 *pKeySet = (float2*)(interKeys + psKeySizes[index] + keyValOffsets[index].x);
	pKeySet[0] = key;
	keyValOffsets[index].x += keySize;
	if (curIndex[index] != 0)
	{
	interOffsetSizes[psCounts[index] + curIndex[index]].x = 
		(interOffsetSizes[psCounts[index] + curIndex[index] - 1].x + 
		 interOffsetSizes[psCounts[index] + curIndex[index] - 1].y);
	}
	interOffsetSizes[psCounts[index] + curIndex[index]].y = keySize;
}

__device__ void gpuEmitValFloat2(float2		val, 
				 size_t		valSize,
				 size_t*	psValSizes,
				 size_t*	psCounts,
				 int2*		keyValOffsets,
				 char*		interVals,
				 int4*		interOffsetSizes,
				 size_t*	curIndex)
{
	size_t index = (blockIdx.x * blockDim.x + threadIdx.x);

	float2 *pValSet = (float2*)(interVals + psValSizes[index] + keyValOffsets[index].y);
	pValSet[0] = val;
	keyValOffsets[index].y += valSize;
	if (curIndex[index] != 0)
	{
	interOffsetSizes[psCounts[index] + curIndex[index]].z = 
		(interOffsetSizes[psCounts[index] + curIndex[index] - 1].z + 
		 interOffsetSizes[psCounts[index] + curIndex[index] - 1].w);
	}
	interOffsetSizes[psCounts[index] + curIndex[index]].w = valSize;
}
 
//---------------------------------------------------------------------------------------------------------------------
//int type
//----------------------------------------------------------------------------------------------------------------------
__device__ void gpuEmitKeyInt(int		key, 
				 size_t		keySize, 
				 size_t*	psKeySizes,
				 size_t*	psCounts,
				 int2*		keyValOffsets,
				 char*		interKeys,
				 int4*		interOffsetSizes,
				 size_t*	curIndex)
{
	size_t index = (blockIdx.x * blockDim.x + threadIdx.x);
	int *pKeySet = (int*)(interKeys + psKeySizes[index] + keyValOffsets[index].x);
	pKeySet[0] = key;
	keyValOffsets[index].x += keySize;
	if (curIndex[index] != 0)
	{
	interOffsetSizes[psCounts[index] + curIndex[index]].x = 
		(interOffsetSizes[psCounts[index] + curIndex[index] - 1].x + 
		 interOffsetSizes[psCounts[index] + curIndex[index] - 1].y);
	}
	interOffsetSizes[psCounts[index] + curIndex[index]].y = keySize;
}

__device__ void gpuEmitValInt(int		val, 
				 size_t		valSize,
				 size_t*	psValSizes,
				 size_t*	psCounts,
				 int2*		keyValOffsets,
				 char*		interVals,
				 int4*		interOffsetSizes,
				 size_t*	curIndex)
{
	size_t index = (blockIdx.x * blockDim.x + threadIdx.x);

	int *pValSet = (int*)(interVals + psValSizes[index] + keyValOffsets[index].y);
	pValSet[0] = val;
	keyValOffsets[index].y += valSize;
	if (curIndex[index] != 0)
	{
	interOffsetSizes[psCounts[index] + curIndex[index]].z = 
		(interOffsetSizes[psCounts[index] + curIndex[index] - 1].z + 
		 interOffsetSizes[psCounts[index] + curIndex[index] - 1].w);
	}
	interOffsetSizes[psCounts[index] + curIndex[index]].w = valSize;
}

//---------------------------------------------------------------------------------------------------------------------
//int2 type
//----------------------------------------------------------------------------------------------------------------------
__device__ void gpuEmitKeyInt2(int2		key, 
				 size_t		keySize, 
				 size_t*	psKeySizes,
				 size_t*	psCounts,
				 int2*		keyValOffsets,
				 char*		interKeys,
				 int4*		interOffsetSizes,
				 size_t*	curIndex)
{
	size_t index = (blockIdx.x * blockDim.x + threadIdx.x);
	int2 *pKeySet = (int2*)(interKeys + psKeySizes[index] + keyValOffsets[index].x);
	pKeySet[0].x = key.x;
	pKeySet[0].y = key.y;
	keyValOffsets[index].x += keySize;
	if (curIndex[index] != 0)
	{
	interOffsetSizes[psCounts[index] + curIndex[index]].x = 
		(interOffsetSizes[psCounts[index] + curIndex[index] - 1].x + 
		 interOffsetSizes[psCounts[index] + curIndex[index] - 1].y);
	}
	interOffsetSizes[psCounts[index] + curIndex[index]].y = keySize;
}

__device__ void gpuEmitValInt2(int2		val, 
				 size_t		valSize,
				 size_t*	psValSizes,
				 size_t*	psCounts,
				 int2*		keyValOffsets,
				 char*		interVals,
				 int4*		interOffsetSizes,
				 size_t*	curIndex)
{
	size_t index = (blockIdx.x * blockDim.x + threadIdx.x);

	int2 *pValSet = (int2*)(interVals + psValSizes[index] + keyValOffsets[index].y);
	pValSet[0] = val;
	keyValOffsets[index].y += valSize;
	if (curIndex[index] != 0)
	{
	interOffsetSizes[psCounts[index] + curIndex[index]].z = 
		(interOffsetSizes[psCounts[index] + curIndex[index] - 1].z + 
		 interOffsetSizes[psCounts[index] + curIndex[index] - 1].w);
	}
	interOffsetSizes[psCounts[index] + curIndex[index]].w = valSize;
}
//---------------------------------------------------------------------------------------------------------------------
//int5 type
//----------------------------------------------------------------------------------------------------------------------
__device__ void gpuEmitKeyInt5(int5		key, 
				 size_t		keySize, 
				 size_t*	psKeySizes,
				 size_t*	psCounts,
				 int2*		keyValOffsets,
				 char*		interKeys,
				 int4*		interOffsetSizes,
				 size_t*	curIndex)
{
	size_t index = (blockIdx.x * blockDim.x + threadIdx.x);
	int5 *pKeySet = (int5*)(interKeys + psKeySizes[index] + keyValOffsets[index].x);
	pKeySet[0] = key;
	keyValOffsets[index].x += keySize;
	if (curIndex[index] != 0)
	{
	interOffsetSizes[psCounts[index] + curIndex[index]].x = 
		(interOffsetSizes[psCounts[index] + curIndex[index] - 1].x + 
		 interOffsetSizes[psCounts[index] + curIndex[index] - 1].y);
	}
	interOffsetSizes[psCounts[index] + curIndex[index]].y = keySize;
}

__device__ void gpuEmitValInt5(int5		val, 
				 size_t		valSize,
				 size_t*	psValSizes,
				 size_t*	psCounts,
				 int2*		keyValOffsets,
				 char*		interVals,
				 int4*		interOffsetSizes,
				 size_t*	curIndex)
{
	size_t index = (blockIdx.x * blockDim.x + threadIdx.x);

	int5 *pValSet = (int5*)(interVals + psValSizes[index] + keyValOffsets[index].y);
	pValSet[0] = val;
	keyValOffsets[index].y += valSize;
	if (curIndex[index] != 0)
	{
	interOffsetSizes[psCounts[index] + curIndex[index]].z = 
		(interOffsetSizes[psCounts[index] + curIndex[index] - 1].z + 
		 interOffsetSizes[psCounts[index] + curIndex[index] - 1].w);
	}
	interOffsetSizes[psCounts[index] + curIndex[index]].w = valSize;
}

//---------------------------------------------------------------------------------------------------------------------
//pointer type
//----------------------------------------------------------------------------------------------------------------------
__device__ void CopyData(char4 *des, char4 *src, size_t size)
{
	//if data size is less than 4, simply copy it
	if (size < 4)
	{
		for (int i = 0; i < size; i++)
			des[i] = src[i];
		return;
	}

	//if data size is greater than 4, use vector
	int size4 = size >> 2;
 
	char *pDes = NULL;
	char *pSrc = NULL;

	for (int i = 0; i < size4; i++)
	{
		pDes = (char*)&des[i];
		pSrc = (char*)&src[i];

		for (int j = 0; j < 4; j++)
			pDes[j] = pSrc[j];
	}

	int remainder = size & 3;

	if (remainder > 0)
	{
		pDes += 4;
		pSrc += 4;

		for (int i = 0; i < remainder; i++)
			pDes[i] = pSrc[i];	
	}
} 

__device__ void gpuEmitKeyPointer(char	*key, 
				 size_t		keySize, 
				 size_t*	psKeySizes,
				 size_t*	psCounts,
				 int2*		keyValOffsets,
				 char*		interKeys,
				 int4*		interOffsetSizes,
				 size_t*	curIndex)
{
	size_t index = (blockIdx.x * blockDim.x + threadIdx.x);
	char4 *pKeySet = (char4*)(interKeys + psKeySizes[index] + keyValOffsets[index].x);
	CopyData(pKeySet, (char4*)key, keySize);
	keyValOffsets[index].x += keySize;
	if (curIndex[index] != 0)
	{
	interOffsetSizes[psCounts[index] + curIndex[index]].x = 
		(interOffsetSizes[psCounts[index] + curIndex[index] - 1].x + 
		 interOffsetSizes[psCounts[index] + curIndex[index] - 1].y);
	}
	interOffsetSizes[psCounts[index] + curIndex[index]].y = keySize;
}

__device__ void gpuEmitValPointer(char		*val, 
				 size_t		valSize,
				 size_t*	psValSizes,
				 size_t*	psCounts,
				 int2*		keyValOffsets,
				 char*		interVals,
				 int4*		interOffsetSizes,
				 size_t*	curIndex)
{
	size_t index = (blockIdx.x * blockDim.x + threadIdx.x);
 
	char4 *pValSet = (char4*)(interVals + psValSizes[index] + keyValOffsets[index].y);
	CopyData(pValSet, (char4*)val, valSize);
	keyValOffsets[index].y += valSize;
	if (curIndex[index] != 0)
	{
	interOffsetSizes[psCounts[index] + curIndex[index]].z = 
		(interOffsetSizes[psCounts[index] + curIndex[index] - 1].z + 
		 interOffsetSizes[psCounts[index] + curIndex[index] - 1].w);
	}
	interOffsetSizes[psCounts[index] + curIndex[index]].w = valSize;
}

//---------------------------------------------------------------------------------------------------------------------
//emit key and value
//----------------------------------------------------------------------------------------------------------------------

__device__ void gpuEmitIntermediate(char*		key, 
				 char*		val, 
				 size_t		keySize, 
				 size_t		valSize,
				 size_t*	psKeySizes,
				 size_t*	psValSizes,
				 size_t*	psCounts,
				 int2*		keyValOffsets,
				 char*		interKeys,
				 char*		interVals,
				 int4*		interOffsetSizes,
				 size_t*	curIndex)
{
	size_t index = (blockIdx.x * blockDim.x + threadIdx.x);

	char4 *pKeySet = (char4*)(interKeys + psKeySizes[index] + keyValOffsets[index].x);
	char4 *pValSet = (char4*)(interVals + psValSizes[index] + keyValOffsets[index].y);

	CopyData(pKeySet, (char4*)key, keySize);
	CopyData(pValSet, (char4*)val, valSize);

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

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

	curIndex[index]++;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品综合网| 免费观看在线综合色| 91福利小视频| 欧美aⅴ一区二区三区视频| 欧美激情在线免费观看| 欧美日韩国产123区| 盗摄精品av一区二区三区| 一级日本不卡的影视| 久久影视一区二区| 欧美日韩中文国产| 不卡av在线免费观看| 久久丁香综合五月国产三级网站| 国产精品福利一区二区三区| 日韩欧美一级二级| 欧美影视一区二区三区| 成人晚上爱看视频| 六月丁香婷婷久久| 亚洲一区二区美女| 亚洲欧美一区二区三区孕妇| 久久综合视频网| 日韩电影免费在线看| 欧美成人伊人久久综合网| 天天综合日日夜夜精品| 亚洲免费av观看| 久久免费国产精品| 日韩欧美高清dvd碟片| 欧美高清视频不卡网| 91国模大尺度私拍在线视频| 成人黄动漫网站免费app| 美洲天堂一区二卡三卡四卡视频| 亚洲香肠在线观看| 亚洲欧洲精品一区二区三区不卡| 国产午夜一区二区三区| 日韩精品中文字幕在线一区| 69p69国产精品| 欧美亚洲禁片免费| 91国模大尺度私拍在线视频| 成人激情动漫在线观看| 成人免费毛片aaaaa**| 成人国产电影网| 粉嫩aⅴ一区二区三区四区| 国产盗摄视频一区二区三区| 精品一区二区影视| 另类成人小视频在线| 蜜臀av在线播放一区二区三区| 五月婷婷综合激情| 日韩精品成人一区二区在线| 亚洲18色成人| 首页国产欧美久久| 久久精品国产精品亚洲综合| 欧美a级一区二区| 奇米影视在线99精品| 美女视频免费一区| 国内精品伊人久久久久av影院| 国产一区二区主播在线| 丁香激情综合五月| 色视频一区二区| 欧美伊人精品成人久久综合97 | 国产精品成人一区二区艾草| 国产精品入口麻豆九色| 国产精品久线观看视频| 亚洲美女精品一区| 亚洲一级不卡视频| 婷婷国产在线综合| 国内精品久久久久影院色| 国产馆精品极品| 99九九99九九九视频精品| 欧美私人免费视频| 678五月天丁香亚洲综合网| 精品国产电影一区二区| 国产网站一区二区| 亚洲激情自拍偷拍| 欧美aaaaaa午夜精品| 国产91色综合久久免费分享| aaa欧美大片| 欧美日韩国产系列| 久久免费午夜影院| 日韩一区在线播放| 视频一区二区中文字幕| 极品尤物av久久免费看| 成人av网站大全| 欧美性生活久久| 久久夜色精品国产噜噜av| 亚洲欧洲国产日韩| 日韩成人一区二区| 成人动漫在线一区| 91精品国产综合久久久久久久| 久久嫩草精品久久久久| 亚洲国产精品一区二区尤物区| 国产一区三区三区| 欧美天堂一区二区三区| 国产亚洲1区2区3区| 亚洲一区二区三区国产| 国产91精品露脸国语对白| 欧美影院一区二区| 亚洲国产精品成人综合| 日韩电影在线看| 99re亚洲国产精品| 久久久精品国产99久久精品芒果| 亚洲一级二级在线| 岛国精品在线观看| 欧美一区二区久久| 亚洲永久精品国产| 成年人国产精品| 日韩精品中午字幕| 亚洲18女电影在线观看| 91视频观看免费| 久久青草国产手机看片福利盒子| 亚洲高清免费观看| 色综合一个色综合亚洲| 久久久精品国产免大香伊| 日本人妖一区二区| 色婷婷久久一区二区三区麻豆| 久久久久久毛片| 蜜臀av一区二区| 欧美人狂配大交3d怪物一区| 亚洲少妇屁股交4| 国产乱一区二区| 精品国产乱码久久久久久浪潮| 日韩国产一二三区| 欧美日韩午夜在线| 亚洲一区二区三区四区的| av电影在线观看完整版一区二区| 久久精品欧美日韩精品| 国产伦精一区二区三区| 日韩欧美高清一区| 美腿丝袜亚洲综合| 51久久夜色精品国产麻豆| 亚洲狠狠爱一区二区三区| 成av人片一区二区| 亚洲欧洲无码一区二区三区| 成人精品视频一区二区三区 | 国产欧美日韩一区二区三区在线观看| 免费在线欧美视频| 欧美一区二区三区视频免费| 午夜精品久久久久久久久久久 | 在线综合亚洲欧美在线视频| 亚洲国产日韩一区二区| 在线免费观看日本一区| 亚洲综合免费观看高清在线观看| 色94色欧美sute亚洲线路一ni| 亚洲同性gay激情无套| 91老师片黄在线观看| **欧美大码日韩| 91一区二区三区在线观看| 1024成人网| 欧美在线看片a免费观看| 亚洲国产美国国产综合一区二区| 欧美日本视频在线| 美女视频黄 久久| 欧美精品一区二区三区高清aⅴ| 精品一区二区日韩| 久久先锋影音av鲁色资源| 成人久久视频在线观看| 亚洲男女一区二区三区| 欧美日韩大陆一区二区| 日本va欧美va精品发布| 精品乱人伦小说| 国产成人精品www牛牛影视| 亚洲日本青草视频在线怡红院| 99国产精品一区| 亚洲一区电影777| 精品日韩一区二区三区免费视频| 国产乱人伦精品一区二区在线观看| 国产午夜久久久久| 99re视频精品| 日本91福利区| 久久人人97超碰com| 97久久人人超碰| 婷婷久久综合九色综合伊人色| 2023国产精华国产精品| 99re视频精品| 奇米精品一区二区三区在线观看| 国产三级精品三级| 在线视频国内自拍亚洲视频| 免费在线观看不卡| 欧美国产1区2区| 欧美影院一区二区| 国产剧情一区在线| 亚洲午夜三级在线| 久久人人爽爽爽人久久久| 日本韩国欧美三级| 国模无码大尺度一区二区三区| 亚洲日穴在线视频| 日韩一区二区免费高清| 99国产精品视频免费观看| 男男成人高潮片免费网站| 国产精品国产馆在线真实露脸| 欧美日韩激情一区二区| 国产a久久麻豆| 亚洲成人手机在线| 国产精品区一区二区三| 在线不卡中文字幕播放| av亚洲精华国产精华| 精品夜夜嗨av一区二区三区| 亚洲精品欧美激情| 久久久久国色av免费看影院| 欧美日韩免费电影| 波多野结衣中文字幕一区| 美女脱光内衣内裤视频久久网站|