2014-11-04 21:25:20 +03:00
|
|
|
.. _pyb.ADC:
|
|
|
|
|
2014-11-01 01:21:37 +03:00
|
|
|
class ADC -- analog to digital conversion: read analog values on a pin
|
|
|
|
======================================================================
|
2014-10-31 04:37:19 +03:00
|
|
|
|
2015-06-11 00:29:56 +03:00
|
|
|
.. only:: port_pyboard
|
2014-10-31 04:37:19 +03:00
|
|
|
|
2015-06-11 00:29:56 +03:00
|
|
|
Usage::
|
|
|
|
|
|
|
|
import pyb
|
|
|
|
|
|
|
|
adc = pyb.ADC(pin) # create an analog object from a pin
|
|
|
|
val = adc.read() # read an analog value
|
|
|
|
|
|
|
|
adc = pyb.ADCAll(resolution) # creale an ADCAll object
|
|
|
|
val = adc.read_channel(channel) # read the given channel
|
|
|
|
val = adc.read_core_temp() # read MCU temperature
|
|
|
|
val = adc.read_core_vbat() # read MCU VBAT
|
|
|
|
val = adc.read_core_vref() # read MCU VREF
|
2014-10-31 04:37:19 +03:00
|
|
|
|
2015-06-11 00:29:56 +03:00
|
|
|
.. only:: port_wipy
|
2014-10-31 04:37:19 +03:00
|
|
|
|
2015-06-11 00:29:56 +03:00
|
|
|
Usage::
|
|
|
|
|
|
|
|
import pyb
|
2014-10-31 04:37:19 +03:00
|
|
|
|
2015-06-11 00:29:56 +03:00
|
|
|
adc = pyb.ADC(channel) # create an analog object on one of the 4 ADC channels
|
|
|
|
val = adc.read() # read an analog value
|
2014-10-31 04:37:19 +03:00
|
|
|
|
|
|
|
Constructors
|
|
|
|
------------
|
|
|
|
|
2015-06-11 00:29:56 +03:00
|
|
|
.. only:: port_pyboard
|
2014-10-31 04:37:19 +03:00
|
|
|
|
2015-06-11 00:29:56 +03:00
|
|
|
.. class:: pyb.ADC(pin)
|
|
|
|
|
|
|
|
Create an ADC object associated with the given pin.
|
|
|
|
This allows you to then read analog values on that pin.
|
2014-10-31 04:37:19 +03:00
|
|
|
|
2015-06-11 00:29:56 +03:00
|
|
|
.. only:: port_wipy
|
|
|
|
|
|
|
|
.. class:: pyb.ADC(channel)
|
|
|
|
|
|
|
|
Create an ADC object on the given channel. Each channel is associated
|
|
|
|
to a specific pin. For more info check the `pinout and alternate functions
|
|
|
|
table. <https://raw.githubusercontent.com/wipy/wipy/master/docs/PinOUT.png>`_
|
|
|
|
This allows you to then read analog values on that pin.
|
|
|
|
|
|
|
|
.. warning::
|
|
|
|
|
|
|
|
ADC pin input range is 0-1.4V (being 1.8V the absolute maximum that it
|
|
|
|
can withstand). When GPIO2, GPIO3, GPIO4 or GPIO5 are remapped to the
|
|
|
|
ADC block, 1.8 V is the maximum. If these pins are used in digital mode,
|
|
|
|
then the maximum allowed input is 3.6V.
|
2014-10-31 04:37:19 +03:00
|
|
|
|
|
|
|
Methods
|
|
|
|
-------
|
|
|
|
|
|
|
|
.. method:: adc.read()
|
|
|
|
|
|
|
|
Read the value on the analog pin and return it. The returned value
|
|
|
|
will be between 0 and 4095.
|
|
|
|
|
2015-06-11 00:29:56 +03:00
|
|
|
.. only:: port_pyboard
|
|
|
|
|
|
|
|
.. method:: adc.read_timed(buf, freq)
|
|
|
|
|
|
|
|
Read analog values into the given buffer at the given frequency. Buffer
|
|
|
|
can be bytearray or array.array for example. If a buffer with 8-bit elements
|
|
|
|
is used, sample resolution will be reduced to 8 bits.
|
|
|
|
|
|
|
|
Example::
|
|
|
|
|
|
|
|
adc = pyb.ADC(pyb.Pin.board.X19) # create an ADC on pin X19
|
|
|
|
buf = bytearray(100) # create a buffer of 100 bytes
|
|
|
|
adc.read_timed(buf, 10) # read analog values into buf at 10Hz
|
|
|
|
# this will take 10 seconds to finish
|
|
|
|
for val in buf: # loop over all values
|
|
|
|
print(val) # print the value out
|
|
|
|
|
|
|
|
This function does not allocate any memory.
|
|
|
|
|
|
|
|
.. only:: port_wipy
|
|
|
|
|
|
|
|
.. method:: adc.enable()
|
|
|
|
|
|
|
|
Enable the ADC channel.
|
|
|
|
|
|
|
|
.. method:: adc.disable()
|
|
|
|
|
|
|
|
Disable the ADC channel.
|