LVDS接口总结--(5)IDELAY3仿真

news/2025/2/20 13:34:42/

仿真参考资料如下:

 https://zhuanlan.zhihu.com/p/386057087

`timescale 1 ns/1 ps
module tb_idelay3_ctrl();parameter	REF_CLK		=  2.5        ;  // 400MHzparameter	DIN_CLK	    =  3.3        ;  // 300MHzreg			                ref_clk     ;reg			                clk_din     ;reg			                rst     ;wire                        din     ;reg   [8 : 0]               cntvaluein;wire  [8 : 0]               cntalueout  ;wire                        rdy         ;wire                        dout        ;reg   [15 : 0]              test_pattern = 16'h0c55;reg   [3 : 0]               data_cnt = 4'h0;initial beginrst = 1;ref_clk = 0;clk_din = 0;#500;rst = 0;endalways #(REF_CLK/2)  ref_clk = ~ref_clk;
always #(DIN_CLK/2)  clk_din = ~clk_din;always @(posedge clk_din or posedge rst)beginif(rst)data_cnt <= 4'd0;elsedata_cnt <= data_cnt +1'd1;endassign	din = test_pattern[data_cnt];always @(posedge clk_din or posedge rst)beginif(rst)cntvaluein <= 9'd0;else if(data_cnt == 4'd15)cntvaluein <= cntvaluein +1'd1;else;endidelay3_ctrl  u_idelay_ctrl (.ref_clk    ( ref_clk       ),.rst        ( rst           ),.din        ( din           ),.cntvaluein ( cntvaluein    ),.cntalueout ( cntalueout    ),.rdy        ( rdy           ),.dout       ( dout          ));   endmodule

module idelay3_ctrl(input									ref_clk		    ,input									rst		    ,input				            	    din		    ,input       [8 : 0]                     cntvaluein  ,output      [8 : 0]                     cntalueout  ,output                                  rdy         ,output  	                            dout	     );IDELAYCTRL #(.SIM_DEVICE("ULTRASCALE")  // Set the device version for simulation functionality (ULTRASCALE)) inst_IDELAYCTRL (.RDY(rdy), 					// 1-bit output: Ready output.REFCLK(ref_clk), 	// 1-bit input: Reference clock input.RST(rst) 		// 1-bit input: Active high reset input);	IDELAYE3 #(.CASCADE("NONE"),               // Cascade setting (MASTER, NONE, SLAVE_END, SLAVE_MIDDLE).DELAY_FORMAT("TIME"),          // Units of the DELAY_VALUE (COUNT, TIME).DELAY_SRC("IDATAIN"),          // Delay input (DATAIN, IDATAIN).DELAY_TYPE("VAR_LOAD"),           // Set the type of tap delay line (FIXED, VARIABLE, VAR_LOAD).DELAY_VALUE(0),                // Input delay value setting.IS_CLK_INVERTED(1'b0),         // Optional inversion for CLK.IS_RST_INVERTED(1'b0),         // Optional inversion for RST.REFCLK_FREQUENCY(400.0),       // IDELAYCTRL clock input frequency in MHz (200.0-800.0).SIM_DEVICE("ULTRASCALE_PLUS"), // Set the device version for simulation functionality (ULTRASCALE,// ULTRASCALE_PLUS, ULTRASCALE_PLUS_ES1, ULTRASCALE_PLUS_ES2).UPDATE_MODE("ASYNC")           // Determines whe     n updates to the delay will take effect (ASYNC, MANUAL,SYNC))IDELAYE3_inst (.CASC_OUT(),       // 1-bit output: Cascade delay output to ODELAY input cascade.CNTVALUEOUT(cntalueout), // 9-bit output: Counter value output.DATAOUT(dout),         // 1-bit output: Delayed data output.CASC_IN(1'd0),         // 1-bit input: Cascade delay input from slave ODELAY CASCADE_OUT.CASC_RETURN(1'd0), // 1-bit input: Cascade delay returning from slave ODELAY DATAOUT.CE(1'b0),                    // 1-bit input: Active-High enable increment/decrement input.CLK(ref_clk),                 // 1-bit input: Clock input.CNTVALUEIN(cntvaluein[8:0]),   // 9-bit input: Counter value input.DATAIN(),           // 1-bit input: Data input from the logic.EN_VTC(!rdy),           // 1-bit input: Keep delay constant over VT.IDATAIN(din),         // 1-bit input: Data input from the IOBUF.INC(1'b0),                // 1-bit input: Increment / Decrement tap delay input.LOAD(1'b1),               // 1-bit input: Load DELAY_VALUE input.RST(1'b0)                  // 1-bit input: Asynchronous Reset to the DELAY_VALUE);endmodule

delay tap =0

127ps

delay tap =1

131ps

delay tap =2

135ps

delay tap =3

139ps

 

delay tap =100

527ps

delay tap =200

927ps

delay tap =219

1003ps

delay tap =468

1999ps

delay tap =511

2171ps

根据上表可知  delay_tap = 127 + 4N  (N的取值为0到511)

根据简单的计算可知,双沿300M数据(对应单沿600M数据),数据持续时间为1.66ns,取到中间需要0.83ns,对应177taps


http://www.ppmy.cn/news/1572892.html

相关文章

蓝桥杯篇---IAP15F2K61S2中断

文章目录 前言简介中断源1.外部中断2.定时器中断3.串口中断4.ADC中断5.PCA中断6.SPI中断7.PWM中断 中断优先级中断相关寄存器1.IE2.IP3.TCON4.SCON 中断使用步骤1.配置中断源2.使能中断3.设置优先级4.编写中断服务程序5.清除中断标志 示例代码&#xff1a;外部中断使用示例代码…

计算机视觉+Numpy和OpenCV入门

Day 1&#xff1a;Python基础Numpy和OpenCV入门 Python基础 变量与数据类型、函数与类的定义、列表与字典操作文件读写操作&#xff08;读写图像和数据文件&#xff09; 练习任务&#xff1a;写一个Python脚本&#xff0c;读取一个图像并保存灰度图像。 import cv2 img cv2.im…

DeepSeek生成思维导图

一、准备阶段 工具准备 安装思维导图软件&#xff08;推荐XMind/MindMaster/在线工具如ProcessOn&#xff09; 打开DeepSeek官网或集成平台&#xff08;https://www.deepseek.com/&#xff09; 明确需求 确定思维导图核心主题&#xff08;如"碳中和实施方案"&…

【CSS进阶】CSS元素的水平、垂直居中方法

在前端开发中&#xff0c;实现 水平居中 和 垂直居中 是常见的需求。不同的 HTML 元素&#xff08;块级元素、行内元素、行内块元素&#xff09;以及不同的布局方式&#xff08;传统布局、Flexbox、Grid、绝对定位&#xff09;会有不同的居中方法。以下是各类居中方式的总结&am…

DeepSeek-V3模型底层架构的核心技术一(多Token预测(MTP)技术)

一、DeepSeek-V3的框架结构 DeepSeek-V3的框架结构基于三大核心技术构建:多头潜在注意力(MLA)、DeepSeekMoE架构和多token预测(MTP)。这些创新使得模型在处理长序列、平衡计算负载以及生成连贯文本方面表现出色。 1. 基础架构 DeepSeek-V3的基础架构仍然基于Transformer框…

借3D视觉定位东风,汽车零部件生产线实现无人化的精准飞跃

在新能源汽车市场的推动下&#xff0c;汽车零部件制造业正迎来前所未有的发展机遇。然而&#xff0c;传统的生产方式已经无法满足现代制造业对高效、精准的要求。为了应对这一挑战&#xff0c;越来越多的企业开始探索智能化生产的道路。 在这个过程中&#xff0c;3D视觉定位系…

服务器硬件知识--------linux系统初识and安装

#!/bin/bash 学IT&#xff0c;好技术&#xff0c;私&#xff01; 一、服务器硬件与linux系统初识及安装 1、服务器硬件知识 我们知道&#xff0c;组成计算机的硬件主要有主机和输入/输出设备。主机包括机箱、电源、主板、CPU&#xff08;Central Processing Unit&#xff0c;…

ESP32鼠标驱动(ble hid device_demo)【ESP32指向鼠标】

ESP32鼠标驱动(ble hid device_demo)【ESP32指向鼠标】 我使用的vscode开发esp32&#xff0c;用的是ESP-IDF v5.12固件&#xff0c;其提供了很多例程&#xff0c;在搜索里面输入“ESP-IDF: Show Examples Projects”&#xff0c;便可看到例程&#xff0c;如下图所示&#xff0…