计算机视觉技术-目标检测数据集

目标检测领域没有像MNIST和Fashion-MNIST那样的小数据集。 为了快速测试目标检测模型,我们收集并标记了一个小型数据集。 首先,我们拍摄了一组香蕉的照片,并生成了1000张不同角度和大小的香蕉图像。 然后,我们在一些背景图片的随机位置上放一张香蕉的图像。 最后,我们在图片上为这些香蕉标记了边界框。

1、下载数据集

包含所有图像和CSV标签文件的香蕉检测数据集可以直接从互联网下载。

%matplotlib inline
import os
import pandas as pd
import torch
import torchvision
from d2l import torch as d2l

#@save
d2l.DATA_HUB['banana-detection'] = (
    d2l.DATA_URL + 'banana-detection.zip',
    '5de26c8fce5ccdea9f91267273464dc968d20d72')

2、读取数据集 

通过read_data_bananas函数,我们读取香蕉检测数据集。 该数据集包括一个的CSV文件,内含目标类别标签和位于左上角和右下角的真实边界框坐标。

#@save
def read_data_bananas(is_train=True):
    """读取香蕉检测数据集中的图像和标签"""
    data_dir = d2l.download_extract('banana-detection')
    csv_fname = os.path.join(data_dir, 'bananas_train' if is_train
                             else 'bananas_val', 'label.csv')
    csv_data = pd.read_csv(csv_fname)
    csv_data = csv_data.set_index('img_name')
    images, targets = [], []
    for img_name, target in csv_data.iterrows():
        images.append(torchvision.io.read_image(
            os.path.join(data_dir, 'bananas_train' if is_train else
                         'bananas_val', 'images', f'{img_name}')))
        # 这里的target包含(类别,左上角x,左上角y,右下角x,右下角y),
        # 其中所有图像都具有相同的香蕉类(索引为0)
        targets.append(list(target))
    return images, torch.tensor(targets).unsqueeze(1) / 256

通过使用read_data_bananas函数读取图像和标签,以下BananasDataset类别将允许我们创建一个自定义Dataset实例来加载香蕉检测数据集。

#@save
class BananasDataset(torch.utils.data.Dataset):
    """一个用于加载香蕉检测数据集的自定义数据集"""
    def __init__(self, is_train):
        self.features, self.labels = read_data_bananas(is_train)
        print('read ' + str(len(self.features)) + (f' training examples' if
              is_train else f' validation examples'))

    def __getitem__(self, idx):
        return (self.features[idx].float(), self.labels[idx])

    def __len__(self):
        return len(self.features)

最后,我们定义load_data_bananas函数,来为训练集和测试集返回两个数据加载器实例。对于测试集,无须按随机顺序读取它。

#@save
def load_data_bananas(batch_size):
    """加载香蕉检测数据集"""
    train_iter = torch.utils.data.DataLoader(BananasDataset(is_train=True),
                                             batch_size, shuffle=True)
    val_iter = torch.utils.data.DataLoader(BananasDataset(is_train=False),
                                           batch_size)
    return train_iter, val_iter

让我们读取一个小批量,并打印其中的图像和标签的形状。 图像的小批量的形状为(批量大小、通道数、高度、宽度),看起来很眼熟:它与我们之前图像分类任务中的相同。 标签的小批量的形状为(批量大小,m,5),其中m是数据集的任何图像中边界框可能出现的最大数量。

小批量计算虽然高效,但它要求每张图像含有相同数量的边界框,以便放在同一个批量中。 通常来说,图像可能拥有不同数量个边界框;因此,在达到m之前,边界框少于m的图像将被非法边界框填充。 这样,每个边界框的标签将被长度为5的数组表示。 数组中的第一个元素是边界框中对象的类别,其中-1表示用于填充的非法边界框。 数组的其余四个元素是边界框左上角和右下角的(xy)坐标值(值域在0~1之间)。 对于香蕉数据集而言,由于每张图像上只有一个边界框,因此m=1。

batch_size, edge_size = 32, 256
train_iter, _ = load_data_bananas(batch_size)
batch = next(iter(train_iter))
batch[0].shape, batch[1].shape

 (torch.Size([32, 3, 256, 256]), torch.Size([32, 1, 5]))

 让我们展示10幅带有真实边界框的图像。 我们可以看到在所有这些图像中香蕉的旋转角度、大小和位置都有所不同。 当然,这只是一个简单的人工数据集,实践中真实世界的数据集通常要复杂得多。

imgs = (batch[0][0:10].permute(0, 2, 3, 1)) / 255
axes = d2l.show_images(imgs, 2, 5, scale=2)
for ax, label in zip(axes, batch[1][0:10]):
    d2l.show_bboxes(ax, [label[0][1:5] * edge_size], colors=['w'])

3、演示 

 

