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

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

?? softviterbiqaminrayleigh.c

?? Hard Viterbi QPSK in AWGN, Rayleight soft Viterbi QAM in AWGN, Rayleight viterbi QAM in AWGN, Rayl
?? C
字號:
#include <stdio.h>
#include <math.h>
#include <stdlib.h>
#include <time.h>
#include "random.h"
// make the complex structure
typedef struct complex1
{
	double real;
	double imag;
}complex;
// define the number of the iteration
#define ITERATION pow(10, 3)
#define THENUMBEROFDATA 1000

void convolution(int *data, int *codeddata);
double modulation(int data);
void demodulation(double * r_data);
int bercheck(int data, double d_data);
double comparison(double com1, double com2);
void viterbi_decode(int *d_data, int *decode_data);
void quantization(double r_data, int *d_data);
double dis(int data, int data1, int data2, int value1, int value2);

void main()
{
	FILE *fp1;
	double Noisepower;
	complex Noise;
	int data[THENUMBEROFDATA];
	int codeddata[2*(THENUMBEROFDATA+2)];
	int cr_data[2];
	int ci_data[2];
	complex m_data;
	complex r_data;
	complex H;
	complex er_data;
	int d_data[3];
	int d_data1[3];
	int dd_data[6*(THENUMBEROFDATA+2)];
	int decode_data[THENUMBEROFDATA+2];
	int error;
	double avgerr;
	int EbofN0;
	
	// open and make the text file 
	fp1=fopen("result_16qam_ViterbiSoft_Rayleigh.txt","w");
	srand(time(0));
	for(EbofN0=11; EbofN0<=15; EbofN0+=1)
	{
		double sumerr=0.0;
		int run;		
		int i;
		int l;
			    
		for(run=0;run<ITERATION;run++)
		{
			// generate the real part data 		
			generate_random(&data[0], THENUMBEROFDATA);
			
			convolution(data, codeddata);
			// generate the imaginary part data
            //generate_random(&data1[0], THENUMBEROFDATA/2);
			
            for (i=0; i<=(THENUMBEROFDATA/2);i++)
			{				
				cr_data[0]=codeddata[4*i];
				cr_data[1]=codeddata[4*i+1];
                ci_data[0]=codeddata[4*i+2];
				ci_data[1]=codeddata[4*i+3];
				// modulated the real part signal
				m_data.real = modulation(cr_data);
				// modulated the imaginary part signal 
				m_data.imag = modulation(ci_data);


				// make the noisepower	
				Noisepower=1/(2*pow(10,(double)EbofN0/10));
				// make the real part of noise
				Noise.real = sqrt(Noisepower/2)*GaussRand();
				// make the imaginary part of noise
				Noise.imag = sqrt(Noisepower/2)*GaussRand();

				H.real = sqrt(1.0/2.0)*GaussRand();
				H.imag = sqrt(1.0/2.0)*GaussRand();
			
				// receive the real part of the signal 
			    r_data.real = sqrt(1.0/10.0)*(H.real*m_data.real-H.imag*m_data.imag) + Noise.real;
			    r_data.imag = sqrt(1.0/10.0)*(H.real*m_data.imag+H.imag*m_data.real) + Noise.imag;

				er_data.real = (r_data.real*H.real+r_data.imag*H.imag)/(pow(H.real,2)+pow(H.imag,2));
				er_data.imag = (r_data.imag*H.real-r_data.real*H.imag)/(pow(H.real,2)+pow(H.imag,2));

						
				quantization(er_data.real,d_data);
				quantization(er_data.imag,d_data1);
				//quantization(er_data.real,d_data);
				//quantization(er_data.imag,d_data1);
                
				dd_data[6*i]=d_data[0];
				dd_data[6*i+1]=d_data[1];
				dd_data[6*i+2]=d_data[2];
				dd_data[6*i+3]=d_data1[0];
				dd_data[6*i+4]=d_data1[1];
				dd_data[6*i+5]=d_data1[2];
			}

			viterbi_decode(dd_data,decode_data);
			// check the error 

			for (l=0;l<=(THENUMBEROFDATA-1);l++)
			{
				error= bercheck(data[l], decode_data[l]);
				sumerr = sumerr + error;
			}
		}
		//calculated the BER
		avgerr = sumerr / (ITERATION*THENUMBEROFDATA);
		fprintf(fp1,"%.7f\n",avgerr);	
		printf("%.7f\n", avgerr);
	}
	fclose(fp1);
}

