初学者
10 分钟

使用TPD2015FN和PIC32MZ2048EFM100在工业及其他高需求环境中控制电感和电阻负载

用于电机、电磁阀和灯驱动的高侧开关(8通道)

IPD Click - 2015 with Curiosity PIC32 MZ EF

已发布 6月 24, 2024

点击板

IPD Click - 2015

开发板

Curiosity PIC32 MZ EF

编译器

NECTO Studio

微控制器单元

PIC32MZ2048EFM100

增强工业自动化和需要控制电阻性和感性负载的应用,每个通道的电流容量高达0.5A,负载高达50mH。

A

A

硬件概览

它是如何工作的?

IPD Click - 2015 基于东芝半导体的TPD2015FN,这是一款具有MOSFET输出的8通道高侧开关,设计用于直接由CMOS和TTL逻辑电路驱动。它非常适合驱动电感性和电阻性负载,如工业可编程逻辑控制器、工业使用的电机、继电器、工厂自动化设备中的灯等。TPD2015FN的一个关键优势是内置的过电流和过温保护,通过防止过热和过电流来提高系统稳定性。TPD2015FN能够处理来自电感负载的反电动势,而不会超过组件的电压耐受性,优化用于高达50mH负载,每通道电流容量为0.5A,支持8-24V的外部

电源供应。各通道可以并联运行以增加输出的电流能力。如前所述,该Click板集成了全面的保护机制,包括当温度超过175°C时停用所有输出(OUT1-OUT8)的过温保护和在负载短路期间限制电压和电流的过电流保护,确保设备及其连接的外围设备的安全。设计用于与CMOS和TTL系统的直接集成,IPD Click具有每个输出通道的输入控制端子,允许独立的通道控制。IN1到IN4输入通过mikroBUS™插座直接接口,额外的IN5到IN8输入通过未填充的头部访问。TPD2015FN的每个输入控制引脚都配有内置

的300kΩ下拉电阻,以在开路状态下保持低逻辑状态。该Click板默认未填充东芝半导体的CRS20140A感性负载解耦二极管,允许用户在较高感性负载情况下添加。此外,它配备了用于所使用负载开关及其电源管理的二极管配置跳线。这些跳线已预配置,无需任何调整即可立即使用。该Click板可以通过VCC SEL跳线选择在3.3V或5V逻辑电压水平下运行。这样,无论是3.3V还是5V的MCU都可以正确使用通信线。此外,该Click板还配备了包含易于使用的函数和示例代码的库,可以作为进一步开发的参考。

IPD Click - 2015 hardware overview image

功能概述

开发板

Curiosity PIC32 MZ EF 开发板是一个完全集成的 32 位开发平台,特点是高性能的 PIC32MZ EF 系列(PIC32MZ2048EFM),该系列具有 2MB Flash、512KB RAM、集成的浮点单元(FPU)、加密加速器和出色的连接选项。它包括一个集成的程序员和调试器,无需额外硬件。用户可以通过 MIKROE 

mikroBUS™ Click™ 适配器板扩展功能,通过 Microchip PHY 女儿板添加以太网连接功能,使用 Microchip 扩展板添加 WiFi 连接能力,并通过 Microchip 音频女儿板添加音频输入和输出功能。这些板完全集成到 PIC32 强大的软件框架 MPLAB Harmony 中,该框架提供了一个灵活且模块化的接口

来应用开发、一套丰富的互操作软件堆栈(TCP-IP、USB)和易于使用的功能。Curiosity PIC32 MZ EF 开发板提供了扩展能力,使其成为连接性、物联网和通用应用中快速原型设计的绝佳选择。

Curiosity PIC32MZ EF double side image

微控制器概述 

MCU卡片 / MCU

default

建筑

PIC32

MCU 内存 (KB)

2048

硅供应商

Microchip

引脚数

100

RAM (字节)

524288

使用的MCU引脚

mikroBUS™映射器

Load 1 Control
RPB4
AN
Load 2 Control
RA9
RST
ID COMM
RPD4
CS
NC
NC
SCK
NC
NC
MISO
NC
NC
MOSI
Power Supply
3.3V
3.3V
Ground
GND
GND
Load 3 Control
RPE8
PWM
Load 4 Control
RF13
INT
NC
NC
TX
NC
NC
RX
NC
NC
SCL
NC
NC
SDA
Power Supply
5V
5V
Ground
GND
GND
1

