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

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

?? ofdm_receiver.c

?? ofdm的完整系統(tǒng)模型,包含信道參數(shù),多徑模型,doppler頻移等都可以自由修改!是您做仿真的有力幫助.c語言運(yùn)行速度快!
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
                  #include "cgs.h"
#include "ofdm_system.h"
#include "fft.h"
//#include "fft_c.h"

/* function : ofdm frame de_package */
void	initial_matrix(row,column,matrix)
int	row;
int	column;
Complex *matrix;
{
	int	i,j;
	for (i = 0;i < row ; i++){
		for (j = 0;j < column ; j++){
			matrix[i*column+j].real = 0;
			matrix[i*column+j].imag = 0;
		}
	}
}

void	initial_vector(column, vector)
int column;
double *vector;
{
	int i;
	for (i = 0; i < column ; i++){
			vector[i] = 0;
	}
}
void ofdm_depak(ofdm_buffer, data_buffer, pilot_buffer)
Complex *ofdm_buffer;
Complex *data_buffer;
Complex *pilot_buffer;
{
	int i, d_idx, p_idx;
	double 	xreal[SUBCARRIERS], ximag[SUBCARRIERS], 
			yreal[SUBCARRIERS], yimag[SUBCARRIERS];
	
	/* remove cp */
	for (i = 0; i < SUBCARRIERS; i++) {
		xreal[i] = ofdm_buffer[CP_LENGTH+i].real;
		ximag[i] = ofdm_buffer[CP_LENGTH+i].imag;
	}
	
	/* perform fft */
	fft(SUBCARRIERS, xreal, ximag, yreal, yimag);
	
	/* seperate data and pilot */
	d_idx = 0;
	for (i = 0; i < SUBCARRIERS; i++) {
		if ((i-PILOT_PHASE) % PILOT_GAP ==  0) {
			p_idx = (int) (i-PILOT_PHASE) / PILOT_GAP;
			pilot_buffer[p_idx].real = yreal[i];
			pilot_buffer[p_idx].imag = yimag[i];
		}
		else {
			if (i >= FREQ_GUARD_LEN && i < (SUBCARRIERS-FREQ_GUARD_LEN)) {
				data_buffer[d_idx].real = yreal[i];
				data_buffer[d_idx].imag = yimag[i];
				d_idx++;
			}
		}
	}
	
	/* demodulate pilot */
	for (i = 0; i < PILOT_LENGTH; i++) {
		pilot_buffer[i] = c_mul(pilot_buffer[i], NormPilot[i]);
		//pilot_buffer[i] = c_dvd(pilot_buffer[i], cVpilot[i]);
	}
	
}



/* function : frequency response --> impulse response */
void freq2tau(pilot_buf)
Complex *pilot_buf;
{
	int i;
	double 	xreal[PILOT_LENGTH], ximag[PILOT_LENGTH], 
			yreal[PILOT_LENGTH], yimag[PILOT_LENGTH];
	
	for (i = 0; i < PILOT_LENGTH; i++) {
		xreal[i] = pilot_buf[i].real;
		ximag[i] = pilot_buf[i].imag;
	}
	ifft(PILOT_LENGTH, xreal, ximag, yreal, yimag);

	for (i = 0; i < PILOT_LENGTH; i++) {
		pilot_buf[i].real = yreal[i];
		pilot_buf[i].imag = yimag[i];
	}

}



/* function : MST algorithm */
void channel_mst(pilot_rev, pilot_proc)
Complex *pilot_rev;
Complex *pilot_proc;
{
	int i, j, max_idx;
	double max_value;
	int tap_idx[MST_TAP_LEN];
	double tap_power[PILOT_LENGTH];
	
	/* caculate each tap's power */
	for (i = 0; i < PILOT_LENGTH; i++) {
		tap_power[i] = pilot_rev[i].real * pilot_rev[i].real + pilot_rev[i].imag * pilot_rev[i].imag;
	}

	/* search for most significant taps */
	for (j = 0; j < MST_TAP_LEN; j++) {

		max_idx = 0;
		max_value = tap_power[max_idx];
		for (i = 1; i < PILOT_LENGTH; i++) { 
			if (tap_power[i] > max_value) {
				max_value = tap_power[i];
				max_idx = i;
			}
		}
		tap_idx[j] = max_idx;
		tap_power[max_idx] = 0;
	}
	
	/* zero force at none MST */
	for (i = 0; i < PILOT_LENGTH; i++) {
		pilot_proc[i].real = 0;
		pilot_proc[i].imag = 0;
	}
	for (j = 0; j < MST_TAP_LEN; j++) {
		pilot_proc[tap_idx[j]] = pilot_rev[tap_idx[j]];
	}

}



