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

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

?? scramblelong1.cpp

?? 用matlab程序實現WCDMA系統的仿真
?? CPP
字號:
#include <malloc.h>
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#include "mex.h"

#define	SEQUENCE_LENGTH	33554432	/* 2^25 */
#define CODE_LENGTH		38400
#define BUFFER_LENGTH	25
#define ARRAY_LENGTH	26
#define LOG2(arg) (log( (double) arg)/log(2))

#define OFFSET		16777232
#define COUNT1		16777199
#define MAX_CODE_NUMBER	16777215
#define NDIMS			2



void scramble_long(unsigned long code_num,short int *scramble_real,short int *scramble_imag)
/*****************************************************************************************************
/void scramble_long(unsigned long code_num,short int *scramble_real,short int *scramble_imag)
/
/
/ Copyright 2002 The Mobile and Portable Radio Research Group
/
/This function generages the "long scramble code" by using the algorithm specified in 
/ETSI TS 125 213 V3.2.0 (2000-03).  The function generates this code by using the implementation 
/that is pictorially described in figure 5 of the aforementioned specificatoin.  
/This implemtation takes advantage of two shift registers, which this function emulates via 
/circular buffers.  The first circular buffer, X, is initiallized using code_num. The second circular 
/buffer Y is initiallized by setting all elements to 1.
/
/The function then performs the following operation using modulo 2 arithmetic
/	x(n+25) = x(n+3) + x(n+1)
/	y(n+25) = y(n+3) + y(n+2) + y(n+1) + y(n)
/	z(n) = x(n+4) + x(n+7) + x(n+18)
/	w(n) = y(n+4) + y(n+6) + y(n+17)
/	Clong1 = x(n) + y(n)
/	Clong2 = w(n) + z(n)
/	Scramble_long(n) = Clong1 * (1 + j*((-1)^n)*Clong2(2*floor(n/2)))
/
/Parameters
/	Input
/		code_num		unsigned value between 0 and 16777215 that determines the scramble code number
/
/	Output
/		*scramble_real	double valued array that stores the real part of the scramble code
/		*scramble_imag	double valued array that stores the imaginary part of the scramble code  
/******************************************************************************************************/

