【我的电赛日记(二)】ADF4351锁相环模块

您所在的位置:网站首页 锁相环可以产生什么信号 【我的电赛日记(二)】ADF4351锁相环模块

【我的电赛日记(二)】ADF4351锁相环模块

2024-07-13 10:43| 来源: 网络整理| 查看: 265

ADF4351锁相环模块

这篇日记可能只会对做信号的朋友有帮助,毕竟其他方向使用这个模块的概率不大 锁相环这个模块曾经在2015年全国大学生电子设计竞赛的E题中出现过,大致就是需要使用锁相环模块制作一个可以通过点频的方式输出一个固定的频率信号作为本振源,然后再使用它进行扫频操作。题目大致如下: 在这里插入图片描述

虽然不知道之后还用不用的上,但是学习一下如何使用锁相环模块还是很有必要的🤡

一、硬件连接 首先在硬件方面,我是直接购买的ADF4351的成品模块,价格大概在130左右: 在这里插入图片描述关于这个模块的性能,包括详细的硬件资料我就不多加赘述了,网上很多可以自行去找,首先我们来看一下他的引脚分布以及各个接口的作用: 在这里插入图片描述因为我做的是软件方向,所以我大致介绍几个实际开发中会用到的: 1.数据口:唯一一组需要和单片机主控相连接的IO口,实际应用中也只需要用到GND,CE,LE,DAT以及CLK这5个引脚,连接图大致如下,左边是单片机开发板的接口,右边是ADF4351上的接口。 在这里插入图片描述 2.时钟选择:当把上面两个引脚相连接时,模块默认使用板载晶振,如图所示,此时 W1 端跳线帽接上面两排针。如需输入外部时钟,可将跳线帽切换到下面两排针,将外部时钟信号从 P1 端输入,同时可将板载晶振取下来,避免干扰。没有特殊需求的话默认就可以。

3.信号输出:信号输出 1 和信号输出 2 大小相同,相位相反。

4.外部时钟输入:时钟选择默认时,该接口不用输入任何信号。

接下来是单片机主控,这里我选用的依然是STM32F103ZET6最小系统板,具体连线参照上图即可: 在这里插入图片描述二、STM32软件设计 1.点频程序:也就是输出一个固定频率的信号,这里直接放代码,看不懂可以再问我:

#include "stdio.h" #include "ADF4351.h" #include "delay.h" int main(void) { delay_init(); //延时初始化 delay_ms(300); //ADF4351初始化 ADF4351Init(); ADF4351WriteFreq(400); //设置固定输出频率为400MHZ while(1) { ; } }

上面是点频程序的主函数,接下来是ADF4351.c,里面封装好了使用ADF4351这个模块的主要函数:

#include "ADF4351.h" #include "delay.h" //#define #define ADF4351_R0 ((u32)0X2C8018) #define ADF4351_R1 ((u32)0X8029) #define ADF4351_R2 ((u32)0X10E42) #define ADF4351_R3 ((u32)0X4B3) #define ADF4351_R4 ((u32)0XEC803C) #define ADF4351_R5 ((u32)0X580005) #define ADF4351_R1_Base ((u32)0X8001) #define ADF4351_R4_Base ((u32)0X8C803C) #define ADF4351_R4_ON ((u32)0X8C803C) #define ADF4351_R4_OFF ((u32)0X8C883C) //#define ADF4351_RF_OFF ((u32)0XEC801C) #define ADF4351_PD_ON ((u32)0X10E42) #define ADF4351_PD_OFF ((u32)0X10E02) void ADF_Output_GPIOInit(void) { GPIO_InitTypeDef GPIO_InitStruct; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE); GPIO_InitStruct.GPIO_Pin = GPIO_Pin_9|GPIO_Pin_10|GPIO_Pin_11|GPIO_Pin_12; GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStruct.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_Init(GPIOC, &GPIO_InitStruct); } void ADF_Input_GPIOInit(void) { GPIO_InitTypeDef GPIO_InitStruct; RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOC, ENABLE); GPIO_InitStruct.GPIO_Pin = GPIO_Pin_9|GPIO_Pin_11|GPIO_Pin_12; GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStruct.GPIO_Mode = GPIO_Mode_Out_PP; GPIO_Init(GPIOC, &GPIO_InitStruct); GPIO_InitStruct.GPIO_Pin = GPIO_Pin_10; GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN_FLOATING ; GPIO_Init(GPIOC, &GPIO_InitStruct); } void delay (int length) { while (length >0) length--; } void WriteToADF4351(u8 count, u8 *buf) { u8 ValueToWrite = 0; u8 i = 0; u8 j = 0; // ADF_Output_GPIOInit(); ADF4351_CE = 1; delay_us(1); ADF4351_CLK = 0; ADF4351_LE = 0; delay_us(1); for(i = count; i>0; i--) { ValueToWrite = *(buf+i-1); for(j=0; j>8) &(0X000000FF)); buf[0] = (u8)((Regster)&(0X000000FF)); WriteToADF4351(4,buf); } void ADF4351_Init_some(void) { WriteOneRegToADF4351(ADF4351_R2); WriteOneRegToADF4351(ADF4351_R3); WriteOneRegToADF4351(ADF4351_R5); } void ADF4351WriteFreq(float Fre) // fre单位MHz -> (xx.x) M Hz { u16 Fre_temp, N_Mul = 1, Mul_Core = 0; u16 INT_Fre, Frac_temp, Mod_temp, i; u32 W_ADF4351_R0 = 0, W_ADF4351_R1 = 0, W_ADF4351_R4 = 0; float multiple; if(Fre 4400.0) Fre = 4400.0; Mod_temp = 1000; Fre = ((float)((u32)(Fre*10)))/10; Fre_temp = Fre; for(i = 0; i = 2199.9) && ((Fre_temp*N_Mul)


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3