实验条件:
- 从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年11月08日
2024年11月08日
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]