/* function : MST + fd_filter algorithm */
void channel_filt(pilot_rev, pilot_proc1, pilot_proc2, win_inc)
Complex *pilot_rev;
Complex *pilot_proc1;
Complex *pilot_proc2;
double win_inc;
{
	int i, j, k, max_idx, tap_count;
	int tap_idx[PILOT_LENGTH];
	double tap_power[PILOT_LENGTH];
	double tot_power, thresh_v, max_value;
	double enta_1, enta_2, enta_3;
	double pow_t, pow_s;

	int win_len, mst_method;
	double win_pow;
	double omiga_pow[1024];

	double 	xreal[1024], ximag[1024], 
			yreal[1024], yimag[1024];

	mst_method = 2;
	pow_t = 0;
	enta_1 = 1.0e-3;

	/* caculate each tap's avarage power */
	for (j = 0; j < PILOT_LENGTH; j++) {
	
		tap_power[j] = 0;
		for (i = 0; i < 1024; i++) {
			tap_power[j] = tap_power[j] + pilot_rev[j+i*PILOT_LENGTH].real * pilot_rev[j+i*PILOT_LENGTH].real + pilot_rev[j+i*PILOT_LENGTH].imag * pilot_rev[j+i*PILOT_LENGTH].imag;
		}
		tap_power[j] = tap_power[j] / 1024;
		pow_t = pow_t + tap_power[j];
	}
	
	if (mst_method == 1) {

		/* MST search according to avarage power */
		thresh_v = pow_t * enta_1;
		tap_count = 0;
		for (j = 0; j < PILOT_LENGTH; j++) {
			if (tap_power[j] >= thresh_v) {
	
				tap_idx[tap_count] = j;
				tap_count++;

				for (i = 0; i < 1024; i++) {
					pilot_proc1[j+i*PILOT_LENGTH] = pilot_rev[j+i*PILOT_LENGTH];
				}
			}
			else {
				for (i = 0; i < 1024; i++) {
					pilot_proc1[j+i*PILOT_LENGTH].real = 0;
					pilot_proc1[j+i*PILOT_LENGTH].imag = 0;
	
					pilot_proc2[j+i*PILOT_LENGTH].real = 0;
					pilot_proc2[j+i*PILOT_LENGTH].imag = 0;
				}
			}
		}
		
		/* search for max point */
		max_idx = tap_idx[0];
		max_value = tap_power[max_idx];
		for (j = 1; j < tap_count; j++) {
			if (tap_power[tap_idx[j]] > max_value) {
				max_idx = tap_idx[j];
				max_value = tap_power[max_idx];
			}
		}		
	}
	else {
		
		/* MST search according to tap number */
		tap_count = MST_TAP_LEN;
		
		/* search for most significant taps */
		pow_s = 0;
		for (j = 0; j < tap_count; j++) {
	
			max_idx = 0;
			max_value = tap_power[max_idx];
			for (i = 1; i < PILOT_LENGTH; i++) { 
				if (tap_power[i] > max_value) {
					max_value = tap_power[i];
					max_idx = i;
				}
			}
			pow_s = pow_s + tap_power[max_idx];		// signal power
			tap_idx[j] = max_idx;
			tap_power[max_idx] = 0;
		}
		max_idx = tap_idx[0];

		/* zero force at none MST */
		for (j = 0; j < PILOT_LENGTH; j++) {
			
			for (i = 0; i < 1024; i++) {
				pilot_proc1[j+i*PILOT_LENGTH].real = 0;
				pilot_proc1[j+i*PILOT_LENGTH].imag = 0;
				
				pilot_proc2[j+i*PILOT_LENGTH].real = 0;
				pilot_proc2[j+i*PILOT_LENGTH].imag = 0;
			}
		}
		
		for (j = 0; j < tap_count; j++) {
			
			for (i = 0; i < 1024; i++) {
				pilot_proc1[tap_idx[j]+i*PILOT_LENGTH] = pilot_rev[tap_idx[j]+i*PILOT_LENGTH];
			}
		}
	}

	/* fd spread domain process */
	/* step1: estimate fd spread */
	for (i = 0; i < 1024; i++) {
		xreal[i] = pilot_proc1[i*PILOT_LENGTH+max_idx].real;
		ximag[i] = pilot_proc1[i*PILOT_LENGTH+max_idx].imag;
	}

	fft(1024, xreal, ximag, yreal, yimag);
	tot_power = 0;
	for (i = 0; i < 1024; i++) {
		omiga_pow[i] = yreal[i] * yreal[i] + yimag[i] * yimag[i];
		tot_power = tot_power + omiga_pow[i];
	}

	/* estimate window length */
	enta_2 = FD_FILT_ENTA;
	win_len = 1;
	win_pow = omiga_pow[0];
	for (i = 1; i <= win_len; i++) {
		win_pow = win_pow + omiga_pow[i] + omiga_pow[1024-i];
	}

	while(win_pow < enta_2*tot_power) {
		win_len++;
		win_pow = win_pow + omiga_pow[win_len] + omiga_pow[1024-win_len];
	}
//	win_len = win_len + win_inc;

	/* estimate snr */
	enta_3 = 10*log10(pow_s/(pow_t - pow_s)) - 2;

	/* caculate window length */
	win_len = win_len + 10 + (int) floor(enta_3*win_inc);

	for (j = 0; j < tap_count; j++) { 
		
		k = tap_idx[j];
		for (i = 0; i < 1024; i++) {
			xreal[i] = pilot_proc1[i*PILOT_LENGTH+k].real;
			ximag[i] = pilot_proc1[i*PILOT_LENGTH+k].imag;
		}

		fft(1024, xreal, ximag, yreal, yimag);

		for (i = win_len+1; i <= 1024-win_len-1; i++) {
			yreal[i] = 0;
			yimag[i] = 0;
		}
		ifft(1024, yreal, yimag, xreal, ximag);

		for (i = 0; i < 1024; i++) {
			pilot_proc2[i*PILOT_LENGTH+k].real = xreal[i];
			pilot_proc2[i*PILOT_LENGTH+k].imag = ximag[i];
		}

	}

	/* log each tap's avarage power to file 
	{
		FILE *log_fp;
		
		log_fp = fopen(LOG_TAP_STP2, "a+");
		
		fprintf(log_fp, "%d\n", win_len);

		fclose(log_fp);
	}*/
}

