DSP

TMS320C5509A自带ADC配置参数计算

2019-07-13 15:24发布

TMS320C5509A自带ADC使用起来比较方便,但是确定参数比较麻烦。作者尝试使用程序计算出来,方便DSP自带ADC的使用。设计的程序可 直接计算出TMS320C5509A自带ADC配置参数,以十六进制形式输出结果,方便可用。 [另外作者发现,TI的TMS320VC5509 DSP
Analog-to-Digital Converter (ADC)Reference Guide(2003年10月版,spru586a)中11页关于ADC Sample and Hold Period值的公式有错误之处。]
开发平台:VC++6.0、Visual Studio2010(均亲测可用)。
void calcu_ADCConfig(double fcpu,double fs) { /* 参数说明: fcpu,CPU时钟频率(MHz);fs,要求的采样速率(Hz)。 */ double Ts=0,fadc=0,fconv=0,Tconv=0,Th=0; double samptimediv=0.0; int cpuclkdiv,convratediv; int i,count=0; fcpu=fcpu*1000000; // Hz Ts=1/fs; // 采样周期 for(cpuclkdiv=0;cpuclkdiv<256;cpuclkdiv++) { fadc=fcpu/(cpuclkdiv+1); //计算ADC时钟频率 for(convratediv = 0; convratediv<16; convratediv++) { fconv=fadc/(2*(convratediv+1)); // ADC转换时钟频率 Tconv=1/fconv; // ADC转换时钟周期 if(fconv<=2000000) //ADC转换时钟频率不大于 2 MHz { Th=Ts-13*Tconv; // 由采样速率计算采样保持时间 if(Th>=0.00004 && Th<=0.0004) // 不得小于40us && Th<=0.0004 不大于400us { samptimediv=fadc*Th/2-(convratediv+1); //计算samptimediv if(samptimediv>=0 && samptimediv <=255) for (i=0;i<256;i++) { //if (fabs(i-samptimediv)<0.00000000002) //0.0000000000001 //float 类型的samptimediv 不能直接和 int 型的i 比较 if (i==(int)samptimediv) //0.00000000000002 { //printf("cpuclkdiv=%d ; convratediv=%d ; samptimediv=%.8f ",cpuclkdiv,convratediv,samptimediv); /* cout<<"cpuclkdiv= "<


TMS320C5509A ADC参数计算。
功能:直接在运行输出窗口以十六进制形式输出ADC配置参数(cpuclkdiv,convratediv,samptimediv,详见参考手册);也可以输出寄存器形式(ADCCLKCTL、ADCCLKDIV)。
------------------------------------------------------------------------------------------------
#include
#include
using namespace std;

void calcu_ADCConfig(double fcpu,double fs);


int main()
{
double fcpu=144;    //CPU时钟频率(MHz)
double fs=2000;     //要求的采样速率(Hz)




double fadc,fadc_conv,x;   // fadc:ADC时钟;  fadc_conv:ADC转换时钟  
double cpuclkdiv,convratediv,samptimediv;    


calcu_ADCConfig(fcpu,fs);


//--------------------------------------------------------------
//---------------结果验证---------------------------------------
cpuclkdiv= 143 ; convratediv= 8 ; samptimediv= 124.000000;
fcpu = fcpu*1000000;   //CPU时钟 144MHz
fadc=fcpu/(cpuclkdiv+1);    //ADC时钟
fadc_conv = fadc/(2*(convratediv + 1));     //ADC转换时钟  
x= 13/fadc_conv + 2*(convratediv+samptimediv+1)/fadc;   // 采样周期
//  ADC采样保持时间     +    采样保持时间
printf("采样周期: Ts=%.8f ",x);
printf("采样速率: fs=%.4f ",1/x);
//--------------------------------------------------------------

return 0;
}
运行结果截图: