你好,
我们正在努力解决如何使用差异ADC。首先,从GP_ADC_RESULT_REG返回的值似乎比我们所预期的要高的一个值,其次是当测量的电压差实际增加时,差值在幅度幅度降低:
1)我们对数据表的读取表明,当配置为P0_ 0和P0_1之间的差分ADC操作时,结果是一个10位2的补码二进制整数,在-1.2v时允许满刻度读数0x200(-512),在+1.2v时允许0x1ff(+511)。这意味着每个ADC计数在测量上大致等于2.3mV(即1.2 / 512 = 2.34e-03)。
我们正在尝试使用DA14580 devkit-basic差分ADC来测量惠斯通电阻桥的两个臂之间的电压差(P0_ 0连接到左手边,P0_1连接到右手边)。用示波器测量P0_ 0为1.54v, P0_1为1.26v。
1.26 - 1.54 = -0.28v
因此,我们期望ADC_Get_Sample()返回的ADC计数在0x388(-120)左右的某个地方,但实际上它在0x235(-459)〜= -1.07V左右。
我们误解了数据表吗?将ADC配置为单端似乎正常工作。
2)我们的惠斯通桥配置为测量NTC热敏电阻。当该热敏电阻的值随温度的变化时,随着温度加热时,电阻减小,因此通过P0_1测量的电压相对于在P0_ 0处测量的电压降低。因此,差分ADC结果应该变得更加负,但实际上它实际上变得更加负因为某些原因。
我们的电桥在左臂的顶部有一个18k(连接到P0_ 0),底部有一个17.7k的电阻,右臂(连接到P0_1)由顶部的18k和底部名义上的10k (@25C)热敏电阻组成。热敏电阻在测量时的电阻在12.5k左右,当我们轻轻地加热它时,它的电阻下降到11k。
我们的固件调用了以下函数:
在睡觉处理手上唤醒adc_calibrate ()
在app_easy_timer()回调处理器中
adc_init(0,gp_adc_sign | gp_adc_chop,0);//差动ADC,签名反转和切块取消偏移电压,不要切换3.6V衰减器
adc_enable_channel(0);// p0_ 0和p0_1
int32_t adccount = adc_get_sample();
...//执行计算等
adc_disable();
我们已经发现编码可能是符号+幅度,而不是2的COMP(我们要求将此信息添加到数据表中)。即0x3FF是最负值(理论上-1.2V)和0x1FF是最正值(理论上+ 1.2V)。
如果我们在范围上测量-0.3v和p0_1之间的范围,则ADC报告0x233(-51)。如果我们将导线切换到P0_0和P0_1(使差异现在+ 0.3V),则ADC返回0x1C4(452)的值。
然而,如果我们接地P0_ 0和P0_1,那么adc出于某种原因返回0x0ff。当然它应该返回0x000?
微分ADC结果实际上看起来是符号、幅度和2的补码的组合。将adc_get_sample()结果转换为范围为-1024到+1023的有符号整数的步骤如下:
对微分ADC的get_adc_sample()结果执行上述条件的代码:
/ *条件差分ADC结果将2的COMP整数与单个结束读数相同的比例* /
静态int32_t namalisedifferendedcount(Int32_t Adccount){
//标志和幅度
if(adccount&0x200){
adcCount = ~(adcCount & 0x1ff);
} 别的 {
//积极的结果是出于某种原因消极的
adcCount = (~adcCount & 0x1ff);
}
//双击以获得与单个结束结果相同的ADC计数
返回adcccount * 2;
}
我们发现的另一件事是,数据表似乎表明,差分ADC引脚之间的差异可以在-1180和+1180 mV之间,但额外的约束是始终必须始终为0到1180mV之间的两个引脚。嗯(至少没有衰减器启用)。
嗨scsims,
对于延迟响应,不幸的是,关于差异模式没有关于ADC的额外信息,并且在任何参考设计中没有使用它,因此我必须运行一些实验以获得以下结论。在差分模式中,当电压差为零时,ADC的输出应接近0x1FF。当电压差为-1.2伏时,ADC的输出应接近0x0,并且当电压差为+1.2伏时,ADC的输出应接近0x3FF。据我所知,当您使用差异模式时,这是映射。
由于PM_dialog
嗨pm_dialog,
谢谢你看了这个,你的结论比我所观察到的行为更加有意义。如我在评论中提到的那样,我们可能已经将引脚驱动到电压限制之外。我会看看我是否可以在某些时候得到一些时间来重现你的实验。
谢谢,
scsims.
你好pm_dialog,
我现在已经复制了你的结果,但有一个例外,我们假设P0_ 0是AIN-和P0_1是AIN +然而,它们是相反的方式。
p0_1 = 0mV,p0_ 0 = + 1180mv然后get_adc_sample()返回0x3FF
p0_1 = 1180mv,p0_ 0 = 0mV然后get_adc_sample()返回0x000
我们也清楚地使用其范围之外的ADC输入,我们假设ADC最大电压仅为P0_0和P0_1达到+1180 mV,但实际上,P0_ 0和P0_1也仅额定到0mV至+之间的额定值1180mv单独。
再次感谢你的帮助。
scsims.