原创 DDS AD9959的实用资料

2008-3-8 17:46 7173 12 31 分类: 模拟

       有很多的朋友十分需要DDS,这里就将现在DDS中最好的一种----AD9959的常用资料发上来,供大家分享!


        AD9959是一款有四个DDS通道,最高达500M SPS的数字频率合成芯片。


        常用电路接法:


 点击看大图


         官方评估板电路:


          pdf


          主要程序:


#include "config.h"
void delay(void)
{
 unsigned int i;
 for(i=0;i<10;i++);
}


/*****************************************************************************

功能描述: 加载寄存器,上升延有效



*****************************************************************************/
void run(void)
{
 CLR_IOUPDATE;
 CLR_IOUPDATE;
 CLR_IOUPDATE;
 CLR_IOUPDATE;
 CLR_IOUPDATE;
 CLR_IOUPDATE;
 CLR_IOUPDATE;
 
 
 SET_IOUPDATE;
 SET_IOUPDATE;   
}


/*****************************************************************************
函数名: write_a_byte

功能描述: 通过串口写一个字节,MSB first,上升延有效



*****************************************************************************/
void write_a_byte(uint8 w_data)
{
 uint8 i;    
 for(i=0;i<8;i++)
  {
   if(w_data & 0x80)
   {
    SET_SDIO0;
   }
   else
   {
    CLR_SDIO0;
   }
   w_data <<= 1;
   SET_DDSSCLK;
   CLR_DDSSCLK;
  }
}


/*****************************************************************************
函数名: write_CSR

功能描述: 写CSR寄存器:

*****************************************************************************/
void write_CSR(uint8 w_data)
{
 CLR_SDIO3;
 CLR_DDSCS;
 write_a_byte(0x00);    //write address 0.  CSR's address is 0.
 write_a_byte(w_data);
 SET_DDSCS;
 SET_SDIO3;
}



void write_FR1(uint8 w_data1,uint8 w_data2,uint8 w_data3)
{
 CLR_SDIO3;
 CLR_DDSCS;
 
 write_a_byte(0x01);    //write address 1.  FR1's address is 0x01
 write_a_byte(w_data1);
 write_a_byte(w_data2);
 write_a_byte(w_data3);
 
 SET_DDSCS;
 SET_SDIO3;
}



void write_FR2(uint8 w_data1,uint8 w_data2)
{
 CLR_SDIO3;
 CLR_DDSCS;
 
 write_a_byte(0x02);    //write address 2
 write_a_byte(w_data1);
 write_a_byte(w_data2);
 
 SET_DDSCS;
 SET_SDIO3;
}


void write_CFR(uint8 w_data1,uint8 w_data2,uint8 w_data3)
{
 CLR_SDIO3;
 CLR_DDSCS;
 
 write_a_byte(0x03);
 write_a_byte(w_data1);
 write_a_byte(w_data2);
 write_a_byte(w_data3);
 
 SET_DDSCS;
 SET_SDIO3;
}


void write_CTW0(uint32 F_word)  //Channel Frequency Tuning Word  (CTW0)
{
 CLR_SDIO3;
 CLR_DDSCS;
 
 write_a_byte(0x04);
 write_a_byte(((unsigned char *)(&F_word))[3]);
 write_a_byte(((unsigned char *)(&F_word))[2]);
 write_a_byte(((unsigned char *)(&F_word))[1]);
 write_a_byte(((unsigned char *)(&F_word))[0]);
 
 SET_DDSCS;
 SET_SDIO3;
}


void write_CPW0(uint16 P_word)                  //Channel Phase1 Offset Word (CPW0) (0x05)
{
 CLR_SDIO3;
 CLR_DDSCS;
 
 write_a_byte(0x05);
 write_a_byte(((unsigned char *)(&P_word))[1]&0x3F);
 write_a_byte((((unsigned char *)(&P_word))[0]));
 
 SET_DDSCS;
 SET_SDIO3;
}


void write_ACR(uint32 A_word)
{
 CLR_SDIO3;
 CLR_DDSCS;
 write_a_byte(0x06);
 
 write_a_byte(((unsigned char *)(&A_word))[3]);
 write_a_byte(((unsigned char *)(&A_word))[2]);
 write_a_byte(((unsigned char *)(&A_word))[1]);
 
 SET_DDSCS;
 SET_SDIO3;
}


void write_LSR(uint8 rising,uint8 falling)
{
 CLR_SDIO3;
 CLR_DDSCS;
 
 write_a_byte(0x07);
 write_a_byte(rising);
 write_a_byte(falling);
 
 SET_DDSCS;
 SET_SDIO3;
}


void write_RDW(uint32 rising)
{
 CLR_SDIO3;
 CLR_DDSCS;
 
 write_a_byte(0x08);
 write_a_byte(((unsigned char *)(&rising))[3]);
 write_a_byte(((unsigned char *)(&rising))[2]);
 write_a_byte(((unsigned char *)(&rising))[1]);
 write_a_byte(((unsigned char *)(&rising))[0]);
 
 SET_DDSCS;
 SET_SDIO3;
}


