2019-09-04 15:33:40 +10:00
|
|
|
.. currentmodule:: machine
|
|
|
|
.. _machine.ADC:
|
|
|
|
|
|
|
|
class ADC -- analog to digital conversion
|
|
|
|
=========================================
|
|
|
|
|
|
|
|
The ADC class provides an interface to analog-to-digital converters, and
|
|
|
|
represents a single endpoint that can sample a continuous voltage and
|
|
|
|
convert it to a discretised value.
|
|
|
|
|
2022-01-21 22:29:11 +11:00
|
|
|
For extra control over ADC sampling see :ref:`machine.ADCBlock <machine.ADCBlock>`.
|
|
|
|
|
2019-09-04 15:33:40 +10:00
|
|
|
Example usage::
|
|
|
|
|
2022-01-21 22:29:11 +11:00
|
|
|
from machine import ADC
|
2019-09-04 15:33:40 +10:00
|
|
|
|
2022-01-21 22:29:11 +11:00
|
|
|
adc = ADC(pin) # create an ADC object acting on a pin
|
|
|
|
val = adc.read_u16() # read a raw analog value in the range 0-65535
|
|
|
|
val = adc.read_uv() # read an analog value in microvolts
|
2019-09-04 15:33:40 +10:00
|
|
|
|
|
|
|
Constructors
|
|
|
|
------------
|
|
|
|
|
2022-01-21 22:29:11 +11:00
|
|
|
.. class:: ADC(id, *, sample_ns, atten)
|
2019-09-04 15:33:40 +10:00
|
|
|
|
|
|
|
Access the ADC associated with a source identified by *id*. This
|
|
|
|
*id* may be an integer (usually specifying a channel number), a
|
|
|
|
:ref:`Pin <machine.Pin>` object, or other value supported by the
|
|
|
|
underlying machine.
|
|
|
|
|
2022-01-21 22:29:11 +11:00
|
|
|
If additional keyword-arguments are given then they will configure
|
|
|
|
various aspects of the ADC. If not given, these settings will take
|
|
|
|
previous or default values. The settings are:
|
|
|
|
|
|
|
|
- *sample_ns* is the sampling time in nanoseconds.
|
|
|
|
|
|
|
|
- *atten* specifies the input attenuation.
|
|
|
|
|
2019-09-04 15:33:40 +10:00
|
|
|
Methods
|
|
|
|
-------
|
|
|
|
|
2022-01-21 22:29:11 +11:00
|
|
|
.. method:: ADC.init(*, sample_ns, atten)
|
|
|
|
|
|
|
|
Apply the given settings to the ADC. Only those arguments that are
|
|
|
|
specified will be changed. See the ADC constructor above for what the
|
|
|
|
arguments are.
|
|
|
|
|
|
|
|
.. method:: ADC.block()
|
|
|
|
|
|
|
|
Return the :ref:`ADCBlock <machine.ADCBlock>` instance associated with
|
|
|
|
this ADC object.
|
|
|
|
|
|
|
|
This method only exists if the port supports the
|
|
|
|
:ref:`ADCBlock <machine.ADCBlock>` class.
|
|
|
|
|
2019-09-04 15:33:40 +10:00
|
|
|
.. method:: ADC.read_u16()
|
|
|
|
|
|
|
|
Take an analog reading and return an integer in the range 0-65535.
|
|
|
|
The return value represents the raw reading taken by the ADC, scaled
|
|
|
|
such that the minimum value is 0 and the maximum value is 65535.
|
2022-01-21 22:29:11 +11:00
|
|
|
|
|
|
|
.. method:: ADC.read_uv()
|
|
|
|
|
|
|
|
Take an analog reading and return an integer value with units of
|
|
|
|
microvolts. It is up to the particular port whether or not this value
|
|
|
|
is calibrated, and how calibration is done.
|