找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2213|回复: 1
收起左侧

51单片机AD9851远程幅频特性制作 附测试程序与资料

[复制链接]
ID:498094 发表于 2021-9-27 03:22 | 显示全部楼层 |阅读模式
本设计为一远程幅频特性测试的系统,在硬件上,采用单片机控制 AD9851信号发生模块,完成波幅,步进,输出频率的设置,通过高速 A/D 转换实时将输出波幅显示到液晶显示屏上。各个模块是相互独立的,保证了模块能够稳定输出频率为 1MHz-40MHz 峰值可调的信号波。利用适用于中频放大的 AD8367 芯片,对
波形进行无明显失真的放大。此外还利用频率检测模块以及有效值检波模块,两者能够在 1-500M 的范围内提供出良好的数据供软件部分拟合成幅频特性曲线。
所研究关键技术的嵌入式系统,具有高精度、高可靠性和低功耗等优点,主要从传感器数据采集、无线网络设计功能入手,利用嵌入式系统的控制优势,实现整个系统的智能控制和监测。本设计远程幅频特性测试系统将硬件平台采集的各种重要参数显示在 PC 机终端,让用户更加直观清晰的观测到幅频特性的改变。

制作出来的实物图如下:
1.jpg 2.jpg 3.jpg


单片机源程序如下:
  1. #include "AD9851.H"
  2. #include "stdio.h"
  3. #include "nokia_5110.h"
  4. //***************************************************//
  5. //函数1:           ad9851_reset()                    //
  6. //函数2:           ad9851_reset_serial()             //
  7. //函数3:           ad9851_wr_parrel(unsigned char w0,double frequence)//
  8. //函数4:           ad9851_wr_serial(unsigned char w0,double frequence)//
  9. //版本:              V1.1                            //
  10. //***************************************************//
  11. //                  子程序说明                       //
  12. //***************************************************//
  13. //函数1:  ad9851_reset()
  14. //        复位ad9851,之后为并口写入模式        
  15. //函数2:  ad9851_reset_serial()
  16. //        复位ad9851,之后为串口写入模式
  17. //函数3:  ad9851_wr_parrel(unsigned char w0,double frequence)
  18. //        并口写ad9851数据,w0为ad9851中w0的数据,frequence
  19. //        为写入的频率       
  20. //函数4:  ad9851_wr_serial(unsigned char w0,double frequence)
  21. //        串口写ad9851数据,w0为ad9851中w0的数据,frequence
  22. //        为写入的频率       
  23. //需定义的位:
  24. //ad9851_w_clk    ;
  25. //ad9851_fq_up    ;
  26. //ad9851_rest     ;
  27. //ad9851_bit_data ;
  28. //例:
  29. //sbit ad9851_w_clk    =P2^2;
  30. //sbit ad9851_fq_up    =P2^1;
  31. //sbit ad9851_rest     =P2^0;
  32. //sbit ad9851_bit_data =P1^7;
  33. //***************************************************//
  34. //                 写数据说明                        //
  35. //***************************************************//
  36. //写数据例:
  37. //       ad9851_reset()
  38. //       wr_lcd02_data(unsigned char x)
  39. //       ad9851_wr_parrel(0x01,1000)
  40. //       ad9851_wr_serial(0x01,1000)
  41. //***************************************************//
  42. //---------------------------------------------------//
  43. //并行写1000Hz程序
  44. //        ad9851_reset();
  45. //        ad9851_wr_parrel(0x01,100000);
  46. //0X01为开六备频
  47. //ad9851_wr_parrel(0x00,1000);
  48. //0X00为不开六备频
  49. //---------------------------------------------------//
  50. //---------------------------------------------------//
  51. //串行写1000Hz程序
  52. //ad9851_reset_serial();
  53. //ad9851_wr_serial(0x01,1000);
  54. //0X01为开六备频
  55. //ad9851_wr_serial(0x00,1000);
  56. //0X00为不开六备频
  57. //---------------------------------------------------//
  58. //---------------------------------------------------//
  59. //                   程序                            //
  60. //---------------------------------------------------//
  61. ////
  62. ////sbit ad9851_w_clk    =P2^2;  //P2.2口接AD9851的w_clk脚/PIN7
  63. ////sbit ad9851_fq_up    =P2^1;  //P2.1口接AD9851的fq_up脚/PIN8
  64. ////sbit ad9851_rest     =P2^0;  //P2.0口接AD9851的rest脚/PIN12
  65. ////sbit ad9851_bit_data =P1^7;  //P1.7口接AD9851的D7脚/PIN25
  66. //////P1为8位数据口
  67. //***************************************************//
  68. //              ad9851复位(并口模式)                 //
  69. //---------------------------------------------------//
  70. void ad9851_reset()
  71. {
  72.         ad9851_w_clk=0;
  73.         ad9851_fq_up=0;
  74.         //rest信号
  75.         ad9851_rest=0;
  76.         ad9851_rest=1;
  77.         ad9851_rest=0;
  78. }
  79. //***************************************************//
  80. //              ad9851复位(并口模式)                 //
  81. //---------------------------------------------------//
  82. void ad9851_reset_serial()
  83. {
  84.         ad9851_w_clk=0;
  85.         ad9851_fq_up=0;
  86.         //rest信号
  87.         ad9851_rest=0;
  88.         ad9851_rest=1;
  89.         ad9851_rest=0;
  90.         //w_clk信号
  91.         ad9851_w_clk=0;
  92.         ad9851_w_clk=1;
  93.         ad9851_w_clk=0;
  94.         //fq_up信号
  95.         ad9851_fq_up=0;
  96.         ad9851_fq_up=1;
  97.         ad9851_fq_up=0;
  98. }
  99. //***************************************************//
  100. //          向ad9851中写命令与数据(并口)             //
  101. //---------------------------------------------------//
  102. void ad9851_wr_parrelnums(unsigned char w0,double frequence)
  103. {
  104.         u8 i;
  105.         for(i = 0; i < 5; i++)
  106.                 ad9851_wr_parrel(w0, frequence);
  107. }
  108. void ad9851_wr_parrel(unsigned char w0,double frequence)
  109. {
  110.         unsigned char w;
  111.         long int y;
  112.         double x;
  113.         //计算频率的HEX值
  114.         x=4294967295/180;//适合180M晶振/180为最终时钟频率(或30M六倍频)
  115.         //如果时钟频率不为180MHZ,修改该处的频率值,单位MHz !!!
  116.         frequence=frequence/1000000;
  117.         frequence=frequence*x;
  118.         y=frequence;
  119.         //写w0数据
  120.         w=w0;   
  121.         P1=w;      //w0
  122.         ad9851_w_clk=1;
  123.         ad9851_w_clk=0;
  124.         //写w1数据
  125.         w=(y>>24);
  126.         P1=w;      //w1
  127.         ad9851_w_clk=1;
  128.         ad9851_w_clk=0;
  129.         //写w2数据
  130.         w=(y>>16);
  131.         P1=w;      //w2
  132.         ad9851_w_clk=1;
  133.         ad9851_w_clk=0;
  134.         //写w3数据
  135.         w=(y>>8);
  136.         P1=w;      //w3
  137.         ad9851_w_clk=1;
  138.         ad9851_w_clk=0;
  139.         //写w4数据
  140.         w=(y>>=0);
  141.         P1=w;      //w4
  142.         ad9851_w_clk=1;
  143.         ad9851_w_clk=0;
  144.         //移入始能
  145.         ad9851_fq_up=1;
  146.         ad9851_fq_up=0;
  147. }
  148. //***************************************************//
  149. //          向ad9851中写命令与数据(串口)             //
  150. //---------------------------------------------------//
  151. void ad9851_wr_serial(unsigned char w0,double frequence)
  152. {
  153.         u8 diss[30];
  154.         static adenter = 0;
  155.         unsigned char i,w;
  156.         long int y;
  157.         double x;
  158.         sprintf(diss, "SADEnter:%d", (int)adenter++);
  159.         LCD_write_english_string(10,3,diss);
  160.         //计算频率的HEX值
  161.         x=4294967295/180;//适合180M晶振/180为最终时钟频率(或30M六倍频)
  162.         //如果时钟频率不为180MHZ,修改该处的频率值,单位MHz  !!!
  163.         frequence=frequence/1000000;
  164.         frequence=frequence*x;
  165.         y=frequence;
  166.         //写w4数据
  167.         w=(y>>=0);
  168.         for(i=0;i<8;i++)
  169.         {
  170.                 ad9851_bit_data=(w>>i)&0x01;
  171.                 ad9851_w_clk=1;
  172.                 ad9851_w_clk=0;
  173.         }
  174.         //写w3数据
  175.         w=(y>>8);
  176.         for(i=0;i<8;i++)
  177.         {
  178.                 ad9851_bit_data=(w>>i)&0x01;
  179.                 ad9851_w_clk=1;
  180.                 ad9851_w_clk=0;
  181.         }
  182.         //写w2数据
  183.         w=(y>>16);
  184.         for(i=0;i<8;i++)
  185.         {
  186.                 ad9851_bit_data=(w>>i)&0x01;
  187.                 ad9851_w_clk=1;
  188.                 ad9851_w_clk=0;
  189.         }
  190.         //写w1数据
  191.         w=(y>>24);
  192.         for(i=0;i<8;i++)
  193.         {
  194.                 ad9851_bit_data=(w>>i)&0x01;
  195.                 ad9851_w_clk=1;
  196.                 ad9851_w_clk=0;
  197.         }
  198.         //写w0数据
  199.         w=w0;   
  200.         for(i=0;i<8;i++)
  201.         {
  202.                 ad9851_bit_data=(w>>i)&0x01;
  203.                 ad9851_w_clk=1;
  204.                 ad9851_w_clk=0;
  205.         }
  206.         //移入始能
  207.         ad9851_fq_up=1;
  208.         ad9851_fq_up=0;
  209. }