void write_FDW(uint32 falling)
{
 CLR_SDIO3;
 CLR_DDSCS;
 
 write_a_byte(0x09);
 write_a_byte(((unsigned char *)(&falling))[3]);
 write_a_byte(((unsigned char *)(&falling))[2]);
 write_a_byte(((unsigned char *)(&falling))[1]);
 write_a_byte(((unsigned char *)(&falling))[0]);
 
 SET_DDSCS;
 SET_SDIO3;
}


void write_CTWn(uint8 n,uint32 w_data)
{
 CLR_SDIO3;
 CLR_DDSCS;
 
 write_a_byte(n+0x09);   //CTWn's address is n+0x09.n>=1 and n<=15.
 write_a_byte(((unsigned char *)(&w_data))[3]);
 write_a_byte(((unsigned char *)(&w_data))[2]);
 write_a_byte(((unsigned char *)(&w_data))[1]);
 write_a_byte(((unsigned char *)(&w_data))[0]);
 
 SET_DDSCS;
 SET_SDIO3;
}


#define PLL_DIV 5
#define systemp_frequency (22.1184*1000000*PLL_DIV)


void set_frequency(uint32 f)
{
 unsigned long int temp;
 temp=(unsigned long int)f*(0xFFFFFFFF/(float)systemp_frequency+1.0/systemp_frequency);
 write_CTW0(temp);
}



uint32 change(uint32 f)
{
 unsigned long int temp;
 temp=(unsigned long int)f*(0xFFFFFFFF/(float)systemp_frequency+1.0/systemp_frequency);
 return temp;
}


void AD9959_init(void)
{
 uint16 i;
 DDS_DDR = 0xff;
 CLR_DDSRESET;
 for(i=0;i<10000;i++);
 
 SET_DDSCS;
 CLR_DDSSCLK;
 SET_SDIO3;
 SET_DDSRESET;
 
 for(i=0;i<10000;i++);
 
 CLR_DDSRESET;
 for(i=0;i<100;i++);
}

PARTNER CONTENT

文章评论19条评论)

登录后参与讨论

用户1456817 2009-7-14 15:23

大侠有没有做过AD9954的内部存储器啊?我正在做,可是10天了还是不知道要怎么去控制,能大些资料或是给我些意见吗?我的邮箱是huangxinqing1987@126.com qq:418430126 谢谢啦

用户416932 2009-3-23 22:05

文件损坏,解压不了!楼主,是不是李世鹤先生的《TD-SCDMA第三代移动通信系统标准》呢???

用户416932 2009-3-23 21:55

谢谢,下来看看,最近爱上学习TD,我们自己的3G通信技术标准!!!

用户800139 2009-2-10 19:01

原理图是错的

用户177851 2008-12-2 12:17

dasdfaasdfasdfasdfa

用户800139 2008-9-13 09:54

到学校没有?

用户800139 2008-9-13 09:53

我又焊了一片,现象一样

用户800139 2008-8-19 14:30

likee,你有电话吗?能否留一个。我的ad9959就是不输出,寄存器都能写进去,还能读出来,是不是ad9959坏了?

daiqiumiao_806246054 2008-8-7 10:25

如果没有记错是那样的。

daiqiumiao_806246054 2008-8-7 10:21

我现在的电脑上没有那些资料,开学的时候就可以给你。
相关推荐阅读
daiqiumiao_806246054 2011-01-06 13:57
linux下yum代理设置
    我们在安装好linux后,经常会使用yum来更新系统,但是系统默认的代理是国外的,国内一般的网络不能访问,这里讲解具体做法,把代理换成国内的。attachment download      ...
daiqiumiao_806246054 2010-12-30 09:48
【转】ORACLE 10g下载地址
Oracle Database 10g Release 2 (10.2.0.1.0) Enterprise/Standard Edition for Microsoft Windows (32-bit...
daiqiumiao_806246054 2010-11-29 11:06
找工作的进来看
如下是我所有的开放性问题回答,希望对大家有帮助!1.      When choosing your first job/employer, what will you consider and wh...
daiqiumiao_806246054 2010-11-29 09:47
中长期规划---螺旋式上升方式修改完善职业之路
一、中长期职业发展的自我准备1、心态上随时做好准备 机会是给有准备的人的------“有准备”是你在做准备的过程中让“别人”认为你“有准备”!别人是包括你现在的老板和别的老板,以及你身边的人!他们对你...
daiqiumiao_806246054 2010-03-17 21:26
移动
分集方式传输损耗和距离关系光纤网络G网...
daiqiumiao_806246054 2010-03-17 09:40
GSM
特点  使用直观  GSM系统有几项重要特点:防盗拷能力佳、网络容量大、手机号码资源丰富、通话清晰、稳定性强不易受干扰、信息灵敏、通话死角少、手机耗电量低。  技术特点  1.频谱效率。由于采用了高效...
EE直播间
更多
我要评论
19
12
关闭 站长推荐上一条 /3 下一条