Crowding Counter 之 裁剪图像进行数据集扩充

现有的Crowding Counter任务数据集大小均不大,例如ShanghaiTech数据集的大小就几百张,因此为了增强训练的效果,通常会将数据集进行扩充,较为简单的方法就是将原始的图像进行局部裁剪,从而达到扩充的目的。

以下代码以ShanghaiTech的数据集为示例(不同示例数据集的.mat文件读取方法不同)

文件说明:

原始.mat文件放在groundPath/下;

原始图像放在imagePath/下;

因为将一张图像裁剪为9份,因此用for循环控制每一次的图像存储到单独的一个文件夹中;

def createImageAndMat():
	originalIndex = [    # 从这些点开始裁剪矩阵
					[50,50],[250,50],[400,50],
					[50,100],[250,100],[400,100],
					[50,250],[250,250],[400,250]
				]

	h = 425    # 需要裁剪矩阵的长和宽
	w = 565
	image_index = 300

	for index_i in range(0, 9):
		x = originalIndex[index_i][0]
		y = originalIndex[index_i][1]
		for i in range(1,301):
			print(i)
			image = imagePath+"IMG_"+str(i)+".jpg"
			img = cv2.imread(image)
			cropImg = img[(y):(y+h), (x):(x+w)]
			cv2.imwrite("./justPoint/img_"+str(index_i+1)+"/IMG_"+str(image_index+i)+".jpg", cropImg)

			mat = loadmat(groundPath+"GT_IMG_"+str(i)+".mat")
			coordinates = mat["image_info"][0][0][0][0][0]
			coords = []
			for j in range(0, len(coordinates)):
				x_1 = coordinates[j][0]
				y_1 = coordinates[j][1]
				if x_1 >= x and x_1 <= x+w:
					if y_1 >= y and y_1 <= y+h:
						x_1 = x_1-x
						y_1 = y_1-y
						coords.append([x_1, y_1])
			mat["image_info"][0][0][0][0][0] = coords
			scipy.io.savemat("./justPoint/ground_truth_"+str(index_i+1)+"/GT_IMG_"+str(image_index+i)+".mat", mat)
		image_index += 300    # 原始图像为300张,每次裁剪生成300个新图像,因此加300

当得到裁剪后的图像以及.mat文件后,可以用下面代码进行将mat文件中的点标注到图像上来查看是否正确:

def showImageaAfterProcess():
	for i in range(601,900):
		img = "./justPoint/img_2/IMG_"+str(i)+".jpg"
		image = cv2.imread(img)

		mat = loadmat("./justPoint/ground_truth_2/GT_IMG_"+str(i)+".mat")
		coords = mat["image_info"][0][0][0][0][0]
		print(len(coords))

		point_size = 1
		point_color = (0, 0, 255) # BGR
		thickness = 4 #  0 、4、8
		for coor in coords:
			cv2.circle(image, (int(coor[0]),int(coor[1])), point_size, point_color, thickness)
		cv2.imwrite("./justPoint/img_3/IMG_"+str(i)+".jpg", image, [int(cv2.IMWRITE_JPEG_QUALITY),95])

由于裁剪后的图像尺寸小于原始图像,因此如果需要将原始图像和裁剪后的图像进行大小调整,可以参考这篇博客:https://blog.csdn.net/zxs0222/article/details/107899079

完毕;

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值