解码 / 编码图像和视频¶
该软件包提供用于执行 IO 的函数
操作。它们目前特定于读取和写入图像,并且
视频。torchvision.io
图像¶
| 
 | 将 JPEG 或 PNG 图像读取到 3 维 RGB 或灰度 Tensor 中。 | 
| 
 | 检测图像是 JPEG 还是 PNG,并执行适当的作以将图像解码为 3 维 RGB 或灰度 Tensor。 | 
| 
 | 采用 CHW 布局中的输入张量,并返回一个缓冲区,其中包含其相应 JPEG 文件的内容。 | 
| 
 | 将 JPEG 图像解码为 3 维 RGB 或灰度 Tensor。 | 
| 
 | 获取 CHW 布局中的输入张量并将其保存在 JPEG 文件中。 | 
| 
 | 采用 CHW 布局中的输入张量,并返回一个缓冲区,其中包含其相应 PNG 文件的内容。 | 
| 
 | 将 PNG 图像解码为 3 维 RGB 或灰度 Tensor。 | 
| 
 | 获取 CHW 布局中的输入张量(如果是灰度图像,则为 HW)并将其保存在 PNG 文件中。 | 
| 
 | 读取文件的字节内容并将其输出为具有一维的 uint8 张量。 | 
| 
 | 将具有一维的 uint8 张量的内容写入文件。 | 
| 读取图像时支持各种模式。 | 
视频¶
| 
 | 从文件中读取视频,同时返回视频帧和音频帧 | 
| 
 | 列出视频帧时间戳。 | 
| 
 | 在视频文件中写入 [T, H, W, C] 格式的 4d 张量 | 
细粒度视频 API¶
除了功能之外,我们还提供高性能
与函数相比,用于更精细的控制。
它在完全支持 torchscript 的同时完成所有这些工作。read_videoread_video
警告
细粒度视频 API 目前处于 Beta 阶段,不保证向后兼容性。
| 
 | 细粒度视频阅读 API。 | 
检查视频的示例:
import torchvision
video_path = "path to a test video"
# Constructor allocates memory and a threaded decoder
# instance per video. At the moment it takes two arguments:
# path to the video file, and a wanted stream.
reader = torchvision.io.VideoReader(video_path, "video")
# The information about the video can be retrieved using the
# `get_metadata()` method. It returns a dictionary for every stream, with
# duration and other relevant metadata (often frame rate)
reader_md = reader.get_metadata()
# metadata is structured as a dict of dicts with following structure
# {"stream_type": {"attribute": [attribute per stream]}}
#
# following would print out the list of frame rates for every present video stream
print(reader_md["video"]["fps"])
# we explicitly select the stream we would like to operate on. In
# the constructor we select a default video stream, but
# in practice, we can set whichever stream we would like
video.set_current_stream("video:0")