资源 | 清华大学发布珠算:一个用于生成模型的Python库

2017 年 5 月 9 日 机器之心

选自Github

机器之心编译

参与:吴攀


5 月 27-28 日,机器之心主办的第一届全球机器智能峰会(GMIS 2017)将在北京 898 创新空间举行。在峰会第一天下午的「机器学习」主题 Session 上,清华大学副教授朱军将分享演讲《珠算:贝叶斯深度学习的 GPU 库(ZhuSuan: a GPU Library with Bayesian Deep Learning)》。近日,清华大学机器学习组已经在 GitHub 上发布了「珠算(ZhuSuan)」这一软件库。机器之心在本文中编译介绍了该项目的介绍文档,如果你想现场聆听对该项目的更详细深入的介绍,可访问 GMIS 官网 gmis.jiqizhixin.com 了解参会方式或点击文末「阅读原文」直达购票地址。


  • 珠算项目地址:https://github.com/thu-ml/zhusuan

  • 朱军教授 GMIS 2017演讲时间:5 月 27 日 14:10-14:30

  • 演讲主题:珠算:贝叶斯深度学习的 GPU 库


珠算(ZhuSuan)是一个构建于 TensorFlow 之上的用于生成模型(Generative Model)的 Python 库。和现有的主要为监督式任务设计的深度学习库不同,珠算的特点是其在很大程度上根基于贝叶斯推理(Bayesian Inference),因此支持各种生成模型:既包括传统的分层贝叶斯模型,也有最近的深度生成模型。


使用珠算,用户可以享有深度学习的强大拟合能力和多 GPU 训练支持,同时还能通过执行原理上的贝叶斯推理来使用生成模型建模这个复杂的世界、利用无标注数据和处理不确定性。


支持的推理


变分推理和随机变分推理(VI & SVI)


  • 支持多种变分后验:


  • 平均场后验(Mean-field posterior):全因素分解

  • 有结构的后验(Structured posterior):具有用户指定的依赖关系


  • 支持的变分目标:


  • SGVB:随机梯度变分贝叶斯(Stochastic gradient variational Bayes)

  • IWAE:重要程度加权的目标(Importance weighted objectives)

  • NVIL:具有方差减缩的得分函数估计器(Score function estimator with variance reduction)

  • VIMCO:具有方差减缩的多样本得分函数估计器(Multi-sample score function estimator with variance reduction)


自适应重要程度采样


  • 重新加权的唤醒-睡眠(RWS:Reweighted Wake-sleep):带有用户指定的自适应提议


马尔可夫链蒙特卡洛(MCMC)


  • 哈密尔顿蒙特卡洛(HMC):带有步长和 mass adaptation


安装


珠算仍处在开发阶段。在第一个稳定版(1.0)发布之前,请在主目录中运行以下代码来克隆这个库:


pip install .


这会自动安装珠算及其依赖包。


如果你正在开发珠算,你可能需要以「可编辑」或「开发」模式进行安装。具体参见下面的开发一节。


文档


在线文档地址:http://zhusuan.readthedocs.io/


示例