/*function : channel transmission */
void	channel_trans(pilot_rev, pilot_proc)
Complex *pilot_rev; 
Complex *pilot_proc;
{
	int	i,j;
	int	tmp_ind;
	for (i = 0; i < 1024; i++){
		tmp_ind = i - fmod(i,inter_K);
		for (j = 0; j < PILOT_LENGTH; j++){
			pilot_proc[i*PILOT_LENGTH + j].real = pilot_rev[tmp_ind*PILOT_LENGTH + j].real;
			pilot_proc[i*PILOT_LENGTH + j].imag = pilot_rev[tmp_ind*PILOT_LENGTH + j].imag;
		}
	}
}
/*function : sub-block estimation algorithm*/
void	sub_esti_poly(pilot_rev, pilot_proc1, pilot_proc2)
Complex *pilot_rev;
Complex *pilot_proc1;
Complex *pilot_proc2;
{
	int i, j, k, max_idx, tap_count;
	int	tmp_i,tmp_j,tmp_k;
	double	tmp_real,tmp_imag;
	int tap_idx[PILOT_LENGTH];
	double tap_power[PILOT_LENGTH];
	double tot_power, thresh_v, max_value;
	double enta_1, enta_2, enta_3;
	double pow_t, pow_s;
	int win_len, mst_method;
	double win_pow;
	double omiga_pow[repeat_M];

	double 	xreal[repeat_M], ximag[repeat_M], 
			yreal[repeat_M], yimag[repeat_M];
	
	double	multi_matrix[poly_g+1][repeat_M];
	Complex	factor_matrix[poly_g+1][PILOT_LENGTH];
	double	recov_matrix[sub_clk_size][poly_g+1];
	double	tmp_v;
	int	tmp_clk_size = sub_clk_size;
	FILE	*fp;
	char	* filename;
	float	tmp_fv;
	mst_method = 2;
	pow_t = 0;
	enta_1 = 1.0e-3;

	/* caculate each tap's avarage power */
	for (j = 0; j < PILOT_LENGTH; j++) {
	
		tap_power[j] = 0;
		for (i = 0; i < repeat_M; i++) {
			tap_power[j] = tap_power[j] + pilot_rev[j+i*inter_K*PILOT_LENGTH].real * pilot_rev[j+i*inter_K*PILOT_LENGTH].real + pilot_rev[j+i*inter_K*PILOT_LENGTH].imag * pilot_rev[j+i*inter_K*PILOT_LENGTH].imag;
		}
		tap_power[j] = tap_power[j] / repeat_M;
		pow_t = pow_t + tap_power[j];
	}
	
	if (mst_method == 1) {

		for (j = 0; j < PILOT_LENGTH; j++) {
			
			for (i = 0; i < sub_clk_size; i++) {
				pilot_proc1[j+i*PILOT_LENGTH].real = 0;
				pilot_proc1[j+i*PILOT_LENGTH].imag = 0;
				
				pilot_proc2[j+i*PILOT_LENGTH].real = 0;
				pilot_proc2[j+i*PILOT_LENGTH].imag = 0;
			}
		}
		/* MST search according to avarage power */
		thresh_v = pow_t * enta_1;
		tap_count = 0;
		for (j = 0; j < PILOT_LENGTH; j++) {

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人黄色av网站在线| 91久久香蕉国产日韩欧美9色| 日本一二三四高清不卡| 欧美特级限制片免费在线观看| 精品一区二区三区日韩| 亚洲精品国产一区二区三区四区在线| 欧美不卡一二三| 国产大片一区二区| 日韩黄色免费网站| 中文字幕在线观看不卡| 欧美一区二区三区在线| av在线免费不卡| 日本不卡在线视频| 亚洲色图在线播放| 精品久久久久久久人人人人传媒 | 91精品国产一区二区三区蜜臀| 国产毛片精品视频| 亚洲国产你懂的| 国产区在线观看成人精品| 在线成人午夜影院| 99久久精品一区二区| 久久精品av麻豆的观看方式| 亚洲精品视频在线| 国产性天天综合网| 欧美xxxx在线观看| 91精品免费在线| 色诱视频网站一区| 大桥未久av一区二区三区中文| 天使萌一区二区三区免费观看| 国产精品不卡一区| 久久久99久久| 日韩美女一区二区三区| 欧美性高清videossexo| aaa亚洲精品| 国产精品99久久久| 毛片av一区二区| 日韩有码一区二区三区| 亚洲美女一区二区三区| 欧美韩日一区二区三区| 久久精品夜色噜噜亚洲a∨| 9191成人精品久久| 欧美日韩一级二级三级| 欧美中文字幕一二三区视频| 99久久精品国产毛片| 成人午夜免费av| 国产不卡视频一区二区三区| 精彩视频一区二区| 免费成人av在线播放| 青青草国产成人99久久| 日韩在线观看一区二区| 日韩va欧美va亚洲va久久| 午夜视频在线观看一区| 亚洲aaa精品| 亚洲国产精品自拍| 亚洲午夜免费福利视频| 一区二区不卡在线播放 | 成人性视频网站| 国产盗摄精品一区二区三区在线| 国内久久婷婷综合| 国产一区二区三区精品欧美日韩一区二区三区 | 亚洲欧美一区二区三区极速播放| 国产日韩欧美激情| 国产亚洲美州欧州综合国| 精品日韩在线观看| 日韩三级视频在线看| 日韩一区二区三区视频| 欧美草草影院在线视频| 久久久亚洲精华液精华液精华液| 久久精品人人做人人综合| 国产女人18毛片水真多成人如厕| 国产清纯美女被跳蛋高潮一区二区久久w| 日韩一区和二区| 欧美电视剧免费观看| 欧美成人猛片aaaaaaa| 国产午夜精品一区二区三区视频| 欧美精品一区二区在线观看| 国产午夜精品久久久久久久| 日韩一区日韩二区| 视频一区二区三区在线| 久久se精品一区二区| www.性欧美| 欧美日韩视频在线第一区| 在线电影欧美成精品| 国产亚洲精品资源在线26u| 亚洲欧美成aⅴ人在线观看| 中文字幕亚洲成人| 亚洲国产精品一区二区www在线| 视频一区二区国产| 国产91精品一区二区麻豆亚洲| 色噜噜狠狠色综合欧洲selulu| 8v天堂国产在线一区二区| 91精品国产综合久久久久久 | 亚洲第一成人在线| 久久er精品视频| av亚洲精华国产精华| 欧美久久一二区| 欧美国产综合一区二区| 性做久久久久久久免费看| 5月丁香婷婷综合| 久久精品视频在线免费观看| 一区二区三区四区不卡在线| 精品一二三四区| 在线看一区二区| 欧美高清在线精品一区| 五月综合激情日本mⅴ| 韩国av一区二区| 欧美日韩精品免费观看视频| 国产日韩欧美精品一区| 日本欧美大码aⅴ在线播放| 91在线丨porny丨国产| 久久综合999| 日韩av午夜在线观看| 99re在线视频这里只有精品| 欧美日韩黄色一区二区| 中文字幕va一区二区三区| 免费高清在线视频一区·| 欧美日韩在线播放三区四区| 日韩欧美资源站| 亚洲va中文字幕| 91麻豆福利精品推荐| 国产午夜亚洲精品理论片色戒| 亚洲欧美激情插| 国产精品一品二品| 亚洲精品一区二区三区蜜桃下载| 亚洲国产精品久久久久秋霞影院 | 91麻豆免费视频| 国产亚洲精品中文字幕| 精品在线一区二区三区| 欧美久久久久免费| 亚洲视频一二三区| jlzzjlzz亚洲日本少妇| 久久先锋资源网| 久久国产精品免费| 欧美一区二区日韩| 日一区二区三区| 欧美日韩精品一区二区三区四区| 亚洲视频一区二区免费在线观看| 午夜精品影院在线观看| 国产成人综合视频| 精品伦理精品一区| 麻豆精品一区二区| 日韩欧美中文字幕制服| 五月天亚洲精品| 欧美三区在线视频| 一个色综合网站| 91色|porny| 成人欧美一区二区三区1314| 成人av电影在线观看| 欧美激情一二三区| 成人激情图片网| 中文字幕欧美日韩一区| 高清成人在线观看| 中文乱码免费一区二区| 成人激情视频网站| 亚洲欧洲韩国日本视频 | 色综合色综合色综合色综合色综合| 国产女主播一区| 懂色av中文字幕一区二区三区 | 奇米888四色在线精品| 欧美精品乱码久久久久久按摩| 调教+趴+乳夹+国产+精品| 884aa四虎影成人精品一区| 免费观看日韩av| 26uuu色噜噜精品一区二区| 国产伦精品一区二区三区免费| 久久精品亚洲麻豆av一区二区| 丁香亚洲综合激情啪啪综合| 国产精品嫩草99a| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 成人午夜碰碰视频| 亚洲柠檬福利资源导航| 欧美日韩高清在线| 美日韩一区二区| 国产三区在线成人av| 成人av资源站| 一区二区三区视频在线看| 制服丝袜成人动漫| 国产老肥熟一区二区三区| 国产精品日产欧美久久久久| 日本韩国精品在线| 爽爽淫人综合网网站| 26uuu色噜噜精品一区| 成人av片在线观看| 亚洲香肠在线观看| 久久综合给合久久狠狠狠97色69| 成人精品亚洲人成在线| 亚洲国产三级在线| 精品成人佐山爱一区二区| 99精品欧美一区二区三区综合在线| 亚洲国产精品一区二区久久恐怖片| 精品久久久久久久久久久久久久久久久| 国产电影一区二区三区| 亚洲国产综合视频在线观看| 午夜精品久久久久久久蜜桃app| 日韩午夜激情av| 91美女在线观看| 日本欧美一区二区三区乱码| 日韩欧美中文字幕公布| 欧亚一区二区三区| 国产成人欧美日韩在线电影|