复制代码
  1. #include "STC12C5A60S2.H"
  2. #include "key.h"
  3. #include "stdio.h"
  4. #include "DDS9851.H"
  5. #include "USART.H"
  6. #include "nokia_5110.h"

  7. u8 Task_ID = 0;
  8. u8 OLD_Task_ID = 0;
  9. u8 i, RUN;
  10. u8 enter = 0;
  11. u8 dis[30];
  12. int k1 = 0, k2 = 0, k3 = 0, k4 = 0;
  13. u32 Fre = 100000;
  14. double pinlv;
  15. void init(void)
  16. {
  17. ////        IT0=1;
  18. ////        EX0 = 1;
  19. ////        IT1=1;
  20. ////        EX1 = 1;
  21. ////        EA = 1;
  22.         P0=0x00;
  23.         P1=0x00;
  24.         P2=0x00;
  25.         P3=0xff;
  26. }
  27. char disbuf[20];
  28. void main()
  29. {
  30.         init();
  31.         LCD_init();
  32.         UsartInit();
  33.         LCD_write_english_string(10,2,"AD9851XX");
  34.         Key_Init();
  35.         ad9851_wr_parrel(0x01, (double)Fre);        //0X00为不开六备频 0X01为开六备频
  36.         LCD_clear();
  37.         LCD_write_english_string(24,2,"AD9851");
  38.         LCD_Show_CEStr(10,0,"康威电子");
  39.         LCD_write_english_string(3,4,"000,100,000Hz");
  40.         LCD_write_english_string(10,3,"Point");
  41.         while(1)
  42.         {
  43.                 KeyRead();
  44.                 OLD_Task_ID = Task_ID;
  45.                 switch(Keycode)
  46.                 {
  47.                         case E_K_L: Task_ID++; Task_ID %= 3;break;
  48.                 }
  49.                 if(Task_ID != OLD_Task_ID)
  50.                 {
  51.                         LCD_clear();
  52.                         LCD_Show_CEStr(10,0,"电子");
  53.                         switch(Task_ID)
  54.                         {
  55.                                 case 0: LCD_write_english_string(24,3,"Point");break;
  56.                                 case 1: LCD_write_english_string(24,2,"Sweep");break;
  57.                                 case 2: LCD_write_english_string(24,2,"Step");changefre(&f_step, Keycode, dis);break;
  58.                         }       
  59.                 }
  60.                 if((Keycode != 0) && (Keycode != D_K_L))
  61.                         Sweeper_state = 0;
  62.                 switch(Task_ID)
  63.                 {
  64.                         case 0:
  65.                                 if(Keycode != 0)
  66.                                 {
  67.                                         pinlv = changefre(&Fre, Keycode, dis);
  68.                                         LCD_write_english_string(3,4,dis);
  69.                                         ad9851_wr_parrel(0x01, pinlv);
  70.                                 }
  71.                         break;
  72.                         case 1:
  73.                                 sweep_freq();
  74. ……………………

  75. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

代码与资料下载: AD9851-Nokia5110资料包-驱动 PDF-V7.0.7z (3.64 MB, 下载次数: 38)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:1531 发表于 2021-9-27 08:05 | 显示全部楼层
这东西的应用场景是什么?
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表