“仔细看看!”

Click board™ 原理图

IPD Click - 2015 Schematic schematic

一步一步来

项目组装

Curiosity PIC32MZ EF front image hardware assembly

从选择您的开发板和Click板™开始。以Curiosity PIC32 MZ EF作为您的开发板开始。

Curiosity PIC32MZ EF front image hardware assembly
GNSS2 Click front image hardware assembly
Prog-cut hardware assembly
GNSS2 Click complete accessories setup image hardware assembly
Curiosity PIC32 MZ EF MB 1 Access - upright/background hardware assembly
Necto image step 2 hardware assembly
Necto image step 3 hardware assembly
Necto image step 4 hardware assembly
Necto image step 5 hardware assembly
Necto image step 6 hardware assembly
Curiosity PIC32 MZ EF MCU Step hardware assembly
Necto No Display image step 8 hardware assembly
Necto image step 9 hardware assembly
Necto image step 10 hardware assembly
Debug Image Necto Step hardware assembly

实时跟踪您的结果

应用程序输出

此款Click板可通过两种方式进行接口连接和监控:

  • Application Output - 在调试模式下,使用“Application Output”窗口进行实时数据监控。按照本教程正确设置它。

软件支持

库描述

该库包含 IPD Click - 2015 驱动程序的 API。

关键功能:

  • ipd2015_all_pins_set - IPD 2015 引脚设置功能

  • ipd2015_set_out_level - IPD 2015 设置输出电平功能

  • ipd2015_get_out_state - IPD 2015 获取输出电平功能

开源

代码示例

完整的应用程序代码和一个现成的项目可以通过NECTO Studio包管理器直接安装到NECTO Studio 应用程序代码也可以在MIKROE的GitHub账户中找到。

/*!
 * @file main.c
 * @brief IPD 2015 Click Example.
 *
 * # Description
 * This example demonstrates the use of IPD 2015 click board by toggling the output state.
 *
 * The demo application is composed of two sections :
 *
 * ## Application Init
 * Initializes the driver and logger.
 *
 * ## Application Task
 * Switches on all output pins state for 2 seconds, then switches them off, and turns them on one by one.
 *
 * @author Stefan Ilic
 *
 */

#include "board.h"
#include "log.h"
#include "ipd2015.h"

static ipd2015_t ipd2015;   /**< IPD 2015 Click driver object. */
static log_t logger;    /**< Logger object. */

void application_init ( void ) 
{
    log_cfg_t log_cfg;  /**< Logger config object. */
    ipd2015_cfg_t ipd2015_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.
    ipd2015_cfg_setup( &ipd2015_cfg );
    IPD2015_MAP_MIKROBUS( ipd2015_cfg, MIKROBUS_1 );
    if ( DIGITAL_OUT_UNSUPPORTED_PIN == ipd2015_init( &ipd2015, &ipd2015_cfg ) ) 
    {
        log_error( &logger, " Communication init." );
        for ( ; ; );
    }
    
    log_info( &logger, " Application Task " );
}

void application_task ( void ) 
{
    log_printf( &logger, " Turning OUT 1 to OUT 4 HIGH \r\n" );
    ipd2015_all_pins_set( &ipd2015 );
    Delay_ms( 2000 );

    log_printf( &logger, " Turning OUT 1 to OUT 4 LOW \r\n" );
    ipd2015_all_pins_clear( &ipd2015 );
    Delay_ms( 2000 );

    log_printf( &logger, " Turning OUT 1 to OUT 4 one by one \r\n" );
    uint8_t out_sel = IPD2015_OUT1_PIN_MASK;
    do
    {
        ipd2015_set_out_level( &ipd2015, out_sel, IPD2015_PIN_STATE_HIGH );
        Delay_ms( 2000 );
        ipd2015_set_out_level( &ipd2015, out_sel, IPD2015_PIN_STATE_LOW );
        out_sel <<=  1;
    }
    while ( out_sel <= IPD2015_OUT4_PIN_MASK );
    
}

void main ( void ) 
{
    application_init( );

    for ( ; ; ) 
    {
        application_task( );
    }
}

// ------------------------------------------------------------------------ END

额外支持

资源

喜欢这个项目吗?

'购买此套件' 按钮会直接带您进入购物车,您可以在购物车中轻松添加或移除产品。