2025-09-30 11:56:06 +08:00
|
|
|
|
## machine.ADC
|
|
|
|
|
|
|
|
|
|
|
|
**machine.ADC** 类是 machine 模块下的一个硬件类,用于指定 ADC 设备的配置和控制,提供对 ADC 设备的操作方法。
|
|
|
|
|
|
|
|
|
|
|
|
- ADC(Analog-to-Digital Converter,模数转换器),用于将连续变化的模拟信号转化为离散的数字信号。
|
|
|
|
|
|
- ADC 设备两个重要参数:采样值、分辨率;
|
|
|
|
|
|
- 采样值:当前时间由模拟信号转化的数值信号的数值;
|
|
|
|
|
|
- 分辨率:以二进制(或十进制)数的位数来表示,一般有 8 位、10 位、12 位、16 位等,它说明模数转换器对输入信号的分辨能力,位数越多,表示分辨率越高,采样值会更精确。
|
|
|
|
|
|
|
|
|
|
|
|
### 构造函数
|
|
|
|
|
|
|
|
|
|
|
|
在 RT-Thread MicroPython 中 `ADC` 对象的构造函数如下:
|
|
|
|
|
|
|
|
|
|
|
|
#### **class machine.ADC**(id, channel)
|
|
|
|
|
|
|
|
|
|
|
|
- **id**:使用的 ADC 设备编号,`id = 1` 表示编号为 1 的 ADC 设备,或者表示使用的 ADC 设备名,如 `id = "adc"` 表示设备名为 `adc` 的 ADC 设备;
|
|
|
|
|
|
- **channel**:使用的 ADC 设备通道号,每个 ADC 设备对应多个通道;
|
|
|
|
|
|
|
|
|
|
|
|
例如:`ADC(1,4)` 表示当前使用编号为 1 的 ADC 设备的 4 通道。
|
|
|
|
|
|
|
|
|
|
|
|
### 方法
|
|
|
|
|
|
|
|
|
|
|
|
#### **ADC.init**(channel)
|
|
|
|
|
|
|
|
|
|
|
|
根据输入的层参数初始化 ADC 对象,入参为使用的 ADC 对象通道号;
|
|
|
|
|
|
|
|
|
|
|
|
#### **ADC.deinit**()
|
|
|
|
|
|
|
|
|
|
|
|
用于关闭 ADC 对象,ADC 对象 deinit 之后需要重新 init 才能使用。
|
|
|
|
|
|
|
|
|
|
|
|
#### **ADC.read**()
|
|
|
|
|
|
|
|
|
|
|
|
用于获取并返回当前 ADC 对象的采样值。例如当前采样值为 2048,对应设备的分辨率为 12位,当前设备参考电压为 3.3V ,则该 ADC 对象通道上实际电压值的计算公式为:**采样值 * 参考电压 / (1 << 分辨率位数)**,即 `vol = 2048 / 4096 * 3.3 V = 1.15V`。
|
|
|
|
|
|
|
|
|
|
|
|
### 示例
|
|
|
|
|
|
|
|
|
|
|
|
``` python
|
|
|
|
|
|
>>> from machine import ADC # 从 machine 导入 ADC 类
|
|
|
|
|
|
>>> adc = ADC(1, 13) # 创建 ADC 对象,当前使用编号为 1 的 ADC 设备的 13 通道
|
|
|
|
|
|
>>> adc.read() # 获取 ADC 对象采样值
|
|
|
|
|
|
4095
|
|
|
|
|
|
>>> adc.deinit() # 关闭 ADC 对象
|
|
|
|
|
|
>>> adc.init(13) # 开启并重新配置 ADC 对象
|
|
|
|
|
|
```
|