航拍图像是高清大图,现在主流模型和处理大小1000往下,和计算力有关,工程角度来说要分割多块分别处理。
写了一个分割大图像为小图像的小程序。考虑到处理大小是1000往下,所以我的设计思路如下:
分成nxm块。
n=向上取整(图像高度/1000)
m=向上取整(图像高度/1000)
例如:3200x2400的图像,
n=4
m=3
得到子图像大小为:800x800,无论用one-stage或者two-stage,不是特别小的目标都能够处理了。如果需要其他大小,可以自己更改一下比例,比如缩小一倍,将n和m都乘2就可以。
因为我要处理的是数据集,所以写了for循环,针对文件夹批量处理。
代码如下:
# -*- coding:utf-8 -*-
import os
import matplotlib.pyplot as plt
import cv2
import numpy as np
def divide_img(img_path, img_name, save_path):
imgg=img_path+img_name
img = cv2.imread(imgg)
# img = cv2.cvtColor(img,cv2.COLOR_BGR2RGB)
h = img.shape[0]
w = img.shape[1]
n=int(np.floor(h*1.0/1000))+1
m=int(np.floor(w*1.0/1000))+1
print('h={}