低功耗 12 位模数转换器,用于系统监控和电流感应中的实时性能
A
A
硬件概览
它是如何工作的?
ADC 26 Click 基于德州仪器 (Texas Instruments) 的 ADS1015L,这是一款带有 I2C 兼容接口的低功耗 12 位模数转换器 (ADC)。它集成了多个关键组件,包括 ΔΣ ADC 核心、内部电压参考、时钟振荡器、可编程增益放大器 (PGA) 和可编程数字比较器。通过这一组合,ADC 能以高达 3300 次每秒 (SPS) 的速率完成转换,非常适用于既需高速又需低噪声的应用场景。ADS1015L 的 ADC 核心可对模拟输入通道 (IN0-IN3) 接收的差分信号进行测量,其全量程输入电压范围广泛,从 ±0.256V 到 ±6.144V。如此宽的范围使得 ADS1015L 能够高精度地处理大小不一的信号,非常适合电源电压跟踪、电流检测和温度测量等常规系统监控任务。这些特点也使其适用于可穿戴设备和个人电子产品的应用。该 IC 的架构包括一个差分开关电容 ΔΣ 调制器和一个数字滤波器,确保出色的共模信号衰
减和高抗噪性。输入信号与内部电压参考进行比较,而调制器则生成高速比特流。此比特流经由数字滤波器处理后,生成与测量电压成正比的数字输出码。ADS1015L 支持两种操作模式,可根据应用需求优化功耗和性能。在单次转换模式下,ADC 在接收到请求后执行一次测量,将结果存储在内部寄存器中,并进入掉电状态。此模式非常适合需要周期性测量或在两次转换之间有较长空闲期的系统。在连续转换模式下,ADC 在完成一次测量后立即开始新的测量,保持与配置数据速率一致的转换速率。此模式非常适合实时监控应用,因为数据寄存器始终包含最新的测量结果。此 Click 板™ 采用支持 MIKROE 新推出的 “Click Snap” 功能的独特格式。与标准版 Click 板不同,该功能允许通过断开 PCB 使主要 IC 区域变为可移动状态,从而为实现多种新功能提供可能性。得益于
Snap 功能,ADS1015L 可以通过访问标有 1-8 的引脚直接独立运行。此外,Snap 部分包含一个指定的固定螺丝孔位置,方便用户将 Snap 板固定在所需位置。ADC 26 Click 使用支持高达 400kHz 时钟速度的 I2C 接口,确保与主 MCU 的快速高效通信。I2C 地址可以通过位于 Snap 板部分的板载 ADDR SEL 跳线轻松配置,从而允许多个设备在同一总线上共存。此外,该板具有一个警报中断 (AR) 引脚,该引脚会在转换数据超出设置的上下限阈值寄存器值时触发,或者可用作转换就绪引脚。此 Click 板™ 仅支持 3.3V 逻辑电压运行。在使用不同逻辑电平的 MCU 之前,必须进行适当的逻辑电压电平转换。它还配备了包含功能和示例代码的库,可作为进一步开发的参考。
功能概述
开发板
PIC32MZ Clicker 是一款紧凑型入门开发板,它将 Click 板™的灵活性带给您喜爱的微控制器,使其成为实现您想法的完美入门套件。它配备了一款板载 32 位带有浮点单元的 Microchip PIC32MZ 微控制器,一个 USB 连接器,LED 指示灯,按钮,一个 mikroProg 连接器,以及一个用于与外部电子设备接口的头部。得益于其紧凑的设计和清晰易识别的丝网标记,它提供了流畅且沉浸式的工作体验,允许在任
何情况下、任何地方都能访问。PIC32MZ Clicker 开 发套件的每个部分都包含了使同一板块运行最高效的必要组件。除了可以选择 PIC32MZ Clicker 的编程方式,使用 USB HID mikroBootloader 或通过外部 mikroProg 连接器为 PIC,dsPIC 或 PIC32 编程外,Clicker 板还包括一个干净且调节过的开发套件电源供应模块。USB Micro-B 连接可以提供多达 500mA 的电流,这足以操作所有板载和附加模块。所有
mikroBUS™ 本身支持的通信方法都在这块板上,包 括已经建立良好的 mikroBUS™ 插槽、重置按钮以及若干按钮和 LED 指示灯。PIC32MZ Clicker 是 Mikroe 生态系统的一个组成部分,允许您在几分钟内创建新的应用程序。它由 Mikroe 软件工具原生支持,得益于大量不同的 Click 板™(超过一千块板),其数量每天都在增长,它涵盖了原型制作的许多方面。
微控制器概述
MCU卡片 / MCU

建筑
PIC32
MCU 内存 (KB)
1024
硅供应商
Microchip
引脚数
64
RAM (字节)
524288
使用的MCU引脚
mikroBUS™映射器
“仔细看看!”
Click board™ 原理图

一步一步来
项目组装
实时跟踪您的结果
应用程序输出
1. 应用程序输出 - 在调试模式下,“应用程序输出”窗口支持实时数据监控,直接提供执行结果的可视化。请按照提供的教程正确配置环境,以确保数据正确显示。