// quantization function 
void quantization(double r_data, int *d_data)
{
	if (r_data<=-sqrt(1.0/10.0)*3*3/4)
	{
		d_data[0]=0;
		d_data[1]=0;
		d_data[2]=0;
	}else if (r_data<=-sqrt(1.0/10.0)*3*2/4)
	{
		d_data[0]=0;
		d_data[1]=0;
		d_data[2]=1;
	}else if (r_data<=-sqrt(1.0/10.0)*3*1/4)
	{
		d_data[0]=0;
		d_data[1]=1;
		d_data[2]=0;
	}else if (r_data <= 0 )
	{
		d_data[0]=0;
		d_data[1]=1;
		d_data[2]=1;
	}else if (r_data<=sqrt(1.0/10.0)*3*1/4)
	{
		d_data[0]=1;
		d_data[1]=0;
		d_data[2]=0;
	}else if (r_data<=sqrt(1.0/10.0)*3*2/4)
	{
		d_data[0]=1;
		d_data[1]=0;
		d_data[2]=1;
	}else if (r_data<=sqrt(1.0/10.0)*3*3/4)
	{
		d_data[0]=1;
		d_data[1]=1;
		d_data[2]=0;
	}else 
	{
		d_data[0]=1;
		d_data[1]=1;
		d_data[2]=1;
	}
}

// modulation function
double modulation(int *data)
{
	int m_data;
	if (*data==1)
	{
		if(*(data+1)==1)
		{
			m_data=1;
		}
		else
		{
			m_data=3;
		}
	}
	else
	{
		if(*(data+1)==1)
		{
			m_data=-1;
		}
		else
		{
			m_data=-3;
		}		
	}
	return (m_data);
}
// demodulation function
void demodulation(double *r_data)
{
	if (r_data[0]>=0.0)
	{
		if (r_data[0]>=sqrt(1.0/10.0)*2.0)
		{
			r_data[0]=1;
     		r_data[1]=0;
		}
		else
		{
			r_data[0]=1;
			r_data[1]=1;
		}
	}
	else
	{
		if (r_data[0]<=sqrt(1.0/10.0)*(-2.0))
		{
			r_data[0]=0;
     		r_data[1]=0;
		}
		else
		{
			r_data[0]=0;
     		r_data[1]=1;
		}
	}
}
// error check function
int bercheck(int data, double d_data)
{
	int error=0;
	if ((double)data==d_data)
	{
		error=0;
	}
	else
	{
		error=1;
		
	}
	return (error);
}

// convolution code
void convolution(int *data, int *codeddata)
{
	int a = data[0];
	int b = 0;
	int c = 0;
	int N =0;
	//int codeddata[12];
	for(N=0;N<=(THENUMBEROFDATA+1);N++)
	{
		codeddata[2*N] = a^b^c;
		codeddata[2*N+1] = a^c;
		a = data[N+1];
		b = data[N];
		if(N == 0)
		{
			c = 0;
		}else
		{
			c = data[N-1];
		}
		if(N>=(THENUMBEROFDATA-1))
		{
			a=0;
		}
		if(N>=THENUMBEROFDATA)
		{
			b=0;
		}
	}
}

