PSTAT 115 Homework4 课业解析
PSTAT 115 Homework4 课业解析
题意:
蒙特卡洛采样之拒绝采样
解析:
给定一个概率分布p(z)=p~(z)/Zp,p~(z)已知,Zp为归一化常数,为未知数。对该分布进行拒绝采样,我们引入一个简单地参考分布,记作q(x),q(x)分布的采样是易于实现的,比如均匀分布。再引入一个常数k,满足kq(z)>p~(z)。每次采样中首先从q(z)采样一个数值z0,然后在区间[0,kq(z0)]进行均匀采样,得到u0。如果u0<p~(z0),则保留该采样值,否则丢弃该采样值。最后得到的数据就是一个对该分布的近似采样。为了提高接受效率,防止舍弃过多的采样值而导致采样效率低下,k值应该满足在kq(z)>p~(z)的基础上尽可能小。
涉及知识点:
拒绝采样
更多可+薇❤讨论:Rainbow890722
Homework 4
PSTAT 115, Fall 2019
Due on November 3, 2019 at 11:59 pm
Note: If you are working with a partner, please submit only one homework per group with both names
and whether you are taking the course for graduate credit or not. Submit your Rmarkdown (.Rmd) and the
compiled pdf on Gauchospace.
1. Rejection Sampling the Beta distribution. Assume we did not have access to the rbeta function for
sampling from a Beta, but we were able to evaluate the density, dbeta. This is a very common setting
in Bayesian statistics, since we can always evaluate the (proportional) posterior density p(θ | y) ∝ p(y |
θ)p(θ) but we don’t have immediate access to a method for sampling from this distribution.
(a) Let p(x) be a Beta(3, 9) density, q1(x) a Uniform(0, 1) density, and q2(x) a Normal(µ = 0.25, σ =
0.15) density.
(b) Use rejection sampling to sample from p(x) by proposing samples from q1(x). To do so, first find
M1 = max
x
p(x)/q1(x) using the optimize function and set lower=0, upper=1, and maximum =
TRUE (since we are maximizing not minimizing, the default). M will be the value in the objective
argument returned by optimize (maximum tells us where the maximum occurs, but not what height
it achieves). Propose 10000 samples and keep only the accepted samples.
(c) Use rejection sampling to sample from p(x) by proposing samples from q2(x). To do this you
need to find M2 = max
x
p(x)/q2(x) as above. Propose 10000 samples and keep only the accepted
samples.
(d) Plot the p(x), M1q1(x) and M2q2(x) all on the same plot and verify visually that the scaled
proposal densities “envelope” the target, p(x). Set the xlimits of the plot from 0 to 1. Use different
color lines for the various densities so are clearly distinguishable.
(e) Which rejection sampler had the higher rejection rate? Why does this make sense given the plot
from the previous part? This means when proposing 10000 samples from each proposal, the Monte
Carlo error of our approximation will be higher when proposing from ____ (choose q1 or q2).
(f) Report the variance of Beta(3, 9) distribution by computing the variance of the beta samples. How
does this compare to the theoretical variance (refer to the probability cheatsheet).
2. Interval estimation with rejection sampling.
(a) Use rejection sampling to sample from the following density:
p(x) = 1
4
|sin(x)| × I{x ∈ [0, 2π]}
Use a proposal density which is uniform from 0 to 2π and generate at least 1000 true samples from
p(x). Compute and report the Monte Carlo estimate of the upper and lower bound for the 50%
quantile interval using the quantile function on your samples. Compare this to the 50% HPD
region calculated on the samples. What are the bounds on the HPD region? Report the length of
the quantile interval and the total length of the HPD region. What explains the difference? Hint:
to compute the HPD use the hdi function from the HDInterval package. As the first argument
pass in density(samples), where samples is the name of your vector of true samples from the
density. Set the allowSplit argument to true and use the credMass argument to set the total
probability mass in the HPD region to 50%.
(b) Plot p(x) using the curve function (base plotting) or stat_function (ggplot). Add lines corresponding to the intervals / probability regions computed in the previous part to your plot using
1
them segments function (base plotting) or geom_segements (ggplot). To ensure that the lines
don’t overlap visually, for the HPD region set the y-value of the segment to 0 and for the quantile
interval set the y-value to to 0.01. Make the segments for HPD region and the segment for quantile
interval different colors. Report the length of the quantile interval and the total length of the HPD
region, verifying that indeed the HPD region is smaller.
PSTAT 115 Homework4 课业解析的更多相关文章
- android中使用DisplayMetrics获取屏幕参数
--关于Density int android.graphics.Bitmap.getDensity(),返回bitmap-density(密度).默认的density就是当前display-dens ...
- 【算法】(查找你附近的人) GeoHash核心原理解析及代码实现
本文地址 原文地址 分享提纲: 0. 引子 1. 感性认识GeoHash 2. GeoHash算法的步骤 3. GeoHash Base32编码长度与精度 4. GeoHash算法 5. 使用注意点( ...
- CSharpGL(9)解析OBJ文件并用CSharpGL渲染
CSharpGL(9)解析OBJ文件并用CSharpGL渲染 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码中包含10多个独立的Demo ...
- Sharepoint学习笔记—习题系列--70-576习题解析 -(Q112-Q115)
Question 112 You are designing a public-facing SharePoint 2010 Web site for an elementary school th ...
- 【Jsoup网页解析】
下载链接:http://jsoup.org/download 一.普通的请求方式(不带有cookie) 使用举例: 第一步: Connection conn=Jsoup.connect(url); 第 ...
- Java集合---Array类源码解析
Java集合---Array类源码解析 ---转自:牛奶.不加糖 一.Arrays.sort()数组排序 Java Arrays中提供了对所有类型的排序.其中主要分为Prim ...
- 书籍推荐《以C语言解析电脑》
这本书要想买到,在大陆看起来比较难,理出个目录,看个大概: 另外在这个地方可以预览前20页:http://openebook.hyread.com.tw/ebookservice/hyviewer/o ...
- 深度解析SDN——利益、战略、技术、实践(实战派专家力作,业内众多专家推荐)
深度解析SDN——利益.战略.技术.实践(实战派专家力作,业内众多专家推荐) 张卫峰 编 ISBN 978-7-121-21821-7 2013年11月出版 定价:59.00元 232页 16开 ...
- 115个Java面试题和答案——终极列表(下)
第一篇讨论了面向对象编程和它的特点,关于Java和它的功能的常见问题,Java的集合类,垃圾收集器,本章主要讨论异常处理,Java小应用程序,Swing,JDBC,远程方法调用(RMI),Servle ...
随机推荐
- Nginx反向代理之动静分离
我们已经知道了什么是正向代理与反向代理,这次我们就讲一下Nginx的动静分离的案例,其实质运用的就是反向代理,专门用一台服务器代理服务器上的图片资源. 想使用代理必然要配置代理,配置反向代理,必须要用 ...
- 这个注册的 IP 网络都不通了,Eureka 注册中心竟然无法踢掉它!
本文导读: 微服务技术架构选型介绍 k8s 容器化部署架构方案 Eureka 注册中心问题场景 问题解决手段及原理剖析 阅读本文建议先了解: 注册中心基本原理 K8s(Kuberneters)基本概念 ...
- Django REST Framework之频率限制
开放平台的API接口调用需要限制其频率,以节约服务器资源和避免恶意的频繁调用 使用 自定义频率限制组件:utils/thottle.py class MyThrottle(BaseThrottle): ...
- 商用hadoop集群的配置命令分布
角色 安装 hdfs配置 yarn配置 hdfs 格式化 启动yarn服务 启动hdfs服务 master yum install hadoop-hdfs-namenode yum install h ...
- 还在用SVN的人,要不要学Git?
还在用SVN的人,要不要学Git? 提出这个问题,是因为很多小伙伴还不会使用Git. 在Git之前,是SVN的天下. SVN诞生于2001年,由于较为先进的管理方式而迅速取代了CVS. 很多80后小伙 ...
- Kotlin学习系列(一)
基本类型 在Kotlin中任何事物都是对象你可以在任何变量上调用相应的方法或属性.Kotlin的一些内置类型如下: Number: 包含整形与浮点型 Character: 字符(Chat) Boole ...
- Scanner类的next()方法和nextLine()方法的异同点
通过一段代码就可以明白其中的奥妙!! import java.util.Scanner; public class next_nextLine { public static void main(St ...
- 品Spring:关于@Scheduled定时任务的思考与探索,结果尴尬了
非Spring风格的代码与Spring的结合 现在的开发都是基于Spring的,所有的依赖都有Spring管理,这没有问题. 但是要突然写一些非Spring风格的代码时,可能会很不习惯,如果还要和Sp ...
- win10 php安装redis 扩展
redis下载:https://github.com/MicrosoftArchive/redis/releases 我下载的是zip包,下载后安装redis. 开始安装php的reids扩展 查看p ...
- MIPI CSI2-TX接口基于FPGA实现
MIPI CSI2-TX用途: 跟海思的3559A芯片进行图像数据传输: MIPI CSI2-TX接口特性: xilinx 7系列芯片最大支持1.25Gbps: 最大支持lanes数量为4: 支持的图 ...