{
	unsigned long temp_code_num;
	unsigned short *x_buf_front,*x_buf_end;		//Points to the begining and end of the X circular buffer
	unsigned short *y_buf_front,*y_buf_end;		//Points to the begining and end of the Y circular buffer
	unsigned short *x0;		//Points to x(n)
	unsigned short *x3;		//Points to x(n+3)
	unsigned short *x4;		//Points to x(n+4)
	unsigned short *x7;		//Points to x(n+7)
	unsigned short *x18;	//Points to x(n+18)
	unsigned short *x25;	//Points to x(n+25)
	unsigned short *x_temp;	//Temporary Pointer
	unsigned short *y0;		//Points to y(n)
	unsigned short *y1;		//Points to y(n+1)
	unsigned short *y2;		//Points to y(n+2)
	unsigned short *y3;		//Points to y(n+3)
	unsigned short *y4;		//Points to y(n+4)
	unsigned short *y6;		//Points to y(n+6)
	unsigned short *y17;	//Points to y(n+17)
	unsigned short *y25;	//Points to y(n+25)
	unsigned short *y_temp;	//Temporary Pointer	
	unsigned short x1_hold; //Stores x(n)
	unsigned short y1_hold; //Stores y(n)
	unsigned short x2_hold;	//Stores the result of x(n+4) + x(n+7) + x(n+18)
	unsigned short y2_hold;	//Stores the result of y(n+4) + y(n+6) + y(n+17)
	short int *c_long_1,*c_long_1_temp;	//Pointers and temporary pointers to Clong1
	short int *c_long_2,*c_long_2_temp;	//Pointers and temporary pointers to Clong2
	short int *temp_real,*temp_imag;	//Temporary Pointers for *scramble_real and *scramble_imag
	int k,num_bits;
//	FILE *fp;


	/* Will shift registers using two circular buffers: 
	   one for the "x" sequence and one for the "y" sequence
	*/

	//Allocate space for code sequences
	if ((c_long_1 = (short int *) mxCalloc(CODE_LENGTH,sizeof(short int)))==NULL)
	{
		printf("\nc_long_1 array not allocated!--exiting\n");
		exit(-2);
	}
	if ( (c_long_2 = (short int *) mxCalloc(CODE_LENGTH,sizeof(short int)))==NULL)
	{
		printf("\nc_long_2 array not allocated!--exiting\n");
		exit(-2);
	}
	c_long_1_temp = c_long_1;
	c_long_2_temp = c_long_2;

	//Allocate buffers
	if ((x_buf_front = (unsigned short *) mxCalloc(ARRAY_LENGTH,sizeof(unsigned short)))==NULL)
	{
		printf("\nx_buf_front array not allocated!--exiting\n");
		exit(-2);
	}
	if ((y_buf_front = (unsigned short *) mxCalloc(ARRAY_LENGTH,sizeof(unsigned short)))==NULL)
	{
		printf("\n y_buf_front array not allocated!--exiting\n");
		exit(-2);
	}

	//Assign pointers to the end of buffer
	x_buf_end=x_buf_front+BUFFER_LENGTH;
	y_buf_end=y_buf_front+BUFFER_LENGTH;

	//Initialize buffers
	/* the code number (code_num) determines the inital condition for
	   the x seqeunce generator.  We therefore need to determine the 
	   binary representation of code_num and store it in the first 24
	   elements of x */
	
	x_temp=x_buf_front;
	temp_code_num=code_num;
	num_bits = (int) (LOG2(temp_code_num)+1);
	for (k=0; k<num_bits; k++)
	{
		*x_temp++ = 0x00000001 & temp_code_num;
		temp_code_num >>= 1;		
	}
	//Set the 24th element in the array equal to 1
	*(x_buf_front+24) = 1;

	//Initialize the "y" buffer by setting all 25 elements equal to 1
	y_temp=y_buf_front;
	for (k=0;k<BUFFER_LENGTH;k++) *y_temp++ = 1;

	//We now implement the sequence computation.
	//First initialize the locations of all pointers
	//Pointers for "x" buffer
	x0=x_buf_front;			//x(n)
	x3=x_buf_front+3;		//x(n+3)
	x4=x_buf_front+4;		//x(n+4)
	x7=x_buf_front+7;		//x(n+7)
	x18=x_buf_front+18;		//x(n+18)
	x25=x_buf_front;		//x(n+25)
	//Pointers for "y" buffer
	y0=y_buf_front;			//y(n)
	y1=y_buf_front+1;		//y(n+1)
	y2=y_buf_front+2;		//y(n+2)
	y3=y_buf_front+3;		//y(n+3)
	y4=y_buf_front+4;		//y(n+4)
	y6=y_buf_front+6;		//y(n+6)
	y17=y_buf_front+17;		//y(n+17)
	y25=y_buf_front;		//y(n+25)

	temp_real=scramble_real;	//assign temporary pointers to output parameter
	temp_imag=scramble_imag;		//assign temporary pointers to output parameter

	for (k=0;k<CODE_LENGTH;k++)
	{
		x1_hold = *x0;	//Shift register output for "x" sequence
		y1_hold = *y0;	//Shift register output for "x" sequence
		
		//Perform Shift register operations
		*x25 = *x0++ ^ *x3++;		//x(n+25) = x(n) + x(n+3)
		*y25 = (((*y0++ ^ *y1++) ^ *y2++) ^ *y3++);	//y(n+25) = y(n) + y(n+1) + y(n+2) + y(n+3)
		x2_hold = ((*x4++ ^ *x7++) ^ *x18++);		//z(n) = x(n+4) + x(n+7) + x(n+18)
		y2_hold = ((*y4++ ^ *y6++) ^ *y17++);		//w(n) = y(n+4) + y(n+6) + y(n+17)
		x25++;
		y25++;
				
		//Create output for c_long_1 and c_long_2 sequences
		// convert a "0" to +1 and a "1" to -1
		*c_long_1_temp++ =  (1 - 2 * (short int) (x1_hold ^ y1_hold));
		*c_long_2_temp++ =  (1 - 2 * (short int) (x2_hold ^ y2_hold));

		//Check for pointer overflow
		if (x18 == x_buf_end) x18 = x_buf_front;
		else if (x7 == x_buf_end) x7 = x_buf_front;
		else if (x4 == x_buf_end) x4 = x_buf_front;
		else if (x3 == x_buf_end) x3 = x_buf_front;
		else if (x0 == x_buf_end) 
		{
			x0 = x_buf_front;
			x25 = x_buf_front;
		}
		if (y17 == y_buf_end) y17 = y_buf_front;
		else if (y6 == y_buf_end) y6 = y_buf_front;
		else if (y4 == y_buf_end) y4 = y_buf_front;
		else if (y3 == y_buf_end) y3 = y_buf_front;
		else if (y2 == y_buf_end) y2 = y_buf_front;
		else if (y1 == y_buf_end) y1 = y_buf_front;
		else if (y0 == y_buf_end) 
		{
			y0 = y_buf_front;
			y25 = y_buf_front;
		}
			
	}

//	Used for debugging purposes
/*
	fp=fopen("sequence_new.txt","w");
	c_long_2_temp=c_long_2;
	c_long_1_temp=c_long_1;
	

	fprintf(fp,"index c1 c2 index c1 c2 index c1 c2\n");
	for (k=0;k<101;k+=2) 
	{
		fprintf( fp,"%d \t %d \t %d \n",k,*c_long_1_temp++,*c_long_2_temp);
		fprintf( fp,"%d \t %d \t %d \n",k,*c_long_1_temp++,*c_long_2_temp);
		c_long_2_temp+=2;
	}
	fclose(fp);
*/	

	//Fill real part of the complex scramble code
	temp_real=scramble_real;
	c_long_1_temp=c_long_1;
	for (k=0;k<CODE_LENGTH;k++) *temp_real++ = *c_long_1_temp++;

	//Fill imaginary part part of the complex scramble code
	c_long_1_temp=c_long_1;
	c_long_2_temp=c_long_2;
	temp_imag=scramble_imag;
	for (k=0;k<CODE_LENGTH;k+=2)
	{
		*temp_imag++ = (*c_long_1_temp++) * (*c_long_2_temp);
		*temp_imag++ = -(*c_long_1_temp++) * (*c_long_2_temp);
		c_long_2_temp+=2;
	}
	mxFree(c_long_1);
	mxFree(c_long_2);
	mxFree(x_buf_front);
	mxFree(y_buf_front);
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品欧美激情| 国产精品卡一卡二| 一区二区三区四区精品在线视频| av午夜精品一区二区三区| 国产精品麻豆视频| 在线观看视频91| 天天影视网天天综合色在线播放| 日韩欧美成人激情| 国产69精品一区二区亚洲孕妇 | 久久女同精品一区二区| 国产精品一线二线三线| 亚洲视频一区在线| 精品国产欧美一区二区| 94-欧美-setu| www.亚洲激情.com| 懂色av一区二区三区免费看| 成人精品电影在线观看| 日韩成人一区二区| 国产偷国产偷亚洲高清人白洁| 91精品办公室少妇高潮对白| 激情图片小说一区| 亚洲成人av电影在线| 国产午夜精品一区二区 | 精品无码三级在线观看视频| 国产精品家庭影院| 一区二区三区日韩在线观看| 亚洲一级不卡视频| 亚洲毛片av在线| 欧美国产1区2区| 日韩精品一区在线| 国产精品丝袜在线| 视频一区免费在线观看| 亚洲精品一二三四区| 天堂蜜桃一区二区三区 | 日韩欧美国产精品一区| 国产日韩欧美一区二区三区综合| 91精品在线麻豆| 日本高清免费不卡视频| 538在线一区二区精品国产| 国产亚洲1区2区3区| 亚洲aaa精品| 成人综合婷婷国产精品久久蜜臀| 国产一区免费电影| 国产剧情av麻豆香蕉精品| 日本乱码高清不卡字幕| 欧美v国产在线一区二区三区| 欧美电影在线免费观看| 在线精品亚洲一区二区不卡| 欧美大片拔萝卜| 亚洲一区二区在线视频| 国产综合色视频| 欧美精品一级二级| 亚洲色图清纯唯美| 国产麻豆一精品一av一免费| 欧美电影免费提供在线观看| 国产精品美女久久久久aⅴ国产馆| 亚洲国产精品人人做人人爽| 亚洲精品国产一区二区三区四区在线| 久久精品久久99精品久久| 免费在线观看精品| 国产一区三区三区| 日韩欧美一区二区免费| 亚洲va欧美va国产va天堂影院| 成人免费视频网站在线观看| 日韩欧美国产一二三区| 性久久久久久久久| 欧美色窝79yyyycom| 欧美一区二区福利视频| 亚洲精品一区二区三区99| 亚洲成人第一页| 在线欧美小视频| 亚洲日韩欧美一区二区在线| 国产美女视频一区| 国产网站一区二区| 国产a精品视频| 国产欧美一区二区三区在线看蜜臀 | 在线中文字幕一区| 中文字幕av不卡| 成人av在线影院| 中文字幕亚洲区| 五月天国产精品| 在线成人免费视频| 麻豆精品一区二区av白丝在线| 国产一区 二区| 欧美激情综合网| 9色porny自拍视频一区二区| 国产精品二三区| 91麻豆免费看片| 久久美女艺术照精彩视频福利播放 | 中国色在线观看另类| 高清beeg欧美| 午夜激情综合网| 欧美一区2区视频在线观看| 蜜臀久久久99精品久久久久久| 91精品国产麻豆国产自产在线 | 国产精品夜夜爽| 国产精品美女一区二区| 91高清视频免费看| 日韩在线一区二区| 精品裸体舞一区二区三区| 国产精品综合一区二区三区| 国产精品日日摸夜夜摸av| 色婷婷亚洲综合| 久久久久久久电影| 成人激情文学综合网| 亚洲欧美视频在线观看视频| 欧美日韩大陆在线| 亚洲日本在线观看| 欧美一区二区日韩一区二区| 国产一区二区精品久久99| 中文字幕欧美激情一区| 欧美综合一区二区| 精品一区二区三区日韩| 亚洲欧美一区二区在线观看| 欧美怡红院视频| 韩国女主播成人在线观看| 亚洲激情男女视频| 精品国内片67194| 一道本成人在线| 国产在线视频精品一区| 一区二区三区四区精品在线视频| 国产精品嫩草影院com| 91豆麻精品91久久久久久| 麻豆精品视频在线观看免费| 亚洲欧洲韩国日本视频| 欧美va亚洲va在线观看蝴蝶网| 97久久精品人人做人人爽| 久久 天天综合| 午夜天堂影视香蕉久久| 国产精品第一页第二页第三页| 欧美精品久久天天躁| 一本到高清视频免费精品| 国产精品一线二线三线| 麻豆精品一区二区三区| 午夜影院久久久| 一区二区三区在线视频观看58| 久久久久久麻豆| 日韩午夜在线观看视频| 麻豆国产欧美日韩综合精品二区 | 国产精品九色蝌蚪自拍| 精品国偷自产国产一区| 欧美日本一区二区| 在线观看日韩毛片| 99精品桃花视频在线观看| 国产精品一区二区久激情瑜伽| 日韩激情一二三区| 亚洲国产日韩综合久久精品| 亚洲欧洲三级电影| 国产精品成人免费精品自在线观看| 日韩欧美电影一区| 91精品国产美女浴室洗澡无遮挡| 日本大香伊一区二区三区| www.日韩在线| 91丝袜美女网| 91在线精品一区二区| 99久久免费视频.com| 成年人国产精品| 日韩一区二区三区在线观看| 欧洲av在线精品| 欧美高清www午色夜在线视频| 欧美色图12p| 丰满少妇在线播放bd日韩电影| 精品一区二区三区免费观看| 久久97超碰色| 成人精品免费网站| 99热99精品| 日本道免费精品一区二区三区| 91精品福利视频| 在线不卡一区二区| 日韩欧美激情一区| 久久嫩草精品久久久精品一| 久久久久99精品一区| 国产精品免费丝袜| 最新久久zyz资源站| 亚洲图片欧美视频| 美国av一区二区| 成人免费高清在线| 欧美日韩高清一区| 久久网这里都是精品| 91精品国产综合久久精品麻豆| 日韩免费高清av| 国产精品久久久久久久久免费丝袜| 亚洲伦理在线免费看| 五月天亚洲精品| 国产精品系列在线观看| 97超碰欧美中文字幕| 欧美精品丝袜中出| 国产丝袜美腿一区二区三区| 一区在线观看免费| 日韩在线卡一卡二| 国产精品一区2区| 欧美午夜电影在线播放| 精品国产乱码久久久久久影片| 中文字幕一区二区三中文字幕| 一区二区成人在线| 国产美女视频91| 欧美剧情片在线观看| 国产精品欧美久久久久一区二区| 亚洲成人自拍网| 成人免费视频一区二区|