AD9361寄存器功能笔记之本振频率设定

2024-02-22 02:59

本文主要是介绍AD9361寄存器功能笔记之本振频率设定,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 LO的产生过程如图:

 

 各个模块都有高灵活性。

 1、参考时钟即是AD9361全局参考时钟,可以是外接晶振的片上DCXO,或是外部输入的有驱动能力的时钟信号。根据FM-COMMS5的设计,参考时钟可以使用时钟Buffer + 40MHz晶振构成的参考频率源。

  (1)关于DCXO的说明:DCXO即数控晶体振荡器,AD9361通过外接晶体和内部数控电容构建DCXO,外接晶体谐振频率需要在19MHz~50MHz 范围内。数控电容对于外接晶振的微调范围是±60 ppm。因此DCXO输出频率范围大致在20MHz~50MHz。

 相关的寄存器:(说明:[4]表示这个寄存器的从低到高第4位,共有第0位到第8位;有些功能是多个寄存器联合表示)

 

 (2)关于外部输入时钟的说明:外部输入时钟频率范围是5MHz~320MHz(推荐在19MHz~80MHz范围内),注意输入信号幅度不要超过1.3Vpp。

 2、预分频/倍频可以对参考时钟进行预处理,即×2 ×1 ÷2 ÷4,这样的预处理可以完成时钟和后级鉴相器的隔离,同时调整频率使得PD正常工作。

 相关的寄存器:

 

 3、核心部件小数-N分频锁相环,包含频率合成经典结构:电流泵鉴相器、可编程环路滤波器,压控LC振荡器(VCO),小数分频器。

  RF-PLL的结构图:

  

 (1)鉴相器。正常工作前需要校准。其输出电流大小可以进行调节,范围0.1mA~6.4mA,步进100uA。

  相关寄存器:(这些是Rx-PLL的电荷泵)

  

    Tx-PLL的电荷泵寄存器地址是把第二个字加4,如0x23B变为0x27B,0x246变为0x286,etc.

  (2)环路滤波器。环路滤波器由电阻电容组成,每一个阻值容值都可以改变,字长4bit,4'b0000表示最小值,4'b1111表示最大值。除了电容C3,每一个元件都有使能位。电阻除能表示短路(0R),电容除能表示开路(0pF)。

   

   RC参数计算公式:(上方有横线表示位取反,Bypass表示使能位)

    

    

    

    

    

   每个元件所有可能的标称值之表格:

   

 

   为了获得良好的性能,ADI建议使用官方表格中的参数。

   ADI给了6张表,分别是在TDD和FDD模式下,电荷泵输入的参考信号频率为40MHz,60MHz和80MHz时的配置。电荷泵实际输入参考信号频率与表的对应关系是:

   

   先给出配置表:(寄存器的值以十进制表示)

   

   

   

   

   

   

   

   

   

   

   

   

   表格使用方法:

   [1] 根据工作模式(TDD/FDD)和鉴相器(即电荷泵)参考频率,从6个表中选择一个。

   [2] 根据VCO的频率,选择合适的一行。先根据需要的本振频率,确定RF-PLL中VCO的频率。本振频率和VCO频率是“2^n”分频的关系,因此对本振频率进行累乘2,使其落在6GHz~12GHz,就得到期望的VCO工作频率Fd。Fd需要大于等于这一行中的VCO Frequency,并且小于上一行的VCO Frequency。该行对应了一组RF-PLL的配置值。

   [3] 注意:每个表的表头有VCO CAL COUNT值,表示VCO频率校准计数长度,可能的值为128,256,512,1024.(详见VCO部分)在TDD模式下,VCO校准时间短,不进行温度补偿;在FDD模式下,VCO校准时间长,并且进行温度补偿。

   相关寄存器:

   

  (3)压控振荡器。VCO工作频率为6GHz~12GHz,正常工作之前需要向寄存器写好VCO的各种参数,然后执行VCO自动校准。

   关于VCO校准的一点说明:

   [1]以下3种行为会触发VCO自动校准:①当器件状态从WAIT变为ALERT;②TDD模式下,RF频率综合器从掉电休眠状态变为ALERT;③RF频率综合字最低位发生写入。

   [2]VCO校准发生前,需要将RF-PLL环路内所有部件的参数设定写入好,包括电荷泵电流大小、环路滤波器参数、频率合成字等等。

   [3]电荷泵校准必须在VCO校准之前进行。

   [4]TDD模式下,Tx RF-PLL和Rx RF-PLL会交替进行掉电休眠和校准。

   当通过ENABLE和TXNRX进行收发切换,TXNRX直接控制了RF-PLL的工作状态:上电振荡还是掉电休眠。因此TXNRX的跳变只能在ALERT状态下发生,而不许在TX和RX状态下变化TXNRX。

   在ALERT状态下,如果TXNRX信号从0变1,则Rx-PLL掉电休眠,Tx-PLL上电工作;如果TXNRX信号由1变0,则Rx-PLL上电工作,Tx-PLL掉电休眠。时序图标出了TDD模式下收发VCO进行校准的时机。

   

   [5]当AD9361工作在FDD模式,需要更长的VCO校准时间,因为收发频率合成器都始终工作,需要精确的校准来对抗温度变化;在TDD模式,可以减少每次校准时间,因为设备收/发状态持续时间都较短,收发状态切换频繁,校准次数大大增加,温漂不明显。

   校准时间计算:

   

   用MATLAB计算RF-VCO校准时间:

clc; clear; close all;
%% Basic Param
REF_CLK = 40;  % MHz
SCALE = 2;  % Pre-scaler Factor
VCO_CAL_COUNT = 3;  % 0->127, 1->256, 2->512, 3->1024%% Derived Param
wait_2 = 8/REF_CLK + 18/(REF_CLK*SCALE);
wait_alc = 40/(REF_CLK*SCALE);
N_count = 2^(7+VCO_CAL_COUNT);%%
max_calib_time_us = 2 + wait_2 + 9*((12+N_count)/(REF_CLK*SCALE) + wait_alc);disp(['max RF-PLL Calib Time = ', num2str(max_calib_time_us), 'us']);

   [6]VCO校准可以被关闭。

   [7]校准完成标志位是:Rx PLL Lock @ 0x247[1]和Tx PLL Lock @ 0x287[1]。

   相关寄存器:

   

  (4)小数分频器。分频器决定VCO稳定时的输出频率。

   频率合成字的整数和小数部分计算方法:

   

   其中F_REF是RF-PLL的输入参考频率,和上面的REF_CLK是一回事。F_RFPLL是VCO的输出频率(注意这个频率范围是6GHz~12GHz)。

   N_Integer是11bit的整数部分,N_Fractional是23bit的小数部分。(8388593接近2^23=8388608)

   小数分频器中使用抖动(Dither)技术,使得频率字小数部分的末位伪随机化,来降低杂散。

   相关寄存器:(Tx对应的寄存器地址是Rx地址+0x040,如Rx的0x231对应Tx的0x271)

   

 4、2分频链。VCO输出经过2分频得到本振信号。

  

  分频器还包含了正交移相器。

  分频系数是由期望的本振频率指定的。关系如下:

  

  分频值和寄存器设定值的关系是:

  

  相关寄存器:

   

这篇关于AD9361寄存器功能笔记之本振频率设定的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/733934

相关文章

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

基于WinForm+Halcon实现图像缩放与交互功能

《基于WinForm+Halcon实现图像缩放与交互功能》本文主要讲述在WinForm中结合Halcon实现图像缩放、平移及实时显示灰度值等交互功能,包括初始化窗口的不同方式,以及通过特定事件添加相应... 目录前言初始化窗口添加图像缩放功能添加图像平移功能添加实时显示灰度值功能示例代码总结最后前言本文将

使用Python实现批量访问URL并解析XML响应功能

《使用Python实现批量访问URL并解析XML响应功能》在现代Web开发和数据抓取中,批量访问URL并解析响应内容是一个常见的需求,本文将详细介绍如何使用Python实现批量访问URL并解析XML响... 目录引言1. 背景与需求2. 工具方法实现2.1 单URL访问与解析代码实现代码说明2.2 示例调用

最好用的WPF加载动画功能

《最好用的WPF加载动画功能》当开发应用程序时,提供良好的用户体验(UX)是至关重要的,加载动画作为一种有效的沟通工具,它不仅能告知用户系统正在工作,还能够通过视觉上的吸引力来增强整体用户体验,本文给... 目录前言需求分析高级用法综合案例总结最后前言当开发应用程序时,提供良好的用户体验(UX)是至关重要

python实现自动登录12306自动抢票功能

《python实现自动登录12306自动抢票功能》随着互联网技术的发展,越来越多的人选择通过网络平台购票,特别是在中国,12306作为官方火车票预订平台,承担了巨大的访问量,对于热门线路或者节假日出行... 目录一、遇到的问题?二、改进三、进阶–展望总结一、遇到的问题?1.url-正确的表头:就是首先ur

SpringBoot实现基于URL和IP的访问频率限制

《SpringBoot实现基于URL和IP的访问频率限制》在现代Web应用中,接口被恶意刷新或暴力请求是一种常见的攻击手段,为了保护系统资源,需要对接口的访问频率进行限制,下面我们就来看看如何使用... 目录1. 引言2. 项目依赖3. 配置 Redis4. 创建拦截器5. 注册拦截器6. 创建控制器8.

如何评价Ubuntu 24.04 LTS? Ubuntu 24.04 LTS新功能亮点和重要变化

《如何评价Ubuntu24.04LTS?Ubuntu24.04LTS新功能亮点和重要变化》Ubuntu24.04LTS即将发布,带来一系列提升用户体验的显著功能,本文深入探讨了该版本的亮... Ubuntu 24.04 LTS,代号 Noble NumBAT,正式发布下载!如果你在使用 Ubuntu 23.

TP-LINK/水星和hasivo交换机怎么选? 三款网管交换机系统功能对比

《TP-LINK/水星和hasivo交换机怎么选?三款网管交换机系统功能对比》今天选了三款都是”8+1″的2.5G网管交换机,分别是TP-LINK水星和hasivo交换机,该怎么选呢?这些交换机功... TP-LINK、水星和hasivo这三台交换机都是”8+1″的2.5G网管交换机,我手里的China编程has

Django中使用SMTP实现邮件发送功能

《Django中使用SMTP实现邮件发送功能》在Django中使用SMTP发送邮件是一个常见的需求,通常用于发送用户注册确认邮件、密码重置邮件等,下面我们来看看如何在Django中配置S... 目录1. 配置 Django 项目以使用 SMTP2. 创建 Django 应用3. 添加应用到项目设置4. 创建