letterbox实现

数据集中的图片一般为长方形,当模型输入为正方形时直接将长方形图片resize为正方形会使得图片失真,采用letterbox通过填充边界(通常是灰色填充)的方式来保持原始图片的长宽比例,同时又满足模型正方形输入的需要。

import cv2


def letterbox(im, new_shape=(640, 640), color=(114, 114, 114)):
    # Resize and pad image while meeting stride-multiple constraints
    shape = im.shape[:2]  # current shape [height, width]

    # Scale ratio (new / old)
    r = min(new_shape[0] / shape[0], new_shape[1] / shape[1])
    
    # Compute padding
    new_unpad = int(round(shape[1] * r)), int(round(shape[0] * r))    
    dw, dh = (new_shape[1] - new_unpad[0])/2, (new_shape[0] - new_unpad[1])/2  # wh padding 
    top, bottom = int(round(dh - 0.1)), int(round(dh + 0.1))
    left, right = int(round(dw - 0.1)), int(round(dw + 0.1))
    
    if shape[::-1] != new_unpad:  # resize
        im = cv2.resize(im, new_unpad, interpolation=cv2.INTER_LINEAR)
    im = cv2.copyMakeBorder(im, top, bottom, left, right, cv2.BORDER_CONSTANT, value=color)  # add border
    return im
    

src = cv2.imread("1.jpg") 
dst = letterbox(src, (768,768))
cv2.imwrite("letterbox.jpg",dst)

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
yolov5letterbox函数实现是通过填充边界的方式来保持原始图片的长宽比例,并将图片调整为模型所需的正方形输入尺寸。下面是yolov5letterbox函数的实现代码: ```python import cv2 import numpy as np def letterbox(img, new_shape=(640, 640), color=(114, 114, 114), auto=True, scaleFill=False, scaleup=True): shape = img.shape[:2] # 原始图片的尺寸 if isinstance(new_shape, int): new_shape = (new_shape, new_shape) # 计算调整后的图片尺寸 r = min(new_shape[0] / shape[0], new_shape[1] / shape[1]) if scaleup: # 是否放大图片 ratio = r # 缩放比例 else: ratio = min(new_shape[0] / shape[0], new_shape[1] / shape[1]) # 缩小比例 # 计算填充边界的尺寸 dw = int((new_shape[1] - shape[1] * ratio) / 2) # 宽度方向的填充大小 dh = int((new_shape[0] - shape[0] * ratio) / 2) # 高度方向的填充大小 # 创建一个新的画布,并将原始图片按比例缩放后放置在画布中央 if shape[::-1] != new_shape: # 如果原始图片尺寸与目标尺寸不一致 img = cv2.resize(img, (int(shape[1] * ratio), int(shape[0] * ratio)), interpolation=cv2.INTER_LINEAR) top, bottom = dh, dh left, right = dw, dw # 根据填充边界的尺寸,将图片放置在新的画布中央 if auto: # 自动选择填充颜色 mean = np.mean(img, axis=(0, 1)) color = np.round(mean).astype(np.uint8).tolist() img = cv2.copyMakeBorder(img, top, bottom, left, right, cv2.BORDER_CONSTANT, value=color) return img, ratio, (dw, dh) ``` 该函数接受三个参数: - img:原始图片 - new_shape:调整后的图片尺寸,默认为(640, 640) - color:填充边界的颜色,默认为灰色(114, 114, 114) 函数首先计算调整后的图片尺寸,然后根据缩放比例将原始图片按比例缩放,并创建一个新的画布。接着根据填充边界的尺寸,将图片放置在新的画布中央,并返回调整后的图片、缩放比例和填充边界的尺寸。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

给算法爸爸上香

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值