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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? marsgpuemit.cu

?? GPU實現的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一区二区三区免费野_久草精品视频
色综合天天做天天爱| 韩国视频一区二区| 色88888久久久久久影院按摩| 日本一区二区免费在线| 国产成人免费av在线| 欧美激情一区二区三区蜜桃视频| 国产成人av电影| 国产精品福利一区| 欧美在线色视频| 亚洲国产精品久久一线不卡| 在线播放一区二区三区| 另类综合日韩欧美亚洲| 国产亚洲精久久久久久| 色综合色综合色综合| 亚洲国产一区二区三区青草影视| 在线不卡免费欧美| 国产麻豆成人精品| 亚洲色图一区二区| 91精品国产综合久久国产大片| 麻豆视频观看网址久久| 国产精品免费人成网站| 精品视频1区2区| 国产一区二区在线看| 亚洲图片激情小说| 欧美高清激情brazzers| 国产福利精品导航| 亚洲成人动漫在线免费观看| 精品国产污网站| 色先锋久久av资源部| 久久国产乱子精品免费女| 国产精品丝袜久久久久久app| 欧美视频在线一区二区三区 | 一区二区免费看| 欧美一区国产二区| jlzzjlzz欧美大全| 蜜臀va亚洲va欧美va天堂| 中文字幕av一区二区三区| 欧美精品777| 97se狠狠狠综合亚洲狠狠| 美女一区二区视频| 一区二区久久久久| 国产午夜精品一区二区三区四区| 在线看不卡av| 成人午夜激情片| 日韩影院免费视频| 综合色中文字幕| 26uuu欧美| 欧美精品久久99| 91传媒视频在线播放| 国产aⅴ综合色| 久久99精品国产麻豆婷婷洗澡| 亚洲精品中文字幕在线观看| 国产亚洲一区字幕| 日韩三级视频在线观看| 欧美日韩在线观看一区二区 | 欧美精品粉嫩高潮一区二区| 成人h动漫精品一区二区| 国产真实乱偷精品视频免| 日韩精品一级二级| 亚洲国产欧美在线人成| 亚洲欧洲成人自拍| 久久精品男人天堂av| 欧美一级理论性理论a| 色婷婷综合中文久久一本| 成人午夜av电影| 国产一区二区精品久久99| 青娱乐精品视频| 日本成人在线不卡视频| 午夜av电影一区| 亚洲国产一区二区三区| 亚洲国产欧美在线| 亚洲高清在线精品| 亚洲永久免费视频| 一区二区三区蜜桃网| 一区二区三区四区不卡视频| 亚洲天堂中文字幕| 亚洲人成网站色在线观看| 国产精品久久久久影视| 国产精品免费网站在线观看| 国产精品色一区二区三区| 国产午夜精品一区二区三区嫩草| 欧美成人精精品一区二区频| 日韩三级高清在线| 久久亚洲综合av| 欧美国产日韩亚洲一区| 欧美高清在线精品一区| 国产精品久久久久久久久免费桃花| 国产精品色在线| 亚洲精品国产无套在线观| 亚洲女人的天堂| 香蕉影视欧美成人| 奇米四色…亚洲| 国内精品伊人久久久久av一坑| 国产一区二区三区四区在线观看| 国产成人在线视频播放| 波多野结衣在线一区| 色综合久久天天| 宅男噜噜噜66一区二区66| 日韩午夜小视频| 国产目拍亚洲精品99久久精品| 中文字幕日韩欧美一区二区三区| 日韩毛片精品高清免费| 亚洲高清中文字幕| 国产综合色产在线精品| 国产mv日韩mv欧美| 精品视频一区三区九区| xfplay精品久久| 自拍偷拍亚洲欧美日韩| 午夜精品福利一区二区蜜股av| 另类小说综合欧美亚洲| 99精品国产视频| 欧美一区二区国产| 中文字幕电影一区| 五月激情综合婷婷| 国产精品1区2区| 欧美网站一区二区| 久久综合色婷婷| 亚洲黄色性网站| 国产在线精品免费| 欧美伊人久久久久久久久影院| 精品国产精品网麻豆系列| 日韩理论在线观看| 国产一区二区在线免费观看| 91福利国产成人精品照片| 久久久久久久久免费| 亚洲123区在线观看| 成人蜜臀av电影| 欧美一区二区三区在线电影| 国产精品高清亚洲| 久久精品72免费观看| 色综合天天天天做夜夜夜夜做| 日韩精品一区二区在线| 亚洲综合色噜噜狠狠| 国产·精品毛片| 欧美刺激午夜性久久久久久久| 一区二区三区四区视频精品免费| 国产东北露脸精品视频| 日韩欧美第一区| 亚洲va国产va欧美va观看| 94-欧美-setu| 欧美激情在线观看视频免费| 久久av老司机精品网站导航| 欧美色老头old∨ideo| **性色生活片久久毛片| 蜜桃传媒麻豆第一区在线观看| 99re热这里只有精品免费视频| 91麻豆精品国产91久久久更新时间 | 国产乱色国产精品免费视频| 在线精品视频一区二区| 成人欧美一区二区三区小说| 日本中文字幕一区二区有限公司| 91丝袜高跟美女视频| 精品国产一二三区| 免费一级欧美片在线观看| 在线观看91精品国产入口| 久久美女艺术照精彩视频福利播放| 亚洲码国产岛国毛片在线| 国产精品123区| 日韩欧美成人一区二区| 亚洲国产欧美在线| 一本一本久久a久久精品综合麻豆| xfplay精品久久| 日本最新不卡在线| 高清国产一区二区| 欧美丝袜丝交足nylons| 亚洲另类色综合网站| 99久久国产综合精品麻豆| 久久久午夜精品理论片中文字幕| 天堂影院一区二区| 911精品产国品一二三产区 | 国产欧美中文在线| 狠狠色丁香婷婷综合久久片| 欧美中文一区二区三区| 亚洲小少妇裸体bbw| 色婷婷亚洲综合| 亚洲色图在线视频| 成人免费毛片嘿嘿连载视频| 国产精品国产精品国产专区不片| 国产一区二区91| 精品国产免费久久| 久久99久久久久久久久久久| 3d动漫精品啪啪一区二区竹菊| 亚洲在线中文字幕| 欧洲在线/亚洲| 麻豆精品久久久| 精品国产三级电影在线观看| 国产专区欧美精品| 精品毛片乱码1区2区3区| 国产成人亚洲综合色影视| 久久久美女艺术照精彩视频福利播放| 奇米影视7777精品一区二区| 欧美性大战久久| 美国欧美日韩国产在线播放| 51精品视频一区二区三区| 日本欧美久久久久免费播放网| 在线亚洲+欧美+日本专区| 日本免费在线视频不卡一不卡二| 欧美电影免费观看高清完整版在线 | 欧美精品一区二区蜜臀亚洲| 黄页视频在线91|