Difference between revisions of "Analog inputs"

From BitWizard Wiki
Jump to navigation Jump to search
 
(12 intermediate revisions by 2 users not shown)
Line 1: Line 1:
= analog inputs =
= Analog inputs =


Several boards can be configured to use analog inputs. The registers 0x70-0x78 specify the value for the multiplexer register in the ADC module of the used chip. The value is not santiy checked. Any value you specify will be used. It is not expected that things will break if you send a value that is not documented here, but why risk it?
Several boards can be configured to use analog inputs. The registers 0x70-0x78 specify the value for the multiplexer register in the ADC module of the used chip. The value is not santiy checked. Any value you specify will be used. It is not expected that things will break if you send a value that is not documented here, but why risk it?


== reference ==
== Reference ==


The top two bits specify the reference. Possible values are:
The top two bits specify the reference. Possible values are:
Line 12: Line 12:
Other values are not applicable (0x40 = use aref pin, which is connected elsewhere on the bitwizard boards, 0xc0 is "reserved").
Other values are not applicable (0x40 = use aref pin, which is connected elsewhere on the bitwizard boards, 0xc0 is "reserved").


== normal measurements ==
== Normal measurements ==


Normal measurements would return a value of 0 for 0V up to 1023 for the reference value.
Normal measurements would return a value of 0 for 0V up to 1023 for the reference value.
Line 19: Line 19:
! value !! dio pin !! temp || thermo
! value !! dio pin !! temp || thermo
|-
|-
| 0x00 || 6 || S2 || -
| 0x00 || 6 || S2 || T4
|-
|-
| 0x01 || 4 || S1 || -
| 0x01 || 4 || S1 || T3
|-
|-
| 0x02 || 3 || S3 || -
| 0x02 || 3 || S3 || T2
|-
|-
| 0x03 || 1 || S4 || -
| 0x03 || 1 || S4 || T1
|-
|-
| 0x07 || 0 || - || -
| 0x07 || 0 || - || -
Line 62: Line 62:
! value !! dio pins !! temp || thermo
! value !! dio pins !! temp || thermo
|-
|-
| 0x08 || 6 - 4 || S2 - S1 || -
| 0x08 || 6 - 4 || S2 - S1 || T4 - T3 *
|-
|-
| 0x0a || 6 - 1 || S2 - S4 || -
| 0x0a || 6 - 1 || S2 - S4 || T4 - T1


|-
|-
| 0x28 || 4 - 6 || S1 - S2 || -
| 0x28 || 4 - 6 || S1 - S2 || T3 - T4 *
|-
|-
| 0x0c || 4 - 3 || S1 - S3 || -
| 0x0c || 4 - 3 || S1 - S3 || T3 - T2
|-
|-
| 0x0e || 4 - 1 || S1 - S4 || -
| 0x0e || 4 - 1 || S1 - S4 || T3 - T1


|-
|-
| 0x2c || 3 - 4 || S3 - S1 || -
| 0x2c || 3 - 4 || S3 - S1 || T2 - T3
|-
|-
| 0x10 || 3 - 1 || S3 - S4 || -
| 0x10 || 3 - 1 || S3 - S4 || T2 - T1 *


|-
|-
| 0x2a || 1 - 6 || S4 - S2 || -
| 0x2a || 1 - 6 || S4 - S2 || T1 - T4
|-
|-
| 0x2e || 1 - 4 || S4 - S1 || -
| 0x2e || 1 - 4 || S4 - S1 || T1 - T3
|-
|-
| 0x30 || 1 - 3 || S4 - S3 || -
| 0x30 || 1 - 3 || S4 - S3 || T1 - T2 *
|-
|-
| 0x24 || 1 - 1 || S4 - S4 || -
| 0x24 || 1 - 1 || S4 - S4 || T1 - T1
|-
|-
| 0x18 || 1 - 0 || - || -
| 0x18 || 1 - 0 || - || -
Line 94: Line 94:
| 0x26 || 0 - 0 || - || -
| 0x26 || 0 - 0 || - || -
|}
|}

Thermo lines marked with the asterisk are the intended use for the thermocouple board.


Hmm. Maybe a different table is more useful / easier to read in our application. Let me try this:
Hmm. Maybe a different table is more useful / easier to read in our application. Let me try this:


