option for extra precision sacrificing bandwidth
This commit is contained in:
parent
0a936c0147
commit
2fdeb72de7
@ -30,6 +30,8 @@
|
|||||||
//#define ADC_PRESCALE_32 /* Up to ~27kHz. */
|
//#define ADC_PRESCALE_32 /* Up to ~27kHz. */
|
||||||
#define ADC_PRESCALE_64 /* Up to ~18kHz. */
|
#define ADC_PRESCALE_64 /* Up to ~18kHz. */
|
||||||
|
|
||||||
|
#define U8_EXTRA_PRECISION /* (U8 sampling mode only) use 9th ADC reading bit and chop off 1st bit for more precision (sacrificing half of the bandwidth) */
|
||||||
|
|
||||||
#define RECORDING_DELAY_IN_MINUTES 0 /* Wait n minutes before starting to record. */
|
#define RECORDING_DELAY_IN_MINUTES 0 /* Wait n minutes before starting to record. */
|
||||||
#define ADC_CHANNEL AdcChannel0
|
#define ADC_CHANNEL AdcChannel0
|
||||||
#define TIMER_COMPARE 1000 /* 16MHz / 1000 = 16kHz. */
|
#define TIMER_COMPARE 1000 /* 16MHz / 1000 = 16kHz. */
|
||||||
@ -175,10 +177,16 @@ ISR(TIMER1_COMPA_vect) {
|
|||||||
ISR(TIMER1_COMPB_vect) {
|
ISR(TIMER1_COMPB_vect) {
|
||||||
// Retrieve ADC Value and Write to Buffer
|
// Retrieve ADC Value and Write to Buffer
|
||||||
#if defined(SAMPLE_MODE_U8)
|
#if defined(SAMPLE_MODE_U8)
|
||||||
uint8_t adcval = ADCH;
|
#ifdef U8_EXTRA_PRECISION
|
||||||
#elif defined(SAMPLE_MODE_S16)
|
|
||||||
uint8_t l = ADCL; /* Read ADC registers. (Order matters!) */
|
uint8_t l = ADCL; /* Read ADC registers. (Order matters!) */
|
||||||
uint8_t h = ADCH;
|
uint8_t h = ADCH;
|
||||||
|
uint8_t adcval = (h << 7) | (l >> 1);
|
||||||
|
#else
|
||||||
|
uint8_t adcval = ADCH;
|
||||||
|
#endif
|
||||||
|
#elif defined(SAMPLE_MODE_S16)
|
||||||
|
uint8_t l = ADCL;
|
||||||
|
uint8_t h = ADCH;
|
||||||
int16_t adcval = (h << 8) | l;
|
int16_t adcval = (h << 8) | l;
|
||||||
adcval -= 0x0200; /* Make integer signed. */
|
adcval -= 0x0200; /* Make integer signed. */
|
||||||
adcval <<= 6; /* Turn 10-bit integer into 16-bit integer. */
|
adcval <<= 6; /* Turn 10-bit integer into 16-bit integer. */
|
||||||
@ -283,7 +291,7 @@ void setup() {
|
|||||||
#endif
|
#endif
|
||||||
ADCSRB = _BV(ADTS2) | _BV(ADTS0); /* Auto-trigger source select: "Timer/Counter1 Compare Match B". */
|
ADCSRB = _BV(ADTS2) | _BV(ADTS0); /* Auto-trigger source select: "Timer/Counter1 Compare Match B". */
|
||||||
ADMUX = _BV(REFS0) /* Use AREF pin (VCC by default) as reference voltage. */
|
ADMUX = _BV(REFS0) /* Use AREF pin (VCC by default) as reference voltage. */
|
||||||
#if defined(SAMPLE_MODE_U8)
|
#if defined(SAMPLE_MODE_U8) && !defined(U8_EXTRA_PRECISION)
|
||||||
| _BV(ADLAR) /* Left adjust ADC output so we only need to read ADCH. */
|
| _BV(ADLAR) /* Left adjust ADC output so we only need to read ADCH. */
|
||||||
#endif
|
#endif
|
||||||
| (0xF & ADC_CHANNEL); /* Select our ADC input channel. */
|
| (0xF & ADC_CHANNEL); /* Select our ADC input channel. */
|
||||||
|
Loading…
Reference in New Issue
Block a user