飞思卡尔锁相环

合集下载

PLL锁相环程序

PLL锁相环程序

飞思卡尔XS128系列(一)PLL锁相环通俗点说,设置PLL锁相环就相当于超频,单片机超频的原因和PC机是一个道理。

分频的主要原因是外设需要的工作频率往往远低于CPU/MEMORY,这也和PC机南北桥的原理类似。

相对来说,PLL锁相环的设置还是比较简单的,因为东西很死,完全可以照搬。

只是大家也不要太贪,设置太高相对来说不够稳定,进行过PC机超频的应该很有体会,一般我们现在用的XS128我觉得设置在80MHz是比较合适的,相比前几届比赛用的DG128,这个频率已经蛮高的了。

还有就是SYNR,REFDV只有在CLKSEL_PLLSEL=0的情况下才能写入,不过这是系统默认状态。

多半大家可能还会有以下几点疑问:1.PLL锁相环怎么设置?答:通过写REFDV(CRG参考分频寄存器)和SYNR(CRG合成器寄存器)进行设置2.代码里while(!CRGFLG_LOCK);这句是干什么的?答:时钟校正同步3.为什么代码中会有多多少少的几句空语句?答:锁相环从设定到最后稳定还是需要一点点时间的,所以需要加几条空指令/*************************************************************************** ***********------------------------------------Code Warrior 5.0Target : MC9S12XS128Crystal: 16.000Mhz============================================本程序主要包括以下功能:设定系统工作在xxMHZ bus clock时钟下;by:庞辉**************************************************************************** *************/#include <hidef.h> /*common defines and macros*/#include <MC9S12XS128.h> /*derivative information*/#pragma LINK_INFO DERIVATIVE "mc9s12xs128"void SetBusCLK_16M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR=0x00 | 0x01; //VCOFRQ[7:6];SYNDIV[5:0]//fVCO= 2*fOSC*(SYNDIV + 1)/(REFDIV + 1)//fPLL= fVCO/(2 × POSTDIV)//fBUS= fPLL/2//VCOCLK Frequency Ranges VCOFRQ[7:6]//32MHz <= fVCO <= 48MHz 00//48MHz < fVCO <= 80MHz 01//Reserved 10//80MHz < fVCO <= 120MHz 11REFDV=0x80 | 0x01; //REFFRQ[7:6];REFDIV[5:0]//fREF=fOSC/(REFDIV + 1)//REFCLK Frequency Ranges REFFRQ[7:6]//1MHz <= fREF <= 2MHz 00//2MHz < fREF <= 6MHz 01//6MHz < fREF <= 12MHz 10//fREF > 12MHz 11//pllclock=2*osc*(1+SYNR)/(1+REFDV)=32MHz;POSTDIV=0x00; //4:0, fPLL= fVCO/(2xPOSTDIV)//If POSTDIV = $00 then fPLL is identical to fVCO (divide by one)._asm(nop); //BUS CLOCK=16M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_32M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0x40 | 0x03; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=64MHz; REFDV=0x80 | 0x01;POSTDIV=0x00;_asm(nop); //BUS CLOCK=32M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_40M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x04;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=80MHz;_asm(nop); //BUS CLOCK=40M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_48M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x05;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=96MHz;_asm(nop); //BUS CLOCK=48M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it;CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_64M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x07;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=128MHz; _asm(nop); //BUS CLOCK=64M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it; CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_80M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x09;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=160MHz; _asm(nop); //BUS CLOCK=80M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it; CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_88M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x0a;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=176MHz; _asm(nop); //BUS CLOCK=88M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it; CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_96M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x0b;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=192MHz; _asm(nop); //BUS CLOCK=96M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it; CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_104M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x0c;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=208MHz; _asm(nop); //BUS CLOCK=104M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it; CLKSEL_PLLSEL =1; //engage PLL to system;}void SetBusCLK_120M(void){CLKSEL=0X00; //disengage PLL to systemPLLCTL_PLLON=1; //turn on PLLSYNR =0xc0 | 0x0d;REFDV=0x80 | 0x01;POSTDIV=0x00; //pllclock=2*osc*(1+SYNR)/(1+REFDV)=240MHz; _asm(nop); //BUS CLOCK=120M_asm(nop);while(!(CRGFLG_LOCK==1)); //when pll is steady ,then use it; CLKSEL_PLLSEL =1; //engage PLL to system;}void main(void){EnableInterrupts;for(;;){_asm(nop);}}。

飞思卡尔锁相环

飞思卡尔锁相环

