2021-02-21 21:24:53 +08:00
|
|
|
|
<div align="center">
|
|
|
|
|
<img src="https://raw.githubusercontent.com/open-mmlab/mmcv/master/docs/mmcv-logo.png" width="300"/>
|
|
|
|
|
</div>
|
|
|
|
|
|
2021-08-23 10:35:22 +08:00
|
|
|
|
[](https://pypi.org/project/mmcv/) [](https://pypi.org/project/mmcv) [](https://github.com/open-mmlab/mmcv/actions) [](https://codecov.io/gh/open-mmlab/mmcv) [](https://github.com/open-mmlab/mmcv/blob/master/LICENSE)
|
2021-02-21 21:24:53 +08:00
|
|
|
|
|
|
|
|
|
[English](README.md) | 简体中文
|
|
|
|
|
|
|
|
|
|
## 简介
|
|
|
|
|
|
|
|
|
|
MMCV 是一个面向计算机视觉的基础库,它支持了很多开源项目,例如:
|
|
|
|
|
|
2021-04-25 19:25:14 +08:00
|
|
|
|
- [MMClassification](https://github.com/open-mmlab/mmclassification): OpenMMLab 图像分类工具箱
|
|
|
|
|
- [MMDetection](https://github.com/open-mmlab/mmdetection): OpenMMLab 目标检测工具箱
|
|
|
|
|
- [MMDetection3D](https://github.com/open-mmlab/mmdetection3d): OpenMMLab 新一代通用 3D 目标检测平台
|
|
|
|
|
- [MMSegmentation](https://github.com/open-mmlab/mmsegmentation): OpenMMLab 语义分割工具箱
|
|
|
|
|
- [MMAction2](https://github.com/open-mmlab/mmaction2): OpenMMLab 新一代视频理解工具箱
|
|
|
|
|
- [MMTracking](https://github.com/open-mmlab/mmtracking): OpenMMLab 一体化视频目标感知平台
|
|
|
|
|
- [MMPose](https://github.com/open-mmlab/mmpose): OpenMMLab 姿态估计工具箱
|
|
|
|
|
- [MMEditing](https://github.com/open-mmlab/mmediting): OpenMMLab 图像视频编辑工具箱
|
|
|
|
|
- [MMOCR](https://github.com/open-mmlab/mmocr): OpenMMLab 全流程文字检测识别理解工具包
|
|
|
|
|
- [MMGeneration](https://github.com/open-mmlab/mmgeneration): OpenMMLab 图片视频生成模型工具箱
|
2021-02-21 21:24:53 +08:00
|
|
|
|
|
|
|
|
|
MMCV 提供了如下众多功能:
|
|
|
|
|
|
|
|
|
|
- 通用的 IO 接口
|
|
|
|
|
- 图像和视频处理
|
|
|
|
|
- 图像和标注结果可视化
|
|
|
|
|
- 常用小工具(进度条,计时器等)
|
|
|
|
|
- 基于 PyTorch 的通用训练框架
|
|
|
|
|
- 多种 CNN 网络结构
|
|
|
|
|
- 高质量实现的常见 CUDA 算子
|
|
|
|
|
|
|
|
|
|
如想了解更多特性和使用,请参考[文档](http://mmcv.readthedocs.io/en/latest)。
|
|
|
|
|
|
|
|
|
|
提示: MMCV 需要 Python 3.6 以上版本。
|
|
|
|
|
|
|
|
|
|
## 安装
|
|
|
|
|
|
|
|
|
|
MMCV 有两个版本:
|
|
|
|
|
|
|
|
|
|
- **mmcv-full**: 完整版,包含所有的特性以及丰富的开箱即用的 CUDA 算子。注意完整版本可能需要更长时间来编译。
|
2021-04-25 19:25:14 +08:00
|
|
|
|
- **mmcv**: 精简版,不包含 CUDA 算子但包含其余所有特性和功能,类似 MMCV 1.0 之前的版本。如果你不需要使用 CUDA 算子的话,精简版可以作为一个考虑选项。
|
2021-02-21 21:24:53 +08:00
|
|
|
|
|
2021-04-25 19:25:14 +08:00
|
|
|
|
**注意**: 请不要在同一个环境中安装两个版本,否则可能会遇到类似 `ModuleNotFound` 的错误。在安装一个版本之前,需要先卸载另一个。`如果CUDA可用,强烈推荐安装mmcv-full`。
|
2021-02-21 21:24:53 +08:00
|
|
|
|
|
2021-04-25 19:25:14 +08:00
|
|
|
|
a. 安装完整版
|
2021-02-21 21:24:53 +08:00
|
|
|
|
|
|
|
|
|
在安装 mmcv-full 之前,请确保 PyTorch 已经成功安装在环境中,可以参考 PyTorch 官方[文档](https://pytorch.org/)。
|
|
|
|
|
|
|
|
|
|
我们提供了不同 PyTorch 和 CUDA 版本的 mmcv-full 预编译包,可以大大简化用户安装编译过程。强烈推荐通过预编译包来安装。
|
|
|
|
|
|
|
|
|
|
i. 安装最新版本
|
|
|
|
|
|
|
|
|
|
如下是安装最新版 ``mmcv-full`` 的命令
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
pip install mmcv-full -f https://download.openmmlab.com/mmcv/dist/{cu_version}/{torch_version}/index.html
|
|
|
|
|
```
|
|
|
|
|
|
2021-07-20 17:18:28 +08:00
|
|
|
|
请将链接中的 ``{cu_version}`` 和 ``{torch_version}`` 根据自身需求替换成实际的版本号,例如想安装和 ``CUDA 11.1``、``PyTorch 1.9.0`` 兼容的最新版 ``mmcv-full``,使用如下替换过的命令
|
2021-02-21 21:24:53 +08:00
|
|
|
|
|
|
|
|
|
```shell
|
2021-07-20 17:18:28 +08:00
|
|
|
|
pip install mmcv-full -f https://download.openmmlab.com/mmcv/dist/cu111/torch1.9.0/index.html
|
2021-02-21 21:24:53 +08:00
|
|
|
|
```
|
|
|
|
|
|
2021-10-13 20:25:49 +08:00
|
|
|
|
注意: PyTorch 在 1.x.0 和 1.x.1 之间通常是兼容的,故 mmcv-full 只提供 1.x.0 的编译包。如果你的 PyTorch 版本是 1.x.1,你可以放心地安装在 1.x.0 版本编译的 mmcv-full。例如,如果你的 PyTorch 版本是 1.8.1、CUDA 版本是 11.1,你可以使用以下命令安装 mmcv-full。
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
pip install mmcv-full -f https://download.openmmlab.com/mmcv/dist/cu111/torch1.8.0/index.html
|
|
|
|
|
```
|
|
|
|
|
|
2021-02-21 21:24:53 +08:00
|
|
|
|
如果想知道更多 CUDA 和 PyTorch 版本的命令,可以参考下面的表格,将链接中的 ``=={mmcv_version}`` 删去即可。
|
|
|
|
|
|
|
|
|
|
ii. 安装特定的版本
|
|
|
|
|
|
|
|
|
|
如下是安装特定版本 ``mmcv-full`` 的命令
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/{cu_version}/{torch_version}/index.html
|
|
|
|
|
```
|
|
|
|
|
|
2021-07-20 17:18:28 +08:00
|
|
|
|
首先请参考版本发布信息找到想要安装的版本号,将 ``{mmcv_version}`` 替换成该版本号,例如 ``1.3.9``。
|
|
|
|
|
然后将链接中的 ``{cu_version}`` 和 ``{torch_version}`` 根据自身需求替换成实际的版本号,例如想安装和 ``CUDA 11.1``、``PyTorch 1.9.0`` 兼容的 ``mmcv-full`` 1.3.9 版本,使用如下替换过的命令
|
2021-02-21 21:24:53 +08:00
|
|
|
|
|
|
|
|
|
```shell
|
2021-07-20 17:18:28 +08:00
|
|
|
|
pip install mmcv-full==1.3.9 -f https://download.openmmlab.com/mmcv/dist/cu111/torch1.9.0/index.html
|
2021-02-21 21:24:53 +08:00
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
对于更多的 PyTorch 和 CUDA 版本组合,请参考下表:
|
|
|
|
|
|
|
|
|
|
<table class="docutils">
|
|
|
|
|
<tbody>
|
|
|
|
|
<tr>
|
|
|
|
|
<th width="80"> CUDA </th>
|
2021-07-20 17:18:28 +08:00
|
|
|
|
<th valign="bottom" align="left" width="100">torch 1.9</th>
|
2021-03-28 14:04:24 +08:00
|
|
|
|
<th valign="bottom" align="left" width="100">torch 1.8</th>
|
2021-02-21 21:24:53 +08:00
|
|
|
|
<th valign="bottom" align="left" width="100">torch 1.7</th>
|
|
|
|
|
<th valign="bottom" align="left" width="100">torch 1.6</th>
|
|
|
|
|
<th valign="bottom" align="left" width="100">torch 1.5</th>
|
|
|
|
|
<th valign="bottom" align="left" width="100">torch 1.4</th>
|
|
|
|
|
<th valign="bottom" align="left" width="100">torch 1.3</th>
|
|
|
|
|
</tr>
|
2021-03-28 14:04:24 +08:00
|
|
|
|
<tr>
|
|
|
|
|
<td align="left">11.1</td>
|
2021-07-20 17:18:28 +08:00
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code>pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu111/torch1.9.0/index.html</code></pre> </details> </td>
|
2021-03-28 14:04:24 +08:00
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code>pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu111/torch1.8.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"> </td>
|
|
|
|
|
<td align="left"> </td>
|
|
|
|
|
<td align="left"> </td>
|
|
|
|
|
<td align="left"> </td>
|
|
|
|
|
<td align="left"> </td>
|
|
|
|
|
</tr>
|
2021-02-21 21:24:53 +08:00
|
|
|
|
<tr>
|
|
|
|
|
<td align="left">11.0</td>
|
2021-03-28 14:04:24 +08:00
|
|
|
|
<td align="left"> </td>
|
2021-07-20 17:18:28 +08:00
|
|
|
|
<td align="left"> </td>
|
2021-02-21 21:24:53 +08:00
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code>pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu110/torch1.7.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"> </td>
|
|
|
|
|
<td align="left"> </td>
|
|
|
|
|
<td align="left"> </td>
|
|
|
|
|
<td align="left"> </td>
|
|
|
|
|
</tr>
|
|
|
|
|
<tr>
|
|
|
|
|
<td align="left">10.2</td>
|
2021-07-20 17:18:28 +08:00
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code>pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu102/torch1.9.0/index.html</code></pre> </details> </td>
|
2021-03-28 14:04:24 +08:00
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code>pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu102/torch1.8.0/index.html</code></pre> </details> </td>
|
2021-02-21 21:24:53 +08:00
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code>pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu102/torch1.7.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code>pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu102/torch1.6.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code>pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu102/torch1.5.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"> </td>
|
|
|
|
|
<td align="left"> </td>
|
|
|
|
|
</tr>
|
|
|
|
|
<tr>
|
|
|
|
|
<td align="left">10.1</td>
|
2021-07-20 17:18:28 +08:00
|
|
|
|
<td align="left"> </td>
|
2021-03-28 14:04:24 +08:00
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code> pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu101/torch1.8.0/index.html</code></pre> </details> </td>
|
2021-02-21 21:24:53 +08:00
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code> pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu101/torch1.7.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code> pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu101/torch1.6.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code> pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu101/torch1.5.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code>pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu101/torch1.4.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code>pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu101/torch1.3.0/index.html</code></pre> </details> </td>
|
|
|
|
|
</tr>
|
|
|
|
|
<tr>
|
|
|
|
|
<td align="left">9.2</td>
|
2021-03-28 14:04:24 +08:00
|
|
|
|
<td align="left"> </td>
|
2021-07-20 17:18:28 +08:00
|
|
|
|
<td align="left"> </td>
|
2021-02-21 21:24:53 +08:00
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code> pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu92/torch1.7.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code> pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu92/torch1.6.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code> pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu92/torch1.5.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code>pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu92/torch1.4.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code>pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cu92/torch1.3.0/index.html</code></pre> </details> </td>
|
|
|
|
|
</tr>
|
|
|
|
|
<tr>
|
|
|
|
|
<td align="left">cpu</td>
|
2021-09-07 17:32:11 +08:00
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code> pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cpu/torch1.9.0/index.html</code></pre> </details> </td>
|
2021-03-28 14:04:24 +08:00
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code> pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cpu/torch1.8.0/index.html</code></pre> </details> </td>
|
2021-02-21 21:24:53 +08:00
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code> pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cpu/torch1.7.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code> pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cpu/torch1.6.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code> pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cpu/torch1.5.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code>pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cpu/torch1.4.0/index.html</code></pre> </details> </td>
|
|
|
|
|
<td align="left"><details><summary> 安装 </summary><pre><code>pip install mmcv-full=={mmcv_version} -f https://download.openmmlab.com/mmcv/dist/cpu/torch1.3.0/index.html</code></pre> </details> </td>
|
|
|
|
|
</tr>
|
|
|
|
|
</tbody>
|
|
|
|
|
</table>
|
|
|
|
|
|
|
|
|
|
除了使用预编译包之外,另一种方式是在本地进行编译,直接运行下述命令
|
|
|
|
|
|
|
|
|
|
```python
|
|
|
|
|
pip install mmcv-full
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
但注意本地编译可能会耗时 10 分钟以上。
|
|
|
|
|
|
2021-04-25 19:25:14 +08:00
|
|
|
|
b. 安装精简版
|
|
|
|
|
|
|
|
|
|
```python
|
|
|
|
|
pip install mmcv
|
|
|
|
|
```
|
|
|
|
|
|
2021-02-21 21:24:53 +08:00
|
|
|
|
c. 安装完整版并且编译 onnxruntime 的自定义算子
|
|
|
|
|
|
2021-07-07 13:09:04 +08:00
|
|
|
|
- 详细的指南请查看 [这里](docs/deployment/onnxruntime_op.md)。
|
2021-02-21 21:24:53 +08:00
|
|
|
|
|
2021-07-07 13:09:04 +08:00
|
|
|
|
如果想从源码编译 MMCV,请参考[该文档](https://mmcv.readthedocs.io/en/latest/get_started/build.html)。
|
2021-02-21 21:24:53 +08:00
|
|
|
|
|
|
|
|
|
## FAQ
|
|
|
|
|
|
2021-07-07 13:09:04 +08:00
|
|
|
|
如果你遇到了安装问题,CUDA 相关的问题或者 RuntimeErrors,可以首先参考[问题解决页面](https://mmcv.readthedocs.io/en/latest/faq.html) 看是否已经有解决方案。
|
2021-02-21 21:24:53 +08:00
|
|
|
|
|
|
|
|
|
## 贡献指南
|
|
|
|
|
|
|
|
|
|
我们感谢所有的贡献者为改进和提升 MMCV 所作出的努力。请参考[贡献指南](CONTRIBUTING.md)来了解参与项目贡献的相关指引。
|
2021-04-16 21:22:51 +08:00
|
|
|
|
|
2021-05-13 21:55:44 +08:00
|
|
|
|
## 许可证
|
|
|
|
|
|
|
|
|
|
`MMCV` 目前以 Apache 2.0 的许可证发布,但是其中有一部分功能并不是使用的 Apache2.0 许可证,我们在 [许可证](LICENSES.md) 中详细地列出了这些功能以及他们对应的许可证,如果您正在从事盈利性活动,请谨慎参考此文档。
|
2021-04-16 21:22:51 +08:00
|
|
|
|
## 欢迎加入 OpenMMLab 社区
|
|
|
|
|
|
2021-10-13 20:25:49 +08:00
|
|
|
|
扫描下方的二维码可关注 OpenMMLab 团队的 [知乎官方账号](https://www.zhihu.com/people/openmmlab),加入 OpenMMLab 团队的 [官方交流 QQ 群](https://jq.qq.com/?_wv=1027&k=GJP18SjI)
|
2021-04-16 21:22:51 +08:00
|
|
|
|
|
|
|
|
|
<div align="center">
|
|
|
|
|
<img src="docs/_static/zhihu_qrcode.jpg" height="400" /> <img src="docs/_static/qq_group_qrcode.jpg" height="400" />
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
我们会在 OpenMMLab 社区为大家
|
|
|
|
|
|
|
|
|
|
- 📢 分享 AI 框架的前沿核心技术
|
|
|
|
|
- 💻 解读 PyTorch 常用模块源码
|
|
|
|
|
- 📰 发布 OpenMMLab 的相关新闻
|
|
|
|
|
- 🚀 介绍 OpenMMLab 开发的前沿算法
|
|
|
|
|
- 🏃 获取更高效的问题答疑和意见反馈
|
|
|
|
|
- 🔥 提供与各行各业开发者充分交流的平台
|
|
|
|
|
|
|
|
|
|
干货满满 📘,等你来撩 💗,OpenMMLab 社区期待您的加入 👬
|