Shortcuts

可视化

1 总体设计

可视化可以给深度学习的模型训练和测试过程提供直观解释。在 OpenMMLab 算法库中,我们期望可视化功能的设计能满足以下需求:

  • 提供丰富的开箱即用可视化功能,能够满足大部分计算机视觉可视化任务

  • 高扩展性,可视化功能通常多样化,应该能够通过简单扩展实现定制需求

  • 能够在训练和测试流程的任意点位进行可视化

  • OpenMMLab 各个算法库具有统一可视化接口,利于用户理解和维护

基于上述需求,OpenMMLab 2.0 引入了可视化对象 Visualizer 和各个可视化存储后端 VisBackend 如 LocalVisBackendWandbVisBackendTensorboardVisBackend 等。此处的可视化不仅仅包括图片数据格式,还包括配置内容、标量和模型图等数据的可视化。

  • 为了方便调用,Visualizer 提供的接口实现了绘制和存储的功能。可视化存储后端 VisBackend 作为 Visualizer 的内部属性,会在需要的时候被 Visualizer 调用,将数据存到不同的后端

  • 考虑到绘制后会希望存储到多个后端,Visualizer 可以配置多个 VisBackend,当用户调用 Visualizer 的存储接口时候,Visualizer 内部会遍历的调用 VisBackend 存储接口

两者的 UML 关系图如下

2 可视化器 Visualizer

可视化对象 Visualizer 对外提供了所有接口。可以将其接口分成 3 大类,如下所示

(1) 绘制相关接口

上述接口除了 draw_featmap 外都可以链式调用,因为该方法调用后可能会导致图片尺寸发生改变。为了避免给用户带来困扰, draw_featmap 被设置为静态方法。

(2) 存储相关接口

以 add 前缀开头的接口表示存储接口。datasample 是 OpenMMLab 2.0 架构中设计的各个下游库统一的抽象数据接口,而 add_datasample 接口可以直接处理该数据格式,例如可视化预测结果、可视化 Dataset 或者 DataLoader 输出、可视化中间预测结果等等都可以直接调用下游库重写的 add_datasample 接口。 所有下游库都必须要继承 Visualizer 并实现 add_datasample 接口。以 MMDetection 为例,应该继承并通过该接口实现目标检测中所有预置任务的可视化功能,例如目标检测、实例分割、全景分割任务结果的绘制和存储。

(3) 其余功能性接口

  • set_image 设置原始图片数据,默认输入图片格式为 RGB

  • get_image 获取绘制后的 Numpy 格式图片数据,默认输出格式为 RGB

  • show 可视化

  • get_backend 通过 name 获取特定存储后端

  • close 关闭所有已经打开的资源,包括 VisBackend

关于其用法,可以参考 可视化器用户教程

3 可视化存储后端 VisBackend

在绘制后可以将绘制后的数据存储到多个可视化存储后端中。为了统一接口调用,MMEngine 提供了统一的抽象类 BaseVisBackend,和一些常用的 VisBackend 如 LocalVisBackendWandbVisBackendTensorboardVisBackend。 BaseVisBackend 定义了对外调用的接口规范,主要接口和属性如下:

BaseVisBackend 定义了 5 个常见的写数据接口,考虑到某些写后端功能非常强大,例如 WandB,其具备写表格,写视频等等功能,针对这类需求用户可以直接获取 experiment 对象,然后调用写后端对象本身的 API 即可。而 LocalVisBackendWandbVisBackendTensorboardVisBackend 等都是继承自 BaseVisBackend,并根据自身特性实现了对应的存储功能。用户也可以继承 BaseVisBackend 从而扩展存储后端,实现自定义存储需求。 关于其用法,可以参考 存储后端用户教程

Read the Docs v: stable
Versions
latest
stable
v0.10.2
v0.10.1
v0.10.0
v0.9.1
v0.9.0
v0.8.5
v0.8.4
v0.8.3
v0.8.2
v0.8.1
v0.8.0
v0.7.4
v0.7.3
v0.7.2
v0.7.1
v0.7.0
v0.6.0
v0.5.0
v0.4.0
v0.3.0
v0.2.0
Downloads
epub
On Read the Docs
Project Home
Builds

Free document hosting provided by Read the Docs.