备战飞思卡尔智能车大赛.开始模块总结.锁相环设置.公式: PLLCLK=2*OSCCLK*(SYNR+1)/(REFDV+1),fbus=PLLCLK/2void INIT_PLL(void){CLKSEL &= 0x7f; //选用外部时钟.准备设置锁相环PLLCTL &= 0x8F; //禁止锁相环SYNR = 0xc9; //设置SYNRREFDV = 0x81; //设置REFDVPLLCTL |=0x70; //锁相环使能asm NOP; asm NOP; //两个机器周期缓冲时间while(!(CRGFLG&0x08)); //等待锁相环锁定CLKSEL |= 0x80; //设置锁相环为时钟源}飞思卡尔XS128的PLL锁相环详细设置说明——关于如何提高总线工作频率PLL锁相环就相当于超频单片机超频的原因和PC机是个一道理。

分频的主要原因是外设需要的工作频率往往远低于CPU/MEMORY这也和PC机南北桥的原理类似。

总线频率设置过程1、禁止总中断2、寄存器CLKSEL(时钟选择寄存器)的第七位置0即CLKSEL_PLLSEL=0。

选择时钟源为外部晶振OSCCLK(外接晶振频率)在PLL(锁相环)程序执行前内部总线频率为OSCCLK/23. PLLCTL_PLLON=1 打开PLL4.设置SYNR时钟合成寄存器、REFDV时钟分频寄存器、POSTDIV三个寄存器的参数5、_asm(nop) _asm(nop);加入两条空指令使锁相环稳定6、while(!(CRGFLG_LOCK==1));//时钟校正同步7、CLKSEL_PLLSEL=1; 下面详细说一下频率的计算一、时钟合成寄存器SYNR寄存器结构VCOFRQ[1:0]控制压控振动器VCO的增益默认值为00VCO的频率与VCOFRQ[1:0]对应表什么是锁相环呢?MCU的支撑电路一般需要外部时钟来给MCU提供时钟信号,而外部时钟的频率可能偏低,为了使系统更加快速稳定运行,需要提升系统所需要的时钟频率。

锁相环工作原理

锁相环工作原理

锁相环工作原理锁相环路是一种反馈电路,锁相环的英文全称是Phase-Locked Loop,简称PLL。

其作用是使得电路上的时钟和某一外部时钟的相位同步。

因锁相环可以实现输出信号频率对输入信号频率的自动跟踪,所以锁相环通常用于闭环跟踪电路。

锁相环在工作的过程中,当输出信号的频率与输入信号的频率相等时,输出电压与输入电压保持固定的相位差值,即输出电压与输入电压的相位被锁住,这就是锁相环名称的由来。

在数据采集系统中,锁相环是一种非常有用的同步技术,因为通过锁相环,可以使得不同的数据采集板卡共享同一个采样时钟。

因此,所有板卡上各自的本地80MHz和20MHz时基的相位都是同步的,从而采样时钟也是同步的。

因为每块板卡的采样时钟都是同步的,所以都能严格地在同一时刻进行数据采集。

锁相环路是一个相位反馈自动控制系统。

它由以下三个基本部件组成:鉴相器(PD)、环路滤波器(LPF)和压控振荡器(VCO)。

锁相环的工作原理:1. 压控振荡器的输出经过采集并分频;2. 和基准信号同时输入鉴相器;3. 鉴相器通过比较上述两个信号的频率差,然后输出一个直流脉冲电压;4. 控制VCO,使它的频率改变;5. 这样经过一个很短的时间,VCO 的输出就会稳定于某一期望值。

锁相环可用来实现输出和输入两个信号之间的相位同步。

当没有基准(参考)输入信号时,环路滤波器的输出为零(或为某一固定值)。

这时,压控振荡器按其固有频率fv进行自由振荡。

当有频率为fR的参考信号输入时,uR 和uv同时加到鉴相器进行鉴相。

如果fR和fv相差不大,鉴相器对uR和uv进行鉴相的结果,输出一个与uR和uv的相位差成正比的误差电压ud,再经过环路滤波器滤去ud中的高频成分,输出一个控制电压uc,uc将使压控振荡器的频率fv(和相位)发生变化,朝着参考输入信号的频率靠拢,最后使fv= fR,环路锁定。

环路一旦进入锁定状态后,压控振荡器的输出信号与环路的输入信号(参考信号)之间只有一个固定的稳态相位差,而没有频差存在。

锁相环pll原理与应用

锁相环pll原理与应用
锁相环pll原理与应用
$number {01}
目 录
• 锁相环PLL的基本原理 • 锁相环PLL的种类与特性 • 锁相环PLL的应用 • 锁相环PLL的发展趋势与挑战 • 锁相环PLL的设计与实现
01
锁相环PLL的基本原理
PLL的基本结构
鉴相器(PD)
用于比较输入信号和反馈信号的相位 差。
压控振荡器(VCO)
相位同步
锁相环PLL用于电力系统的相位同步,确保不同电源之间的相位一 致,提高电力系统的稳定性。
频率跟踪
锁相环PLL用于电力系统的频率跟踪,实时监测电网频率变化,确 保电力系统的正常运行。
故障定位
通过分析电网信号的相位和频率变化,结合锁相环PLL实现电力故 障的快速定位和排查。
其他领域的应用
电子测量
PLL的发展趋势
高速化
随着通信技术的发展, 对信号的传输速率要求 越来越高,锁相环PLL 的频率合成速度和跟踪
速度也在不断加快。
数字化
随着数字信号处理技术 的进步,越来越多的锁 相环PLL开始采用数字 控制方式,提高了系统 的稳定性和灵活性。
集成化
为了减小电路体积和降 低成本,锁相环PLL的 集成化程度越来越高, 越来越多的功能被集成
软件PLL具有灵活性高、可重 构性好等优点,但同时也存在 计算量大、实时性差等缺点。
各种PLL的优缺点比较
1 2
3
模拟PLL
优点是响应速度快、跟踪性能好;缺点是元件参数漂移、温 度稳定性差。
数字PLL
优点是精度高、稳定性好、易于集成;缺点是响应速度慢、 跟踪性能较差。
软件PLL
优点是灵活性高、可重构性好;缺点是计算量大、实时性差 。

锁相环工作原理

锁相环工作原理

锁相环工作原理锁相环是一种常见的电子设备,用于调整和稳定信号的相位。

它在许多领域中都有广泛的应用,包括通信系统、雷达、无线电、光学和音频设备等。

下面将详细介绍锁相环的工作原理。

一、引言锁相环是一种反馈控制系统,它通过比较输入信号和参考信号的相位差,并根据差异来调整输出信号的相位,从而使输出信号与参考信号保持同步。

锁相环通常由相位比较器、低通滤波器、电压控制振荡器(VCO)和分频器等组成。

二、工作原理1. 相位比较器相位比较器是锁相环的核心部件之一。

它将输入信号和参考信号进行相位比较,并输出相位差。

常见的相位比较器有边沿比较器和恒幅比较器。

边沿比较器通过检测输入信号和参考信号的边沿来计算相位差,而恒幅比较器则通过比较输入信号和参考信号的幅度来计算相位差。

2. 低通滤波器相位比较器输出的相位差信号通常包含噪声和高频成份,需要经过低通滤波器进行滤波处理。

低通滤波器的作用是去除高频噪声,使得输出信号更加平滑。

3. 电压控制振荡器(VCO)VCO是锁相环中的一种振荡器,其输出频率可以通过调节输入电压来控制。

VCO的输出频率与输入电压成正比。

在锁相环中,VCO的输出频率被用作反馈信号,通过调节输入电压来实现相位的调整。

4. 分频器分频器用于将VCO的输出信号分频,以提供参考信号给相位比较器。

分频器的作用是将高频信号转换为低频信号,使得相位比较器能够更精确地进行相位比较。

三、工作流程锁相环的工作流程如下:1. 输入信号和参考信号经过相位比较器进行相位比较,得到相位差信号。

2. 相位差信号经过低通滤波器进行滤波处理,去除高频噪声。

3. 滤波后的信号作为输入电压,调节VCO的输出频率。

4. VCO的输出信号经过分频器分频后作为参考信号,再次经过相位比较器进行相位比较。

5. 反复循环上述步骤,直到输入信号和参考信号的相位差趋于稳定,锁定在一个特定的相位差值上。

6. 输出信号与参考信号保持同步,实现相位的稳定和调整。

飞思卡尔MC9S12XS128功能模块驱动

飞思卡尔MC9S12XS128功能模块驱动

用了一年多飞思卡尔MC9S12XS128这款处理器,现在总结下各个功能模块的驱动.//锁相环时钟的初始化总线频率为40MHz(总线时钟为锁相环时钟的一半)//晶振为11.0592MHzvoid PLL_init(void) //PLLCLK=2*OSCCLK*(SYNR+1)/(REFDV+1) { //锁相环时钟= 2*11.0592*(39+1)/(10+1)=80MHz 总线时钟为40MHzREFDV=0x0A;SYNR=0x67; //0110_0111 低6位的值为19,高两位的值为推荐值while(CRGFLG_LOCK != 1);CLKSEL_PLLSEL = 1; //选定锁相环时钟//FCLKDIV=0x0F; //Flash Clock Divide Factor 16M/16=1M}//周期中断定时器的初始化-// //周期中断通道1用于脉冲累加器的定时采样,定时周期为: 10ms= (199+1)*(1999+1)/(40M) (没有使用)//周期中断通道0用于控制激光管的轮流发射,定时周期为: 2000us= (399+1)*(199+1)/(40M)//2011/4/4 15:24 定时时间改为1msvoid PIT_init(void){PITCFLMT_PITE = 0; // 禁止使用PIT模块 PITCFLMT :PIT 控制强制加载微计数器寄存器。

PITCE_PCE0 = 1; // 使能定时器通道0//PITCE_PCE1 = 1; //使能定时器通道1PITMUX = 0; //通道0,和通道1均选择8位微计数器0//修改时间只需要改下面四行PITMTLD0 = 199; //向8位微计数器中加载的值PITLD0 = 199; //向16位计数器中加载的值//PITMTLD1 = 39; //向8位微计数器中加载的值 8位,最大值不要超过255//PITLD1 = 1999; //向16位计数器中加载的值PITINTE |= 0x01; //使能定时器通道0的中断PITCFLMT_PITE = 1;//使能PIT模块}//脉冲累加器的初始化, PT7口外接光电编码器//最新修改: 2011/3/25 16:53void PT7_PulAcc_Init(void){DDRT &= 0x77;//设置PT7,PT3口为输入(硬件上PT7,PT3通过跳线联到了一块)PERT |= 0x80; //使能通道7的上拉电阻PPST &= 0x7f; //电阻设为上拉电阻TCTL4 &= 0x3f; //禁止PT3的输入捕捉功能PACTL = 0x50; //启动脉冲累加计数器,上升沿触发,禁止触发中断和溢出中断,主定时器禁止}//通道1用于控制舵机1 PWM 高电平有效,//通道3用于控制电机1 PWM 低电平有效,这与前两代车高电平有效有区别!!!!!//通道7用于给上排激光管提供PWM信号 PWM高电平有效!!!!!//通道6用于给下排激光管提供PWM信号 PWM高电平有效!!!!!// 2011-03-17 7:56 增加了A端口的使用新增通道6//2011-6-9 23:03 //增加了通道4,5的联合使用,用于控制下排方向舵机 void PWM_init(void){PWME = 0x00;//PWM禁止PWMPRCLK = 0x03; // ClockA=40M/8=5M, Clock B = 40M/1=40M PWMSCLB = 10; // Clock SB= 40/2*10= 2MHz(供电机)PWMSCLA = 5; // SA = Clock A/2*5 = 5M/10 = 500K = SA 用于控制舵机PWMPOL = 0xe2; //1110_0010通道7,通道6与通道1、通道5先输出高电平然后输出低电平,POLx=1先输出高电平后输出低电平; PPOLx=0先输出低电平)PWMCAE = 0x00; // 左对齐输出(CAEx=0为左对齐,反之为中心对齐)//PWMCLK = 0010_1010 (0 1 4 5位控制SA_1;或A_0; 2 3 6 7位控制SB_1 或B_0)//为PWM通道1选择时钟 SA(500KHz),//为PWM通道5选择时钟 SA(500KHz),//为通道3选择时钟 SB(10MHz)//为通道7选择时钟B(40MHz)//为通道6选择时钟B(40MHz)PWMCLK = 0x2A; //0010_1010PWMCTL = 0x70; //0111_0000 CON45=1,把通道4,5联合使用。

锁相环的基本原理锁相环基本原理及其应用

锁相环的基本原理锁相环基本原理及其应用

锁相环的基本原理锁相环基本原理及其应用锁相环的基本原理锁相环基本原理及其应用锁相环及其应用所谓锁相环路,实际是指自动相位控制电路(APC),它是利用两个电信号的相位误差,通过环路自身调整作用,实现频率准确跟踪的系统,称该系统为锁相环路,简称环路,通常用PLL表示。

锁相环路是由鉴相器(简称PD)、环路滤波器(简称LPF或LF)和压控振荡器(简称VCO)三个部件组成闭合系统。

这是一个基本环路,其各种形式均由它变化而来PLL概念设环路输入信号v= Viomimsin(ωit+φi)环路输出信号v= Vosin(ωot+φo)——其中ωo=ωr+△ωo通过相位反馈控制,最终使相位保持同步,实现了受控频率准确跟踪基准信号频率的自动控制系统称为锁相环路。

PLL构成由鉴相器(PD)环路滤波器(LPF)压控振荡器(VCO)组成的环路。

PLL原理从捕捉过程→锁定A.捕捉过程(是失锁的)a. b.φi┈φi均是随时间变化的,经相位比较产生误差相位φe=φi-φo,也是变化的。

φe(t)由鉴相器产生误差电压v(t)=f(φde)完成相位误差—电压的变换作用。

v(t)为交流电压。

dc.v(t)经环路滤波,滤除高频分量和干扰噪声得到纯净控制电压,由VCO产生d控制角频差△ω0,使ω0随ωi变化。

B.锁定(即相位稳定)a. b.一旦锁定φe(t)=φe∞(很小常数)v(t)= V(直流电压)ddω0≡ωi输出频率恒等于输入频率(无角频差,同时控制角频差为最大△ω0max, 即ω0=ωr+△ω0max。

ωr为VCO固有振荡角频率。

)锁相基本组成和基本方程(时域)各基本组成部件鉴相器(PD)数学模式v(t)=AsinφdDe(t)相位模式环路滤波器(LPF) 数学模式v(t)=A(P) v(t)cFd相位模式压控振荡器(VCO)数学模式相位模式环路模型相位模式:指锁相环(PLL)输入相位和输出相位的反馈调节关系。

相位模型:把鉴相器,环路滤波器和压控振荡器三个部件的相位模型依次级联起来就构成锁相相位模型。

锁相环指标 -回复

锁相环指标 -回复

锁相环指标-回复什么是锁相环指标?锁相环(Phase-Locked Loop,简称PLL)是一种用于时钟生成和频率合成的电路。

锁相环指标是对锁相环电路性能进行评估和描述的一系列参数。

这些指标可以用来评估PLL的稳定性、带宽、相位噪声等重要性能。

1. 锁相环的基本原理和结构锁相环由相位比较器、低通滤波器、电压控制振荡器(Voltage-Controlled Oscillator,简称VCO)和分频器组成。

其基本原理是通过不断调整VCO的频率和相位,使其与参考信号保持同步。

相位比较器将参考信号和VCO输出的信号进行相位比较,并产生一个误差信号。

这个误差信号经过低通滤波器后,被送至VCO进行频率和相位调整。

2. 锁相环指标的分类锁相环指标通常可以分为稳定性指标、带宽指标、相位噪声指标等几个方面。

稳定性指标主要包括:锁定时间、追踪范围、捕获范围等。

锁定时间是指锁相环从失锁状态转移到锁定状态所需的时间,是评估锁相环速度的重要指标。

追踪范围是指锁相环能追踪的输入频率范围,超出追踪范围的输入信号会导致失锁。

捕获范围是指锁相环能捕获的输入频率范围,超出捕获范围的输入信号也会导致失锁。

带宽指标主要包括:环路带宽、相位裕度等。

环路带宽是指锁相环的频率响应范围,描述了PLL对输入信号的跟随能力。

相位裕度是指锁相环频率响应的相位裕量,决定了锁定后的相位稳定度。

相位噪声指标主要包括:相位噪声密度、杂散频率等。

相位噪声密度是指在单位频率范围内,锁相环输出信号的相位噪声功率。

杂散频率是指锁相环输出信号中除了基频外的其它频率分量。

3. 如何评估锁相环指标评估锁相环指标通常需要进行实验测试或进行模拟仿真。

其中,常用的测试方法包括锁定时间测试、频率响应测试、相位噪声测试等。

在锁定时间测试中,输入一个频率变化较大的信号,观察锁相环从失锁到锁定所需的时间。

锁相环的响应快速且稳定的特性表示较好的锁定时间。

频率响应测试通常通过输入不同频率的正弦波信号,并测量锁相环输出的幅值和相位,以绘制幅频响应和相频响应曲线。

飞思卡尔单片机PLL时钟总线模块

飞思卡尔单片机PLL时钟总线模块

要设定PWM模块首先要确定片内总线时钟,MC9S12XS系列单片机增加了时钟产生器模块,锁定内部频率更高的压控振荡器VCO频率,作为系统时钟,单片机的内部时钟可达80MHz,片内总线时钟可达40MHz。

先给出一段例程Code:1.REFDV=0x07; //REFDIV=72.SYNR=0x53; //SYNDIV=193.while(LOCK!=1); //等待VCO稳定4.POSTDIV=0; //POSTDIV=0,VCO时钟=80MHz5.CLKSEL_PLLSEL=1; //选择由Fpll产生总线时钟,Fbus=Fpll/2=40MHz注:LOCK之前省去了寄存器名,这里是屏蔽不给发出来。

下面开始简单分析一下寄存器(1)时钟分频寄存器(CRG Reference Divider Register ,REFDV)REFDV寄存器的高两位REFFRQ[ 1:0 ]表示参考时钟范围REFDV的低六位为分频因子REFDV的值,有效值的范围为0~63.(2)时钟合成寄存器(CRG Synthesizer Register , SYNR)SYNR高两位控制压控振动器VCO的增益SYNR寄存器的低六位可写入0~63.可将锁相环时钟倍频1~64倍。

锁相环产生的时钟频率可由下面的公式得到PLLCLK=2 * OSCCLK * ( SYNR+1 ) / ( REFDV+1 )(3)锁相环寄存器(PLL Control Register , PLLCTL)CME:时钟监控允许位。

PLLON:锁相环电路允许位。

FM [ 1 : 0 ]:选择附加调频滤波器以降低VCO噪声,默认值表示不使用该滤波器,可写入01,10或11,表示参考频率相对于VCO偏高1%,2%,4%时自动调整。

FSTWKP:时钟快速唤醒CPU功能位。

PRE:CPU伪停止状态时,实时中断(RT1)允许位。

PCE:CPU虚拟停止时,看门狗(COP)允许位。

锁相环的组成和原理及应用

锁相环的组成和原理及应用

锁相环的组成和原理及应用一.锁相环的基本组成许多电子设备要正常工作,通常需要外部的输入信号与内部的振荡信号同步,利用锁相环路就可以实现这个目的。

锁相环路是一种反馈控制电路,简称锁相环(PLL)。

锁相环的特点是:利用外部输入的参考信号控制环路内部振荡信号的频率和相位。

因锁相环可以实现输出信号频率对输入信号频率的自动跟踪,所以锁相环通常用于闭环跟踪电路。

锁相环在工作的过程中,当输出信号的频率与输入信号的频率相等时,输出电压与输入电压保持固定的相位差值,即输出电压与输入电压的相位被锁住,这就是锁相环名称的由来。

锁相环通常由鉴相器(PD)、环路滤波器(LF)和压控振荡器(VCO)三部分组成,锁相环组成的原理框图如图8-4-1所示。

锁相环中的鉴相器又称为相位比较器,它的作用是检测输入信号和输出信号的相位差,并将检测出的相位差信号转换成uD(t)电压信号输出,该信号经低通滤波器滤波后形成压控振荡器的控制电压uC(t),对振荡器输出信号的频率实施控制。

二.锁相环的工作原理锁相环中的鉴相器通常由模拟乘法器组成,利用模拟乘法器组成的鉴相器电路如图8-4-2所示。

鉴相器的工作原理是:设外界输入的信号电压和压控振荡器输出的信号电压分别为:(8-4-1)(8-4-2)式中的ω0为压控振荡器在输入控制电压为零或为直流电压时的振荡角频率,称为电路的固有振荡角频率。

则模拟乘法器的输出电压uD 为:用低通滤波器LF将上式中的和频分量滤掉,剩下的差频分量作为压控振荡器的输入控制电压uC(t)。

即uC(t)为:(8-4-3)式中的ωi为输入信号的瞬时振荡角频率,θi(t)和θO(t)分别为输入信号和输出信号的瞬时位相,根据相量的关系可得瞬时频率和瞬时位相的关系为:即(8-4-4)则,瞬时相位差θd为(8-4-5)对两边求微分,可得频差的关系式为(8-4-6)上式等于零,说明锁相环进入相位锁定的状态,此时输出和输入信号的频率和相位保持恒定不变的状态,uc(t)为恒定值。

锁相环_精品文档

锁相环_精品文档

锁相环锁相环,又称为锁相放大器或者锁相放大器,是一种基于反馈机制的控制系统,用于稳定和锁定两个信号的相位差。

锁相环的原理可以在许多领域中得到应用,包括通信、电子仪器、雷达等。

锁相环工作原理锁相环的核心原理是采用一个反馈环来纠正输入信号的相位差。

一般来说,锁相环由三个主要部分组成:相位比较器、低通滤波器和可变频率振荡器。

首先,锁相环将输入信号和参考信号通过相位比较器进行比较,产生一个误差信号。

相位比较器会计算两个信号之间的相位差,并且生成一个电压或电流信号,表示这个相位差。

如果输入信号和参考信号的相位差为零,那么相位比较器输出的误差信号也将为零。

接着,误差信号通过低通滤波器进行滤波处理,去除高频噪声和杂散信号。

低通滤波器可以使锁相环对于高频噪声具有良好的抑制能力,提高系统的稳定性和抗干扰性。

最后,滤波后的误差信号被送往可变频率振荡器,控制其输出的频率和相位。

可变频率振荡器会根据误差信号的大小和方向来调整输出信号的频率和相位,以减小相位差。

如果误差信号为正,则输出频率增加;如果误差信号为负,则输出频率减小。

通过不断调整输出频率和相位,锁相环可以将输入信号和参考信号的相位差保持在一个可接受的范围内。

应用领域锁相环在通信领域中有广泛的应用。

在通信系统中,锁相环可以用来确保发送和接收的信号保持同步。

例如,在无线通信中,锁相环可以用来抑制多径干扰和载波漂移,提高通信质量和稳定性。

另外,锁相环还可以用于时钟恢复和数据捕获等方面。

除了通信领域外,锁相环在电子仪器和雷达等领域也有重要的应用。

在电子仪器中,锁相环可以用来稳定和控制仪器的频率和相位。

例如,在频谱分析仪和信号发生器中,锁相环可以确保仪器输出的信号具有准确的频率和相位信息。

在雷达系统中,锁相环可以用来实现目标检测和跟踪。

通过锁相环,雷达可以准确地测量目标和干扰源之间的相对相位差,从而提高雷达测量的精度和可靠性。

总结锁相环是一种基于反馈机制的控制系统,用于稳定和锁定两个信号的相位差。

锁相环PLL原理与应用

锁相环PLL原理与应用

锁相环PLL原理与应用锁相环(Phase-Locked Loop, PLL)是一种常用的控制系统,广泛应用于电子和通信领域。

它可以用于频率合成、时钟恢复以及相位同步等应用中。

本文将对PLL的原理和常见的应用进行详细介绍。

PLL的原理:首先,参考信号经过相位比较器与VCO的输出信号进行比较。

相位比较器的输出为一个控制电压,表示两个信号之间的相位差。

这个控制电压经过低通滤波器进行滤波处理,得到一个平滑的控制电压,该电压用于调节VCO的频率。

VCO产生的频率与输入的控制电压成正比,通过调节控制电压,可以改变VCO的输出频率。

通过反馈控制的方式,当VCO的频率与参考信号接近时,相位比较器的输出误差会减小,最终收敛到零,实现了锁相环的目标。

在PLL中,分频器的作用是将VCO的高频输出信号分频得到一个相位稳定的低频信号,用作相位比较器的参考信号。

通过适当选择分频比,可以实现对VCO输出频率的精确控制。

PLL的应用:1.频率合成器:PLL经常被用于频率合成器的设计。

通过选择适当的参考频率和分频比,可以实现对输出频率的精确控制。

例如,在通信系统中,PLL被用于合成不同的载波频率用于不同用户之间的信号传输。

2.时钟恢复:在数字通信中,接收端需要从接收到的数据中恢复时钟信号。

PLL可以通过将接收到的数据作为参考信号,并控制VCO的频率,使得输出的时钟信号与发送端时钟同步。

3.数字时钟锁定:在数字系统中,不同的模块可能具有不同的时钟源,为了实现数据的正确和稳定传输,需要将不同的时钟源进行同步。

PLL可以用于将这些时钟同步,并控制其频率和相位,以便实现正确的数据传输。

4.相位同步:在通信系统中,要求不同的发送端和接收端之间的信号具有相同的相位特性,以便实现正确的信号传输。

PLL可以用于将这些信号进行相位同步,确保信号的准确传输。

在实际应用中,PLL还可用于频率测量、频率锁定等领域。

它的具体应用取决于实际需求。

在总结,锁相环是一种基于反馈控制的系统,通过将参考信号的相位与振荡器的输出信号进行比较,以实现对输出信号的频率和相位的稳定控制。

锁相环工作原理

锁相环工作原理

锁相环工作原理锁相环(PLL)是一种常见的控制系统,用于同步电路中的时钟和数据信号。

它的工作原理涉及到频率比较器、相位检测器、环路滤波器和振荡器等元件,通过这些元件的相互作用,锁相环可以实现信号的精准同步和稳定输出。

接下来,我们将详细介绍锁相环的工作原理。

首先,锁相环的核心部分是频率比较器,它用来比较输入信号和反馈信号的频率差异。

当两者频率不一致时,频率比较器会输出一个误差信号,这个误差信号将被送入相位检测器。

相位检测器的作用是将误差信号转换成相位差,然后送入环路滤波器。

环路滤波器用来滤除误差信号中的高频成分,同时增强低频成分,以保证锁相环的稳定性和收敛速度。

经过环路滤波器处理后的信号将被送入振荡器,振荡器的频率和相位将根据输入信号和反馈信号的比较结果进行调整,最终实现输入信号和反馈信号的同步。

除了频率比较器、相位检测器、环路滤波器和振荡器外,锁相环还包括分频器和反馈回路。

分频器用来将振荡器的输出信号分频,以生成反馈信号;反馈回路则将反馈信号送回频率比较器,形成闭环控制系统。

总的来说,锁相环的工作原理是通过不断比较输入信号和反馈信号的频率差异,将误差信号转换成相位差,经过滤波和调整后最终实现信号的同步。

它在通信、控制系统和数字信号处理等领域有着广泛的应用,能够提高系统的稳定性和抗干扰能力。

在实际应用中,锁相环的参数调节和设计是非常重要的,需要根据具体的系统要求和信号特性进行合理选择和优化。

同时,锁相环也存在一些问题,如振荡器的相位噪声、环路滤波器的稳定性等,需要在设计和实现中加以考虑和解决。

综上所述,锁相环作为一种重要的同步控制系统,在电子领域有着广泛的应用。

通过频率比较器、相位检测器、环路滤波器和振荡器等元件的相互作用,锁相环可以实现信号的精准同步和稳定输出,为各种电子设备和系统提供了可靠的时钟和数据同步功能。

锁相环工作原理

锁相环工作原理

锁相环工作原理锁相环是一种常见的电路系统,用于提供稳定的频率和相位锁定功能。

它在许多应用中被广泛使用,如通信系统、音频处理、频谱分析等。

本文将详细介绍锁相环的工作原理及其组成部分。

一、锁相环的基本原理锁相环的基本原理是通过比较输入信号和反馈信号的相位差,并根据相位差的大小来调整输出信号的频率和相位,使其与输入信号保持同步。

锁相环的核心是一个相位比较器,它将输入信号和反馈信号进行相位比较,并产生一个误差信号。

根据误差信号的大小和方向,锁相环会调整其输出信号的频率和相位,使得误差信号趋近于零。

二、锁相环的组成部分1. 相位比较器:相位比较器是锁相环的核心部分,用于比较输入信号和反馈信号的相位差。

常见的相位比较器有边沿比较器、模拟比较器和数字比较器等。

2. 低通滤波器:低通滤波器用于滤除相位比较器输出中的高频噪声,保留低频成分。

它可以平滑误差信号,减小锁相环的震荡和抖动。

3. 振荡器:振荡器是锁相环的参考信号源,用于提供稳定的参考频率。

常见的振荡器有晶体振荡器和电感电容振荡器等。

4. 分频器:分频器用于将输入信号分频,以匹配振荡器的频率。

通过分频器,锁相环可以工作在不同的频率范围内。

5. 控制电路:控制电路根据相位比较器输出的误差信号,调整振荡器的频率和相位,以使其与输入信号保持同步。

控制电路通常由比例积分控制器(PID控制器)和电压控制振荡器(VCO)组成。

三、锁相环的工作过程1. 初始状态:锁相环开始工作时,相位比较器将输入信号和反馈信号进行比较,产生一个误差信号。

2. 错位信号处理:误差信号经过低通滤波器平滑处理,去除高频噪声。

3. 控制信号生成:平滑后的误差信号经过控制电路处理,生成控制信号。

4. 控制信号调节:控制信号调节振荡器的频率和相位,使其与输入信号同步。

5. 反馈信号生成:调节后的振荡器输出信号作为反馈信号,与输入信号进行相位比较。

6. 误差信号更新:相位比较器再次比较输入信号和反馈信号,产生新的误差信号。

锁相环工作原理

锁相环工作原理

锁相环工作原理锁相环是一种常用于频率合成和时钟恢复的电路,它能够将输入信号的相位和频率与参考信号同步。

在本文中,我们将详细介绍锁相环的工作原理及其应用。

一、锁相环的基本组成部份锁相环主要由相位比较器、环路滤波器、电压控制振荡器(VCO)以及分频器组成。

1. 相位比较器(Phase Detector)相位比较器是锁相环的核心部份,其作用是将输入信号与参考信号进行相位比较,并输出一个误差信号。

常见的相位比较器有边沿比较器、乘法器和加法器等。

2. 环路滤波器(Loop Filter)环路滤波器的作用是对相位比较器输出的误差信号进行滤波和放大,以产生稳定的控制电压。

通常,环路滤波器由低通滤波器和放大器组成。

3. 电压控制振荡器(Voltage Controlled Oscillator,VCO)电压控制振荡器是一种根据输入电压的变化而改变输出频率的电路。

在锁相环中,VCO的输出频率受到环路滤波器输出的控制电压的调节。

4. 分频器(Divider)分频器将VCO的输出信号进行分频,以产生参考信号。

分频器通常使用可编程分频器,可以根据需要选择不同的分频比。

二、锁相环的工作原理锁相环的工作原理可以简单地描述为以下几个步骤:1. 初始状态锁相环的初始状态是未锁定状态,VCO的输出频率与参考信号的频率存在差异,相位比较器输出的误差信号不为零。

2. 相位比较相位比较器将输入信号与参考信号进行相位比较,产生一个误差信号。

误差信号的幅度和相位表示了输入信号与参考信号之间的差异。

3. 环路滤波误差信号经过环路滤波器进行滤波和放大,产生一个稳定的控制电压。

该控制电压的大小和极性取决于输入信号与参考信号之间的相位差。

4. 控制VCO控制电压作用于VCO,调节其输出频率。

当控制电压为正时,VCO的输出频率增加;当控制电压为负时,VCO的输出频率减小。

5. 反馈VCO的输出信号经过分频器进行分频,产生一个参考信号。

该参考信号与输入信号进行比较,形成反馈回路。

锁相环原理及应用

锁相环原理及应用

锁相电路(PLL)及其应用自动相位控制(APC)电路,也称为锁相环路(PLL),它能使受控振荡器的频率和相位均与输入参考信号保持同步,称为相位锁定,简称锁相。

它是一个以相位误差为控制对象的反馈控制系统,是将参考信号与受控振荡器输出信号之间的相位进行比较,产生相位误差电压来调整受控振荡器输出信号的相位,从而使受控振荡器输出频率与参考信号频率相一致。

在两者频率相同而相位并不完全相同的情况下,两个信号之间的相位差能稳定在一个很小的范围内。

目前,锁相环路在滤波、频率综合、调制与解调、信号检测等许多技术领域获得了广泛的应用,在模拟与数字通信系统中已成为不可缺少的基本部件。

一、锁相环路的基本工作原理1.锁相环路的基本组成锁相环路主要由鉴频器(PD)、环路滤波器(LF)和压控振荡器(VCO)三部分所组成,其基本组成框图如图3-5-16所示。

图1 锁相环路的基本组成框图将图3-5-16的锁相环路与图1的自动频率控制(AFC)电路相比较,可以看出两种反馈控制的结构基本相似,它们都有低通滤波器和压控振荡器,而两者之间不同之处在于:在AFC环路中,用鉴频器作为比较部件,直接利用参考信号的频率与输出信号频率的频率误差获取控制电压实现控制。

因此,AFC系统中必定存在频率差值,没有频率差值就失去了控制信号。

所以AFC系统是一个有频差系统,剩余频差的大小取决于AFC系统的性能。

在锁相环路(PLL)系统中,用鉴相器作为比较部件,用输出信号与基准信号两者的相位进行比较。

当两者的频率相同、相位不同时,鉴相器将输出误差信号,经环路滤波器输出控制信号去控制VCO ,使其输出信号的频率与参考信号一致,而相位则相差一个预定值。

因此,锁相环路是一个无频差系统,能使VCO 的频率与基准频率完全相等,但二者间存在恒定相位差(稳态相位差),此稳态相位差经鉴相器转变为直流误差信号,通过低通滤波器去控制VCO ,使0f 与r f 同步。

2.锁相环路的捕捉与跟踪过程当锁相环路刚开始工作时,其起始时一般都处于失锁状态,由于输入到鉴相器的二路信号之间存在着相位差,鉴相器将输出误差电压来改变压控振荡器的振荡频率,使之与基准信号相一致。

锁相环工作原理

锁相环工作原理

锁相环工作原理锁相环是一种常用于频率合成和时钟恢复的电路。

它通过对输入信号进行频率和相位的调整,使其与参考信号保持同步。

锁相环广泛应用于通信、雷达、测量仪器等领域。

一、基本原理锁相环由相位比较器、低通滤波器、电压控制振荡器(VCO)和分频器组成。

其工作原理如下:1. 参考信号输入:外部提供一个稳定的参考信号,作为锁相环的参考频率。

2. 相位比较:将输入信号与参考信号进行相位比较,得到相位误差信号。

3. 低通滤波:将相位误差信号经过低通滤波器滤波,得到平滑的控制电压。

4. 控制振荡器调频:将控制电压作为输入,控制电压控制振荡器的频率,实现频率的调整。

5. 分频:将控制振荡器的输出信号进行分频,得到反馈信号。

6. 反馈:将分频后的信号与输入信号进行相位比较,得到新的相位误差信号。

通过不断的相位比较、滤波和调频,锁相环可以实现输入信号与参考信号的同步。

二、工作过程锁相环的工作过程可以分为锁定和跟踪两个阶段。

1. 锁定阶段:在初始状态下,锁相环的输出与输入信号存在相位差。

相位比较器将输入信号与参考信号进行比较,得到相位误差信号。

经过低通滤波器滤波后,控制电压作用于VCO,调整其频率。

经过分频器分频后,反馈信号与输入信号再次进行相位比较,得到新的相位误差信号。

通过不断的反馈和调节,相位误差逐渐减小,最终锁定在一个稳定的值,输出信号与参考信号同步。

2. 跟踪阶段:当输入信号发生频率或相位变化时,锁相环需要跟踪这些变化。

相位比较器检测到相位误差信号增大,低通滤波器将其平滑后,调节VCO的频率。

通过分频器反馈信号与输入信号进行相位比较,得到新的相位误差信号。

锁相环通过不断的反馈和调节,使输出信号重新与输入信号同步。

三、应用领域锁相环在许多领域中都有广泛的应用,包括但不限于以下几个方面:1. 频率合成:锁相环可以将一个稳定的参考信号与一个可调频率的振荡器相结合,生成一个具有所需频率的输出信号。

这在通信系统、雷达系统等需要精确频率合成的应用中非常重要。

锁相环

锁相环

锁相环简介:锁相环是指一种电路或者模块,它用于在通信的接收机中,其作用是对接收到的信号进行处理,并从其中提取某个时钟的相位信息。

或者说,对于接收到的信号,仿制一个时钟信号,使得这两个信号从某种角度来看是同步的(或者说,相干的)。

由于锁定情形下(即完成捕捉后),该仿制的时钟信号相对于接收到的信号中的时钟信号具有一定的相差,所以很形象地称其为锁相器。

锁相环由鉴相器、环路滤波器和压控振荡器组成。

鉴相器用来鉴别输入信号Ui与输出信号Uo之间的相位差,并输出误差电压Ud。

Ud 中的噪声和干扰成分被低通性质的环路滤波器滤除,形成压控振荡器(VCO)的控制电压Uc。

Uc作用于压控振荡器的结果是把它的输出振荡频率fo拉向环路输入信号频率fi ,当二者相等时,环路被锁定,称为入锁。

维持锁定的直流控制电压由鉴相器提供,因此鉴相器的两个输入信号间留有一定的相位差。

PLL:phase Locked Loop 相同步回路,锁相回路,用来统一整合时脉讯号,使内存能正确的存取资料。

直接数字频率合成(DDS—Digital Direct Frequency Synthesis)技术是一种新的频率合成方法,是频率合成技术的一次革命,JOSEPH TIERNEY等3人于1971年提出了直接数字频率合成的思想,但由于受当时微电子技术和数字信号处理技术的限制,DDS技术没有受到足够重视,随着电子工程领域的实际需要以及数字集成电路和微电子技术的发展,DDS技术日益显露出它的优越性。

DDS是一种全数字化的频率合成器,由相位累加器、波形ROM、D/A转换器和低通滤波器构成。

时钟频率给定后,输出信号的频率取决于频率控制器,频率分辨率取决于累加器位数,相位分辨率取决于ROM的地址线位数,幅度量化噪声取决于ROM的数据位字长和D/A转换器位数。

DDS有如下优点:⑴频率分辨率高,输出频点多,可达N个频点(N为相位累加器位数);⑵频率切换速度快,可达us量级;⑶频率切换时相位连续;⑷可以输出宽带正交信号;⑸输出相位噪声低,对参考频率源的相位噪声有改善作用;⑹可以产生任意波形;⑺全数字化实现,便于集成,体积小,重量轻,因此八十年代以来各国都在研制和发展各自的DDS产品,如美国QUALCOMM公司的Q2334,Q2220;STANFORD公司的STEL-1175,STEL-1180;AD公司的AD7008,AD9850,AD9854等。

锁相环(PLL)的工作原理

锁相环(PLL)的工作原理

锁相环(PLL)的工作原理1.锁相环的基本组成许多电子设备要正常工作,通常需要外部的输入信号与内部的振荡信号同步,利用锁相环路就可以实现这个目的。

锁相环路是一种反馈控制电路,简称锁相环(PLL,Phase-Locked Loop)。

锁相环的特点是:利用外部输入的参考信号控制环路内部振荡信号的频率和相位。

因锁相环可以实现输出信号频率对输入信号频率的自动跟踪,所以锁相环通常用于闭环跟踪电路。

锁相环在工作的过程中,当输出信号的频率与输入信号的频率相等时,输出电压与输入电压保持固定的相位差值,即输出电压与输入电压的相位被锁住,这就是锁相环名称的由来。

锁相环通常由鉴相器(PD,Phase Detector)、环路滤波器(LF,Loop Filter)和压控振荡器(VCO,Voltage Controlled Oscillator)三部分组成,锁相环组成的原理框图如图8-4-1所示。

锁相环中的鉴相器又称为相位比较器,它的作用是检测输入信号和输出信号的相位差,并将检测出的相位差信号转换成u D(t)电压信号输出,该信号经低通滤波器滤波后形成压控振荡器的控制电压u C(t),对振荡器输出信号的频率实施控制。

2.锁相环的工作原理锁相环中的鉴相器通常由模拟乘法器组成,利用模拟乘法器组成的鉴相器电路如图8-4-2所示。

鉴相器的工作原理是:设外界输入的信号电压和压控振荡器输出的信号电压分别为:(8-4-1)(8-4-2)式中的ω0为压控振荡器在输入控制电压为零或为直流电压时的振荡角频率,称为电路的固有振荡角频率。

则模拟乘法器的输出电压u D为:用低通滤波器LF将上式中的和频分量滤掉,剩下的差频分量作为压控振荡器的输入控制电压u C (t)。

即u C(t)为:(8-4-3)式中的ωi为输入信号的瞬时振荡角频率,θi(t)和θO(t)分别为输入信号和输出信号的瞬时位相,根据相量的关系可得瞬时频率和瞬时位相的关系为:即(8-4-4)则,瞬时相位差θd为:(8-4-5)对两边求微分,可得频差的关系式为(8-4-6)上式等于零,说明锁相环进入相位锁定的状态,此时输出和输入信号的频率和相位保持恒定不变的状态,u c(t)为恒定值。

锁相环(PLL)的工作原理

锁相环(PLL)的工作原理

锁相环(PLL)的工作原理1.锁相环的基本组成许多电子设备要正常工作,通常需要外部的输入信号与内部的振荡信号同步,利用锁相环路就可以实现这个目的。

锁相环路是一种反馈控制电路,简称锁相环(PLL,Phase-Locked Loop)。

锁相环的特点是:利用外部输入的参考信号控制环路内部振荡信号的频率和相位。

因锁相环可以实现输出信号频率对输入信号频率的自动跟踪,所以锁相环通常用于闭环跟踪电路。

锁相环在工作的过程中,当输出信号的频率与输入信号的频率相等时,输出电压与输入电压保持固定的相位差值,即输出电压与输入电压的相位被锁住,这就是锁相环名称的由来。

锁相环通常由鉴相器(PD,Phase Detector)、环路滤波器(LF,Loop Filter)和压控振荡器(VCO,Voltage Controlled Oscillator)三部分组成,锁相环组成的原理框图如图8-4-1所示。

锁相环中的鉴相器又称为相位比较器,它的作用是检测输入信号和输出信号的相位差,并将检测出的相位差信号转换成u D(t)电压信号输出,该信号经低通滤波器滤波后形成压控振荡器的控制电压u C(t),对振荡器输出信号的频率实施控制。

2.锁相环的工作原理锁相环中的鉴相器通常由模拟乘法器组成,利用模拟乘法器组成的鉴相器电路如图8-4-2所示。

鉴相器的工作原理是:设外界输入的信号电压和压控振荡器输出的信号电压分别为:(8-4-1)(8-4-2)式中的ω0为压控振荡器在输入控制电压为零或为直流电压时的振荡角频率,称为电路的固有振荡角频率。

则模拟乘法器的输出电压u D为:用低通滤波器LF将上式中的和频分量滤掉,剩下的差频分量作为压控振荡器的输入控制电压u C (t)。

即u C(t)为:(8-4-3)式中的ωi为输入信号的瞬时振荡角频率,θi(t)和θO(t)分别为输入信号和输出信号的瞬时位相,根据相量的关系可得瞬时频率和瞬时位相的关系为:即(8-4-4)则,瞬时相位差θd为:(8-4-5)对两边求微分,可得频差的关系式为(8-4-6)上式等于零,说明锁相环进入相位锁定的状态,此时输出和输入信号的频率和相位保持恒定不变的状态,u c(t)为恒定值。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

备战飞思卡尔智能车大赛.开始模块总结.锁相环设置.公式: PLLCLK=2*OSCCLK*(SYNR+1)/(REFDV+1),fbus=PLLCLK/2void INIT_PLL(void){CLKSEL &= 0x7f; //选用外部时钟.准备设置锁相环PLLCTL &= 0x8F; //禁止锁相环SYNR = 0xc9; //设置SYNRREFDV = 0x81; //设置REFDVPLLCTL |=0x70; //锁相环使能asm NOP; asm NOP; //两个机器周期缓冲时间while(!(CRGFLG&0x08)); //等待锁相环锁定CLKSEL |= 0x80; //设置锁相环为时钟源}飞思卡尔XS128的PLL锁相环详细设置说明——关于如何提高总线工作频率PLL锁相环就相当于超频 单片机超频的原因和PC机是个一道理。

分频的主要原因是外设需要的工作频率往往远低于CPU/MEMORY 这也和PC机南北桥的原理类似。

总线频率设置过程1、禁止总中断2、寄存器CLKSEL(时钟选择寄存器)的第七位置0 即CLKSEL_PLLSEL=0。

选择时钟源为外部晶振OSCCLK(外接晶振频率) 在PLL(锁相环)程序执行前 内部总线频率为OSCCLK/23. PLLCTL_PLLON=1 打开PLL4.设置SYNR 时钟合成寄存器 、REFDV 时钟分频寄存器 、POSTDIV三个寄存器的参数5、_asm(nop) _asm(nop);加入两条空指令 使锁相环稳定6、while(!(CRGFLG_LOCK==1));//时钟校正同步7、CLKSEL_PLLSEL=1; 下面详细说一下频率的计算一、时钟合成寄存器SYNR寄存器结构 VCOFRQ[1:0]控制压控振动器VCO的增益 默认值为00 VCO的频率与VCOFRQ[1:0]对应表什么是锁相环呢?MCU的支撑电路一般需要外部时钟来给MCU提供时钟信号,而外部时钟的频率可能偏低,为了使系统更加快速稳定运行,需要提升系统所需要的时钟频率。

这就得用到锁相环了。

例如MCU用的外部晶振是16M的无源晶振,则可以通过锁相环PLL把系统时钟倍频到24M,从而给系统提供更高的时钟信号,提高程序的运行速度。

51单片机,AVR单片机内部没有锁相环电路,其系统时钟直接由外部晶振提供。

而XS128内部集成了锁相环电路,其系统时钟既可由外部晶振直接提供,也可以通过锁相环倍频后提供,当然,还有由XS128内部的时钟电路来提供(当其它来源提供的系统时钟不稳定时,内部时钟电路就起作用了,也就是自时钟模式)。

锁相环作为一个提供系统时钟的模块,是一个基本的模块,几乎每次编程序都得用到。

下面记一下怎样配置锁相环来设定想要的系统时钟。

锁相环PLL、自时钟模式和前面说的实时中断RTI、看门狗COP都属于系统时钟与复位CRG 中的模块,固前面用到的寄存器,这里有些会再用到。

在程序中配置锁相环的步骤如下:第一、禁止总中断;第二、寄存器CLKSEL的第七位置0,即CLKSEL_PLLSEL=0。

选择时钟源为外部晶振OSCCLK,在PLL程序执行前,内部总线频率为OSCCLK/2。

CLKSEL_PLLSEL=0时,系统时钟由外部晶振直接提供,系统内部总线频率=OSCCLK/2(OSCCLK 为外部晶振频率)。

CLKSEL_PLLSEL=1时,系统时钟由锁相环提供,此时系统内部总线频率=PLLCLK/2 (PLLCLK为锁相环倍频后的频率)。

第三、禁止锁相环PLL,即PLLCTL_PLLON=0。

当PLLCTL_PLLON=0时,关闭PLL电路。

当PLLCTL_PLLON=1时,打开PLL电路。

第四、根据想要的时钟频率设置SYNR和REFDV两个寄存器。

SYNR和REFDV两个寄存器专用于锁相环时钟PLLCLK的频率计算,计算公式是:PLLCLK=2*OSCCLK*(SYNR+1)/(REFDV+1)其中,PLLCLK为PLL模块输出的时钟频率;OSCCLK为晶振频率;SYNR、REFDV分别为寄存器SYNR、REFDV中的值。

这两个寄存器只有在PLLSEL=0时才能够写入(这里就是第二步的设置原因所在了)。

第五、打开PLL,即PLLCTL_PLLON=1。

第六、CRGFLG_LOCK位,确定PLL是否稳定。

当锁相环PLL电路输出的频率达到目标频率的足够小的误差范围内时,LOCK位置1,此时说明PLLCLK已经稳定,可以作为系统的时钟了。

该位在正常情况下为只读位。

第七、PLLCLK稳定后,允许锁相环时钟源PLLCLK为系统提供时钟,即CLKSEL_PLLSEL=1。

到这里,锁相环的设置就完毕了。

如果想更灵活地配置系统时钟,就还得用到下面的寄存器了,下面逐一说说:1、CRGFLG_LOCKIF 锁相环的中断标志位。

当系统时钟因为稳定或不稳定而导致LOCK位(上面已提到)变化时,该位置1。

此时,如果CRGINT_LOCKIE=1,则产生中断。

CRGINT_LOCKIE=1时,则允许产生锁相环锁定中断。

CRGINT_LOCKIE=0时,则不允许。

2、CLKSEL_PLLWAI是等待模式PLL停止位。

当CLKSEL_PLLWAI=1时,系统进入等待模式时,锁相环PLL停止工作。

当CLKSEL_PLLWAI=0时,系统进入等待模式时,锁相环PLL仍然工作。

下面顺便说一下与自时钟模式相关的几个寄存器:CRGFLG_SCMIF 自时钟模式中断标志位。

当SCM位变化时,该位置1。

此时,如果CRGINT_SCMIE=1,则产生中断。

CRGFLG_SCM 自时钟模式状态位。

当晶振频率不稳定时,该位置1,系统会进入自时钟模式,系统的时钟将由自时钟模式下的时钟提供。

CRGINT_SCMIE 自时钟模式中断的使能位。

当CRGINT_SCMIE=1时,允许产生自时钟模式中断。

当CRGINT_SCMIE=0时,不能产生自时钟模式中断。

PLLCTL_SCME 自时钟模式使能位。

在自时钟模式下,该位不能被清0。

PLLCTL_SCME=1时,晶振时钟失灵系统将强制进入自时钟模式。

当PLLCTL_SCME=0时,晶振失灵将导致时钟监控器复位。

下面附一条锁相环的初始化程序; void MCUInit() {DISABLE_INTERRUPTS; //(1)禁止总中断CLKSEL &= 0x7f; //(2)CLKSEL的第7位置0,选择系统时钟源为OSCCLK PLLCTL &= 0xbf; // (3)禁止PLL , PLLCTL.6(pllon)设为0;先关闭PLL SYNR = 0x01; //(4)根据需要的时钟频率设置SYNR和REFDV寄存器REFDV = 0x00; PLLCTL |= (1<<6); //(5)打开PLL , PLLCTL.6(pllon)设为1;开PLL while (( CRGFLG&0x08) == 0x00); //(6)通过判断LOCK位,//确定PLL是否稳定CLKSEL |= (1<<7); //(7)时钟频率稳定后,允许锁相环时钟源作为系统时钟源;//本句执行后:BusClock=PLLCLK/2 }什么是锁相环呢?MCU的支撑电路一般需要外部时钟来给MCU提供时钟信号,而外部时钟的频率可能偏低,为了使系统更加快速稳定运行,需要提升系统所需要的时钟频率。

这就得用到锁相环了。

例如MCU用的外部晶振是16M的无源晶振,则可以通过锁相环PLL把系统时钟倍频到24M,从而给系统提供更高的时钟信号,提高程序的运行速度。

51单片机,AVR单片机内部没有锁相环电路,其系统时钟直接由外部晶振提供。

而XS128内部集成了锁相环电路,其系统时钟既可由外部晶振直接提供,也可以通过锁相环倍频后提供,当然,还有由XS128内部的时钟电路来提供(当其它来源提供的系统时钟不稳定时,内部时钟电路就起作用了,也就是自时钟模式)。

锁相环作为一个提供系统时钟的模块,是一个基本的模块,几乎每次编程序都得用到。

下面记一下怎样配置锁相环来设定想要的系统时钟。

锁相环PLL、自时钟模式和前面说的实时中断RTI、看门狗COP都属于系统时钟与复位CRG 中的模块,固前面用到的寄存器,这里有些会再用到。

在程序中配置锁相环的步骤如下:第一、禁止总中断;第二、寄存器CLKSEL的第七位置0,即CLKSEL_PLLSEL=0。

选择时钟源为外部晶振OSCCLK,在PLL程序执行前,内部总线频率为OSCCLK/2。

CLKSEL_PLLSEL=0时,系统时钟由外部晶振直接提供,系统内部总线频率=OSCCLK/2(OSCCLK 为外部晶振频率)。

CLKSEL_PLLSEL=1时,系统时钟由锁相环提供,此时系统内部总线频率=PLLCLK/2 (PLLCLK为锁相环倍频后的频率)。

第三、禁止锁相环PLL,即PLLCTL_PLLON=0。

当PLLCTL_PLLON=0时,关闭PLL电路。

当PLLCTL_PLLON=1时,打开PLL电路。

第四、根据想要的时钟频率设置SYNR和REFDV两个寄存器。

SYNR和REFDV两个寄存器专用于锁相环时钟PLLCLK的频率计算,计算公式是:PLLCLK=2*OSCCLK*(SYNR+1)/(REFDV+1)其中,PLLCLK为PLL模块输出的时钟频率;OSCCLK为晶振频率;SYNR、REFDV分别为寄存器SYNR、REFDV中的值。

这两个寄存器只有在PLLSEL=0时才能够写入(这里就是第二步的设置原因所在了)。

第五、打开PLL,即PLLCTL_PLLON=1。

第六、CRGFLG_LOCK位,确定PLL是否稳定。

当锁相环PLL电路输出的频率达到目标频率的足够小的误差范围内时,LOCK位置1,此时说明PLLCLK已经稳定,可以作为系统的时钟了。

该位在正常情况下为只读位。

第七、PLLCLK稳定后,允许锁相环时钟源PLLCLK为系统提供时钟,即CLKSEL_PLLSEL=1。

到这里,锁相环的设置就完毕了。

如果想更灵活地配置系统时钟,就还得用到下面的寄存器了,下面逐一说说:1、CRGFLG_LOCKIF 锁相环的中断标志位。

当系统时钟因为稳定或不稳定而导致LOCK位(上面已提到)变化时,该位置1。

此时,如果CRGINT_LOCKIE=1,则产生中断。

CRGINT_LOCKIE=1时,则允许产生锁相环锁定中断。

CRGINT_LOCKIE=0时,则不允许。

2、CLKSEL_PLLWAI是等待模式PLL停止位。

当CLKSEL_PLLWAI=1时,系统进入等待模式时,锁相环PLL停止工作。

当CLKSEL_PLLWAI=0时,系统进入等待模式时,锁相环PLL仍然工作。

相关文档
最新文档