zoukankan      html  css  js  c++  java
  • 置换检验

    显著性检验可以告诉我们某个观测值是否有效,,例如检测两组样本均值差异的假设检验可以告诉我们这两组样本的均值是否相等。由于一些因素的限制,我们一般得到的样本都是小样本,而我们想知道总体样本的分布,这时就需要置换检验。

    下面通过一个简单例子来介绍Permutation test的思想。

           假设我们设计了一个实验来验证加入某种生长素后拟南芥的侧根数量会明显增加。A组是加入某种生长素后,拟南芥的侧根数量;B是不加生长素时,拟南芥的侧根数量(均为假定值)。

    A组侧根数量(共12个数据):24 43 58 67 61 44 67 49 59 52 62 50

    B组侧根数量(共16个数据):42 43 65 26 33 41 19 54 42 20 17 60 37 42 55 28

            我们来用假设检验的方法来判断生长素是否起作用。我们的零假设为:加入的生长素不会促进拟南芥的根系发育。在这个检验中,若零假设成立,那么A组数据的分布和B组数据的分布是一样的,也就是服从同个分布。

    接下来构造检验统计量——A组侧根数目的均值同B组侧根数目的均值之差。

    statistic:= mean(Xa)-mean(Xb)

    对于观测值有 Sobs:=mean(Xa)-mean(Xb)=(24+43+58+67+61+44+67+49+59+52+62+50)/12-(42+43+65+26+33+41+19+54+42+20+17+60+37+42+55+28)/16=14

    我们可以通过Sobs在置换分布(permutation distribution)中的位置来得到它的P-value。

    Permutation test的具体步骤是:

    1.将A、B两组数据合并到一个集合中,从中挑选出12个作为A组的数据(X'a),剩下的作为B组的数据(X'b)。

    Gourp:=24 43 58 67 61 44 67 49 59 52 62 50 42 43 65 26 33 41 19 54 42 20 17 60 37 42 55 28

    挑选出 X'a:=43 17 44 62 60 26 28 61 50 43 33 19

    X'b:=55 41 42 65 59 24 54 52 42 49 37 67 67 20 42 58

    2.计算并记录第一步中A组同B组的均值之差。Sper:=mean(X'a)-mean(X'b)= -7.875

    3.对前两步重复999次(重复次数越多,得到的背景分布越”稳定“)

    这样我们得到有999个置换排列求得的999个Sper结果,这999个Sper结果能代表拟南芥小样本实验的抽样总体情况。

    permutation test

    如上图所示,我们的观测值 Sobs=14 在抽样总体右尾附近,说明在零假设条件下这个数值是很少出现的。在permutation得到的抽样总体中大于14的数值有9个,所以估计的P-value是9/999=0.01

    最后还可以进一步精确P-value结果(做一个抽样总体校正),在抽样总体中加入一个远大于观测值 Sobs=14的样本,最终的P-value=(9+1)/(999+1)=0.01。(为什么这样做是一个校正呢?自己思考:))

    P<0.05,结果表明我们的原假设不成立,加入生长素起到了促使拟南芥的根系发育的作用。

  • 相关阅读:
    最新版Butterknife plugin支持butterknife7.0.1和兼容butterknife 6.1.0及下面
    Cocos2D中Action的进阶使用技巧(一)
    开源库Fab-Transformation简单使用解析
    tip of Firefox extention foxyproxy
    jQuery树形菜单,使用zTree插件,异步载入 &amp; 编辑功能&amp;Check 共存
    创建数据库以及其属性的sql语句
    Node.js开发入门—使用AngularJS
    自己动手写shell命令之ls
    剑指 | 7-利用两个栈构建一个队列
    css3使用transform属性制作js弹性运动
  • 原文地址:https://www.cnblogs.com/flightless/p/10229866.html
Copyright © 2011-2022 走看看