释放模拟信号的全部潜力,它们将转化为数字清晰度的领域,在信号转换方面树立新的标准。
A
A
硬件概览
它是如何工作的?
ADC 23 Click 基于德州仪器的 ADS127L11,这是一款宽带 24 位 Δ-Σ 模数转换器。数字滤波器可配置为宽带或低延迟操作,以优化宽带交流性能或直流信号的数据吞吐量。它经过优化,可在低功耗下提供高分辨率。Δ-Σ 解调器生成低分辨率、高频数据,然后去除噪声。数字滤波器同时抽取和滤波调制器数据,从而提供高分辨率的最终输出数据。ADS127L11 集成了输入和参考缓冲器,以减少信号负载。您可以选择板载 ADR4525,这是来自 Analog Devices 的超低噪声高精度电压参考,作为参考电压。或者,您可
以通过 VEXT 接头选择外部电压参考。选择可以通过 VREF SEL 跳线进行。默认设置为 2.5V 的内部电压参考。ADC 可以使用外部时钟或内部振荡器操作。高速度模式下时钟的标称值为 25.6MHz,低速度模式下为 3.2MHz。您可以通过 CLK 接头添加外部振荡器。ADC 的模拟输入是差分的,输入定义为差分电压,为获得最佳性能,您应该驱动差分信号输入。为此,ADC 23 Click 配备了两个 SMA 连接器。ADC 23 Click 使用标准的 4 线 SPI 串行接口与主 MCU 通信,支持 SPI 模式 1。ADC 可以通过
RST 引脚复位。启动 STR 引脚同步数字处理,如果 STR 引脚处于高电平逻辑状态,ADC 立即开始转换,每次转换时数据准备 DRY 引脚脉冲。延迟定义为从同步到 DRY 引脚下降沿的时间。此 Click board™ 可以通过 VCC SEL 跳线选择使用 3.3V 或 5V 逻辑电压水平。这样,3.3V 和 5V 的 MCU 都可以正确使用通信线路。此外,这款 Click board™ 配备了包含易于使用的功能和示例代码的库,可用于进一步开发。
功能概述
开发板
32L496GDISCOVERY Discovery 套件是一款功能全面的演示和开发平台,专为搭载 Arm® Cortex®-M4 内核的 STM32L496AG 微控制器设计。该套件适用于需要在高性能、先进图形处理和超低功耗之间取得平衡的应用,支持无缝原型开发,适用于各种嵌入式解决方案。STM32L496AG 采用创新的节能架构,集成
了扩展 RAM 和 Chrom-ART 图形加速器,在提升图形性能的同时保持低功耗,使其特别适用于音频处理、图形用户界面和实时数据采集等对能效要求较高的应用。为了简化开发流程,该开发板配备了板载 ST-LINK/V2-1 调试器/编程器,提供即插即用的调试和编程体验,使用户无需额外硬件即可轻松加载、调
试和测试应用程序。凭借低功耗特性、增强的内存能力以及内置调试工具,32L496GDISCOVERY 套件是开发先进嵌入式系统、实现高效能解决方案的理想选择。
微控制器概述
MCU卡片 / MCU

建筑
ARM Cortex-M4
MCU 内存 (KB)
1024
硅供应商
STMicroelectronics
引脚数
169
RAM (字节)
327680
使用的MCU引脚
mikroBUS™映射器
“仔细看看!”
Click board™ 原理图

一步一步来
项目组装
软件支持
库描述
该库包含 ADC 23 Click 驱动程序的 API。
关键功能:
adc23_get_voltage- ADC 23 读取电压水平功能。adc23_read_conversion_data- ADC 23 读取转换数据功能。adc23_start_conversion- ADC 23 开始转换功能。
开源
代码示例
完整的应用程序代码和一个现成的项目可以通过NECTO Studio包管理器直接安装到NECTO Studio。 应用程序代码也可以在MIKROE的GitHub账户中找到。
/*!
* @file main.c
* @brief ADC 23 Click example
*
* # Description
* This example demonstrates the use of the ADC 23 Click board™
* by reading and writing data by using SPI serial interface and reading results of AD conversion.
*
* The demo application is composed of two sections :
*
* ## Application Init
* Initialization of SPI module and log UART.
* After driver initialization, the app executes a default configuration.
*
* ## Application Task
* The demo application reads the voltage levels from analog input and displays the results.
* Results are being sent to the UART Terminal, where you can track their changes.
*
* @author Nenad Filipovic
*
*/
#include "board.h"
#include "log.h"
#include "adc23.h"
static adc23_t adc23;
static log_t logger;
void application_init ( void )
{
log_cfg_t log_cfg; /**< Logger config object. */
adc23_cfg_t adc23_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.
adc23_cfg_setup( &adc23_cfg );
ADC23_MAP_MIKROBUS( adc23_cfg, MIKROBUS_1 );
if ( SPI_MASTER_ERROR == adc23_init( &adc23, &adc23_cfg ) )
{
log_error( &logger, " Communication init." );
for ( ; ; );
}
if ( ADC23_ERROR == adc23_default_cfg ( &adc23 ) )
{
log_error( &logger, " Default configuration." );
for ( ; ; );
}
log_info( &logger, " Application Task " );
Delay_ms ( 100 );
}
void application_task ( void )
{
static float voltage = 0.0;
if ( ADC23_OK == adc23_get_voltage( &adc23, &voltage ) )
{
log_printf( &logger, " Voltage : %.2f [mV]\r\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
额外支持
资源
类别:模数转换器































