直扩码分多址DS-CDMA是利用高速的WALSH正交码序列作为地址码,与多用户信息数据相乘得到信息数据的直接扩频信号,再经过BPSK调制后发送出去,经过AWGN无线信道的传输后,在接收端与本地产生的地址码进行相关检测,从中将地址码与本地码一致的用户数据选出,把不一致的用户数据删除。
上传时间: 2014-01-02
上传用户:270189020
计算循环平稳信号的3阶累积量,用于信号检测方面的,用在高阶谱估计中,很有用的函数
上传时间: 2013-12-22
上传用户:liansi
直接序列扩频DSSS, 跳频扩频FHSS, 码分多址CDMA编译码, 的实现
上传时间: 2017-07-02
上传用户:zm7516678
此模型是的信号发生器是由b.mat的simulink模型动态生成,共有10个用户,扩频信号是由gold码或产生,共有恒模算法、子空间算法、改进型恒模算法和最小能量检测算法等几个算法程序。
上传时间: 2017-05-04
上传用户:zxc280395350
/****************temic*********t5557***********************************/ #include <at892051.h> #include <string.h> #include <intrins.h> #include <stdio.h> #define uchar unsigned char #define uint unsigned int #define ulong unsigned long //STC12C2051AD的SFR定义 sfr WDT_CONTR = 0xe1;//stc2051的看门狗?????? /**********全局常量************/ //写卡的命令 #define write_command0 0//写密码 #define write_command1 1//写配置字 #define write_command2 2//密码写数据 #define write_command3 3//唤醒 #define write_command4 4//停止命令 #define TRUE 1 #define FALSE 0 #define OK 0 #define ERROR 255 //读卡的时间参数us #define ts_min 250//270*11.0592/12=249//取近似的整数 #define ts_max 304//330*11.0592/12=304 #define t1_min 73//90*11.0592/12=83:-10调整 #define t1_max 156//180*11.0592/12=166 #define t2_min 184//210*11.0592/12=194 #define t2_max 267//300*11.0592/12=276 //***********不采用中断处理:采用查询的方法读卡时关所有中断****************/ sbit p_U2270B_Standby = P3^5;//p_U2270B_Standby PIN=13 sbit p_U2270B_CFE = P3^3;//p_U2270B_CFE PIN=6 sbit p_U2270B_OutPut = P3^7;//p_U2270B_OutPut PIN=2 sbit wtd_sck = P1^7;//SPI总线 sbit wtd_si = P1^3; sbit wtd_so = P1^2; sbit iic_data = P1^2;//lcd IIC sbit iic_clk = P1^7; sbit led_light = P1^6;//测试绿灯 sbit led_light1 = P1^5;//测试红灯 sbit led_light_ok = P1^1;//读卡成功标志 sbit fengmingqi = P1^5; /***********全局变量************************************/ uchar data Nkey_a[4] = {0xA0, 0xA1, 0xA2, 0xA3};//初始密码 //uchar idata card_snr[4]; //配置字 uchar data bankdata[28] = {1,2,3,4,5,6,7,1,2,3,4,5,6,7,1,2,3,4,5,6,7,1,2,3,4,5,6,7}; //存储卡上用户数据(1-7)7*4=28 uchar data cominceptbuff[6] = {1,2,3,4,5,6};//串口接收数组ram uchar command; //第一个命令 uchar command1;// //uint temp; uchar j,i; uchar myaddr = 8; //uchar ywqz_count,time_count; //ywqz jishu: uchar bdata DATA; sbit BIT0 = DATA^0; sbit BIT1 = DATA^1; sbit BIT2 = DATA^2; sbit BIT3 = DATA^3; sbit BIT4 = DATA^4; sbit BIT5 = DATA^5; sbit BIT6 = DATA^6; sbit BIT7 = DATA^7; uchar bdata DATA1; sbit BIT10 = DATA1^0; sbit BIT11 = DATA1^1; sbit BIT12 = DATA1^2; sbit BIT13 = DATA1^3; sbit BIT14 = DATA1^4; sbit BIT15 = DATA1^5; sbit BIT16 = DATA1^6; sbit BIT17 = DATA1^7; bit i_CurrentLevel;//i_CurrentLevel BIT 00H(Saves current level of OutPut pin of U2270B) bit timer1_end; bit read_ok = 0; //缓存定时值,因用同一个定时器 union HLint { uint W; struct { uchar H;uchar L; } B; };//union HLint idata a union HLint data a; //缓存定时值,因用同一个定时器 union HLint0 { uint W; struct { uchar H; uchar L; } B; };//union HLint idata a union HLint0 data b; /**********************函数原型*****************/ //读写操作 void f_readcard(void);//全部读出1~7 AOR唤醒 void f_writecard(uchar x);//根据命令写不同的内容和操作 void f_clearpassword(void);//清除密码 void f_changepassword(void);//修改密码 //功能子函数 void write_password(uchar data *data p);//写初始密码或数据 void write_block(uchar x,uchar data *data p);//不能用通用指针 void write_bit(bit x);//写位 /*子函数区*****************************************************/ void delay_2(uint x) //延时,时间x*10us@12mhz,最小20us@12mhz { x--; x--; while(x) { _nop_(); _nop_(); x--; } _nop_();//WDT_CONTR=0X3C;不能频繁的复位 _nop_(); } ///////////////////////////////////////////////////////////////////// void initial(void) { SCON = 0x50; //串口方式1,允许接收 //SCON =0x50; //01010000B:10位异步收发,波特率可变,SM2=0不用接收到有效停止位才RI=1, //REN=1允许接收 TMOD = 0x21; //定时器1 定时方式2(8位),定时器0 定时方式1(16位) TCON = 0x40; //设定时器1 允许开始计时(IT1=1) TH1 = 0xfD; //FB 18.432MHz 9600 波特率 TL1 = 0xfD; //fd 11.0592 9600 IE = 0X90; //EA=ES=1 TR1 = 1; //启动定时器 WDT_CONTR = 0x3c;//使能看门狗 p_U2270B_Standby = 0;//单电源 PCON = 0x00; IP = 0x10;//uart you xian XXXPS PT1 PX1 PT0 PX0 led_light1 = 1; led_light = 0; p_U2270B_OutPut = 1; } /************************************************/ void f_readcard()//读卡 { EA = 0;//全关,防止影响跳变的定时器计时 WDT_CONTR = 0X3C;//喂狗 p_U2270B_CFE = 1;// delay_2(232); //>2.5ms /* // aor 用唤醒功能来防碰撞 p_U2270B_CFE = 0; delay_2(18);//start gap>150us write_bit(1);//10=操作码读0页 write_bit(0); write_password(&bankdata[24]);//密码block7 p_U2270B_CFE =1 ;// delay_2(516);//编程及确认时间5.6ms */ WDT_CONTR = 0X3C;//喂狗 led_light = 0; b.W = 0; while(!(read_ok == 1)) { //while(p_U2270B_OutPut);//等一个稳定的低电平?超时判断? while(!p_U2270B_OutPut);//等待上升沿的到来同步信号检测1 TR0 = 1; //deng xia jiang while(p_U2270B_OutPut);//等待下降沿 TR0 = 0; a.B.H = TH0; a.B.L = TL0; TH0 = TL0 = 0; TR0 = 1;//定时器晚启动10个周期 //同步头 if((324 < a.W) && (a.W < 353)) ;//检测同步信号1 else { TR0 = 0; TH0 = TL0 = 0; goto read_error; } //等待上升沿 while(!p_U2270B_OutPut); TR0 = 0; a.B.H = TH0; a.B.L = TL0; TH0 = TL0 = 0; TR0 = 1;//b.N1<<=8; if(a.B.L < 195);//0.5p else { TR0 = 0; TH0 = TL0 = 0; goto read_error; } //读0~7块的数据 for(j = 0;j < 28;j++) { //uchar i; for(i = 0;i < 16;i++)//8个位 { //等待下降沿的到来 while(p_U2270B_OutPut); TR0 = 0; a.B.H = TH0; a.B.L = TL0; TH0 = TL0 = 0; TR0 = 1; if(t2_max < a.W/*)&&(a.W < t2_max)*/)//1P { b.W >>= 2;//先左移再赋值 b.B.L += 0xc0; i++; } else if(t1_min < a.B.L/*)&&(a.B.L < t1_max)*/)//0.5p { b.W >>= 1; b.B.L += 0x80; } else { TR0 = 0; TH0 = TL0 = 0; goto read_error; } i++; while(!p_U2270B_OutPut);//上升 TR0 = 0; a.B.H = TH0; a.B.L = TL0; TH0 = TL0 = 0; TR0 = 1; if(t2_min < a.W/*)&&(a.W < t2_max)*/)//1P { b.W >>= 2; i++; } else if(t1_min < a.B.L/*a.W)&&(a.B.L < t1_max)*/)//0.5P //else if(!(a.W==0)) { b.W >>= 1; //temp+=0x00; //led_light1=0;led_light=1;delay_2(40000); } else { TR0 = 0; TH0 = TL0 = 0; goto read_error; } i++; } //取出奇位 DATA = b.B.L; BIT13 = BIT7; BIT12 = BIT5; BIT11 = BIT3; BIT10 = BIT1; DATA = b.B.H; BIT17 = BIT7; BIT16 = BIT5; BIT15 = BIT3; BIT14 = BIT1; bankdata[j] = DATA1; } read_ok = 1;//读卡完成了 read_error: _nop_(); } } /***************************************************/ void f_writecard(uchar x)//写卡 { p_U2270B_CFE = 1; delay_2(232); //>2.5ms //psw=0 standard write if (x == write_command0)//写密码:初始化密码 { uchar i; uchar data *data p; p = cominceptbuff; p_U2270B_CFE = 0; delay_2(31);//start gap>330us write_bit(1);//写操作码1:10 write_bit(0);//写操作码0 write_bit(0);//写锁定位0 for(i = 0;i < 35;i++) { write_bit(1);//写数据位1 } p_U2270B_CFE = 1; led_light1 = 0; led_light = 1; delay_2(40000);//测试使用 //write_block(cominceptbuff[4],p); p_U2270B_CFE = 1; bankdata[20] = cominceptbuff[0];//密码存入 bankdata[21] = cominceptbuff[1]; bankdata[22] = cominceptbuff[2]; bankdata[23] = cominceptbuff[3]; } else if (x == write_command1)//配置卡参数:初始化 { uchar data *data p; p = cominceptbuff; write_bit(1);//写操作码1:10 write_bit(0);//写操作码0 write_bit(0);//写锁定位0 write_block(cominceptbuff[4],p); p_U2270B_CFE= 1; } //psw=1 pssword mode else if(x == write_command2) //密码写数据 { uchar data*data p; p = &bankdata[24]; write_bit(1);//写操作码1:10 write_bit(0);//写操作码0 write_password(p);//发口令 write_bit(0);//写锁定位0 p = cominceptbuff; write_block(cominceptbuff[4],p);//写数据 } else if(x == write_command3)//aor //唤醒 { //cominceptbuff[1]操作码10 X xxxxxB uchar data *data p; p = cominceptbuff; write_bit(1);//10 write_bit(0); write_password(p);//密码 p_U2270B_CFE = 1;//此时数据不停的循环传出 } else //停止操作码 { write_bit(1);//11 write_bit(1); p_U2270B_CFE = 1; } p_U2270B_CFE = 1; delay_2(560);//5.6ms } /************************************/ void f_clearpassword()//清除密码 { uchar data *data p; uchar i,x; p = &bankdata[24];//原密码 p_U2270B_CFE = 0; delay_2(18);//start gap>150us //操作码10:10xxxxxxB write_bit(1); write_bit(0); for(x = 0;x < 4;x++)//发原密码 { DATA = *(p++); for(i = 0;i < 8;i++) { write_bit(BIT0); DATA >>= 1; } } write_bit(0);//锁定位0:0 p = &cominceptbuff[0]; write_block(0x00,p);//写新配置参数:pwd=0 //密码无效:即清除密码 DATA = 0x00;//停止操作码00000000B for(i = 0;i < 2;i++) { write_bit(BIT7); DATA <<= 1; } p_U2270B_CFE = 1; delay_2(560);//5.6ms } /*********************************/ void f_changepassword()//修改密码 { uchar data *data p; uchar i,x,addr; addr = 0x07;//block7 p = &Nkey_a[0];//原密码 DATA = 0x80;//操作码10:10xxxxxxB for(i = 0;i < 2;i++) { write_bit(BIT7); DATA <<= 1; } for(x = 0;x < 4;x++)//发原密码 { DATA = *(p++); for(i = 0;i < 8;i++) { write_bit(BIT7); DATA >>= 1; } } write_bit(0);//锁定位0:0 p = &cominceptbuff[0]; write_block(0x07,p);//写新密码 p_U2270B_CFE = 1; bankdata[24] = cominceptbuff[0];//密码存入 bankdata[25] = cominceptbuff[1]; bankdata[26] = cominceptbuff[2]; bankdata[27] = cominceptbuff[3]; DATA = 0x00;//停止操作码00000000B for(i = 0;i < 2;i++) { write_bit(BIT7); DATA <<= 1; } p_U2270B_CFE = 1; delay_2(560);//5.6ms } /***************************子函数***********************************/ void write_bit(bit x)//写一位 { if(x) { p_U2270B_CFE = 1; delay_2(32);//448*11.0592/120=42延时448us p_U2270B_CFE = 0; delay_2(28);//280*11.0592/120=26写1 } else { p_U2270B_CFE = 1; delay_2(92);//192*11.0592/120=18 p_U2270B_CFE = 0; delay_2(28);//280*11.0592/120=26写0 } } /*******************写一个block*******************/ void write_block(uchar addr,uchar data *data p) { uchar i,j; for(i = 0;i < 4;i++)//block0数据 { DATA = *(p++); for(j = 0;j < 8;j++) { write_bit(BIT0); DATA >>= 1; } } DATA = addr <<= 5;//0地址 for(i = 0;i < 3;i++) { write_bit(BIT7); DATA <<= 1; } } /*************************************************/ void write_password(uchar data *data p) { uchar i,j; for(i = 0;i < 4;i++)// { DATA = *(p++); for(j = 0;j < 8;j++) { write_bit(BIT0); DATA >>= 1; } } } /*************************************************/ void main() { initial(); TI = RI = 0; ES = 1; EA = 1; delay_2(28); //f_readcard(); while(1) { f_readcard(); //读卡 f_writecard(command1); //写卡 f_clearpassword(); //清除密码 f_changepassword(); //修改密码 } }
标签: 12345
上传时间: 2017-10-20
上传用户:my_lcs
这是一篇哈尔滨工业大学2012年 物理电子学工学博士的毕业论文。相干多普勒激光雷达是测量遥感风场和运动目标速度的有力工具。相干多普勒激光雷达的发射源普遍使用单纵模激光器,而锁模激光所具有的宽频谱、窄脉宽、高峰值功率等特性使其在作为相干激光雷达发射源方面具有潜在的应用价值。本文从理论上和实验上对基于锁模激光的相干多普勒激光雷达进行了研究。 理论上,在单频外差探测原理的基础上,考虑了具有 m+1 个模式、纵模间隔为 ω 的本振光,与发生了 Δω 频移的信号光相干拍频后的理论模型,证明了相位差恒定的锁模激光可以实现相干混频,并可以通过低通滤波或 FFT 频谱分析的方式检测出差频信号。利用这一理论模型进行了数值模拟计算,分析了信号光在不同的频移值时的拍频波形,讨论了实现相干探测本振光与信号光应满足的条件。 基于相干多普勒激光雷达系统对发射光源的要求,进行了锁模激光器的实验研究。通过使用不同的锁模器件得到锁模激光输出,其中主动锁模和调 Q 主动锁模都获得了单脉冲宽度在百皮秒量级、锁模深度 100%、锁模几率 95%以上的稳定的锁模脉冲序列输出。对被动锁模、主动锁模、调 Q 主动锁模的激光输出特性进行了对比研究,主动锁模脉冲序列包络时间较长但峰值功率较低,而调 Q 主动锁模峰值功率高但包络时间较短,不同类型的激光输出为后续的相干测速实验提供了多种选择。 利用声光移频器模拟外差探测中信号光发生的多普勒频移,进行了锁模激光拍频实验研究,并与单纵模激光拍频实验结果进行了比较。使用锁模激光在频移为 30 ~ 80 MHz 的范围内进行了拍频实验研究,拍频波形及信号处理的结果均与理论分析相符, 测量结果的相对误差在 0.5%以下。 分别使用脉宽为 10 ns和 16 ns 的调 Q 单纵模脉冲进行拍频,在信号光频移为 150 MHz 时测量结果的相对误差分别为 3.7%和 1.6%。对比实验结果发现,调 Q 单纵模脉冲由于有限的脉宽限制了拍频后包络的数量,导致误差相对较大,而锁模脉冲序列由于具有较长包络时间,在测量较低频移值时仍具有较高的精度,即测量低速目标时更具有优势。在具有较长包络时间的同时,锁模激光还具有高峰值功率和窄脉宽的特点。使用光纤耦合的方式进行了相干拍频实验,得到了稳定的相干拍频波形,FFT 频谱分析的结果与设定值和理论分析相符。
标签: 激光雷达
上传时间: 2022-02-12
上传用户:
随着物理治疗在现代医学中越来越广泛的应用,电疗、光疗以及磁疗等物理治疗设备的研究逐步受到人们的重视。短波治疗是一种高频电疗法,具有消除组织炎症、促进细胞代谢等显著作用。目前,市场上短波治疗设备般基于多级放大的原理,具有效率低、损耗大等缺点,因此,设计一种高效、低损耗的短波治疗设备具有重要的研究意义本课题设计一款短波治疗仪设备。该系统利用E类高效功放电路作为射频信号源,通过 Pspice软件将设计的E类功放仿真验证,实现输出频率为2712MHz,输出最大功率50W的射频信号源发生电路。系统利用电压和电流互感耦合器以及檢波电路设计一种驻波比检测电路,经验证达到很好的检测效果。在阻抗自动匹配电路模块中,通过继电器控制T型匹配网络中串联以及并联的电容阵列,实现阻抗的自动匹配,并利用 Matlab对r型匹配网络的匹配区域进行仿真验证。中央处理器部分电路作为控制单元,将驻波比检测电路中檢测到的电压驻波比进行处理,根据处理结果去调整继电器开关状态,从而对匹配网络的匹配状况进行实时调整。在射频信号源和匹配网络之间,利用传输线变压器对射频信号源和输出进行电器隔离。此外,设计一种基于分步原理的阻抗匹配方法,在保证匹配速度的同时,也确保了匹配精度达到较好的匹配效果。最后,对短波治疗仪整体设备进行测试,结果表明该短波治疗仪电路达到预期设计目标.关键词:E类功率放大;驻波比检测;自动阻抗匹配;匹配网络;阻抗匹配算法
上传时间: 2022-03-24
上传用户:XuVshu
一、产品概述SX1278 是一款高性能、低功耗、远距离的微功率无线模块,内部自动扩频计算和硬件校验处理,用户不需要了解太复杂的射频知识,和硬件调,只是需要调试底层 SPI 通信,和理解好函数的意义。就可以轻松的应用此模块。模块非常适合远距离,低数据量和低功耗等应用场合。模块的射频芯片基于扩频跳频技术,在稳定性、抗干扰能力以及接收灵敏度上都超越现有的 GFSK 射频模块。二、产品特点基于 LoRa 扩频调制技术。半双工通讯,SPI 通信控制。420~450MHz 免申请频段,其他频段可定制。免调试,2.1-3.6V 宽电压范围。微功率发射,标准 100mW,设置功率寄存器。接收灵敏度高达-148dBm,最大发射功率+20dBm。硬件检验,和硬件扩频编码,可以自定义调频机制。接收,发射,CAD 检测,休眠等多种模式任意却换。贴片封装,方便客户嵌入自己的 PCB。C 语言函数封装,直接调入函数接口。三、应用领域智能家居、智能交通、传感网络;工业自动化、农业现代化、建筑智能化;自动抄表系统;水利、油田、矿井、气象等设备信息采集;路灯控制、电网监测、风光互补系统;工业设备数据无线传输以及工业环境监测;掌机数据采集,嵌入式设备数据传输;其他一切需要无线代替有线通讯的情况
标签: sx1278
上传时间: 2022-03-26
上传用户:trh505
本书系统地介绍了通信建模仿真方法和模型验证技术,并结合作者近年在教学科研中所设计的大量基础的和较深入的建模仿真实例,详细讨论了 Matlab/Simulink 作为仿真实现平台在电子与通信工程中应用的基本方法、技巧和难点。本书重点讨论了建模仿真原理和相关的数值计算方法、模拟通信系统、模数转换、调制与编码、信道模拟、载波与符号同步、信道均衡、跳频系统和直接扩频系统、通信模型正确性评估、仿真数据验证和数据处理技术等内容,并在仿真实例中展示了科学研究论文和报告所必须的数据处理和表现技巧。 本书提供了约 150 个建模仿真实例, 80多道思考题,以及全部实例代码和一个电子教案。这些实例根据基本数学原理,结合 Simulink 的 S 函数编程,也使用了通信工具箱、信号处理工具箱和相关模型库的模块和函数,以便于读者追源求本,深入理解建模和仿真的实质。 本书可作为高等院校通信工程、电子信息类专业的本科生和研究生系统仿真课程的教材或进行相关课题研究的参考书,也可作为相关专业课程设计和毕业设计等综合性实践教学的指导材料,还可供通信工程专业技术人员、教师等作为解决通信系统设计、评估和建模仿真领域实际问题的参考资料。
上传时间: 2022-04-23
上传用户:
1 产品简介1.1 产品特点下载速度快,超越 JLINK V8,接近 JLINK V9采用 2.4G 无线通信,自动跳频支持 1.8V~5V 设备,自动检测支持 1.8V/3.3V/5V 电源输出,上位机设置支持目标板取电/给目标板供电支持 MDK/IAR 编译器,无需驱动,不丢固件支持 Cortex M0/M1/M3/M4/M7 等内核 ARM 芯片支持仿真调试,支持代码下载、支持虚拟串口提供 20P 标准 JTAG 接口、提供 4P 简化 SWD 接口支持 XP/WIN7/WIN8/WIN10 等操作系统尺寸小巧,携带方便1.2 基本参数产品名称 ATK-HSWLDBG 高速无线调试器产品型号 ATK-HSWLDBG支持芯片 ARM Cortex M0/M1/M3/M4/M7 全系列通信方式 USB(免驱)仿真接口 JTAG、SWD支持编译器 MDK、IAR串口速度 10Mbps(max)烧录速度 10M通信距离 ≥10MTX 端工作电压 5V(USB 供电)TX 端工作电流 151mARX 端工作电压 3.3V/5V(USB 或者 JTAG 或者 SWD 供电)RX 端工作电流 132mA@5V工作温度 -40℃~+85℃尺寸 66.5mm*40mm*17mm1.3 产品实物图图 发送端图 接收端图 接收端接口输出电压示意图,所有标注 GND 的引脚均为地线1.4 接线示意图高速无线调试器发送端,接线图:高速无线调试器接收端,JTAG/SWD 接口供电,接线示意图:高速无线调试器接收端,USB 接口供电,接线示意图:1.5 高速无线调试器工作原理示意图电脑端 高速无线调试器发送端 USB 接口目标 MCU 高速无线调试器接收端 JTAG/SWD 接口目标 MCU 高速无线调试器接收端5V 电源JTAG/SW 接口 USB 接口高速无线调试器JTAG/SW 接口 目标 MCU 高速无线调试器接收端USB 接口 电脑端 高速无线调试器发送端无线模块无线模块2、MDK 配置教程注意:低版本 MDK 对高速无线调试器的支持不完善,推荐 MDK5.23及以上版本。MDK5.23~MDK5.26 对高速 DAP 的支持都有 bug,必须打补丁。参考“mdk 补丁”文件夹下的相关文档解决。SWD 如果接3 线,请查看第 10 章,常见问题 1。要提高速度,参考 4.2 节配置无线参数为大包模式。如果无线通信不稳定,参考常见问题 4。
标签: 高速无线调试器
上传时间: 2022-06-04
上传用户:d1997wayne