news 2026/6/23 4:48:34

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/22 22:15:46

基于SpringBoot的拍立得购买平台的介绍

基于SpringBoot的拍立得购买平台介绍 一、平台背景与目标 背景&#xff1a; 随着复古文化与即时摄影的流行&#xff0c;拍立得相机&#xff08;如富士Instax、宝丽来&#xff09;因其独特的成像效果和收藏价值&#xff0c;成为年轻人喜爱的潮流单品。然而&#xff0c;传统线下购…

作者头像 李华
网站建设 2026/6/23 2:03:10

外部群消息监听的轮询与 Hook 机制对比

在构建企业微信自动化系统时&#xff0c;如何“实时且准确”地捕获外部群消息是核心挑战。目前行业内主要存在两种技术路径&#xff1a;基于 UI 层的**轮询&#xff08;Polling&#xff09;**与基于内存/系统层的 Hook&#xff08;钩子&#xff09;。 1. 轮询机制&#xff08;…

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

springboot基于Web的共享旅游装备管理系统

基于 SpringBoot 的 Web 共享旅游装备管理系统是一款专为旅游爱好者和装备所有者打造的在线平台&#xff0c;通过 SpringBoot 框架的高效性和 Web 端的便捷性&#xff0c;实现旅游装备的共享、租赁、管理全流程数字化&#xff0c;旨在降低旅游出行成本&#xff0c;提高装备利用…

作者头像 李华
网站建设 2026/6/22 14:07:50

基于springboot的骑行交流论坛

以下是一个基于 Spring Boot 的骑行交流论坛的详细介绍&#xff0c;涵盖系统定位、核心功能、技术架构、特色设计及用户体验优化&#xff0c;旨在打造一个集社交、知识分享、活动组织于一体的骑行爱好者专属社区。一、系统定位与目标 核心用户群体 骑行爱好者&#xff08;公路车…

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

网络安全入门必备:你必须掌握的100个网络基础知识

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

作者头像 李华
网站建设 2026/6/22 14:52:43

Open-AutoGLM元宇宙集成实战(从零到一的场景迁移全记录)

第一章&#xff1a;Open-AutoGLM元宇宙集成实战概述Open-AutoGLM 是一个面向元宇宙场景的开源自动语言生成框架&#xff0c;融合了多模态理解、智能代理决策与实时环境交互能力。该系统通过集成大型语言模型&#xff08;LLM&#xff09;与虚拟世界接口协议&#xff0c;实现了在…

作者头像 李华