31.3.3.3 Output Formats
The ADC has two output registers: The Sample (ADCn.SAMPLE) and Result (ADCn.RESULT) registers. The 16-bit Sample register will always be updated with the latest ADC conversion output (one sample). All accumulation modes will accumulate samples in an internal sample accumulator, configured by the Sample Accumulation Number Select (SAMPNUM) bit field in the Control F (ADCn.CTRLF) register. The sample accumulator is sufficiently wide to avoid overflow for all supported accumulation configurations. The accumulated result will automatically transfer to the 32-bit Result register at the end of a Burst or Series mode accumulation. In single conversion modes, the Result register will be updated with the latest sample, identical to the Sample register.
Operating modes with scaling can be selected to limit the accumulated result to 16 bits of resolution. Scaling is always applied after accumulating the last sample in Burst or Series modes and is carried out by right shifting the accumulated result by SAMPNUM-4 bits.
The Left Adjust (LEFTADJ) bit in the Control F register enables left shifting of the output data in the modes where this is supported. If enabled, this will left shift the output from both the Result and the Sample registers.
The data format for a sample in Single-Ended mode is an unsigned number, where
0x0000
represents zero, and 0x0FFF
represents the
largest number (full scale). If the analog input is higher than the reference level of
the ADC, the 12-bit ADC output will be equal the maximum value of
0x0FFF
. Likewise, if the input is below 0V, the ADC output will
be0x0000
. For Differential mode, the data format is two's
complement, with sign extension.
The following tables show the Result register output formats for single-ended and differential conversions by mode of operation and left adjustment.
MODE | LEFTADJ | RES[31:24] | RES[23:16] | RES[15:12] | RES[11:8] | RES[7:0] |
---|---|---|---|---|---|---|
0 |
X(1) | 0x00 |
Conversion[7:0] | |||
1 |
0 | 0x00 |
Conversion[11:0] | |||
1 | 0x00 |
Conversion[11:0] << 4 | ||||
2 , 4 |
X(1) | 0x00 |
Accumulation[23:0] | |||
3 ,
5 |
X | 0x00 |
Scaled accumulation[15:0](2) |
- Left adjust is not available in 8-bit mode or accumulation modes without scaling.
- If SAMPNUM < 4, the result is left-shifted 4-SAMPNUM bits such that bit 15 is the MSb.
MODE | LEFTADJ | RES[31:24] | RES[23:16] | RES[15:12] | RES[11:8] | RES[7:0] |
---|---|---|---|---|---|---|
0 |
X(1) | Sign extension | Signed conversion[7:0] | |||
1 |
0 | Sign extension | Signed conversion[11:0] | |||
1 | Sign extension | Signed conversion[11:0] << 4 | ||||
2 , 4 |
X(1) | Sign extension | Signed accumulation[23:0] | |||
3 ,
5 |
X | Sign extension | Signed scaled accumulation[15:0](2) |
- Left adjust is not available in 8-bit mode or accumulation modes without scaling.
- If SAMPNUM < 4, the result is left-shifted 4-SAMPNUM bits such that bit 15 is the MSb.
The following table shows the Sample register output formats by mode of operation, left adjustment, and Differential or Single-Ended conversions.
MODE | LEFTADJ | DIFF | SAMPLE[15:12] | SAMPLE[11:8] | SAMPLE[7:0] |
---|---|---|---|---|---|
0 | X | 0 |
0x00 |
Conversion[7:0] | |
1 |
Sign extension | Signed conversion[7:0] | |||
Other | 0 | 0 |
0x00 |
Conversion[11:0] | |
1 |
Sign extension | Signed conversion[11:0] | |||
1 | 0 |
Conversion[11:0] << 4 | |||
1 |
Signed conversion[11:0] << 4 |