FPGA ad9248驱动

ad9248的最高时钟频率65mhz,采用cmos3.3v电压的并行io接口,做成电子模块后一般为双通道adc,有两个对外输出时钟cha_clk与chb_clk,一个并行输入端口,14分辨率的ddr_data,其模块逻辑如下,首先向adc发送一对差分时钟作为cha_clk和chb_clk,然后adc返回给fpga一个双沿数据ddr_data,通过iddr原语进行数据解析并将解析后的数据作为cha_data和chb_data输出,同时处理解析后数据的时钟为user_clk,而差分时钟由ad_clk产生。cha_over和chb_over表示接收到的外部电压是否超过量程+-5v。同时参数代表单极性输出还是双极性输出。

MMCM IP配置如下,需要注意user_clk与ad_clk相位差90

module ad9248_driver#(parameter   UNIPOLAR = 1
)(input               i_ad_clk50m     ,input               i_user_clk50m   ,input       [13:0]  i_ddr_data      ,input               i_cha_over      ,input               i_chb_over      ,output              o_cha_clk       ,output              o_chb_clk       ,output  reg [13:0]  o_cha_data      ,output  reg [13:0]  o_chb_data      );assign  o_cha_clk = i_ad_clk50m ;assign  o_chb_clk = !i_ad_clk50m;wire    [13:0]  w_cha_data  ;wire    [13:0]  w_chb_data  ;//超量程则将前一刻输出作为有效值	always@(posedge i_user_clk50m) begino_cha_data <= w_cha_data;o_chb_data <= w_chb_data;endgenvar i;generatefor(i = 0; i < 14; i = i + 1) beginIDDR #(.DDR_CLK_EDGE   ("SAME_EDGE_PIPELINED"  ),  .INIT_Q1        (1'b0                   ),  .INIT_Q2        (1'b0                   ),  .SRTYPE         ("SYNC"                 )   ) IDDR_inst (.Q1     (w_cha_data[i]  ),  // 上升沿数据.Q2     (w_chb_data[i]  ),  // 下降沿数据.C      (i_ad_clk50m    ),  // 时钟输入.CE     (1'b1           ),  // 时钟使能.D      (i_ddr_data[i]  ),  // 输入数据.R      (1'b0           ),  // 复位(可选).S      (1'b0           )   // 置位(可选));endendgenerate    reg		[15:0]		r_cnt	;always@(posedge i_user_clk50m) beginif(r_cnt < 1)r_cnt <= r_cnt + 1;elser_cnt <= 0;endreg					r_vld	;always@(posedge i_user_clk50m) beginif(r_cnt == 1)r_vld <= 1;elser_vld <= 0;endila_0 your_instance_name (.clk(i_user_clk50m), // input wire clk.probe0(i_cha_over), // input wire [0:0]  probe0  .probe1(i_chb_over), // input wire [0:0]  probe1 .probe2(o_cha_data), // input wire [13:0]  probe2 .probe3(o_chb_data), // input wire [13:0]  probe3.probe4(r_vld		) // input wire [0:0]  probe4
);endmodule

测试用的顶层文件


module ad_sample(input				i_clk50m		,input				i_rst_n			,input       [13:0]  i_ddr_data      ,input               i_cha_over      ,input               i_chb_over      ,output              o_cha_clk       ,output              o_chb_clk       );wire		w_ad_clk	;wire		w_usr_clk	;clk_wiz_0 
mmcm(.clk_out1	(w_ad_clk	),  .clk_out2	(w_usr_clk	), .resetn		(i_rst_n	), // input resetn.locked		(),       // output locked.clk_in1	(i_clk50m	)
);    wire		[13:0]	w_cha_data	;wire		[13:0]	w_chb_data	;ad9248_driver
ad9248_driver_u(.i_ad_clk50m    (w_ad_clk	),.i_user_clk50m  (w_usr_clk	),.i_ddr_data     (i_ddr_data	),.i_cha_over     (i_cha_over	),.i_chb_over     (i_chb_over	),.o_cha_clk      (o_cha_clk	),.o_chb_clk      (o_chb_clk	),.o_cha_data     (w_cha_data	),.o_chb_data     (w_chb_data	)
);endmodule

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/921455.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/921455.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring MVC 处理请求的流程

