news 2026/6/9 20:19:36

FPGA实现TDC算法(FPGA实现延时)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
FPGA实现TDC算法(FPGA实现延时)

一、FPGA如何实现延时
1.关于ps级别的延时
2.关于ns级别的延时
3.关于10ns级别的延时
4.关于1ms级别的延时


参考:https://www.baidu.com/link?url=sojRDWma1MokFTKgGgf-i-d2hLSTZg2HX45zu5TtJ1YlmEATIqwTc6NexEPZIozYA314EHQVPEYFcWGDBOGFZXGVsz-i1kSbTa6KuoHIJm_&wd=&eqid=89e7a2d40503cda6000000066948d8ee
参考:https://baijiahao.baidu.com/s?id=1827942128414919469&wfr=spider&for=pc
参考:https://blog.csdn.net/gaoxcv/article/details/124591638
使用carry进位链实现ps级别延时
参考:http://www.360doc.com/content/25/0926/10/64556539_1162023558.shtml
参考:https://blog.csdn.net/ipfs8storage/article/details/154445402
(* keep_hierarchy = "TRUE" *)
module TDL
#(
parameter NUM_STAGES = 264
)(
//Inputs
iRST,
iHIT,
iSTORE_STOP,

//Outputs
oTHERMOMETER_VALUE,
oFED
);

//Singal type definition
//Inputs
input iRST;
input iHIT;
input iSTORE_STOP;

//Outputs
output [NUM_STAGES - 1 : 0] oTHERMOMETER_VALUE;
output oFED;


// Define interenal signals
(* dont_touch = "TRUE" *) wire [NUM_STAGES - 1 : 0] wFIS_VALUE;
(* dont_touch = "TRUE" *) wire STORE_STOP_BUFG;
/*(* dont_touch = "TRUE" *)*/ wire wFED;

wire [NUM_STAGES - 1 : 0] rVALUE;
BUFG bufg_inst (
.I(iSTORE_STOP), // 输入时钟信号
.O(STORE_STOP_BUFG) // 输出缓冲后的时钟信号
);

//FINE TDC DELAY CHAIN
genvar i;
generate
for(i = 0 ; i <= (NUM_STAGES / 4) - 1; i = i + 1)
begin : generate_block
if(i == 0)begin : CARRY4_first
(* dont_touch = "TRUE" *)
CARRY4 CARRY4_first_inst(
.CO (wFIS_VALUE[3 : 0]), // 4-bit carry out
.O (),
.CI (1'b0), // 1-bit carry cascade input
.CYINIT (iHIT), // 1-bit carry initialization
.DI (4'b0000), // 4-bit carry-MUX data in
.S (4'b1111) // 4-bit carry-MUX select input
);
end
else
begin : CARRY4_others
(* dont_touch = "TRUE" *)
CARRY4 CARRY4_others_inst(
.CO (wFIS_VALUE[4 * (i + 1) - 1 : 4 * i]),
.O (),
.CI (wFIS_VALUE[4 * i - 1]),
.CYINIT (1'b0), //0表示加法,1表示减法
.DI (4'b0000),
.S (4'b1111)
);
end
end
endgenerate

//FIRST STAGE D FLIP FLOPS TO SAMPLE DELAY CHAIN
genvar j;
generate
for(j = 0 ; j <= NUM_STAGES - 1 ; j = j + 1)
begin
(* dont_touch = "TRUE" *)
FDCE #(
.INIT(1'b0)
) rTDC_VALUE(
.Q (rVALUE[j]),
.C (STORE_STOP_BUFG),
.CE (1'b1),
.CLR (iRST),
.D (wFIS_VALUE[j])
);

end
endgenerate

assign wFED = wFIS_VALUE[0];
assign oFED = wFED;
assign oTHERMOMETER_VALUE = rVALUE;

endmodule


二、FPGA实现频率计
1.使用FPGA统计信号的长度
https://blog.csdn.net/SLAM_masterFei/article/details/105582220


三、FPGA实现延时
短延时(<10ns):IDELAYE2硬核 > 寄存器打拍
中延时(10ns~1ms):计数器 > 移位寄存器
长延时(>1ms):FIFO+外部DDR > 大容量BRAM
皮秒级需求:PLL相位插值 + IDELAYE2
皮秒级需求:使用carry4或者carry8进位链来实现
皮秒级需求:FPGA的DSP来实现延时

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

AI Agent的架构设计:从需求分析到系统规划

AI Agent的架构设计:从需求分析到系统规划 关键词:AI Agent、架构设计、需求分析、系统规划、智能体 摘要:本文围绕AI Agent的架构设计展开,从需求分析入手,逐步深入到系统规划的各个环节。详细阐述了AI Agent的核心概念、算法原理、数学模型,通过实际案例展示了架构设计…

作者头像 李华
网站建设 2026/6/9 3:15:31

搜索研究文献的方式及相关应用探讨

一、wispaper 入口在这&#x1f449;https://www.wispaper.ai/ 追踪自己研究方向的前沿&#xff0c;其实是搞科研关键的技能之一 问题是&#xff0c;每天手动去检索新论文太麻烦&#xff01;看《Nature》《Science》这种综合期刊又太杂&#xff0c;想找对口内容很难&#xf…

作者头像 李华
网站建设 2026/6/8 23:54:35

springboot基于Web的减脂训练营管理系统

基于 SpringBoot Web 的减脂训练营管理系统介绍 随着健康意识提升&#xff0c;减脂训练营&#xff08;如线下健身营、线上减脂课程&#xff09;需求增长&#xff0c;但传统管理模式&#xff08;如纸质登记、微信沟通&#xff09;存在 “学员数据混乱、课程安排低效、效果难追踪…

作者头像 李华
网站建设 2026/6/9 7:54:55

Open-AutoGLM流程提速秘诀:9步变5步,性能提升背后的真相

第一章&#xff1a;Open-AutoGLM流程跳过现象的本质解析在大规模语言模型自动化推理系统中&#xff0c;Open-AutoGLM作为核心调度引擎&#xff0c;其流程跳过现象并非简单的执行遗漏&#xff0c;而是由动态决策机制与上下文感知逻辑共同作用的结果。该现象通常出现在条件满足提…

作者头像 李华
网站建设 2026/6/9 15:18:37

Open-AutoGLM驱动智能制造升级(工业AI模型落地稀缺案例全公开)

第一章&#xff1a;Open-AutoGLM驱动智能制造升级在智能制造加速演进的背景下&#xff0c;Open-AutoGLM作为新一代开源自动化语言模型&#xff0c;正逐步成为工业场景中智能决策与流程优化的核心引擎。该模型融合了自然语言理解、代码生成与多模态数据处理能力&#xff0c;能够…

作者头像 李华
网站建设 2026/6/8 22:09:01

【新手通关秘籍】网络安全入门必看的100个核心知识点

【网络安全入门】学习网络安全必须知道的100 个网络基础知识 什么是链接? 链接是指两个设备之间的连接。它包括用于一个设备能够与另一个设备通信的电缆类型和协议。 2 OSI 参考模型的层次是什么? 有 7 个 OSI 层&#xff1a;物理层&#xff0c;数据链路层&#xff0c;网…

作者头像 李华