0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

探索A/B测试的贝叶斯方法背后的理论

zhKF_jqr_AI 来源:未知 作者:李倩 2018-08-14 09:40 次阅读

编者按:和Google产品分析Zlatan Kremonic一起探索A/B测试的贝叶斯方法背后的理论。

本文将探索A/B测试的贝叶斯方法背后的理论。这一方法最近得到了广泛认同,并在一些情形下取代了流行的频率方法。在讲述理论之后,我们将查看一个实例。

频率统计

频率统计以收集数据、测试假设这一传统方法为中心。频率统计分为以下步骤:

形式化假设。

收集数据。

计算基本的测试统计,包括p值和置信区间。

决定是否驳回零假设(null hypothesis)。

频率统计的重要假定是参数是确定的,不过我们并不知晓。我们接下来收集的数据是那些参数及其分布的一个函数。用数学可以表达为:

其中X是数据样本,θ是零假设下的数据分布,戴帽θ是观测到的参数。

总结科研报告的数据时,这一方法非常有用。置信区间的应用为我们提供了非常直观地理解观测到的参数的方式。不过,这一频率方法有一些缺陷:

当我们发现p值明显增加时,较早停止测试会增加得到假阳性结果的几率。

我们无法测量研究结论为真的概率。

p值容易被误解。

试验必须全部事先指定,这可能导致看起来自相矛盾的结果。

多臂老虎机问题

在我们跳到贝叶斯推理之前,先在一个有用(且经典)的场景下考察我们的问题,这很重要。在多臂老虎机问题中,我们在一家赌场玩老虎机。给定不是所有的老虎机返水率相同这一条件,如果我们同时玩两台老虎机,我们将开始发现两台老虎机的结果不同。这导致了“探索v.s.利用困境”,迫使我们决定到底是利用高返水的机器,还是探索(随机)选项以收集更多数据。不管我们选择利用的程度如何,我们都在让我们的行为适应观测数据,这正是强化学习的一般假定之一。我们的目标是通过提高我们正做出正确决策的确定性,最大化返水,最小化损失。

处理多臂老虎机问题有很多策略,包括Epsilon-Greedy算法和UCB1算法,不过,也该让贝叶斯推理出场了。

贝叶斯统计

贝叶斯统计以贝叶斯定理为中心:

在我们试图得出关于给定数据集的参数的结论的科研问题中,我们可以将参数视作随机变量(有自己的分布):

这里,

P(θ|X)称为后验,意为给定数据X,关于参数θ的新信念。

P(X|θ)称为似然,回答给定当前参数θ有多大可能观测到我们的数据。

P(θ)是先验,意为我们关于θ的旧信念。

P(X)是P(X|θ)P(θ)dθ的积分,但因为它并不包含θ,可以直接忽略这一点,将它作为一个归一化常量。

现在我们看到了贝叶斯范式转变。和频率方法不同,这里我们收集数据的前后都考虑到了参数的分布。知晓参数的分布让我们可以给参数估计分配给定的置信度。

但我们如何知晓后验分布呢?答案在“共轭先验”这一概念之中:如果先验概率分布和后验概率分布同属一个家族,那么它们称为共轭分布,且先验称为似然函数的共轭先验。简单来说,如果我们知道似然函数的分布,我们就可以确定后验和先验的分布。

让我们来看一个例子,假设我们正测量点击率(某人是否点击一则广告)。因为我们测量的是二值输出(点击、没点击),所以我们处理的是伯努利分布,这意味着似然为:

伯努利分布的共轭先验是贝塔分布:

其中B(a, b)为贝塔函数。

我们需要求解后验,首先结合似然和后验:

上式可以简化为:

因此,我们可以看到,事实上P(θ|X)确实属于贝塔分布,只不过超参数略有变动。由此我们得到:

其中,

在我们的点击率问题中,a' = a + 点击数,b' = b + 未点击数。

直觉上,这很合理。因为它告诉我们,后验分布是收集数据的函数,且后验分布可以用作更多样本的先验,其中的超参数直接加上新得到的额外信息

进一步查看下贝塔分布,我们注意到这一分布的均值为:

这和最大化似然时得到的值相同。最后,当a和b增加时,贝塔分布的方差递减,可类比频率方法中置信区间的表现:

例子:汤普森采样

在这个例子中,我们将演示如何使用汤普森采样基于贝叶斯推理解决多臂老虎机问题。我们将使用2000次测试,而三臂的返水率为0.2、0.5、0.75. 首先,我们定义具有给定概率的Bandit(老虎机)类。该类提供一个pull(拉)方法,基于其概率返回奖励或损失(1或0)。我们也能更新a、b,并使用这些值从所得贝塔分布中取样。

importmatplotlib.pyplotasplt

importnumpyasnp

fromscipy.statsimportbeta

NUM_TRIALS =2000

BANDIT_PROBABILITIES = [0.2,0.5,0.75]

classBandit(object):

def__init__(self, p):

self.p = p

self.a =1

self.b =1

defpull(self):

return1ifnp.random.random() < self.pelse0

defsample(self):

returnnp.random.beta(self.a, self.b)

defupdate(self, x):

self.a += x

self.b +=1- x

下面,我们将定义一个函数绘制老虎机的贝塔分布:

defplot(bandits, trial):

x = np.linspace(0,1,200)

forbinbandits:

y = beta.pdf(x, b.a, b.b)

plt.plot(x, y, label="real p: %.4f"% b.p)

plt.title("Bandit distributions after %s trials"% trial)

plt.legend()

plt.show()

