news 2026/4/5 15:33:04

基于smic55nm工艺的高频锁相环电路设计教程:设计800MHz或1GHz输出频率的Ring...

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
基于smic55nm工艺的高频锁相环电路设计教程:设计800MHz或1GHz输出频率的Ring...

锁相环电路,有教程 输出频率800MHz或者1GHz, 采用Ring_VCO的结构,输入参考频率20MHz,分频器是40-50分频,电荷泵电流20uA,工艺是smic55nm 每个模块都有单独的testbench 可送一些仿真,设计参考资料 还有matlab,verilog-a建模推导。 呈现最完整的project 前仿真,无版图

先来聊聊咱们折腾的这个Ring_VCO锁相环项目吧。这玩意儿就像个精密时钟管家,要把20MHz的参考信号硬生生提到800MHz甚至1GHz,中间要过五关斩六将。别急着上代码,先看架构图心里才有谱:

整个PLL链条长这样:参考时钟→分频器→相位检测器→电荷泵→环路滤波器→Ring_VCO→分频器闭环。核心指标是输出频率=参考频率×分频比,所以当分频器在40-50之间蹦跶时,输出正好卡在800MHz-1GHz的区间。

先看分频器模块,Verilog代码得能动态切分频比:

module Divider_N40to50( input clk_in, input [5:0] N_sel, //40~50 output reg clk_out ); reg [5:0] counter; always @(posedge clk_in) begin if(counter >= N_sel-1) begin clk_out <= ~clk_out; counter <= 0; end else begin counter <= counter + 1; end end endmodule

这个计数器的精髓在N_sel的动态加载,仿真时要注意分频切换瞬间的毛刺问题。测试时先固定N值跑眼图,再突然切分频比看锁相环的跟踪速度。

电荷泵是电流搬运工,Verilog-A模型得体现充放电特性:

`include "constants.vams" module CP(up, dn, out); input up, dn; inout out; electrical out; parameter real I=20u from [0:inf); //泵电流20uA analog begin if (up && !dn) I(out) <+ I; else if (!up && dn) I(out) <+ -I; else I(out) <+ 0; end endmodule

重点在死区时间控制——当up和dn同时有效时电流为零,这个状态处理不好会导致锁相环卡在亚稳态。仿真时给互补脉冲看电流积分线性度。

Ring_VCO是频率发生器,用五级反相器环实现:

`include "disciplines.vams" module VCO_Ring(ctrl, out); input ctrl; output out; electrical ctrl, out; parameter real Kvco=300e6; //300MHz/V parameter real Vmin=0.4, Vmax=1.8; //控制电压范围 real freq, phase; integer x; analog begin freq = V(ctrl)*Kvco; phase = idtmod(freq, 0, 1); V(out) <+ 1.8*(phase < 0.5); //生成方波 end endmodule

这个模型的关键是Kvco参数校准,实际要跑DC扫描看freq-vctrl曲线斜率。在Matlab里先建模推导:Δf = Kvco·ΔV,结合工艺角做蒙特卡洛分析。

环路滤波器用二阶无源结构,计算元件值有讲究:

Icp = 20e-6; % 电荷泵电流 Kvco = 300e6; % VCO增益 N = 50; % 分频比 omega_c = 2*pi*200e3; % 环路带宽200kHz zeta = 0.7; % 阻尼系数 C1 = Icp*Kvco/(N*omega_c^2)*(4*zeta^2/(1+1/(4*zeta^2)))); C2 = C1/10; Rz = 2*zeta/(omega_c*sqrt(C1*C2*Icp*Kvco/N));

这组方程解出来的RC值要取E24系列标称值,同时留margin给工艺偏差。仿真时看控制电压的过冲和稳定时间,锁定过程像坐过山车似的。

最后上顶层测试:

testbench pll_tb; reg ref_clk; wire vco_out; initial begin ref_clk = 0; forever #25 ref_clk = ~ref_clk; //20MHz参考 end PLL_top dut( .ref_clk(ref_clk), .vco_out(vco_out) ); initial begin $dumpfile("pll.vcd"); $dumpvars; #1000us $finish; end endmodule

跑瞬态仿真起码要等几百微秒才能锁定。看眼图时用测量游标卡相位误差,相位噪声用spectre的pnoise分析,1GHz时1MHz偏移至少-100dBc/Hz才算合格。

整个项目最坑的地方在环路稳定性——改个滤波电容就能让系统震荡。建议边调参边看Bode图,相关资料推荐Behzad Razavi的《Phase Locking in High-Performance Systems》,里面对Ring振荡器的相位建模特别实用。代码和模型扔GitHub仓库时记得带Makefile,不然别人复现时路径问题能折腾半天。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/31 15:42:00

飞算JavaAI重磅革新!重塑企业级Java开发,效率与品质双飞跃

Java长期以来都是企业级应用开发的核心基石&#xff0c;其开发效率与项目品质直接关乎企业数字化转型的成败。然而&#xff0c;传统Java开发模式始终被开发周期冗长、人力成本高企、代码质量参差不齐等痛点所困扰。在此行业困境下&#xff0c;国家高新技术企业飞算科技自主研发…

作者头像 李华
网站建设 2026/4/4 17:42:25

调和级数求和

调和级数求和&#xff08;Harmonic Series&#xff09;模型是时间复杂度分析中稍微进阶一点的考点。它通常出现在**“跳跃式”循环或者“倍数”相关**的题目中。 如果说前面的题目是“送分题”&#xff0c;这个模型就是**“分水岭题”**&#xff0c;掌握了它&#xff0c;你的算…

作者头像 李华
网站建设 2026/4/3 4:51:51

格子玻尔兹曼方法(LBM)的MRT作用力模型

格子玻尔兹曼方法&#xff08;LBM&#xff09;MRT作用力模型格子玻尔兹曼方法搞流动模拟的老司机都知道&#xff0c;MRT&#xff08;多松弛时间&#xff09;模型可比单松弛时间模型&#xff08;BGK&#xff09;香多了。这玩意儿最大的特点就是数值稳定性强&#xff0c;边界条件…

作者头像 李华
网站建设 2026/4/4 6:59:40

水面上划过的涟漪遇到礁石会拐弯,声波撞上超表面也得乖乖听话。今天咱们来折腾COMSOL里水声超表面的反射特性计算,这玩意儿在声学隐身和定向传声领域正热乎着呢

comsol水声超表面反射系数与反射相位计算。打开模型树先给几何结构来点硬核配置。假设咱们设计的是锯齿状超表面单元&#xff0c;用AppendAxisymmetric搞个二维轴对称模型省点计算量。材料属性直接上内置的液态水&#xff0c;密度和声速参数别照搬默认值&#xff0c;实测海域数…

作者头像 李华