// Viterbi decoding
void viterbi_decode(int *d_data, int *decode_data)
{
	double s[4][(THENUMBEROFDATA+3)];
	int k1;
	int k2;
	int c[2*((THENUMBEROFDATA+2))];
	int l1;
//	int l2;
	int i;
	int l;
	for (i = 0;i<=3;i++)
	{
		for(l=0;l<=THENUMBEROFDATA+2;l++)
		{
			s[i][l]=10000000000000;
		}
	}
    s[0][0]=0;
	s[0][1]=dis(d_data[0],d_data[1],d_data[2],0,0);
	s[1][1]=dis(d_data[0],d_data[1],d_data[2],1,1);
	s[0][2]=s[0][1]+dis(d_data[3],d_data[4],d_data[5],0,0);
	s[1][2]=s[0][1]+dis(d_data[3],d_data[4],d_data[5],1,1);
	s[2][2]=s[1][1]+dis(d_data[3],d_data[4],d_data[5],1,0);
	s[3][2]=s[1][1]+dis(d_data[3],d_data[4],d_data[5],0,1);
	
	for(k2=3;k2<=(THENUMBEROFDATA+2);k2++)
	{
		for(k1=0;k1<=3;k1++)
		{
			if(k1==0)
			{
				s[k1][k2]=comparison(s[k1][k2-1]+dis(d_data[3*(k2-1)],d_data[3*(k2-1)+1],d_data[3*(k2-1)+2],0,0), s[k1+2][k2-1]+dis(d_data[3*(k2-1)],d_data[3*(k2-1)+1],d_data[3*(k2-1)+2],1,1));
			}
			else if(k1==1)
			{
				s[k1][k2]=comparison(s[k1-1][k2-1]+dis(d_data[3*(k2-1)],d_data[3*(k2-1)+1],d_data[3*(k2-1)+2],1,1), s[k1+1][k2-1]+dis(d_data[3*(k2-1)],d_data[3*(k2-1)+1],d_data[3*(k2-1)+2],0,0));
			}
			else if(k1==2)
			{
				s[k1][k2]=comparison(s[k1-1][k2-1]+dis(d_data[3*(k2-1)],d_data[3*(k2-1)+1],d_data[3*(k2-1)+2],1,0), s[k1+1][k2-1]+dis(d_data[3*(k2-1)],d_data[3*(k2-1)+1],d_data[3*(k2-1)+2],0,1));
			}
			else if(k1==3)
			{
				s[k1][k2]=comparison(s[k1-2][k2-1]+dis(d_data[3*(k2-1)],d_data[3*(k2-1)+1],d_data[3*(k2-1)+2],0,1), s[k1][k2-1]+dis(d_data[3*(k2-1)],d_data[3*(k2-1)+1],d_data[3*(k2-1)+2],1,0));
			}
		}
	}
    
	if((s[0][(THENUMBEROFDATA+1)]+dis(d_data[3*(THENUMBEROFDATA+1)],d_data[3*(THENUMBEROFDATA+1)+1],d_data[3*(THENUMBEROFDATA+1)+2],0,0))==comparison(s[0][(THENUMBEROFDATA+1)]+dis(d_data[3*(THENUMBEROFDATA+1)],d_data[3*(THENUMBEROFDATA+1)+1],d_data[3*(THENUMBEROFDATA+1)+2],0,0) , s[2][(THENUMBEROFDATA+1)]+dis(d_data[3*(THENUMBEROFDATA+1)],d_data[3*(THENUMBEROFDATA+1)+1],d_data[3*(THENUMBEROFDATA+1)+2],1,1)))
	{
		c[(THENUMBEROFDATA+1)] = 0;
		decode_data[(THENUMBEROFDATA-1)]=0;
	}
	else 
	{
		c[(THENUMBEROFDATA+1)] = 2;
		decode_data[(THENUMBEROFDATA-1)]=0;
	}
	for (l1=(THENUMBEROFDATA+1);l1>=1;l1--)
	{
		if (c[l1]==0)
		{
			if((s[0][l1-1]+dis(d_data[3*(l1-1)],d_data[3*(l1-1)+1],d_data[3*(l1-1)+2],0,0))==comparison(s[0][l1-1]+dis(d_data[3*(l1-1)],d_data[3*(l1-1)+1],d_data[3*(l1-1)+2],0,0),s[2][l1-1]+dis(d_data[3*(l1-1)],d_data[3*(l1-1)+1],d_data[3*(l1-1)+2],1,1)))
			{
				c[l1-1] = 0;
				decode_data[l1-1]=0;
			}
			else 
			{
				c[l1-1] = 2;
				decode_data[l1-1]=0;
			}
		}else if(c[l1]==1)
		{
			if((s[0][l1-1]+dis(d_data[3*(l1-1)],d_data[3*(l1-1)+1],d_data[3*(l1-1)+2],1,1))==comparison(s[0][l1-1]+dis(d_data[3*(l1-1)],d_data[3*(l1-1)+1],d_data[3*(l1-1)+2],1,1),s[2][l1-1]+dis(d_data[3*(l1-1)],d_data[3*(l1-1)+1],d_data[3*(l1-1)+2],0,0)))
			{
				c[l1-1] = 0;
				decode_data[l1-1]=1;
			}
			else 
			{
				c[l1-1] = 2;
				decode_data[l1-1]=1;
			}
		}else if(c[l1]==2)
		{
			if((s[1][l1-1]+dis(d_data[3*(l1-1)],d_data[3*(l1-1)+1],d_data[3*(l1-1)+2],1,0))==comparison(s[1][l1-1]+dis(d_data[3*(l1-1)],d_data[3*(l1-1)+1],d_data[3*(l1-1)+2],1,0),s[3][l1-1]+dis(d_data[3*(l1-1)],d_data[3*(l1-1)+1],d_data[3*(l1-1)+2],0,1)))
			{
				c[l1-1] = 1;
				decode_data[l1-1]=0;
			}
			else 
			{
				c[l1-1] = 3;
				decode_data[l1-1]=0;
			}
		}else if(c[l1]==3)
		{
			if((s[1][l1-1]+dis(d_data[3*(l1-1)],d_data[3*(l1-1)+1],d_data[3*(l1-1)+2],0,1))==comparison(s[1][l1-1]+dis(d_data[3*(l1-1)],d_data[3*(l1-1)+1],d_data[3*(l1-1)+2],0,1),s[3][l1-1]+dis(d_data[3*(l1-1)],d_data[3*(l1-1)+1],d_data[3*(l1-1)+2],1,0)))
			{
				c[l1-1] = 1;
				decode_data[l1-1]=1;
			} 
			else 
			{
				c[l1-1] = 3;
				decode_data[l1-1]=1;
			}
		}
	}
}

