Чтение АЦП продолжает прыгать на dspic33FJ128MC802, не может получить стабильное чтение, mplab8.92, компилятор xc16
Добрый вечер,
Я пытаюсь реализовать простое 1-канальное устройство АЦП для чтения на dspic33FJ128MC802, которое вручную запускает выборку данных, автоматически преобразует ее после завершения выборки, а также считывает и сохраняет данные.
Это никогда не было проблемой для меня, за исключением этого микроконтроллера, который, кажется, не имеет нормального реализованного АЦП,
Я прочитал раздел таблицы данных на АЦП несколько раз и настроил его на свои лучшие возможности, однако значение ADC1BUF0 постоянно колеблется между 0 и 4096, когда у меня есть источник питания Lab, подключенный напрямую к входу. контакты АЦП.
Я вижу, что значение ADC1BUF0 примерно соответствует входному напряжению (0-3,3 В), когда я приостанавливаю отладчик, он дает пару (2-4) показаний, которые находятся в пределах диапазона +-100 (из 4096 неплохо). Затем, если я продолжу работать и делать паузу с постоянным напряжением, значения, хранящиеся в буфере, внезапно начнут скакать +- 500, иногда даже показывая 4095 (все 1) и 0.
Затем, когда я переключаю лабораторный блок питания на другое напряжение, кажется, что он повторяет процесс отображения нескольких правильных значений, а затем снова начинает прыгать.
По сути, он покажет мне правильное значение примерно в половине случаев, когда я приостанавливаю отладчик.
Я не знаю, что является причиной этого, я знаю, что мне нужно запустить отладчик после изменения напряжения, чтобы он мог очистить буферы, но что-то в этом микроконтроллере кажется определенно неправильным.
Пожалуйста, дайте мне знать, что можно сделать, чтобы это исправить,
Компилятор XC16, IDE - Mplab 8.92
Спасибо,
Ниже моя конфигурация:
[код]
void InitADC() {
TRISAbits.TRISA0=1;
AD1CON1bits.FORM = 0; // Data Output Format: integer//Signed Fraction (Q15 format)
AD1CON1bits.SSRC = 7; // Interan Counter (SAMC) ends sampling and starts convertion
AD1CON1bits.ASAM = 0; // ADC Sample Control: Sampling begins immediately after conversion
AD1CON1bits.AD12B = 1; // 12-bit ADC operation
AD1CON1bits.SIMSAM =1; // 10-bit ADC operation
AD1CON2bits.CHPS = 0; // Converts CH0
AD1CON2bits.CSCNA = 0; // Do not scan inputs
AD1CON2bits.VCFG = 0; // Use voltage reference Vss/Vdd
AD1CON2bits.ALTS = 0; // Always use input select for channel A
AD1CON2bits.BUFM = 0; // Always start filling at buffer 0
AD1CON3bits.ADRC = 0; // ADC Clock is derived from Systems Clock
AD1CON3bits.SAMC = 0; // Auto Sample Time = 0*Tad
AD1CON3bits.ADCS = 2; // ADC Conversion Clock Tad=Tcy*(ADCS+1)= (1/40M)*3 = 75ns (13.3Mhz)
// ADC Conversion Time for 10-bit Tc=12*Tab = 900ns (1.1MHz)
AD1CON1bits.ADDMABM = 1; // DMA buffers are built in conversion order mode
AD1CON2bits.SMPI = 0; // SMPI must be 0
AD1CON4bits.DMABL = 0; // Only 1 DMA buffer for each analog input
//AD1CHS0/AD1CHS123: A/D Input Select Register
AD1CHS0bits.CH0SA = 0; // MUXA +ve input selection (AIN0) for CH0
AD1CHS0bits.CH0NA = 0; // MUXA -ve input selection (Vref-) for CH0
AD1CHS123bits.CH123SA = 0; // MUXA +ve input selection (AIN0) for CH1
AD1CHS123bits.CH123NA = 0; // MUXA -ve input selection (Vref-) for CH1
IFS0bits.AD1IF = 0; // Clear the A/D interrupt flag bit
IEC0bits.AD1IE = 0; // Do Not Enable A/D interrupt
AD1CSSL = 1; //Scan from AN0 only
AD1PCFGL = 0b111111110; //Only AN0 in analog input mode
AD1CON1bits.ADON = 1; // Turn on the A/D converter
}
int main() {
ADPCFG = 0xFFFE; //make ADC pins all digital except AN0 (RA0)
while(1)
{
AD1CON1bits.SAMP = 1;
while(!AD1CON1bits.DONE);
myVoltage = ADC1BUF0;
}
return 0;
}
[/код]
1 ответ
Похоже, я пропустил точку с запятой через некоторое время (!AD1CON1bits.DONE)
Без точки с запятой он не дождался завершения преобразования.
Я исправил это в оригинальном посте, на случай, если кто-то захочет использовать источник в этом посте.
Спасибо,