2. UART 终端 - 使用UART Terminal通过USB to UART converter监视数据传输,实现Click board™与开发系统之间的直接通信。请根据项目需求配置波特率和其他串行设置,以确保正常运行。有关分步设置说明,请参考提供的教程。

3. Plot 输出 - Plot功能提供了一种强大的方式来可视化实时传感器数据,使趋势分析、调试和多个数据点的对比变得更加直观。要正确设置,请按照提供的教程,其中包含使用Plot功能显示Click board™读数的分步示例。在代码中使用Plot功能时,请使用以下函数:plot(insert_graph_name, variable_name);。这是一个通用格式,用户需要将“insert_graph_name”替换为实际图表名称,并将“variable_name”替换为要显示的参数。

软件支持
库描述
该库包含 ADC 26 Click 驱动程序的 API。
关键功能:
adc26_start_conversion
- 此函数启动所选MUX通道和增益级别(满量程范围)的单次转换。adc26_get_alert_pin
- 此函数返回ALERT(数据准备就绪)引脚的逻辑状态。adc26_read_voltage
- 此函数读取原始ADC测量值并将其转换为电压水平。
开源
代码示例
完整的应用程序代码和一个现成的项目可以通过NECTO Studio包管理器直接安装到NECTO Studio。 应用程序代码也可以在MIKROE的GitHub账户中找到。
/*!
* @file main.c
* @brief ADC 26 Click example
*
* # Description
* This example demonstrates the use of ADC 26 click board by reading and
* displaying the voltage levels from IN0-IN1 differential and IN2-IN3
* single-ended analog input channels.
*
* The demo application is composed of two sections :
*
* ## Application Init
* Initializes the driver and performs the click default configuration.
*
* ## Application Task
* Reads the voltage levels from IN0-IN1 differential (+/- 2.048V) and
* IN2-IN3 single-ended (+/- 4.096V) analog input channels and displays
* the results on the USB UART once per second approximately.
*
* @note
* Do not apply more than VCC + 0.3 V to the analog inputs of the device.
*
* @author Stefan Filipovic
*
*/
#include "board.h"
#include "log.h"
#include "adc26.h"
static adc26_t adc26;
static log_t logger;
void application_init ( void )
{
log_cfg_t log_cfg; /**< Logger config object. */
adc26_cfg_t adc26_cfg; /**< Click config object. */
/**
* Logger initialization.
* Default baud rate: 115200
* Default log level: LOG_LEVEL_DEBUG
* @note If USB_UART_RX and USB_UART_TX
* are defined as HAL_PIN_NC, you will
* need to define them manually for log to work.
* See @b LOG_MAP_USB_UART macro definition for detailed explanation.
*/
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_info( &logger, " Application Init " );
// Click initialization.
adc26_cfg_setup( &adc26_cfg );
ADC26_MAP_MIKROBUS( adc26_cfg, MIKROBUS_1 );
if ( I2C_MASTER_ERROR == adc26_init( &adc26, &adc26_cfg ) )
{
log_error( &logger, " Communication init." );
for ( ; ; );
}
if ( ADC26_ERROR == adc26_default_cfg ( &adc26 ) )
{
log_error( &logger, " Default configuration." );
for ( ; ; );
}
log_info( &logger, " Application Task " );
}
void application_task ( void )
{
float voltage = 0;
if ( ADC26_OK == adc26_start_conversion ( &adc26, ADC26_MUX_P_AIN0_N_AIN1, ADC26_PGA_2_048V ) )
{
while ( adc26_get_alert_pin ( &adc26 ) ); // Waits for a data ready indication
if ( ADC26_OK == adc26_read_voltage ( &adc26, &voltage ) )
{
log_printf ( &logger, " Voltage between IN0[P] and IN1[N]: %.3f V\r\n", voltage );
}
}
if ( ADC26_OK == adc26_start_conversion ( &adc26, ADC26_MUX_P_AIN2_N_GND, ADC26_PGA_4_096V ) )
{
while ( adc26_get_alert_pin ( &adc26 ) ); // Waits for a data ready indication
if ( ADC26_OK == adc26_read_voltage ( &adc26, &voltage ) )
{
log_printf ( &logger, " Voltage between IN2 and GND: %.3f V\r\n", voltage );
}
}
if ( ADC26_OK == adc26_start_conversion ( &adc26, ADC26_MUX_P_AIN3_N_GND, ADC26_PGA_4_096V ) )
{
while ( adc26_get_alert_pin ( &adc26 ) ); // Waits for a data ready indication
if ( ADC26_OK == adc26_read_voltage ( &adc26, &voltage ) )
{
log_printf ( &logger, " Voltage between IN3 and GND: %.3f V\r\n\n", voltage );
}
}
Delay_ms ( 1000 );
}
int main ( void )
{
/* Do not remove this line or clock might not be set correctly. */
#ifdef PREINIT_SUPPORTED
preinit();
#endif
application_init( );
for ( ; ; )
{
application_task( );
}
return 0;
}
// ------------------------------------------------------------------------ END