import cv2
import numpy as np
import os
import glob
# 数据增强函数
def augment_data(img):
rows,cols,_ = img.shape
# 水平翻转图像
if np.random.random() > 0.5:
img = cv2.flip(img, 1)
img_name = os.path.splitext(save_path)[0] + "_flip.png"
cv2.imwrite(img_name, img)
print("Saved augmented image:", img_name)
# 随机缩放图像
scale = np.random.uniform(0.9, 1.1)
M = cv2.getRotationMatrix2D((cols/2, rows/2), 0, scale)
img_transformed = cv2.warpAffine(img, M, (cols, rows))
img_name = os.path.splitext(save_path)[0] + "_transform.png"
cv2.imwrite(img_name, img_transformed)
print("Saved augmented image:", img_name)
# 随机旋转图像
angle = np.random.randint(-10, 10)
M = cv2.getRotationMatrix2D((cols/2, rows/2), angle, 1)
img_rotated = cv2.warpAffine(img, M, (cols, rows))
img_name = os.path.splitext(save_path)[0] + "_rotated.png"
cv2.imwrite(img_name, img_rotated)
print("Saved augmented image:", img_name)
# 添加高斯噪音
mean = 0
std = np.random.uniform(5, 15)
noise = np.zeros(img.shape, np.float32)
cv2.randn(noise, mean, std)
noise = np.uint8(noise)
img_noisy = cv2.add(img, noise)
img_name = os.path.splitext(save_path)[0] + "_noisy.png"
cv2.imwrite(img_name, img_noisy)
print("Saved augmented image:", img_name)
# 随机调整对比度和亮度
alpha = np.random.uniform(0.8, 1.2)
beta = np.random.randint(-10, 10)
img_contrast = cv2.convertScaleAbs(img, alpha=alpha, beta=beta)
img_name = os.path.splitext(save_path)[0] + "_contrast.png"
cv2.imwrite(img_name, img_contrast)
print("Saved augmented image:", img_name)
return img
# 读取 data 文件夹中的所有图片,并进行数据增强
data_dir = "data"
save_dir = "result"
if not os.path.exists(save_dir):
os.makedirs(save_dir)
# 使用 glob 库来遍历 data 文件夹中所有图像
for img_path in glob.glob(os.path.join(data_dir, "*.png")):
img = cv2.imread(img_path)
# 获取保存增强后的图片文件名
img_name = os.path.basename(img_path)
save_path = os.path.join(save_dir, img_name)
# 数据增强
augment_data(img)
# 保存原始图片
cv2.imwrite(save_path, img)
print("Saved original image:", save_path)
YOLO图像前处理及格式转换
Richard Yue2024-03-30 21:28
相关推荐
蹦蹦跳跳真可爱58924 分钟前
Python----OpenCV(图像増强——高通滤波(索贝尔算子、沙尔算子、拉普拉斯算子),图像浮雕与特效处理)nananaij29 分钟前
【Python进阶篇 面向对象程序设计(3) 继承】雷羿 LexChien34 分钟前
从 Prompt 管理到人格稳定:探索 Cursor AI 编辑器如何赋能 Prompt 工程与人格风格设计(上)阿蒙Amon39 分钟前
为什么 12 版仍封神?《C# 高级编程》:从.NET 5 到实战架构,进阶者绕不开的必修课无小道41 分钟前
c++-引用(包括完美转发,移动构造,万能引用)爱莉希雅&&&1 小时前
技术面试题,HR面试题敲键盘的小夜猫1 小时前
LLM复杂记忆存储-多会话隔离案例实战开开心心_Every2 小时前
便捷的Office批量转PDF工具高压锅_12202 小时前
Django Channels WebSocket实时通信实战:从聊天功能到消息推送一瓣橙子3 小时前
7.7日 实验03-Spark批处理开发(2)