{| border=1
{| border=1
! !! dio6 <br> S2 !! DIO4 <br> S1 || DIO 3 <br> S3 || DIO 1 <br>S4 || DIO 0
! !! DIO6 <br> S2 <br> T4 !! DIO4 <br> S1<br>T3 || DIO 3 <br> S3<br>T2 || DIO 1 <br>S4<br>T1 || DIO 0
|-
|-
| DIO6<br> S2 || 0x22* || 0x08 || - || 0x0a || -
| DIO6<br> S2 T4 || 0x22* || 0x08 || - || 0x0a || -


|-
|-
| DIO4<br>S1 || 0x18 || - || 0x0c || 0x0e || -
| DIO4<br>S1 T3 || 0x28 || - || 0x0c || 0x0e || -


|-
|-
| DIO3<br>S3 || - || 0x2c || - || 0x10 || -
| DIO3<br>S3 T2 || - || 0x2c || - || 0x10 || -


|-
|-
| DIO1<br>S4 || 0x1a || 0x1e || 0x30 || 0x24 || 0x18
| DIO1<br>S4 T1 || 0x2a || 0x2e || 0x30 || 0x24 || 0x18


|-
|-
Line 116: Line 118:


The 0x22* value only works in "x20" mode with "1" added as described below.
The 0x22* value only works in "x20" mode with "1" added as described below.

The "DIO0" indication means IO 0 on the DIO board. In the pinout of the DIO board, you can see that this is pin 3 on the connector. and so on.
The "DIO0" indication means IO 0 on the DIO board. In the pinout of the DIO board, you can see that this is pin 3 on the connector. and so on.

The "S1" indication means the "sensor 1" input on the "temp" board (which is the middle pin of the 3-pin connector marked S1).
The "S1" indication means the "sensor 1" input on the "temp" board (which is the middle pin of the 3-pin connector marked S1).

The rows describe a positive input, the columns a negative one. So row "S1", column "S3" describes the value to use for S1-S3.
The rows describe a positive input, the columns a negative one. So row "S1", column "S3" describes the value to use for S1-S3.


== Differential x20 measurements ==
== Differential x20 measurements ==


For measuring small diffences, there is a x20 gain mode. The measurements are very similar to the above differential measurements, but the analog value is multiplied by 20 before being measured. The datasheet for the chip doesn't clearly describe how accurate the "20" here is.
For measuring small differences, there is a x20 gain mode. The measurements are very similar to the above differential measurements, but the analog value is multiplied by 20 before being measured. The datasheet for the chip doesn't clearly describe how accurate the "20" here is.


Add one to the values in the above table to obtain the x20 measurements.
Add one to the values in the above table to obtain the x20 measurements.

= Adding and averaging =

By setting a value into the <samples-to-add> register (0x81), you can add samples together. By setting a value in the <number-of-bits-to-shift-the-result> register (0x82) you can divide down (but only by powers of two) to get an average.

Statistics have shown that under certain circumstances, adding a number of samples together will provide a higher resolution than the underlying ADC. In the BitWizard boards, those circumstances are almost always present. One thing to remember is that when you add together say 64 ten-bit samples, you get a 16-bit result. Almost all 16-bit values are possible. However your measurement has not become 16-bits. In practise, you need to average 2^2n samples, to get n more bits of resolution. So to get a full 16-bit result, you need 6 more bits of resolution (n=6), so you need to add 2^12 (4096) samples together.

Latest revision as of 14:12, 9 December 2015

Analog inputs

Several boards can be configured to use analog inputs. The registers 0x70-0x78 specify the value for the multiplexer register in the ADC module of the used chip. The value is not santiy checked. Any value you specify will be used. It is not expected that things will break if you send a value that is not documented here, but why risk it?

Reference

The top two bits specify the reference. Possible values are:

0x80: internal 1.1V 0x00: 5V (or 3.3V) powersupply line.

Other values are not applicable (0x40 = use aref pin, which is connected elsewhere on the bitwizard boards, 0xc0 is "reserved").

Normal measurements

Normal measurements would return a value of 0 for 0V up to 1023 for the reference value.

value dio pin temp thermo
0x00 6 S2 T4
0x01 4 S1 T3
0x02 3 S3 T2
0x03 1 S4 T1
0x07 0 - -


The values 4, 5 and 6 would measure analog values on the pins required for I2C or SPI communication. Interesting to do once, but not particularly useful. These values are added to the "reference selection" value in the previous section.

There are also some special values internal to the chip:

value what
0x20 AGND
0x21 1.1V reference
0x22 temp sensor

You should get "about 0" if you use mux value 0x20. Maybe this can be used to measure the offset of the ADC module. By measuring the 1.1V reference with the power rails as the reference, you can get a measurement of the power supply value.

The temp sensor should give you the temperature in C with about 275 added. The datasheet mentions a typical value of 300 at 25C. The coefficient is documented as "close to 1.0", but a few lines up it is documented (indirectly) as "typically 1.077". The offset is apparently quite variable. So don't count on any absolute accuracy. You'll need to calibrate the offset if you want any kind of accuracy. (If the real temp is 21 degrees (comfortable), the reading could easily end up at 16 or 26, which are clearly too cold and too hot for comfort).

Differential measurements

Differential measurements use one pin as the positive input and another as the negative. In the bitwizard boards only "single sided" measurements are supported. This means that if your signal can go both ways, you have to switch to the other polarity once your measured value is below a certain value. Note that you cannot count on the value becoming zero if the polarity reverses. There will always be a little bit of noise resulting in non-zero ADC conversions even if the input polarity is reversed. You could also request both conversion values, and decide what to do with them in your software. The hardware does not support all combinations. So it might be possible that sometimes you cannot measure a polarity. Casual inspection shows that this does not happen in the subset of inputs available on the bitwizard boards.

In the table below you'll see for instance 6-4 in the dio column, this means that the ADC value represents the voltage of dio pin 6 minus dio pin 4.

This table was difficult to figure out.... It may still contain errors. Please report them if you see one.

value dio pins temp thermo
0x08 6 - 4 S2 - S1 T4 - T3 *
0x0a 6 - 1 S2 - S4 T4 - T1
0x28 4 - 6 S1 - S2 T3 - T4 *
0x0c 4 - 3 S1 - S3 T3 - T2
0x0e 4 - 1 S1 - S4 T3 - T1
0x2c 3 - 4 S3 - S1 T2 - T3
0x10 3 - 1 S3 - S4 T2 - T1 *
0x2a 1 - 6 S4 - S2 T1 - T4
0x2e 1 - 4 S4 - S1 T1 - T3
0x30 1 - 3 S4 - S3 T1 - T2 *
0x24 1 - 1 S4 - S4 T1 - T1
0x18 1 - 0 - -
0x38 0 - 1 - -
0x26 0 - 0 - -

Thermo lines marked with the asterisk are the intended use for the thermocouple board.

Hmm. Maybe a different table is more useful / easier to read in our application. Let me try this:

DIO6
S2
T4
DIO4
S1
T3
DIO 3
S3
T2
DIO 1
S4
T1
DIO 0
DIO6
S2 T4
0x22* 0x08 - 0x0a -
DIO4
S1 T3
0x28 - 0x0c 0x0e -
DIO3
S3 T2
- 0x2c - 0x10 -
DIO1
S4 T1
0x2a 0x2e 0x30 0x24 0x18
DIO0 - - - 0x38 0x26

The 0x22* value only works in "x20" mode with "1" added as described below.

The "DIO0" indication means IO 0 on the DIO board. In the pinout of the DIO board, you can see that this is pin 3 on the connector. and so on.

The "S1" indication means the "sensor 1" input on the "temp" board (which is the middle pin of the 3-pin connector marked S1).

The rows describe a positive input, the columns a negative one. So row "S1", column "S3" describes the value to use for S1-S3.

Differential x20 measurements

For measuring small differences, there is a x20 gain mode. The measurements are very similar to the above differential measurements, but the analog value is multiplied by 20 before being measured. The datasheet for the chip doesn't clearly describe how accurate the "20" here is.

Add one to the values in the above table to obtain the x20 measurements.

Adding and averaging

By setting a value into the <samples-to-add> register (0x81), you can add samples together. By setting a value in the <number-of-bits-to-shift-the-result> register (0x82) you can divide down (but only by powers of two) to get an average.

Statistics have shown that under certain circumstances, adding a number of samples together will provide a higher resolution than the underlying ADC. In the BitWizard boards, those circumstances are almost always present. One thing to remember is that when you add together say 64 ten-bit samples, you get a 16-bit result. Almost all 16-bit values are possible. However your measurement has not become 16-bits. In practise, you need to average 2^2n samples, to get n more bits of resolution. So to get a full 16-bit result, you need 6 more bits of resolution (n=6), so you need to add 2^12 (4096) samples together.