首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Bernoulli样本的梯度

Bernoulli样本的梯度
EN

Stack Overflow用户
提问于 2017-01-31 23:46:53
回答 1查看 793关注 0票数 4

我试图从Bernoulli分布w.r.t计算样本的梯度。(样本为1的)概率p

我尝试使用tensorflow.contrib.distributions中提供的伯努利分布的实现和基于这个discussion的我自己的简单实现。然而,当我尝试计算梯度时,这两种方法都失败了。

使用Bernoulli实现:

代码语言:javascript
运行
复制
import tensorflow as tf
from tensorflow.contrib.distributions import Bernoulli

p = tf.constant([0.2, 0.6])
b = Bernoulli(p=p)
s = b.sample()
g = tf.gradients(s, p)

with tf.Session() as session:
    print(session.run(g))

上面的代码给出了以下错误:

代码语言:javascript
运行
复制
TypeError: Fetch argument None has invalid type <class 'NoneType'>

使用我的实现:

代码语言:javascript
运行
复制
import tensorflow as tf

p = tf.constant([0.2, 0.6])
shape = [1, 2]
s = tf.select(tf.random_uniform(shape) - p > 0.0, tf.ones(shape), tf.zeros(shape))
g = tf.gradients(s, p)

with tf.Session() as session:
    print(session.run(g))

同样的错误:

代码语言:javascript
运行
复制
TypeError: Fetch argument None has invalid type <class 'NoneType'>

有没有办法计算伯努利样本的梯度?

(我的TensorFlow版本是0.12)。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-01-07 22:26:36

由于显而易见的原因,您不能通过离散的随机节点进行支持。因为没有定义渐变。然而,如果你用一个由温度参数控制的连续分布来近似伯努利分布,是的,你可以。

这个想法被称为重新参数化技巧,并在Tensorflow Probability的RelaxedBernoulli中实现(或者也在TF.contrib库中实现)。

Relaxed bernoulli

你可以指定你的伯努利的概率p,这是你的随机变量,等等。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41961649

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档