如果你想运行我们提供的示例,你需要安装额外的依赖包。可以通过执行以下代码完成:


  • pip install ".[examples]"

  • 高斯(Gaussian):HMC

  • Toy 2D Intractable Posterior: SGVB

  • 贝叶斯神经网络:SGVB

  • 变自编码器(VAE):SGVB、IWAE

  • 卷积 VAE:SGVB

  • 半监督 VAE(Kingma, 2014:SGVB、RWS

  • 深度 Sigmoid 信念网络:RWS、VIMCO

  • Logistic Normal 主题模型:HMC


开发


如果要以「可编辑」或「开发」模式安装珠算,在主目录下运行:


pip install -e .


如果要移除安装,运行:


pip uninstall zhusuan


附加的开发用依赖包可通过以下代码安装:


pip install ".[dev]"


1.测试


以下命令可在主目录中运行自动测试:


python -m unittest discover -v


测试范围:在运行测试之后,为了确保测试范围涵盖开发,请运行


coverage report --include="zhusuan/*"


PEP8 代码风格检查:我们遵循 PEP8 Python 代码风格。要进行检查,在主目录中运行


pep8 .


2.文档


文档在 docs/ 目录下,是 RestructuredText(.rst)文件。主页为 index.rst。关于 RestructuredText 的教程可参阅:https://pythonhosted.org/an_example_pypi_project/sphinx.html


API References 是通过 Sphinx 自动生成的。它们在 doc/api/ 目录下,在每次修改代码之后都应该重新生成:


make api


在 docs/ 目录下运行以下代码可将文档编译成网页:


make html


生成的网页存储在 docs/_build 目录,可以通过浏览器查看。



点击阅读原文,报名参与机器之心 GMIS 2017 ↓↓↓

登录查看更多
1

相关内容

在机器学习中,生成模型可以用来直接对数据建模(例如根据某个变量的概率密度函数进行数据采样),也可以用来建立变量间的条件概率分布。条件概率分布可以由生成模型根据贝叶斯定理形成。
【2020新书】使用高级C# 提升你的编程技能,412页pdf
专知会员服务
58+阅读 · 2020年6月26日
干货书《数据科学数学系基础》2020最新版,266页pdf
专知会员服务
321+阅读 · 2020年3月23日
自回归模型:PixelCNN
专知会员服务
27+阅读 · 2020年3月21日
人工智能学习笔记,247页pdf
专知会员服务
185+阅读 · 2019年12月14日
【资源】元学习论文分类列表推荐
专知
19+阅读 · 2019年12月3日
盘一盘 Python 系列 10 - Keras (上)
平均机器
5+阅读 · 2019年8月26日
实验室3篇论文被IJCAI 2019录用
inpluslab
12+阅读 · 2019年5月11日
免费!Google Colab现已支持英伟达T4 GPU
新智元
5+阅读 · 2019年4月25日
TF Boys必看!一文搞懂TensorFlow 2.0新架构!
引力空间站
18+阅读 · 2019年1月16日
NLP预训练模型大集合
机器学习算法与Python学习
8+阅读 · 2018年12月28日
机器学习的Pytorch实现资源集合
专知
11+阅读 · 2018年9月1日
资源 | 清华大学开源OpenKE:知识表示学习平台
机器之心
10+阅读 · 2017年11月4日
A survey on deep hashing for image retrieval
Arxiv
14+阅读 · 2020年6月10日
Arxiv
4+阅读 · 2019年9月26日
Arxiv
3+阅读 · 2019年9月5日
A Probe into Understanding GAN and VAE models
Arxiv
9+阅读 · 2018年12月13日
Adaptive Neural Trees
Arxiv
4+阅读 · 2018年12月10日
Arxiv
23+阅读 · 2018年8月3日
Meta-Learning with Latent Embedding Optimization
Arxiv
6+阅读 · 2018年7月16日
VIP会员
相关VIP内容
相关资讯
【资源】元学习论文分类列表推荐
专知
19+阅读 · 2019年12月3日
盘一盘 Python 系列 10 - Keras (上)
平均机器
5+阅读 · 2019年8月26日
实验室3篇论文被IJCAI 2019录用
inpluslab
12+阅读 · 2019年5月11日
免费!Google Colab现已支持英伟达T4 GPU
新智元
5+阅读 · 2019年4月25日
TF Boys必看!一文搞懂TensorFlow 2.0新架构!
引力空间站
18+阅读 · 2019年1月16日
NLP预训练模型大集合
机器学习算法与Python学习
8+阅读 · 2018年12月28日
机器学习的Pytorch实现资源集合
专知
11+阅读 · 2018年9月1日
资源 | 清华大学开源OpenKE:知识表示学习平台
机器之心
10+阅读 · 2017年11月4日
相关论文
A survey on deep hashing for image retrieval
Arxiv
14+阅读 · 2020年6月10日
Arxiv
4+阅读 · 2019年9月26日
Arxiv
3+阅读 · 2019年9月5日
A Probe into Understanding GAN and VAE models
Arxiv
9+阅读 · 2018年12月13日
Adaptive Neural Trees
Arxiv
4+阅读 · 2018年12月10日
Arxiv
23+阅读 · 2018年8月3日
Meta-Learning with Latent Embedding Optimization
Arxiv
6+阅读 · 2018年7月16日
Top
微信扫码咨询专知VIP会员