<think>好的,我现在需要回答用户关于如何在STM32单片机中实现按键控制的阈值设置的问题。首先,我需要回顾一下用户提供的引用内容,看看有没有相关的实现方法或者模块可以参考。 用户引用了三个设计,都是基于STM32单片机,涉及温湿度、光照检测以及阈值报警功能。这些设计中提到了使用按键电路来设置阈值,比如引用[1]中的基于MPU6050的报警系统,引用[2]中的温湿度报警设计,以及引用[3]中的温湿度光照检测和继电器控制。这些引用都提到了按键用于设置阈值,结合了传感器数据采集和报警功能。 接下来,我需要整理实现按键控制阈值设置的步骤。首先,硬件部分需要按键输入,可能包括独立按键或矩阵键盘。软件部分需要按键扫描检测、阈值变量处理、存储以及显示和报警联动。 对于按键检测,通常有轮询和中断两种方式。轮询简单但占用资源,中断实时性更好。可能需要消抖处理,比如延时去抖动。阈值调整方面,可能需要增减按键,比如每按一次增加或减少一个步长,同时要考虑上下限,避免超出合理范围。存储方面,如果阈值需要掉电保存,可能需要使用EEPROM或者Flash存储。显示部分可能需要LCD或OLED来实时显示当前阈值。报警功能则是在检测到当前值超过阈值时触发蜂鸣器或继电器。 然后需要结合具体的代码示例,比如GPIO初始化、按键扫描函数、阈值处理逻辑、存储函数以及显示和报警部分的代码。需要注意代码的模块化和可维护性,比如将按键处理、阈值调整、显示更新分开处理。 可能还需要考虑多任务处理,比如在实时系统中使用RTOS或者定时器中断来定期检测按键和更新阈值。同时,引用中的设计都是基于STM32F103C8T6,所以需要根据该型号的GPIO配置和相关库函数来编写代码,比如使用HAL库或者标准外设库。 另外,用户提到的引用中,比如引用[2]和[3]都使用了SHT11和DHT11温湿度传感器,这些传感器的数据读取可能需要特定的时序,但阈值设置本身不直接涉及传感器读取,而是在主循环中根据按键输入调整变量,然后将这些变量用于比较。 最后,需要验证逻辑是否正确,比如按键按下是否能正确改变阈值,显示是否更新,存储是否可靠,报警是否在阈值超出时触发。可能还需要考虑用户界面友好,比如通过不同按键组合进入设置模式,调整数值后确认保存等。</think>在STM32单片机中实现按键控制的阈值设置,需要结合按键扫描变量存储及外设控制。以下是分步实现方法: ### 一、硬件设计 1. **按键电路**:使用独立按键或矩阵键盘,连接至GPIO引脚(如上拉输入模式) - 例如:KEY_UP(阈值+)、KEY_DOWN(阈值-)、KEY_ENTER(确认) 2. **主控单元**:STM32F103C8T6核心板(如引用[1][2][3]中方案) 3. **辅助模块**:LCD/OLED显示当前阈值,蜂鸣器用于超限报警 ### 二、软件实现 #### 1. 按键扫描检测 ```c // GPIO初始化(以KEY_UP接PA0为例) void KEY_Init(void) { GPIO_InitTypeDef GPIO_InitStruct; __HAL_RCC_GPIOA_CLK_ENABLE(); GPIO_InitStruct.Pin = GPIO_PIN_0; GPIO_InitStruct.Mode = GPIO_MODE_INPUT; GPIO_InitStruct.Pull = GPIO_PULLUP; HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); } // 按键扫描函数 uint8_t KEY_Scan(void) { if(HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_0) == GPIO_PIN_RESET) { HAL_Delay(20); // 消抖处理 if(HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_0) == GPIO_PIN_RESET) return KEY_UP; } // 其他按键检测... return NONE_PRESS; } ``` #### 2. 阈值处理逻辑 ```c #define MIN_THRESHOLD 0 #define MAX_THRESHOLD 100 int32_t current_threshold = 50; // 默认阈值 void Threshold_Adjust(void) { switch(KEY_Scan()) { case KEY_UP: if(current_threshold < MAX_THRESHOLD) current_threshold++; break; case KEY_DOWN: if(current_threshold > MIN_THRESHOLD) current_threshold--; break; case KEY_ENTER: Save_Threshold(FLASH_ADDR, current_threshold); // 存储阈值 break; } Display_Update(current_threshold); // 更新显示 } ``` #### 3. 阈值存储(EEPROM/Flash) ```c // 使用内部Flash模拟EEPROM void Save_Threshold(uint32_t addr, int32_t value) { HAL_FLASH_Unlock(); FLASH_EraseInitTypeDef EraseInit; EraseInit.TypeErase = FLASH_TYPEERASE_PAGES; EraseInit.PageAddress = addr; EraseInit.NbPages = 1; uint32_t PageError; HAL_FLASHEx_Erase(&EraseInit, &PageError); HAL_FLASH_Program(FLASH_TYPEPROGRAM_WORD, addr, value); HAL_FLASH_Lock(); } int32_t Load_Threshold(uint32_t addr) { return *(__IO int32_t*)addr; } ``` ### 三、系统集成 1. **主循环结构**: ```c int main(void) { HAL_Init(); KEY_Init(); Display_Init(); current_threshold = Load_Threshold(FLASH_ADDR); // 加载存储值 while(1) { Threshold_Adjust(); Sensor_Data = Read_Sensor(); // 如MPU6050/DHT11(引用[1][3]) if(Sensor_Data > current_threshold) Buzzer_Alert(); // 触发报警(引用[1][2]) } } ``` ### 四、优化建议 1. **分层菜单**:通过多次按键进入不同阈值设置层(温度/湿度/光照等,如引用[3]) 2. **步进调节**:长按按键实现快速增减 3. **数据校验**:存储时添加CRC校验 4. **掉电保护**:使用备份寄存器或FRAM(如STM32L系列)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

白云如幻

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值