现在,开始我们的试验。首先,我们初始化三台老虎机。我们将根据预先确定的sample_points绘制它们的分布。每次测试时,我们从每台老虎机的分布中取样,并选择返水率最高的老虎机。被选中的老虎机将有机会拉动它的拉杆,进而更新其a、b值。

defexperiment():

bandits = [Bandit(p)forpinBANDIT_PROBABILITIES]

sample_points = [5,50,100,500,1999]

foriinxrange(NUM_TRIALS):

# 从每个老虎机取样

bestb =None

maxsample = -1

allsamples = []# 收集这些数据以便调试时打印

forbinbandits:

sample = b.sample()

allsamples.append("%.4f"% sample)

ifsample > maxsample:

maxsample = sample

bestb = b

ifiinsample_points:

print"current samples: %s"% allsamples

plot(bandits, i)

# 拉动样本最大的老虎机的拉杆

x = bestb.pull()

# 更新刚刚拉动拉杆的老虎机的分布

bestb.update(x)

调用experiment()函数可以进行测试。

测试5次后

测试50次后

测试100次后

测试500次后

测试1999次后

从试验中,我们可以观察到一些有趣的东西。我们注意到每个分布的均值逐渐向真值收敛。不过我们看到,高返水的老虎机的方差最低,这反映了它具有最高的N。然而,这未必是一个问题,因为最后返水最高的分布和其他两个较低的分布几乎没有重叠的部分,这意味着从较差的老虎机取样将产生较高返水的概率是最小的。

结果概率

基于汤普森采样的贝叶斯推断的另一优势是我们可以计算给定结果优于替代选择的概率。例如,如果我们正测量两个竞争页面的点击率,期望回报将是后验分布的均值。那么,给定均值高于另一均值的概率,可以通过计算两者的联合概率分布函数之下的面积得到。假设均值二高于均值一,则:

结论

就A/B测试问题而言,贝叶斯推理和频率方法之间没有明显的赢家,在选择一种方法之前最好首先评估场景。参考链接部分的最后一个链接提供了关于何处适用老虎机测试(包括汤普森采样)的一些要领。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 贝叶斯
    +关注

    关注

    0

    文章

    77

    浏览量

    12579
  • 数据集
    +关注

    关注

    4

    文章

    1208

    浏览量

    24726

原文标题:基于汤普森采样的贝叶斯A/B测试

文章出处:【微信号:jqr_AI,微信公众号:论智】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    常用的分类方法:朴素

    统计学习方法朴素
    发表于 11-05 09:24

    对朴素算法的理解

    我对朴素算法的理解
    发表于 05-15 14:13

    使用PyMC3包实现线性回归

    1、如何使用PyMC3包实现线性回归  PyMC3(现在简称为PyMC)是一个建模包
    发表于 10-08 15:59

    基于应变模态和方法的杆件损伤识别

    基于应变模态和方法的杆件损伤识别 提出了一种基于空间杆系结构应变模态和
    发表于 10-24 15:02 15次下载

    网络精确推理算法的研究

    网络是以概率理论为基础的不确定知识表示模型,
    发表于 08-15 09:34 38次下载

    算法(bayesian)介绍

    是基于概率的一种算法,是Thomas Bayes:一位伟大的数学大师所创建的。
    发表于 06-01 17:58 0次下载

    基于压缩感知理论的超宽带通信信道估计

    基于压缩感知理论的超宽带通信信道估计_王蔚东
    发表于 01-07 16:00 0次下载

    网络分析

    网络
    发表于 03-31 10:40 2次下载

    如何理解公式

    前言 大家经常看到的公式(Bayes)是写成如下图的形式,通常以P(A|B),P(B|
    发表于 02-02 14:13 3928次阅读
    如何理解<b class='flag-5'>贝</b><b class='flag-5'>叶</b><b class='flag-5'>斯</b>公式

    基于概率的常见的分类方法--朴素

    本文介绍机器学习中一种基于概率的常见的分类方法,朴素,之前介绍的KNN, decision tree 等方法是一种 hard deci
    的头像 发表于 02-03 14:37 5243次阅读
    基于概率的常见的分类<b class='flag-5'>方法</b>--朴素<b class='flag-5'>贝</b><b class='flag-5'>叶</b><b class='flag-5'>斯</b>

    朴素NB经典案例

    分类算法是统计学的一种分类方法,其分类原理就是利用
    发表于 02-28 10:17 2次下载

    统计的一个实践案例让你更快的对算法有更多的了解

    为了大家可以对算法有更多的了解,为大家整理过一篇关于算法的文章。今天将为大家介绍利用
    的头像 发表于 07-16 17:15 1.5w次阅读

    一文秒懂优化/Bayesian Optimization

    ,大神/优化专家们求轻喷,觉得不错的记得帮点赞/在看/转发帮扩散哦!谢谢。 梳理这个问题有这么两个原因: 1、在工业界,最近我看到不少同学在探索并使用
    的头像 发表于 04-09 11:26 1.7w次阅读
    一文秒懂<b class='flag-5'>贝</b><b class='flag-5'>叶</b><b class='flag-5'>斯</b>优化/Bayesian Optimization

    朴素分类 朴素算法的优点

    朴素方法是在算法的基础上进行了相应的简化
    的头像 发表于 10-02 17:14 9346次阅读

    滤波和卡尔曼滤波的区别

    滤波和卡尔曼滤波是两种常用的滤波方法,它们在信号处理、导航、机器人定位等领域有着广泛的应用。
    的头像 发表于 08-01 15:25 696次阅读