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

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

?? ofdm_receiver.c.bak

?? ofdm的完整系統模型,包含信道參數,多徑模型,doppler頻移等都可以自由修改!是您做仿真的有力幫助.c語言運行速度快!
?? BAK
?? 第 1 頁 / 共 2 頁
字號:
     #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 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;
	int	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];

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本欧美一区二区在线观看| 色综合天天在线| 成人a级免费电影| 欧美色区777第一页| 国产人成一区二区三区影院| 一区二区三区在线视频观看58| 视频在线在亚洲| 色婷婷一区二区三区四区| 亚洲精品在线免费观看视频| 亚洲欧美一区二区三区国产精品| 激情欧美一区二区| 欧美三级视频在线观看| 日韩一区日韩二区| 国产综合色在线视频区| 在线综合亚洲欧美在线视频| 亚洲伦理在线免费看| 成人精品视频一区二区三区尤物| 欧美一级xxx| 日韩福利视频网| 欧美系列一区二区| 亚洲精品午夜久久久| 99免费精品在线| 中文字幕在线视频一区| 国产激情偷乱视频一区二区三区| 久久综合成人精品亚洲另类欧美| 免费的成人av| 精品福利视频一区二区三区| 美女视频免费一区| 欧美大肚乱孕交hd孕妇| 久久精品99国产国产精| 精品理论电影在线| 国产在线精品免费| 国产欧美一区二区精品久导航| 国产美女一区二区| 久久久五月婷婷| 国产不卡在线一区| 亚洲视频一区在线观看| 欧美亚洲综合另类| 午夜电影网亚洲视频| 欧美精品一二三区| 蓝色福利精品导航| 国产亚洲视频系列| 国产精品一区免费在线观看| 欧美激情中文字幕一区二区| 成人av先锋影音| 亚洲综合丝袜美腿| 制服丝袜成人动漫| 国内久久婷婷综合| 亚洲日本欧美天堂| 884aa四虎影成人精品一区| 精品在线亚洲视频| 国产精品国产三级国产| 91久久久免费一区二区| 日日嗨av一区二区三区四区| 日韩片之四级片| 从欧美一区二区三区| 一区二区三区欧美视频| 欧美一级二级三级乱码| 豆国产96在线|亚洲| 亚洲国产日韩在线一区模特| 欧美va亚洲va| 色综合色狠狠天天综合色| 日韩黄色免费网站| 国产精品久久三区| 日韩一卡二卡三卡四卡| av不卡免费电影| 美女精品自拍一二三四| 中文字幕一区二区不卡 | 亚洲一区二区av电影| 日韩一级片网站| 国产91精品入口| 日韩专区欧美专区| 国产精品污网站| 日韩一区二区三区免费看| 成人精品视频网站| 美国欧美日韩国产在线播放| 亚洲精品视频免费看| www久久精品| 欧美亚洲综合一区| 成人av电影在线观看| 蜜臀va亚洲va欧美va天堂 | 91色乱码一区二区三区| 日韩精品欧美精品| 成人免费在线视频| 久久久久久久久久久99999| 在线视频观看一区| 成人黄色av电影| 精品一区二区在线看| 亚洲v日本v欧美v久久精品| 国产精品欧美久久久久无广告| 欧美一区在线视频| 欧美午夜一区二区| 色94色欧美sute亚洲线路一ni| 国产另类ts人妖一区二区| 日韩精品免费专区| 亚洲不卡在线观看| 亚洲一区二区三区不卡国产欧美| 国产精品国产三级国产aⅴ原创| xfplay精品久久| 日韩一级视频免费观看在线| 在线电影一区二区三区| 欧美视频在线播放| 欧美丝袜丝交足nylons| 欧洲在线/亚洲| 色婷婷av一区二区三区软件| 99精品欧美一区二区三区小说| 国产精品一级黄| 精品一区二区三区在线播放视频| 蜜桃精品视频在线观看| 男女男精品视频网| 久久精品99久久久| 麻豆一区二区三| 国产乱子轮精品视频| 国产乱淫av一区二区三区| 国内成人免费视频| 韩国三级中文字幕hd久久精品| 久久精品久久精品| 国产美女精品一区二区三区| 国产乱国产乱300精品| 国产成人夜色高潮福利影视| 国产91精品在线观看| 成人动漫一区二区在线| 成人一级片网址| 91日韩在线专区| 欧美伦理电影网| 精品福利一区二区三区| 国产午夜精品理论片a级大结局| 日本一区二区三区电影| 亚洲天天做日日做天天谢日日欢| 国产精品久久久久久久岛一牛影视| 亚洲欧洲国产日本综合| 亚洲一区二区三区激情| 欧美96一区二区免费视频| 精品亚洲国产成人av制服丝袜| 国产精品自产自拍| 色一情一乱一乱一91av| 欧美日韩国产色站一区二区三区| 在线91免费看| 国产性做久久久久久| 亚洲精品成a人| 免费精品视频在线| 不卡的av在线播放| 欧美日韩国产123区| 久久精品一二三| 亚洲久草在线视频| 老司机免费视频一区二区三区| 成人午夜视频在线观看| 欧美综合在线视频| 久久嫩草精品久久久精品| 亚洲天堂网中文字| 男人的天堂久久精品| 91欧美激情一区二区三区成人| 在线成人av影院| 成人欧美一区二区三区1314| 欧美a级理论片| 99re6这里只有精品视频在线观看| 制服丝袜亚洲精品中文字幕| 中文字幕成人在线观看| 日本成人在线一区| 99久久久精品免费观看国产蜜| 欧美一区二区三区在线电影| 中文字幕在线不卡| 国产一区二区三区美女| 欧日韩精品视频| 欧美韩国日本一区| 美女视频黄频大全不卡视频在线播放| 色综合一区二区三区| 精品国免费一区二区三区| 亚洲一区二区影院| 成人黄色网址在线观看| 亚洲精品在线免费播放| 日本在线播放一区二区三区| 91首页免费视频| 国产精品色婷婷久久58| 激情五月播播久久久精品| 欧美巨大另类极品videosbest | 奇米一区二区三区av| 91亚洲精品久久久蜜桃网站| 久久精品免视看| 久久精品国产99久久6| 欧美精品xxxxbbbb| 亚洲一本大道在线| 欧洲av在线精品| 日韩美女精品在线| 99久久99久久精品免费观看| 国产午夜亚洲精品午夜鲁丝片| 美女网站视频久久| 日韩精品一区二区三区视频| 亚洲第一在线综合网站| 色94色欧美sute亚洲13| 中文字幕制服丝袜成人av| hitomi一区二区三区精品| 欧美韩日一区二区三区| 成人激情免费视频| 国产精品伦一区| 色婷婷综合视频在线观看| 亚洲欧美一区二区三区久本道91| 99久久er热在这里只有精品15 | 色综合久久中文综合久久97| 欧美国产综合色视频|