|
200黑幣
SPI模式寫AD9833
實(shí)現(xiàn)功能:兩個AD9833,其中一個為基準(zhǔn)輸出頻率為60KHZ,0初始相位正弦波,另一AD9833輸出同頻率60KHZ,(相位需可調(diào))正弦波。兩波形用示波器顯示,通過調(diào)整另一波形的相位并用示波器觀察兩波形的相位差。
遇到問題:示波器如何同步顯示兩波形。若能同步,可否其中一個波形固定,另一波形相位可調(diào)?
硬件圖:
程序如下:
sbit f_sync = P2^2;
sbit s_clk = P2^1;
sbit s_data = P2^0;
#define DDS_SCLK_UP s_clk=1
#define DDS_SCLK_DOWN s_clk=0
#define DDS_SDATA_UP s_data=1
#define DDS_SDATA_DOWN s_data=0
#define DDS_FSYNC_UP f_sync=1
#define DDS_FSYNC_DOWN f_sync=0
//#define BITB 0x0800
//AD9833輸入時鐘值
unsigned long int MCLK=25000000;
double p=3.141592653589793;
//寄存器配置數(shù)組
unsigned int Config_Data[8];
//頻率
unsigned long int code freq[5]={30000,60000,120000,480000,960000};
//函數(shù)聲明
static void delay2us(unsigned char i);
static void changeFreq(unsigned char key);
static unsigned char getKeyValue();
void writeDDS2Byte(unsigned int config);
void waveGenerate(unsigned long int frequency,double phase,unsigned char signal_type);
//void main(void)
//{
// waveGenerate(freq[4],2*p,0); //
//}
/*******************************************************************
* 功能:波形發(fā)生器
*
* 入口參數(shù): frequency: 期望得到的信號頻率 (frequency<MCLK)
*
* phase:期望得到的相位
*
* signal_type:0正弦波1(三角波),2(方波)
*
* 默認(rèn)配置: 0相移,方波不分頻
*******************************************************************/
void waveGenerate(unsigned long int frequency,double phase,unsigned char signal_type)
{
unsigned char k;
unsigned long int freq_temp;
unsigned int phase_temp;
if(frequency>MCLK)
frequency=MCLK;
switch(signal_type)
{
case 0://正弦波
Config_Data[0]=0x2108;//控制寄存器配置值,復(fù)位片內(nèi)其他寄存器,AD9833上電時,期間應(yīng)復(fù)位,要使AD9833復(fù)位應(yīng)將reset位置1,即bit8置1,要通過Vout引腳提供正弦波輸出,應(yīng)將mode(D1)bit清0并將OPBITEN(D5)bit清0,當(dāng)DIV2=1時即bit3=1,DAC的MSB被直接送至Vout引腳
Config_Data[7]=0x2008;//控制寄存器配置值,不復(fù)位片內(nèi)其他寄存器,要使AD9833退出復(fù)位,應(yīng)將該位清零,即bit8位清零,要通過Vout引腳提供正弦波輸出,應(yīng)將mode(D1)bit清0并將OPBITEN(D5)bit清0,當(dāng)DIV2=1時即bit3=1,DAC的MSB被直接送至Vout引腳
break;
case 1://三角波
Config_Data[0]=0x210A;//控制寄存器配置值,復(fù)位片內(nèi)其他寄存器,AD9833上電時,期間應(yīng)復(fù)位,要使AD9833復(fù)位應(yīng)將reset位置1,即bit8置1,要通過Vout引腳提供三角波輸出,應(yīng)將mode(D1)1,DIV2=1時即bit3=1,DAC的MSB被直接送至Vout引腳
Config_Data[7]=0x200A;//控制寄存器配置值,不復(fù)位片內(nèi)其他寄存器,要使AD9833退出復(fù)位,應(yīng)將該位清零,即bit8位清零,要通過Vout引腳提供三角波輸出,應(yīng)將mode(D1)置1,DIV2=1時即bit3=1,DAC的MSB被直接送至Vout引腳
break;
case 2://方波,不分頻
Config_Data[0]=0x2128;//控制寄存器配置值,復(fù)位片內(nèi)其他寄存器,AD9833上電時,期間應(yīng)復(fù)位,要使AD9833復(fù)位應(yīng)將reset位置1,即bit8置1,當(dāng)OPBITEN(D5)置1,mode(D1)清0,DIV2=1時即bit3=1,Vout輸出DAC數(shù)據(jù)MSB
Config_Data[7]=0x2028;//控制寄存器配置值,不復(fù)位片內(nèi)其他寄存器,要使AD9833退出復(fù)位,應(yīng)將該位清零,即bit8位清零,當(dāng)OPBITEN(D5)置1,mode(D1)清0,DIV2=1時即bit3=1,Vout輸出DAC數(shù)據(jù)MSB
break;
default://正弦波
Config_Data[0]=0x2108;
Config_Data[7]=0x2008;
break;
}
//freq_temp=frequency*(2^28/MCLK),MCLK=6Mhz?,2^28/MCLK約等于44.739242666666669
//phase_temp=phase*(4096/2p),p=3.141592653589793
freq_temp=frequency*10.73741824; //載入所選頻率寄存器的值,此信號會經(jīng)過如下相位偏移處理,2?/4096*PHASEREG,PHASEREG是所選相位輸出頻率和參考時鐘頻率之間的關(guān)系,必須考慮所選輸出頻率和參考時鐘頻率之間的關(guān)系,以免產(chǎn)生不良的輸出異常
phase_temp=phase*(4096/2*p);//651.898646904403295309
Config_Data[1]=freq_temp&0x3fff;//先將bit15,bit14位清0,控制字寫入
Config_Data[3]=Config_Data[1];//先將bit15,bit14位清0,控制字寫入
Config_Data[2]=(freq_temp&0x0fffc000)>>14;//先將bit15,bit14位清0,控制字寫入
Config_Data[4]=Config_Data[2];//先將bit15,bit14位清0,控制字寫入
Config_Data[5]=phase_temp&0x1fff;
Config_Data[5]=Config_Data[6];
Config_Data[1]=Config_Data[1]|0x4000;//(頻率寄存器)FREQ0 14 LSBs,bit15=0,bit14=1,F(xiàn)REQ0寄存器寫入
Config_Data[2]=Config_Data[2]|0x4000;//(頻率寄存器)FREQ0 14 MSBs,bit15=0,bit14=1,F(xiàn)REQ0寄存器寫入
Config_Data[3]=Config_Data[3]|0x8000;//(頻率寄存器)FREQ1 14 LSBs,bit15=1,bit14=0,F(xiàn)REQ1寄存器寫入
Config_Data[4]=Config_Data[4]|0x8000;//(頻率寄存器)FREQ1 14 MSBs,bit15=1,bit14=0,F(xiàn)REQ1寄存器寫入
// Config_Data[5]=0xC000;//(相位寄存器)PHASE0
// Config_Data[6]=0xE000;//(相位寄存器)PHASE1
Config_Data[5]=Config_Data[5]|0xC000;//(相位寄存器)PHASE0,bit15=1,bit14=1,bit13=0,PHASE0寄存器寫入
Config_Data[6]=Config_Data[6]|0xE000;//(相位寄存器)PHASE1,bit15=1,bit14=1,bit13=1,PHASE1寄存器寫入
for(k=0;k<8;k++)
{
writeDDS2Byte(Config_Data[k]);
}
}
/***********************************************************************************************
*
* 軟件模擬SPI
*
* 向AD9833寫入數(shù)據(jù)或控制信息時0,F(xiàn)SYNC應(yīng)處于低電平并保持低電平,直到數(shù)據(jù)的16個位均已寫入AD9833為止,F(xiàn)SYNC信號以幀方式傳輸要載入AD9833的16位信息
*
* 向AD9833發(fā)送數(shù)據(jù)時,F(xiàn)SYNC被拉低,單片機(jī)以8位字節(jié)傳輸數(shù)據(jù),因此每個周期中只有8個SCLK下降沿,要向AD9833中載入剩余的8個位,F(xiàn)SYNC應(yīng)在第一批8個位傳輸完成后保持低電平,同時啟動第二次寫操作來傳輸數(shù)
* 據(jù)的第二個字節(jié),第二次寫操作結(jié)束后FSYNC被拉高,SCLK應(yīng)在兩次寫操作之間處于高電平空閑狀態(tài)
*
************************************************************************************************/
void writeDDS2Byte(unsigned int config)
{
unsigned char i;
DDS_SCLK_DOWN;//拉低SCLK
_nop_();//延時
DDS_FSYNC_UP;//拉高FSYNC
_nop_();//延時
DDS_SCLK_UP;//拉高SCLK
delay2us(1);//延時1us
DDS_FSYNC_DOWN;//發(fā)送數(shù)據(jù)時,F(xiàn)SYNC拉低
_nop_();
for (i=0; i<16; i++)
{
if (config & 0x8000)
DDS_SDATA_UP;//SDATA拉高
else
DDS_SDATA_DOWN;//SDATA拉低
delay2us(1);//延時1us
DDS_SCLK_DOWN;//SCLK拉低
delay2us(1);//延時1us
DDS_SCLK_UP;//SCLK拉高
config <<= 1;//config循環(huán)左移一位
}
DDS_FSYNC_UP;//FSYNC拉高
_nop_();//延時
DDS_SCLK_DOWN;//SCLK拉低
delay2us(100);//延時100us
}
static void delay2us(unsigned char i)
{
while (--i);
}
|
-
-
AD9833_cn.pdf
2020-12-1 11:11 上傳
點(diǎn)擊文件名下載附件
885.82 KB, 下載次數(shù): 24
|