中级
30 分钟

使用3535UVC1W和PIC32MZ2048EFH100提高工作场所安全性并减少紫外线C辐射风险

看见未见之物

UVC Light Click with Flip&Click PIC32MZ

已发布 6月 25, 2024

点击板

UVC Light Click

开发板

Flip&Click PIC32MZ

编译器

NECTO Studio

微控制器单元

PIC32MZ2048EFH100

我们的创新解决方案结合了两个 275nm UV-C LED 和一个绿色 LED,提供视觉指示,帮助用户识别并避免直接暴露于潜在有害的 UV-C 光线。

A

A

硬件概览

它是如何工作的?

UVC Light Click 使用两个 0.7W、275nm 的 LED 和一个绿色 LED,使用户可以看到 UVC 光照射的大致区域,因为这些 UV 波长对人眼不可见,应避免直接暴露于眼睛。UVC Light Click 可用作消毒工具,因为 DNA、RNA 和蛋白质会吸收 200 nm 至 300 nm 范围内的 UV 光。蛋白质的吸收会导致细胞壁破裂并导致有机体死亡。DNA 或 RNA(特别是胸腺嘧啶碱基)的吸收已知会通过形成胸

腺嘧啶二聚体来使 DNA 或 RNA 双螺旋链失活。如果 DNA 中形成了足够多的二聚体,DNA 复制过程将被中断,细胞将无法复制。广泛接受的观点是,使用 UV 光不需要杀死病原体,而是应用足够的 UV 光以防止有机体复制。防止复制所需的 UV 剂量比杀死所需的剂量低几个数量级,使得防止感染的 UV 处理成本在商业上是可行的。UVC Light Click 采用 TPS61169 LED 驱动器与 PWM 

亮度控制,以串联驱动 LED,并采用 MC34671 电池充电器,以允许在 Click 板™ 插入 mikroBUS™ 插槽时对电池进行充电;CHG LED 将指示充电过程,并在电池充电完成后熄灭。当 PWR SEL 跳线重新定位到右侧位置时,如果不需要调光或需要高移动性,可以独立使用 UVC Light 和 Click。

UVC Light Click hardware overview image

功能概述

开发板

Flip&Click PIC32MZ 是一款紧凑型开发板,设计为一套完整的解决方案,它将 Click 板™的灵活性带给您喜爱的微控制器,使其成为实现您想法的完美入门套件。它配备了一款板载 32 位 PIC32MZ 微控制器,Microchip 的 PIC32MZ2048EFH100,四个 mikroBUS™ 插槽用于 Click 板™连接,两个 USB 连接器,LED 指示灯,按钮,调试器/程序员连接器,以及两个与 Arduino-UNO 引脚兼容的头部。得益于创

新的制造技术,它允许您快速构建具有独特功能和特性的小工具。Flip&Click PIC32MZ 开发套件的每个部分都包含了使同一板块运行最高效的必要组件。此外,还可以选择 Flip&Click PIC32MZ 的编程方式,使用 chipKIT 引导程序(Arduino 风格的开发环境)或我们的 USB HID 引导程序,使用 mikroC、mikroBasic 和 mikroPascal for PIC32。该套件包括一个通过 USB 类型-C(USB-C)连接器的干净且调

节过的电源供应模块。所有 mikroBUS™ 本身支持的 通信方法都在这块板上,包括已经建立良好的 mikroBUS™ 插槽、用户可配置的按钮和 LED 指示灯。Flip&Click PIC32MZ 开发套件允许您在几分钟内创建新的应用程序。它由 Mikroe 软件工具原生支持,得益于大量不同的 Click 板™(超过一千块板),其数量每天都在增长,它涵盖了原型制作的许多方面。

Flip&Click PIC32MZ double image

微控制器概述 

MCU卡片 / MCU

default

建筑

PIC32

MCU 内存 (KB)

2048

硅供应商

Microchip

引脚数

100

RAM (字节)

524288

使用的MCU引脚

mikroBUS™映射器

