IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 语义分割数据增强(Data augmentation for semantic segmentation) -> 正文阅读

[人工智能]语义分割数据增强(Data augmentation for semantic segmentation)

数据增强

深度学习模型的鲁棒性(robustness)和泛化性(generality)受到训练数据的多样性和数据量所影响。数据增强(data augmentation)是机器学习和深度学习中经常采用的一个方法,其目的是扩大训练样本的数量。

语义分割是计算机一个重要的下游任务,语义分割的数据增强通常需要对图像及其对应的标签做相同的增强处理


本文总结了3种常用的增强方式:(1)旋转,(2)翻转,(3)裁剪。所有操作均采用opencv库进行


首先使用opencv定义数据读取和保存函数

# 定义数据读取函数
import cv2
import os
import numpy as np
 ___________________________________________________________
 
 def read_data(file, mode=1):
    """
    Args:
        file: 数据路径
        mode: bool值,若读取3通道则1,读取灰度图则为0

    Returns:

    """
    if mode == 1:
        img = cv2.imread(file)
        # print(img.shape)
        img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
        return img
    if mode == 0:
        img = cv2.imread(file, cv2.IMREAD_GRAYSCALE)
        return img
    else:
        raise ValueError("mode should be a bool number 1 or 0")


def save_data(save_pth, img):
    img = img.astype(np.uint8)
    cv2.imwrite(save_pth, img)


旋转操作(Rotate)

	def rotate(img, gt, angle=10):
		"""
		angle: 旋转的角度
		"""	
	    img = read_data(img, 1)
	    gt = read_data(gt, 0)
	    assert img.shape[:2] == gt.shape[:2]
	
	    h, w = img.shape[:2]
	    center = (w / 2, h / 2)
	    mat = cv2.getRotationMatrix2D(center, angle, scale=1)
	    rotated_img = cv2.warpAffine(img, mat, (h, w))
	    rotated_gt = cv2.warpAffine(gt, mat, (h, w))
	    return rotated_img, rotated_gt

翻转操作(flip)

# 翻转图片(水平和垂直) 核心函数:cv.flip()
def flip(img, gt, direction=1):
    """
    Args:
        img:
        direction: bool, 1表示水平翻转,0表示垂直翻转
    Returns:

    """
    # 如果传入的是图像路径:则先调用函数读取图像,再对图像进行翻转
    if type(img) == str:
        img = read_data(img, 1)
        gt = read_data(gt, 0)
        assert img.shape[:2] == gt.shape[:2]
    # 如果传入的是读取的图像数据,则直接对图像进行翻转
    assert img.shape[:2] == gt.shape[:2]
    flipped_img = cv2.flip(img, direction)
    flipped_gt = cv2.flip(gt, direction)
    return flipped_img, flipped_gt

裁剪操作(crop)

# 在输入图像种的左上角,右上角,左下角,右上角,中间分别裁剪大小为(512*512)大小的子图像
def crop(img, gt):
    img = read_data(img, 1)
    gt = read_data(gt, 0)
    assert img.shape[:2] == gt.shape[:2]
		
	# 左上角
    upL_subim, upL_subgt = img[:512, :512, :], gt[:512, :512]
    # 右上角
    upR_subim, upR_subgt = img[:512, -512:, :], gt[:512, -512:]
    # 左下角
    bottomL_subim, bottomL_subgt = img[-512:, :512, :], gt[-512:, :512]
    # 右下角
    bottomR_subim, bottomR_subgt = img[-512:, -512:, :], gt[-512:, -512:]
	# 中间
   	(h, w) = img.shape[:2]
    h_ctr, w_ctr = int(h/2), int(w/2)
    center_subim, center_subgt = img[(h_ctr - 256):(h_ctr + 256), (w_ctr - 256):(w_ctr + 256), :],\
                                 gt[(h_ctr - 256):(h_ctr + 256), (w_ctr - 256):(w_ctr + 256)],
                                                                                   (w - 256):(w + 256)]

    return (upL_subim, upL_subgt), (upR_subim, upR_subgt), (bottomL_subim, bottomL_subgt), (
    bottomR_subim, bottomR_subgt), (center_subim, center_subgt)
  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-03-21 20:50:48  更:2022-03-21 20:55:47 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 1:54:03-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码