Github项目推荐 | Pytorch TVM 扩展

2019 年 5 月 5 日 AI研习社

将TVM集成到PyTorch中。

* TVM:深度学习编译器


Github项目链接:

https://github.com/pytorch/tvm


构建

你需要在这个PR的基础上构建PyTorch:https://github.com/pytorch/pytorch/pull/18588

cd pytorchgit fetch origin pull/18588/head:tvm_devgit checkout tvm_devpython setup.py install

然后,你需要单独构建本仓库:

# Make sure the right llvm-config is in your PATHpython setup.py install

测试

python setup.py test

使用

这个包非常显然地挂钩到 PyTorch 的 JIT 中,因此适用相同的工具(可查看 @torch.jit.script,torch.jit.trace 和 graph_for)。以下是使用示例:

from tvm import relay # This imports all the topi operatorsimport torch_tvm
torch_tvm.enable()
# The following function will be compiled with TVM@torch.jit.scriptdef my_func(a, b, c): return a * b + c

如果要禁用JIT挂钩,请使用 torch_tvm.disable() 。

代码布局

  • register.cpp:设置pybind绑定并调用TVM后端的注册。

  • compiler.{h,cpp}:用TVM编译PyTorch JIT图的主要逻辑。

  • operators.{h,cpp}:从JIT IR映射到TVM操作符的位置。


TODO

  • 添加从Python中将不透明op名称的翻译注册到TVM中(如在operator.cpp中完成)的功能。

  • 零拷贝 set_input

  • 纾困机制(调用PyTorch JIT后备)

  • Threadpool 集成

  • 分配器集成

  • 操作符翻译

    • 卷积

    • BatchNorm

    • RELU

    • AveragePool

    • MaxPool

    • 线性

  • 张量操作

    • 重塑

    • 查看


备受大家期待的强化学习课程终于上线啦!

扫描下方邀请卡,解锁更多课时

点击 阅读原文,查看更多内容
登录查看更多
11

相关内容

还在修改博士论文?这份《博士论文写作技巧》为你指南
【陈天奇】TVM:端到端自动深度学习编译器,244页ppt
专知会员服务
86+阅读 · 2020年5月11日
Sklearn 与 TensorFlow 机器学习实用指南,385页pdf
专知会员服务
129+阅读 · 2020年3月15日
一网打尽!100+深度学习模型TensorFlow与Pytorch代码实现集合
【电子书】Flutter实战305页PDF免费下载
专知会员服务
22+阅读 · 2019年11月7日
【书籍】深度学习框架:PyTorch入门与实践(附代码)
专知会员服务
163+阅读 · 2019年10月28日
【电子书推荐】Data Science with Python and Dask
专知会员服务
43+阅读 · 2019年6月1日
Github 项目推荐 | 用 PyTorch 0.4 实现的 YoloV3
AI研习社
9+阅读 · 2018年8月11日
教程 | 如何通过PyTorch上手Tensor Comprehensions?
机器之心
5+阅读 · 2018年3月12日
推荐|深度学习PyTorch的教程代码
全球人工智能
10+阅读 · 2017年10月8日
推荐|TensorFlow/PyTorch/Sklearn实现的五十种机器学习模型
全球人工智能
24+阅读 · 2017年7月14日
Arxiv
7+阅读 · 2018年6月8日
Arxiv
8+阅读 · 2018年1月25日
VIP会员
Top
微信扫码咨询专知VIP会员