Spring MVC 处理请求的流程流程步骤详解第1步&#xff1a;发起请求 (HTTP Request)第2步&#xff1a;映射处理器 (Handler Mapping)第3步&#xff1a;获取适配器 (Handler Adapter)第4步&#xff1a;执行拦截器前置处理 (Interceptors - preHandle)第5步&#xff1a;真正调用处…

敏捷scrum管理实战经验总结

1.敏捷 敏捷的构成 敏捷由实践来源、应用场景、组织文化、领导力、团队、需求、管理、技术、质量、度量、交付、过程改进、大型项目组合管理以及受监管行业中的敏捷等构成 敏捷开发的特点 短发布周期小批量的方式、开展从需求到实现的开发工作高层级的预先规划结合详细的即时规…

南科大适应、协同与规划的完美融合!P³:迈向多功能的具身智能体

作者&#xff1a;Shengli Zhou1^{1}1, Xiangchen Wang1^{1}1, Jinrui Zhang1^{1}1, Ruozai Tian2^{2}2, Rongtao Xu2,3^{2,3}2,3, Feng Zheng1,2^{1,2}1,2单位&#xff1a;1^{1}1南方科技大学&#xff0c;2^{2}2时空智能&#xff0c;3^{3}3穆罕默德本扎耶德人工智能大学论文标题…

自动化流水线

import React, { useState, useEffect } from ‘react’; import { ChevronRight, CheckCircle, Circle, AlertCircle, Clock, Play, Pause, Settings, Code, Server, Shield, Database, Globe, Zap, FileText, Users, GitBranch, Package, Monitor, ChevronDown } from ‘luci…

【高等数学】第十一章 曲线积分与曲面积分——第三节 格林公式及其应用

上一节&#xff1a;【高等数学】第十一章 曲线积分与曲面积分——第二节 对坐标的曲线积分 总目录&#xff1a;【高等数学】 目录 文章目录1. 格林公式2. 平面上曲线积分与路径无关的条件3. 二元函数的全微分求积4. 曲线积分的基本定理1. 格林公式 单连通与复连通区域 设 DDD …

Boost电路:平均状态空间建模

电路特征介绍如图所示是一个非理想情况下的boost电路&#xff0c;其中L1L_{1}L1​和RL1R_{L1}RL1​是分别是电感和串联电阻&#xff1b;C1C_{1}C1​和RC1R_{C1}RC1​是输出电容和串联电阻&#xff1b;Q1Q_{1}Q1​是MOS管&#xff0c;其导通电阻是RonR_{on}Ron​&#xff1b;D1D…

免费网站模板/网站模板建站的优势/如何下载网站模板搭建网站?

在网站建设领域&#xff0c;“网站模板” 是降低技术门槛、提升建站效率的核心工具&#xff0c;尤其适合非专业开发者或追求低成本、快上线的需求场景。下面从定义、核心优势两方面展开详细解析&#xff0c;帮助你全面理解其价值。 一、什么是网站模板&#xff1f; 网站模板&am…

【MATLAB例程】平面上的组合导航例程,使用EKF融合IMU和GNSS数据,8维状态量和2维观测量,附代码下载链接

文章目录程序详解概述系统架构核心数学模型性能评估算法特点运行结果MATLAB源代码程序详解 概述 本代码实现基于扩展卡尔曼滤波器&#xff08;EKF&#xff09;的二维组合导航系统&#xff0c;融合IMU&#xff08;惯性测量单元&#xff09;和GNSS&#xff08;全球导航卫星系统…

react生命周期,详细版本

React 组件的生命周期分为三个阶段:挂载(Mounting)、更新(Updating) 和 卸载(Unmounting)。以下是类组件生命周期的详细说明(基于 React 16.3+ 版本): 一、挂载阶段(Mounting) 组件实例被创建并插入 DOM 时的流程: constructor(props) ○ 用途:初始化状态(this…

腾讯最新开源HunyuanVideo-Foley本地部署教程:端到端TV2A框架,REPA策略+MMDiT架构,重新定义视频音效新SOTA!

一、模型介绍HunyuanVideo-Foley 是腾讯混元团队在2025年8月底开源的一款端到端视频音效生成模型。它旨在解决AI生成视频“有画无声”的痛点&#xff0c;通过输入视频和文本描述&#xff0c;就能自动生成电影级别的同步音效&#xff0c;显著提升视频的沉浸感。它是专为视频内容…

计算机原理(二)

计算机原理系列 欢迎大家关注「海拉鲁知识大陆」 多交流不迷路 计算机原理&#xff08;一&#xff09; 继续上一篇计算机原理&#xff08;一&#xff09;深入了解程序执行部分&#xff0c;进一步说说程序在冯诺依曼模型上如何执行。如果没有了解的童鞋可以查看我上一篇文章。…

【设计模式】 工厂方法模式

系列文章目录 文章目录系列文章目录需要了解工厂制造细节吗&#xff1f;简单工厂模式实现工厂方法模式的实现简单方法&#xff1f; 工厂方法&#xff1f;总结需要了解工厂制造细节吗&#xff1f; 我们在前面的文章中为大家介绍了简单工厂模式&#xff0c;我们知道 简单工厂模式…

详解 Java 中的 CopyOnWriteArrayList

目录 【1】CopyOnWriteArrayList 简介 【2】核心原理 1.底层数据结构 2.写时复制机制 【3】CopyOnWriteArrayList常用方法及实例 1.添加元素方法 add () 2.获取元素方法 get () 3.删除元素方法remove() 【4】优缺点分析 【5】适用场景 【6】总结 【1】CopyOnWriteAr…

新手SEO优化快速起步教程

本教程专为SEO新手设计&#xff0c;帮助您快速上手优化工作。我们将一步步带您了解基础概念&#xff0c;包括高效挖掘关键词的方法、内容优化的核心技巧&#xff0c;以及网站基础设置的关键步骤。后续还会讲解提升排名的实用策略、如何监控效果并进行调整&#xff0c;确保您能系…

Minecraft图片搜索技巧

以下是更多专注 Minecraft 内容的高质量社区平台&#xff0c;涵盖建筑展示、模组/材质分享、实机截图、艺术创作等方向&#xff0c;按类型分类整理&#xff1a;---一、国际知名综合社区平台 特点 链接 CurseForge 模组/材质/数据包第一仓库&#xff0c;作者更新快&#xff0c;支…

数学建模-非线性规划(NLP)

1-理论知识介绍应用2-基于matlab实现非线性规划1&#xff09;例1% 清除工作台和命令行 clear;clc; x0[0 0 0]; A [-1 1 -1]; b 0; [x,value] fmincon(f1,x0,A,b,[],[],[],[],nonlfun1) function f f1(x)f x(1)^2x(2)^2x(3)^28; end function [c,ceq] nonlfun1(x)c [x(1)…

人工智能学习:什么是seq2seq模型

一、seq2seq模型 Seq2Seq(Sequence-to-Sequence)模型是一种用于处理序列转换问题的深度学习模型,广泛应用于机器翻译、文本摘要、对话系统、语音识别等领域。Seq2Seq模型的核心思想是通过一个编码器(Encoder)将输入序列编码为一个固定长度的上下文向量(Context Vector),…

生态 | 华院计算与深至科技达成战略合作,携手推动AI+医学影像算法升级迭代

8月25日&#xff0c;华院计算技术&#xff08;上海&#xff09;股份有限公司&#xff08;以下简称“华院计算”&#xff09;与上海深至信息科技有限公司&#xff08;以下简称“深至科技”&#xff09;正式签署战略合作协议。双方将秉持“优势互补、资源共享、战略协同、共同发展…

详解MySQL环境变量配置及其在备份中的应用

正确配置MySQL环境变量是保障数据库稳定运行和高效管理的基础。这些变量涵盖了从内存分配、连接设置到日志行为等方方面面&#xff0c;直接决定了数据库的性能表现和功能特性。对于数据库管理员而言&#xff0c;熟练掌握环境变量的配置&#xff0c;是进行性能调优和故障排查的必…

scikit-learn零基础配置(含python、anaconda)

一、Anaconda环境搭建 1、关于Anaconda Anaconda 是一个非常 popular 的 Python 发行版&#xff0c;它不仅包含了 Python 语言本身&#xff0c;还预装了众多常用的科学计算库&#xff0c;如 NumPy、Pandas、Matplotlib 等&#xff0c;能够极大地方便用户的开发和数据分析工作。…