实验条件:
- 从1张图像随机裁剪100张图像
- 裁剪出图像的大小为 60 x 60
- IoU 大于等于 th=0.6 的裁剪框用红色标出,其它裁剪框用蓝色标出
- IoU 比对原始区域用绿框标出
实验代码:
import cv2 as cv import numpy as np np.random.seed(0) # get IoU overlap ratio def iou(a, b): # get area of a area_a = (a[2] - a[0]) * (a[3] - a[1]) # get area of b area_b = (b[2] - b[0]) * (b[3] - b[1]) # get left top x of IoU iou_x1 = np.maximum(a[0], b[0]) # get left top y of IoU iou_y1 = np.maximum(a[1], b[1]) # get right bottom of IoU iou_x2 = np.minimum(a[2], b[2]) # get right bottom of IoU iou_y2 = np.minimum(a[3], b[3]) # get width of IoU iou_w = iou_x2 - iou_x1 # get height of IoU iou_h = iou_y2 - iou_y1 # get area of IoU area_iou = iou_w * iou_h # get overlap ratio between IoU and all area iou = area_iou / (area_a + area_b - area_iou) return iou # crop and create database def crop_bbox(img, gt, Crop_N=200, L=60, th=0.5): # get shape H, W, C = img.shape # each crop for i in range(Crop_N): # get left top x of crop bounding box x1 = np.random.randint(W - L) # get left top y of crop bounding box y1 = np.random.randint(H - L) # get right bottom x of crop bounding box x2 = x1 + L # get right bottom y of crop bounding box y2 = y1 + L # crop bounding box crop = np.array((x1, y1, x2, y2)) # get IoU between crop box and gt _iou = iou(gt, crop) # assign label if _iou >= th: cv.rectangle(img, (x1, y1), (x2, y2), (0,0,255), 1) label = 1 else: cv.rectangle(img, (x1, y1), (x2, y2), (255,0,0), 1) label = 0 return img # read image img = cv.imread("../xiyi.jpg") img1 = img.copy() # gt bounding box gt = np.array((87, 51, 169, 113), dtype=np.float32) # get crop bounding box img = crop_bbox(img, gt, Crop_N=100, L=60, th=0.6) # draw gt cv.rectangle(img, (gt[0], gt[1]), (gt[2], gt[3]), (0,255,0), 1) cv.rectangle(img1,(gt[0], gt[1]), (gt[2], gt[3]), (0,255,0), 1) cv.imshow("result1",img1) cv.imshow("result", img) cv.imwrite("out.jpg", img) cv.waitKey(0) cv.destroyAllWindows()
实验结果:
以上就是python实现图像随机裁剪的示例代码的详细内容,更多关于python 图像裁剪的资料请关注其它相关文章!
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“python实现图像随机裁剪的示例代码”评论...
更新日志
2024年12月23日
2024年12月23日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]