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/10 16:40:22

工业数据孤岛怎么破?Open-AutoGLM模型融合技术让多源数据实时协同

第一章&#xff1a;工业数据孤岛的挑战与Open-AutoGLM的破局使命 在现代工业智能化转型过程中&#xff0c;数据作为核心生产要素&#xff0c;其流动性和可用性直接决定了AI模型的效能。然而&#xff0c;由于设备异构、系统封闭和标准不一&#xff0c;大量工业数据被孤立在不同部…

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

数据孤岛不再!:Open-AutoGLM实现跨部门实时调度的4大关键技术突破

第一章&#xff1a;数据孤岛不再&#xff01;Open-AutoGLM开启智慧城市协同调度新范式在智慧城市建设进程中&#xff0c;交通、能源、环保、医疗等系统长期处于割裂状态&#xff0c;形成严重的数据孤岛。这不仅阻碍了跨部门的高效协同&#xff0c;也极大限制了城市治理的智能化…

作者头像 李华
网站建设 2026/6/10 16:37:47

【医疗AI新突破】:Open-AutoGLM如何实现病历结构化处理准确率超95%

第一章&#xff1a;Open-AutoGLM 电子病历整理辅助在医疗信息化快速发展的背景下&#xff0c;电子病历&#xff08;EMR&#xff09;的自动化处理成为提升临床工作效率的关键环节。Open-AutoGLM 是一个面向医疗场景的开源大语言模型框架&#xff0c;专为结构化与非结构化病历数据…

作者头像 李华
网站建设 2026/6/10 13:37:45

揭秘Open-AutoGLM在农业物联网中的实战应用:5步实现高效边缘推理

第一章&#xff1a;揭秘Open-AutoGLM在农业物联网中的实战应用&#xff1a;5步实现高效边缘推理在农业物联网场景中&#xff0c;实时性与资源受限是边缘设备部署AI模型的主要挑战。Open-AutoGLM作为轻量化大语言模型优化框架&#xff0c;结合知识蒸馏与动态量化技术&#xff0c…

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

FCKEditor插件实现WORD公式粘贴自动转存服务器

吉林码农的"文档导入插件大冒险"&#xff1a;从FCKEditor到全能粘贴王的逆袭之路 第一章&#xff1a;客户爸爸的"核弹级"需求 "老王啊&#xff0c;我们新闻编辑器要加个功能&#xff0c;能直接导入Word/Excel/PPT/PDF&#xff0c;还要保留所有样式和公…

作者头像 李华