NC
NC
AN
NC
NC
RST
NC
NC
CS
NC
NC
SCK
NC
NC
MISO
NC
NC
MOSI
NC
NC
3.3V
Ground
GND
GND
Dimming Control
RC14
PWM
NC
NC
INT
NC
NC
TX
NC
NC
RX
NC
NC
SCL
NC
NC
SDA
Power Supply
5V
5V
Ground
GND
GND
1

“仔细看看!”

Click board™ 原理图

UVC Light Click Schematic schematic

一步一步来

项目组装

Flip&Click PIC32MZ front image hardware assembly

从选择您的开发板和Click板™开始。以Flip&Click PIC32MZ作为您的开发板开始。

Flip&Click PIC32MZ front image hardware assembly
Buck 22 Click front image hardware assembly
Prog-cut hardware assembly
Flip&Click PIC32MZ - 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
Flip&Click PIC32MZ 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

实时跟踪您的结果

通过调试模式的应用程序输出

1. 一旦代码示例加载完成,按下 "DEBUG" 按钮将启动构建过程,并将其编程到创建的设置上,然后进入调试模式。

2. 编程完成后,IDE 中将出现一个带有各种操作按钮的标题。点击绿色的 "PLAY" 按钮开始读取通过 Click board™ 获得的结果。获得的结果将在 "Application Output" 标签中显示。

DEBUG_Application_Output

软件支持

库描述

该库包含 UVC Light Click 驱动程序的 API。

关键功能:

  • uvclight_pwm_start - 此功能启动 PWM 模块

  • uvclight_set_duty_cycle - 此功能设置 PWM 占空比

  • uvclight_pwm_stop - 此功能停止 PWM 模块

开源

代码示例

这个示例可以在 NECTO Studio 中找到。欢迎下载代码,或者您也可以复制下面的代码。

/*!
 * @file 
 * @brief UvcLight Click example
 * 
 * # Description
 * This click has ultraviolet LEDs with 275nm wavelength. UVC radiation refers to wavelengths 
 * shorter than 280 nm. Because of the spectral sensitivity of DNA, only the UVC region 
 * demonstrates significant germicidal properties.
 *
 * The demo application is composed of two sections :
 * 
 * ## Application Init 
 * Initializes the driver.
 * 
 * ## Application Task  
 * Increases and decreases the pwm duty cycle.
 * Results are being sent to the Usart Terminal where you can track their changes.
 * 
 * CAUTION! High intensity UV Light - avoid eye and skin exposure. Avoid looking direclty at light!
 * 
 * @author Nikola Peric
 *
 */
// ------------------------------------------------------------------- INCLUDES

#include "board.h"
#include "log.h"
#include "uvclight.h"

// ------------------------------------------------------------------ VARIABLES

static uvclight_t uvclight;
static log_t logger;

// ------------------------------------------------------ APPLICATION FUNCTIONS

void application_init ( void )
{
    log_cfg_t log_cfg;
    uvclight_cfg_t cfg;

    /** 
     * 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.

    uvclight_cfg_setup( &cfg );
    UVCLIGHT_MAP_MIKROBUS( cfg, MIKROBUS_1 );
    uvclight_init( &uvclight, &cfg );

    uvclight_set_duty_cycle ( &uvclight, 0.0 );
    uvclight_pwm_start( &uvclight );
    Delay_ms( 100 );
    log_info( &logger, "---- Application Task ----" );
}

void application_task ( void )
{
    static int8_t duty_cnt = 1;
    static int8_t duty_inc = 1;
    float duty = duty_cnt / 10.0;

    uvclight_set_duty_cycle ( &uvclight, duty );
    log_printf( &logger, "Duty: %d%%\r\n", ( uint16_t )( duty_cnt * 10 ) );
    Delay_ms( 500 );

    if ( 10 == duty_cnt ) 
    {
        duty_inc = -1;
    }
    else if ( 0 == duty_cnt ) 
    {
        log_printf( &logger, "Cooldown 2 SEC\r\n");
        Delay_ms( 2000 );
        duty_inc = 1;
    }
    duty_cnt += duty_inc;
}

void main ( void )
{
    application_init( );

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

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

额外支持

资源

喜欢这个项目吗?

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