RandomResizedCrop
class paddle.vision.transforms. RandomResizedCrop ( size, scale=(0.08, 1.0), ratio=(3. / 4, 4. / 3), interpolation=’bilinear’, keys=None ) [源代码]
将输入图像按照随机大小和长宽比进行裁剪。 会根据参数生成基于原图像的随机比例(默认值:0.08至1.0)和随机宽高比(默认值:3./4至4./3)。 经过此接口操作后,输入图像将调整为参数指定大小。
参数
size (int|list|tuple) - 输出图像大小,当为单个int值时,生成指定size大小的方形图片,为(height,width)格式的数组或元组时按照参数大小输出。
scale (list|tuple) - 相对于原图的尺寸,随机裁剪后图像大小的范围。默认值:(0.08,1.0)。
ratio (list|tuple) - 裁剪后的目标图像宽高比范围,默认值: (0.75, 1.33)。
interpolation (int|str, optional) - 插值的方法. 默认值: ‘bilinear’. 当使用
pil
作为后端时, 支持的插值方法如下: - “nearest”: Image.NEAREST, - “bilinear”: Image.BILINEAR, - “bicubic”: Image.BICUBIC, - “box”: Image.BOX, - “lanczos”: Image.LANCZOS, - “hamming”: Image.HAMMING。当使用cv2
作为后端时, 支持的插值方法如下: - “nearest”: cv2.INTER_NEAREST, - “bilinear”: cv2.INTER_LINEAR, - “area”: cv2.INTER_AREA, - “bicubic”: cv2.INTER_CUBIC, - “lanczos”: cv2.INTER_LANCZOS4。keys (list[str]|tuple[str], optional) - 与
BaseTransform
定义一致。默认值: None。
返回
numpy ndarray
,随机裁剪和改变大小后的图像。
代码示例
import numpy as np
from PIL import Image
from paddle.vision.transforms import RandomResizedCrop
transform = RandomResizedCrop(224)
fake_img = Image.fromarray((np.random.rand(300, 320, 3) * 255.).astype(np.uint8))
fake_img = transform(fake_img)
print(fake_img.size)