共2条
1/1 1 跳转至页
请指教关于A/D采样转换时间的困惑?
问
#define Fosc 11059200
#define Fcclk (Fosc * 4)
#define Fcco (Fcclk * 4)
#define Fpclk (Fcclk / 4) * 1
ADCR = (1 << 0) | // SEL = 1 ,选择通道0
(0 << 8) | // CLKDIV = 0
(0 << 16) | // BURST = 0 ,软件控制转换操作
(0 << 17) | // CLKS = 0 ,使用11clock转换(即10转换方式)
(1 << 21) | // PDN = 1 , 正常工作模式(非掉电转换模式)
(0 << 22) | // TEST1:0 = 00 ,正常工作模式(非测试模式)
(0 << 24) | // START = 1 ,直接启动ADC转换
(0 << 27); // EDGE = 0 (CAP/MAT引脚下降沿触发ADC转换)
while(1){
ADCR = ADCR | (1 << 24);
IO0SET = (1 << 23);
while( (ADDR&0x80000000)==0 );
IO0CLR = (1 << 23);
ADC_Data = ADDR;
}
观察P0.23引脚上的输出,发现输出高电平的时间小于2us,这意味着A/D转换时间小于2us,可手册上说10位转换时间>=2.44us,怎么回事啊?请指教 答 1: 顶一下忘记说了,我用的是EasyARM2100的开发板做的上述实验 答 2: easyARM2200实测数据间隔为33us,请教
ADCR = (4 << 0) | // SEL = 4 ,选择通道3
((Fpclk / 4500000 - 1) << 8) |
(0 << 16) | // BURST = 0 ,软件控制转换操作
(0 << 17) | // CLKS = 0 ,使用11clock转换
(1 << 21) | // PDN = 1 , 正常工作模式
(0 << 22) | // TEST1:0 = 00 ,正常工作模式
(1 << 24) | // START = 1 ,直接启动ADC转换
(0 << 27); // EDGE = 0 (CAP/MAT引脚下降沿触发ADC转换)
DelayNS(10);
ADC_Data = ADDR; // 读取ADC结果,并清除DONE标志位
ADCR = (ADCR&0xFFFFFF00)|0x04|(1 << 24); // 切换通道并进行第一次转换
while( (ADDR&0x80000000)==0 ); // 等待转换结束
for(j=0; j<200; j++)
{
ADCR = ADCR | (1 << 24); // 再次启运转换
while( (ADDR&0x80000000)==0 );
ADC_Data_b[j] = ADDR; // 读取ADC结果
}
#define Fosc 11059200
#define Fcclk (Fosc * 4)
#define Fcco (Fcclk * 4)
#define Fpclk (Fcclk / 4) * 1
ADCR = (1 << 0) | // SEL = 1 ,选择通道0
(0 << 8) | // CLKDIV = 0
(0 << 16) | // BURST = 0 ,软件控制转换操作
(0 << 17) | // CLKS = 0 ,使用11clock转换(即10转换方式)
(1 << 21) | // PDN = 1 , 正常工作模式(非掉电转换模式)
(0 << 22) | // TEST1:0 = 00 ,正常工作模式(非测试模式)
(0 << 24) | // START = 1 ,直接启动ADC转换
(0 << 27); // EDGE = 0 (CAP/MAT引脚下降沿触发ADC转换)
while(1){
ADCR = ADCR | (1 << 24);
IO0SET = (1 << 23);
while( (ADDR&0x80000000)==0 );
IO0CLR = (1 << 23);
ADC_Data = ADDR;
}
观察P0.23引脚上的输出,发现输出高电平的时间小于2us,这意味着A/D转换时间小于2us,可手册上说10位转换时间>=2.44us,怎么回事啊?请指教 答 1: 顶一下忘记说了,我用的是EasyARM2100的开发板做的上述实验 答 2: easyARM2200实测数据间隔为33us,请教
ADCR = (4 << 0) | // SEL = 4 ,选择通道3
((Fpclk / 4500000 - 1) << 8) |
(0 << 16) | // BURST = 0 ,软件控制转换操作
(0 << 17) | // CLKS = 0 ,使用11clock转换
(1 << 21) | // PDN = 1 , 正常工作模式
(0 << 22) | // TEST1:0 = 00 ,正常工作模式
(1 << 24) | // START = 1 ,直接启动ADC转换
(0 << 27); // EDGE = 0 (CAP/MAT引脚下降沿触发ADC转换)
DelayNS(10);
ADC_Data = ADDR; // 读取ADC结果,并清除DONE标志位
ADCR = (ADCR&0xFFFFFF00)|0x04|(1 << 24); // 切换通道并进行第一次转换
while( (ADDR&0x80000000)==0 ); // 等待转换结束
for(j=0; j<200; j++)
{
ADCR = ADCR | (1 << 24); // 再次启运转换
while( (ADDR&0x80000000)==0 );
ADC_Data_b[j] = ADDR; // 读取ADC结果
}
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
与电子爱好者谈读图四被打赏50分 | |
与电子爱好者谈读图二被打赏50分 | |
【FRDM-MCXN947评测】Core1适配运行FreeRtos被打赏50分 | |
【FRDM-MCXN947评测】双核调试被打赏50分 | |
【CPKCORRA8D1B评测】---移植CoreMark被打赏50分 | |
【CPKCORRA8D1B评测】---打开硬件定时器被打赏50分 | |
【FRDM-MCXA156评测】4、CAN loopback模式测试被打赏50分 | |
【CPKcorRA8D1评测】--搭建初始环境被打赏50分 | |
【FRDM-MCXA156评测】3、使用FlexIO模拟UART被打赏50分 | |
【FRDM-MCXA156评测】2、rt-thread MCXA156 BSP制作被打赏50分 |