[原创]AD9212采样方法
随记
最近由于工程原因用到ADC的采样,选用了ADI公司的AD9212芯片,八通道10位ADC。在进行ADC的采样时,看到的想到的几种方法,在这里做个笔记记录一下。
AD9212简介
详细说明可以在ADI官网上进行搜索查看,具体的一些性能细节这里就不进行详细的介绍了。
ADC芯片在某一时刻采集到电压数据后会在一个时钟周期内将数据串行的输出,若使用FPGA对数据进行接收,所需要做的操作就只是一个串并转换,还是比较简单的对吧。在这里由于AD9212的数据传输是使用的LVDS输出,也可以使用Altera官方(对,我们用的是A家的芯片)的LVDS_RX的IP核进行接收。下面我们把AD9212的一个时序图放上来作为镇文之图。
从图中可以看出DCO作为数据传出的时钟是上下边沿触发的,在每个边沿数据D有效。FCO作为帧定界的信号且与数据D同步,一个时钟周期内10位的有效数据D,且高位在前。主要信息就这些了,信号FCO、DCO、D接入FPGA。
方法1——利用官方LVDS_RX的IP核
简单的说下思路,由于程序均为并行,以下步骤也已并列形式给出。
- 将D和FCO信号引入LVDS_RX中,两位两位的读取,读取时钟为DCO。
- 使用一个11位的Buffer寄存器,在每个上升沿的同时不断的将LVDS_RX读取到的数据以移位的形式添加到最后。(注意这里是使用了11位Buffer,比数据长度多1,其用途可参考下方运行辅助理解)
- 在每个DCO的上升沿对LVDS_RX接收到的FCO进行打一拍处理
- 在每个DCO的上升沿对当前时刻接收到的2位FCO数据和前一个上升沿的数据(上述中打一拍)进行比较判定,若前一时刻为00,当前为11,则11位Buffer的[9:0]位接收到的数据;若前一时刻为01,则11位中Buffer的[10:1]为采集数据;其余条件Buffer保持。
这里最后一个处理中之所以有两种情况是因为LVDS_RX在读的过程中无法确保其开始位置,故这里将两种方法都进行考虑后进行综合。下图描述了LVDS_RX在读取时的两种可能的状态。
- 状态1
- 状态2
方法2——根据时序自行处理
同样简单的说一下思路,该方法对于10-bits ADC需要使用到一个12-bits的Buffer用于数据的缓存。
- DCO上升沿进行采样,数据依次存入Buffer[11,9,7,5,3,1]中。
- DCO下降沿进行采样,数据依次存于Buffer[10,8,6,4,2,0]中。
- 类似于上述方法对FCO一样双边沿采样存于一个Reg[3:0]中。
- 在Reg[3:0]==0011时,标志位置1。
- 在DCO的上升沿在标志位置于1的时候将Buffer中的[11:2]提取出来成为ADC采集到的数据。
- 根据需要添加FIFO进行数据同步。
这一部分后续再时序上可能不如方法1,后期可以通过时序约束进行优化,暂时还未涉及,后续学习后再来添加补充。
希望对阅读的你有着帮助,欢迎探讨。如果有什么觉得不对的,一定不要客气的留言回复大力拍砖~
[原创]AD9212采样方法的更多相关文章
- 采样方法(二)MCMC相关算法介绍及代码实现
采样方法(二)MCMC相关算法介绍及代码实现 2017-12-30 15:32:14 Dark_Scope 阅读数 10509更多 分类专栏: 机器学习 版权声明:本文为博主原创文章,遵循CC 4 ...
- 【原创分享·支付宝支付】HBuilder打包APP调用支付宝客户端支付
前言 最近有点空余时间,所以,就研究了一下APP支付.前面很早就搞完APP的微信支付了,但是由于时间上和应用上的情况,支付宝一直没空去研究.然后等我空了的时候,发现支付宝居然升级了支付逻辑,虽然目前还 ...
- 【原创分享·微信支付】C# MVC 微信支付教程系列之现金红包
微信支付教程系列之现金红包 最近最弄这个微信支付的功能,然后扫码.公众号支付,这些都做了,闲着无聊,就看了看微信支付的其他功能,发现还有一个叫“现金红包”的玩意,想 ...
- 【原创分享·微信支付】 C# MVC 微信支付教程系列之扫码支付
微信支付教程系列之扫码支付 今天,我们来一起探讨一下这个微信扫码支付.何为扫码支付呢?这里面,扫的码就是二维码了,就是我们经常扫一扫的那种二维码图片,例如,我们自己添 ...
- 【原创分享·微信支付】 C# MVC 微信支付教程系列之公众号支付
微信支付教程系列之公众号支付 今天,我们接着讲微信支付的系列教程,前面,我们讲了这个微信红包和扫码支付.现在,我们讲讲这个公众号支付.公众号支付的应用环境常见的用户通过公众号,然后再通 ...
- 【原创分享·微信支付】C# MVC 微信支付之微信模板消息推送
微信支付之微信模板消息推送 今天我要跟大家分享的是“模板消息”的推送,这玩意呢,你说用途嘛,那还是真真的牛逼呐.原因在哪?就是因为它是依赖微信生存的呀,所以他能不 ...
- [原创]java使用JDBC向MySQL数据库批次插入10W条数据测试效率
使用JDBC连接MySQL数据库进行数据插入的时候,特别是大批量数据连续插入(100000),如何提高效率呢?在JDBC编程接口中Statement 有两个方法特别值得注意:通过使用addBatch( ...
- GJM : C#设计模式汇总整理——导航 【原创】
感谢您的阅读.喜欢的.有用的就请大哥大嫂们高抬贵手"推荐一下"吧!你的精神支持是博主强大的写作动力以及转载收藏动力.欢迎转载! 版权声明:本文原创发表于 [请点击连接前往] ,未经 ...
- 信息安全-5:RSA算法详解(已编程实现)[原创]
转发注明出处:http://www.cnblogs.com/0zcl/p/6120389.html 背景介绍 1976年以前,所有的加密方法都是同一种模式: (1)甲方选择某一种加密规则,对信息进行加 ...
随机推荐
- Git Pro - (1) 基础
近乎所有操作都可本地执行 在Git中的绝大多数操作都只需要访问本地文件和资源,不用连网. 三种状态 对于任何一个文件,在 Git 内都只有三 种状态:已提交(committed),已修改(modifi ...
- zookeeper分布式部署-mac先测试
由于平台马上要引入zookeeper+dubbo,为了解决zookeeper单个实例运行的风险,需要做个集群. 1,先说配置:zoo.cfg十分简单,分两种情况: 一种是在一台机器采用不同的端口配置多 ...
- R语言 三个函数sort();rank();order()
R语言入门,弄懂了几个简单的函数,分享一下:R语言排序有几个基本函数: sort():rank():order()sort()是对向量进行从小到大的排序rank()返回的是对向量中每个数值对应的秩or ...
- MVC之路由规则 (自定义,约束,debug)
自定义路由规则的要求,小范围写在前,大范围写在后.路由规则可以注册多条,路由规则的名称不能重复路由规则有顺序,并且按照顺序进行匹配,建议小范围写在前,大范围写在后.路由规则可以设置约束 即正则表达式路 ...
- jQuery on 绑定的事件触发多次
jquery用on绑定事件,在代码执行过程中,可能会遇到多次执行的情况. 解决方案是在on的事件前面加上一个off,再on. $('#btnBind').off('click').on('click' ...
- float、double的有效位数
Java中的浮点类型有两类,分别是float和double类型,其中float取_7__位有效数据,double取_15__位有效数据
- 第三次作业:caculator
第三次作业 作业链接 ********* 遇到的问题: Scan类: 队列的使用方法不了解,上网查询并自己练习了一下才初步了解,才运用到作业 . 判断数字用的 if (input[i] >= ' ...
- Android 之Html的解析(使用jsoup)
Runnable run=new Runnable() { @Override public void run() { // TODO Auto-generated method stub useri ...
- iOS图片编辑功能实现
图片加标签:标签可以编辑 https://github.com/shumingli/waterMark 1. 编辑效果;图片可以放到.缩小.旋转 2. 保存相册效果
- php使用curl简单抓取远程url的方法
这篇文章主要介绍了php使用curl简单抓取远程url的方法,涉及php操作curl的技巧,具有一定参考借鉴价值,需要的朋友可以参考下 本文实例讲述了php使用curl抓取远程url的方法.分 ...