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

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

?? ofdm_bench.c.bak

?? ofdm的完整系統模型,包含信道參數,多徑模型,doppler頻移等都可以自由修改!是您做仿真的有力幫助.c語言運行速度快!
?? BAK
字號:
#include <stdlib.h>
#include <stdio.h>
#include <math.h>
#include <ctype.h>
#include <string.h>

#include "cgs.h"
#include "ofdm_system.h"

Ovector			Data_Buff;
//RayParams		ray_params_1[12];
RayParams		ray_params_1;
GauParams		gauss_params_1;
FreqParams		freq_params_1;
double			Noise_Sigma;
double			Ch_Norm_Factor;

void main( )
{
	int i, j, loop_idx, frm_num, blk_num;
	static long rand_bitseed = 100;
	
	float tmp_real, tmp_imag;
	FILE *fp_true;

	static Complex ofdm_buffer_tx[SUBCARRIERS+CP_LENGTH];
	static Complex ofdm_buffer_rx[SUBCARRIERS+CP_LENGTH];
	
	static Complex pilot_buf1[1024][PILOT_LENGTH];			// noise free
	static Complex pilot_buf2[1024][PILOT_LENGTH];			// LS 
	static Complex pilot_buf3[1024][PILOT_LENGTH];			// MST
	static Complex pilot_buf4[1024][PILOT_LENGTH];			// FILT_STP1
	static Complex pilot_buf5[1024][PILOT_LENGTH];			// FILT_STP2

	static Complex pilot_poly_buf2[1024][PILOT_LENGTH];			// LS 
	static Complex pilot_poly_buf3[1024][PILOT_LENGTH];			// MST
	static Complex pilot_poly_buf4[1024][PILOT_LENGTH];			// poly_step1
	static Complex pilot_poly_buf5[1024][PILOT_LENGTH];			// poly_step2

	static Complex data_buf1[1024][DATA_SUBC_LEN];			// original data
	static Complex data_buf2[1024][DATA_SUBC_LEN];			// with noise

	int	snr_idx;
	double SN_Ratio;
		double	mse_sym_2[1024];	double	mse_sym_3[1024];
	double	mse_sym_4[1024];	double	mse_sym_5[1024];	double	mse_blk_2[300];	double	mse_blk_3[300];	double	mse_blk_4[300];	double	mse_blk_5[300];	double	mse_2[30];	double	mse_3[30];	double	mse_4[30];	double	mse_5[30];		double	ber_sym_1[1024];	double	ber_sym_2[1024];	double	ber_sym_3[1024];	double	ber_sym_4[1024];	double	ber_sym_5[1024];	double	ber_blk_1[300];	double	ber_blk_2[300];	double	ber_blk_3[300];	double	ber_blk_4[300];	double	ber_blk_5[300];		double	ber_1[30];	double	ber_2[30];	double	ber_3[30];	double	ber_4[30];	double	ber_5[30];
	
	initial_matrix(1024,PILOT_LENGTH,pilot_poly_buf2[0]);
	initial_matrix(1024,PILOT_LENGTH,pilot_poly_buf3[0]);
	initial_matrix(1024,PILOT_LENGTH,pilot_poly_buf4[0]);
	initial_matrix(1024,PILOT_LENGTH,pilot_poly_buf5[0]);
//	write_file(target2_file, pilot_poly_buf5[0], 1024, PILOT_LENGTH);
	// [0 : 5 : 30] dB
	for (snr_idx = 0; snr_idx < 1; snr_idx++) {	
		
		/* initial SNR */
		SN_Ratio = SNR_INI + snr_idx * 5.0;
		SN_Ratio = 100;
		/* initial channel */
		initial_sel(&ray_params_1);
		initial_gauss(&gauss_params_1, CHANNEL_DELAY, SIGNAL_POWER, SN_Ratio);
		
		blk_num = 1;
		fp_true = fopen(LOG_TAP_TRUE, "r");
	
		for (loop_idx = 0; loop_idx < blk_num; loop_idx++) {
			printf("fd=%dHz, SNR=%gdB, loop(%d): %d\n", CH_DOPPLER_FREQ, SN_Ratio, blk_num, loop_idx);
	
			for (frm_num = 0; frm_num < 1024; frm_num++) {
	
				ofdm_pakgen(&rand_bitseed, ofdm_buffer_tx, data_buf1[frm_num]);
	
				for (i = 0; i < SUBCARRIERS+CP_LENGTH; i++) {
					ofdm_buffer_rx[i] = rayleigh_sel(ofdm_buffer_tx[i], &ray_params_1);
					ofdm_buffer_rx[i] = awgn_channel(ofdm_buffer_rx[i], &gauss_params_1);
				}
				ofdm_depak(ofdm_buffer_rx, data_buf2[frm_num], pilot_buf2[frm_num]);
			}
			
			/* convert to delay spread domain */
			for (frm_num = 0; frm_num < 1024; frm_num++) {
				freq2tau(pilot_buf2[frm_num]);
			}
//	
//			/* MST channel estimation */
//			for (frm_num = 0; frm_num < 1024; frm_num++) {
//				channel_mst(pilot_buf2[frm_num], pilot_buf3[frm_num]);
//			}
//	
//			/* FILT channel estimation */
//	//		channel_filt(pilot_buf2[0], pilot_buf4[0], pilot_buf5[0], 2.25);
//			
			/* channel transmission */
			channel_trans(pilot_buf2[0], pilot_poly_buf2[0]);
	
			/*new MST channel estimation*/
			for (frm_num = 0; frm_num < 1024; frm_num++) {
				channel_mst(pilot_poly_buf2[frm_num], pilot_poly_buf3[frm_num]);
			}
	
			/*function : MST + polynomial algorithm*/
			channel_poly(pilot_buf2[0], pilot_poly_buf4[0], pilot_poly_buf5[0]);
			/* read channel infor from file */
			for (i = 0; i < 1024; i++) {
				for (j = 0; j < PILOT_LENGTH; j++) {
					fscanf(fp_true, "%f,%f\n", &tmp_real, &tmp_imag);
					pilot_buf1[i][j].real = tmp_real;
					pilot_buf1[i][j].imag = tmp_imag;
				}
			}
			
			/* caculate mse */
			for (i = 0; i < 1024; i++) {
				mse_caculate(pilot_buf1[i], pilot_poly_buf2[i], mse_sym_2, i);
				mse_caculate(pilot_buf1[i], pilot_poly_buf3[i], mse_sym_3, i);
				mse_caculate(pilot_buf1[i], pilot_poly_buf4[i], mse_sym_4, i);
				mse_caculate(pilot_buf1[i], pilot_poly_buf5[i], mse_sym_5, i);
			}
			
			/* frequency interpolate, demodulate & ber count */
			for (frm_num = 0; frm_num < 1024; frm_num++) {
				chn_equalize(pilot_buf1[frm_num], data_buf1[frm_num], data_buf2[frm_num], ber_sym_1, frm_num);
				chn_equalize(pilot_poly_buf2[frm_num], data_buf1[frm_num], data_buf2[frm_num], ber_sym_2, frm_num);
				chn_equalize(pilot_poly_buf3[frm_num], data_buf1[frm_num], data_buf2[frm_num], ber_sym_3, frm_num);
				chn_equalize(pilot_poly_buf4[frm_num], data_buf1[frm_num], data_buf2[frm_num], ber_sym_4, frm_num);
				chn_equalize(pilot_poly_buf5[frm_num], data_buf1[frm_num], data_buf2[frm_num], ber_sym_5, frm_num);
			}			average_func(mse_sym_2, mse_blk_2, 1024, loop_idx);			average_func(mse_sym_3, mse_blk_3, 1024, loop_idx);			average_func(mse_sym_4, mse_blk_4, 1024, loop_idx);			average_func(mse_sym_5, mse_blk_5, 1024, loop_idx);						average_func(ber_sym_1, ber_blk_1, 1024, loop_idx);			average_func(ber_sym_2, ber_blk_2, 1024, loop_idx);			average_func(ber_sym_3, ber_blk_3, 1024, loop_idx);			average_func(ber_sym_4, ber_blk_4, 1024, loop_idx);			average_func(ber_sym_5, ber_blk_5, 1024, loop_idx);	
		}		average_func(mse_blk_2, mse_2, blk_num, snr_idx);		average_func(mse_blk_3, mse_3, blk_num, snr_idx);		average_func(mse_blk_4, mse_4, blk_num, snr_idx);		average_func(mse_blk_5, mse_5, blk_num, snr_idx);				average_func(ber_blk_1, ber_1, blk_num, snr_idx);		average_func(ber_blk_2, ber_2, blk_num, snr_idx);		average_func(ber_blk_3, ber_3, blk_num, snr_idx);		average_func(ber_blk_4, ber_4, blk_num, snr_idx);		average_func(ber_blk_5, ber_5, blk_num, snr_idx);
		fclose(fp_true);
		write_file(target1_file, pilot_buf1[0], 1024, PILOT_LENGTH);
		write_file(target2_file, pilot_poly_buf5[0], 1024, PILOT_LENGTH);
		/* free the channel */
		free_rayleigh_sel(&ray_params_1);
		free_gauss(&gauss_params_1);
	}
	write_file_double(LOG_POLY_MSE_LS, mse_sym_2, 1, 30);
	write_file_double(LOG_POLY_MSE_MST, mse_sym_3, 1, 30);
	write_file_double(LOG_POLY_MSE_STP1, mse_sym_4, 1, 30);
	write_file_double(LOG_POLY_MSE_STP2, mse_sym_5, 1, 30);

	write_file_double(LOG_POLY_BER_IDEAL, ber_1, 1, 30);
	write_file_double(LOG_POLY_BER_LS, ber_2, 1, 30);
	write_file_double(LOG_POLY_BER_MST, ber_3, 1, 30);
	write_file_double(LOG_POLY_BER_STP1, ber_4, 1, 30);
	write_file_double(LOG_POLY_BER_STP2, ber_5, 1, 30);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美不卡一二三| 综合久久给合久久狠狠狠97色| 欧美高清在线视频| 一区二区三区中文在线观看| 韩国三级中文字幕hd久久精品| 成人av在线网站| 精品国产乱码久久久久久免费| 亚洲免费观看在线观看| 国产中文字幕一区| 欧美电影在哪看比较好| |精品福利一区二区三区| 日本不卡不码高清免费观看| 91浏览器入口在线观看| 久久久午夜精品理论片中文字幕| 亚洲成人免费视| 色婷婷国产精品| 日本一区二区三区高清不卡| 日韩高清一级片| 色诱视频网站一区| 国产精品私房写真福利视频| 精品一区二区三区久久久| 在线国产亚洲欧美| 日韩一区日韩二区| a在线播放不卡| 国产清纯白嫩初高生在线观看91 | 亚洲成人www| 99久免费精品视频在线观看| 久久久久国产精品麻豆| 老司机精品视频线观看86 | 精品久久久网站| 免费看日韩精品| 欧美日韩国产在线观看| 亚洲一区欧美一区| 欧美日韩一区二区三区高清| 一区二区免费看| 91精品1区2区| 一区二区三区高清| 精品视频免费看| 亚洲图片欧美视频| 欧美影视一区二区三区| 亚洲综合色视频| 欧美午夜电影在线播放| 夜夜嗨av一区二区三区| 欧美视频自拍偷拍| 亚洲一区二区3| 欧美日韩情趣电影| 天天色天天操综合| 欧美一区二区三区日韩| 久久99国内精品| 中文字幕成人av| 91浏览器打开| 婷婷开心久久网| 精品国产a毛片| 成人毛片在线观看| 一区二区视频在线看| 欧美欧美欧美欧美| 国产乱码精品1区2区3区| 欧美极品aⅴ影院| 91蜜桃传媒精品久久久一区二区| 亚洲一区免费在线观看| 日韩一区和二区| 不卡视频一二三四| 亚洲成人自拍网| 精品国产露脸精彩对白| av影院午夜一区| 天天影视色香欲综合网老头| 欧美va在线播放| 91色porny在线视频| 日韩不卡在线观看日韩不卡视频| 久久影视一区二区| 99re这里都是精品| 日本中文字幕一区二区视频| 中文字幕欧美日本乱码一线二线| 在线免费观看日本欧美| 精品一区二区三区久久| 伊人夜夜躁av伊人久久| 日韩一区二区麻豆国产| 97aⅴ精品视频一二三区| 久久国产免费看| 综合久久国产九一剧情麻豆| 欧美电视剧免费观看| 91美女视频网站| 国产一区二区三区免费在线观看| 亚洲黄网站在线观看| 久久精品日产第一区二区三区高清版 | 激情久久久久久久久久久久久久久久 | 亚洲444eee在线观看| 欧美激情一区三区| 欧美剧情片在线观看| www.激情成人| 国产精品自拍一区| 老鸭窝一区二区久久精品| 亚洲国产一区二区三区青草影视| 欧美极品aⅴ影院| www国产精品av| 欧美日韩夫妻久久| 色国产综合视频| 99精品久久99久久久久| 国产成人午夜高潮毛片| 精品一区二区三区的国产在线播放| 亚洲国产精品久久不卡毛片| 一色屋精品亚洲香蕉网站| 26uuu国产在线精品一区二区| 在线一区二区三区四区| 精品一区二区三区免费播放| 一区二区在线观看视频在线观看| 国产精品视频免费看| 日韩欧美123| 91麻豆精品国产91久久久资源速度| 一本色道久久综合狠狠躁的推荐| 国产又黄又大久久| 日韩精品成人一区二区三区| 亚洲精选在线视频| 中文字幕乱码久久午夜不卡| 欧美亚洲综合在线| 欧美三片在线视频观看| 99久久婷婷国产综合精品| 国产综合一区二区| 美女视频网站黄色亚洲| 亚洲大片免费看| 精品国产免费人成电影在线观看四季| 91精品国产91久久久久久一区二区 | 中文文精品字幕一区二区| 精品免费99久久| 欧美一区二区三区的| 欧美三级在线看| 欧美在线综合视频| 色综合久久66| 国产老妇另类xxxxx| 国产精品123| 国产成人亚洲综合a∨婷婷图片| 极品瑜伽女神91| 久久99最新地址| 美女国产一区二区| 国产综合色视频| 福利电影一区二区三区| 粉嫩在线一区二区三区视频| 国产精品影视网| bt欧美亚洲午夜电影天堂| 欧美在线播放高清精品| 欧美自拍偷拍午夜视频| 欧美日韩免费一区二区三区视频| 欧美午夜精品一区二区蜜桃| 欧美吞精做爰啪啪高潮| 欧美综合色免费| 久久理论电影网| 国产精品丝袜一区| 一级中文字幕一区二区| 亚洲bdsm女犯bdsm网站| 极品少妇xxxx精品少妇| 色噜噜久久综合| 欧美裸体一区二区三区| 欧美xxxx老人做受| 国产欧美va欧美不卡在线| 亚洲欧美色图小说| 免费视频最近日韩| 成人一级视频在线观看| 在线观看www91| 精品久久99ma| 国产精品久久久久桃色tv| 日韩激情在线观看| 懂色av噜噜一区二区三区av| 色综合久久九月婷婷色综合| 欧美日韩高清不卡| 精品对白一区国产伦| 成人欧美一区二区三区1314| 亚洲成人自拍偷拍| 国产成人免费在线观看不卡| 欧美日韩精品一区二区三区蜜桃 | 一区二区免费在线| 久久精品久久久精品美女| 日本大香伊一区二区三区| 欧美一区午夜视频在线观看| 欧美极品美女视频| 首页欧美精品中文字幕| 大白屁股一区二区视频| 欧美不卡一区二区| 亚洲高清视频在线| 国产成人精品亚洲午夜麻豆| 欧美日韩在线播放一区| 国产精品国产自产拍高清av| 日产精品久久久久久久性色| 成人av网站免费观看| 欧美一区二区视频在线观看2022 | 欧美日韩在线不卡| 亚洲欧洲国产专区| 久久成人羞羞网站| 欧美性受xxxx黑人xyx性爽| 国产三级三级三级精品8ⅰ区| 三级欧美在线一区| 色综合天天综合狠狠| 国产调教视频一区| 麻豆成人久久精品二区三区小说| 91视频在线观看免费| 亚洲乱码国产乱码精品精可以看| 国产美女娇喘av呻吟久久| 欧美一区二区三区性视频| 亚洲日本青草视频在线怡红院 | 国产精品无码永久免费888| 奇米888四色在线精品|