double comparison(double com1, double com2)
{
	double com3;
	if(com1>=com2)
	{
		com3=com2;
	}else
	{
		com3=com1;
	}
	return (com3);
}

double dis(int data, int data1, int data2, int value1, int value2)
{
	double distance;
	double value;
	if(value1==0)
	{
		if(value2==0)
		{
			value = 0;
		}
		else
		{
			value = 7/3;
		}
	}
	else
	{
		if(value2==0)
		{
			value = 7;
		}else
		{
			value = 14/3;
		}
	}
	distance = sqrt(pow(((data*4+data1*2+data2)-value),2));
	return (distance);
}






?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
夜夜操天天操亚洲| 国产乱人伦精品一区二区在线观看| 国产成人精品影视| 欧美高清在线精品一区| 午夜精品一区二区三区三上悠亚| 欧美日韩一区二区三区四区| 日韩电影在线免费观看| 成人国产精品免费| 91精品国产全国免费观看| 蜜桃视频一区二区| 91久久香蕉国产日韩欧美9色| 亚洲一区二区在线免费看| 成人一区二区三区视频| 亚洲欧美日本在线| 91.麻豆视频| 亚洲黄色性网站| 国产精品123区| 亚洲欧美日韩国产综合在线| 欧美日韩国产免费一区二区| 国产一区二区三区精品视频| 国产精品福利电影一区二区三区四区| 欧美视频日韩视频在线观看| 中文字幕一区二| 国产v日产∨综合v精品视频| 亚洲嫩草精品久久| 91麻豆精品一区二区三区| 亚洲午夜激情av| 国产视频一区二区在线观看| 欧美性生活久久| 亚洲午夜免费福利视频| 精品电影一区二区三区 | 亚洲一区二区三区四区中文字幕| 91精品国产91综合久久蜜臀| 成人黄色软件下载| 免费精品视频在线| 国产精品热久久久久夜色精品三区| 久久99精品国产麻豆婷婷| 亚洲婷婷综合久久一本伊一区| 欧美一区二区三区电影| 不卡区在线中文字幕| 国产精品不卡视频| 99久精品国产| 蜜臀av性久久久久蜜臀aⅴ四虎| 在线不卡a资源高清| 国产91精品在线观看| 中文在线一区二区| 884aa四虎影成人精品一区| 成人av先锋影音| 国产老妇另类xxxxx| 国产人成一区二区三区影院| 欧美一区二区三区不卡| 在线免费av一区| 日本不卡123| 欧美成人女星排行榜| 欧美色精品天天在线观看视频| 亚洲国产欧美在线人成| 日韩精品中文字幕一区| 成人网在线播放| 国产精品1区2区| 一色屋精品亚洲香蕉网站| 国产欧美日韩久久| 久久亚洲精华国产精华液| 欧美一区二区视频网站| 欧美久久高跟鞋激| 欧美日韩一区中文字幕| 欧美在线观看视频在线| 色综合色狠狠综合色| 丝袜亚洲另类欧美| 亚洲五码中文字幕| 久久色在线视频| 在线观看视频一区二区| 91在线无精精品入口| 99精品视频一区二区三区| 天天做天天摸天天爽国产一区 | 欧美日韩久久不卡| 欧美日韩一卡二卡三卡| 国产成人精品免费| 亚洲va国产天堂va久久en| 亚洲第四色夜色| 亚洲网友自拍偷拍| 久久精品欧美日韩精品| 在线亚洲人成电影网站色www| 成人av网址在线观看| 91在线观看污| 日本韩国欧美三级| 欧美午夜电影在线播放| 国产91精品在线观看| eeuss鲁一区二区三区| 色诱亚洲精品久久久久久| www.日韩精品| 99国产精品国产精品久久| 欧美图片一区二区三区| 欧美一区二区三区四区久久| 欧美大片在线观看一区二区| 日韩精品一区二区在线观看| 精品久久人人做人人爰| 欧美国产精品中文字幕| 亚洲免费av网站| 精品免费国产二区三区| 国产视频一区在线观看| 欧美一区二区视频网站| 国产日韩欧美高清在线| 自拍视频在线观看一区二区| 久久午夜国产精品| 亚洲欧洲精品一区二区三区不卡| 日韩一区二区三区av| 久久这里都是精品| 最新中文字幕一区二区三区| 亚洲一区二区三区四区在线| 久久国产尿小便嘘嘘尿| 不卡av在线免费观看| 欧美性受xxxx| 在线精品视频一区二区三四| 日韩一区二区三区视频在线观看 | 欧美成人午夜电影| 3751色影院一区二区三区| 93久久精品日日躁夜夜躁欧美| 91免费看`日韩一区二区| 欧美精品亚洲一区二区在线播放| 国产欧美日韩精品一区| 亚洲影视在线观看| 国产高清不卡一区| 欧美日韩一区二区三区在线看| 99九九99九九九视频精品| 国产成人自拍网| 欧美日韩亚洲丝袜制服| 国产精品久久久久一区| 奇米精品一区二区三区在线观看| 亚洲午夜电影在线观看| 亚洲不卡一区二区三区| 午夜成人在线视频| 国产91色综合久久免费分享| 成人app下载| 99久久99久久久精品齐齐| 丁香天五香天堂综合| 成a人片国产精品| 日韩欧美的一区二区| 亚洲欧美日韩国产手机在线| 国产一区二区三区| 日韩欧美成人午夜| 亚洲成av人影院| 在线亚洲+欧美+日本专区| 国产亚洲精品超碰| 精品一区二区三区香蕉蜜桃| 欧美精品aⅴ在线视频| 日韩美女久久久| 天天综合色天天综合| 欧美综合久久久| 51精品秘密在线观看| 久久综合色婷婷| 国产精品色婷婷| 在线观看日韩高清av| 日本韩国欧美一区二区三区| 91精品福利在线一区二区三区 | 99r国产精品| 欧美韩日一区二区三区| 国产一区欧美二区| 日韩免费性生活视频播放| 日本午夜一区二区| 91精品国产色综合久久不卡蜜臀 | 欧美v亚洲v综合ⅴ国产v| 青娱乐精品在线视频| 国产91在线观看| 91高清视频免费看| 欧美大胆一级视频| 男人的天堂久久精品| aaa亚洲精品一二三区| 国产精品丝袜久久久久久app| 亚洲成人在线网站| 欧美猛男超大videosgay| 天堂久久一区二区三区| 91麻豆精品国产91久久久久久久久 | 久久久五月婷婷| 亚洲精品国产精华液| 成人激情动漫在线观看| 在线观看91精品国产麻豆| 偷窥少妇高潮呻吟av久久免费| 国产成+人+日韩+欧美+亚洲| 国产精品视频一二三区| 91视频精品在这里| 亚洲国产精品一区二区尤物区| 国产成人av电影| 日韩一区二区在线看| 亚洲乱码日产精品bd| 欧美自拍偷拍一区| 蜜桃久久久久久| 欧美三级欧美一级| 麻豆精品一区二区| 国产欧美日本一区视频| 日本成人中文字幕| 精品国产三级a在线观看| 国产成人在线视频免费播放| 亚洲三级电影全部在线观看高清| 国产精品一线二线三线| 欧美一二三区在线观看| 亚洲电影一区二区| 久久综合国产精品| 一本久道久久综合中文字幕| 视频一区中文字幕国产| 欧美性受极品xxxx喷水|