ESL*_*ner 1 matlab probability cumulative-sum cdf probability-density
我正在努力绘制 PDF 和 CDF 图
Sn=X1+X2+X3+....+Xn 使用中心极限定理,其中 n = 1;2;3;4;5;10;20;40 我将 Xi 视为 (0,3) 之间值的均匀连续随机变量。
Here is what i have done so far -
close all
%different sizes of input X
%N=[1 5 10 50];
N = [1 2 3 4 5 10 20 40];
%interval (1,6) for random variables
a=0;
b=3;
%to store sum of differnet sizes of input
for i=1:length(N)
%generates uniform random numbers in the interval
X = a + (b-a).*rand(N(i),1);
S=zeros(1,length(X));
S=cumsum(X);
cd=cdf('Uniform',S,0,3);
plot(cd);
hold on;
end
legend('n=1','n=2','n=3','n=4','n=5','n=10','n=20','n=40');
title('CDF PLOT')
figure;
for i=1:length(N)
%generates uniform random numbers in the interval
X = a + (b-a).*rand(N(i),1);
S=zeros(1,length(X));
S=cumsum(X);
cd=pdf('Uniform',S,0,3);
plot(cd);
hold on;
end
legend('n=1','n=2','n=3','n=4','n=5','n=10','n=20','n=40');
title('PDF PLOT')
Run Code Online (Sandbox Code Playgroud)
我的输出远未达到我的预期,非常感谢任何帮助。
rand()这可以通过使用和进行矢量化来完成cumsum()。
例如,下面的代码生成 Uniform(0,3) 分布的 10000 个样本的 40 个重复,并存储在X. 为了满足中心极限定理 (CLT)假设,它们是独立同分布 (iid) 的。然后cumsum()将其转换为 的 10000 个副本,其中Sn = X1 + X2 + ...第一行是n = 10000的副本Sn = X1,第五行是n的副本S_5 = X1 + X2 + X3 + X4 + X5。最后一行是n的副本S_40。
% MATLAB R2019a
% Setup
N = [1:5 10 20 40]; % values of n we are interested in
LB = 0; % lowerbound for X ~ Uniform(LB,UB)
UB = 3; % upperbound for X ~ Uniform(LB,UB)
n = 10000; % Number of copies (samples) for each random variable
% Generate random variates
X = LB + (UB - LB)*rand(max(N),n); % X ~ Uniform(LB,UB) (i.i.d.)
Sn = cumsum(X);
Run Code Online (Sandbox Code Playgroud)
从图中可以看出,这种n = 2情况下,总和确实是三角(0,3,6)分布。对于本n = 40例,总和近似呈正态分布(高斯),平均值为 60 ( 40*mean(X) = 40*1.5 = 60)。这显示了概率密度函数 (PDF)和累积分布函数 (CDF) 的分布收敛。
注意:CLT 通常用分布收敛到均值为零的正态分布来表示,因为它已经发生了移动。mean(Sn) = n*mean(X) = n*0.5*(LB+UB)通过减去来移动结果Sn即可完成此操作。
下面的代码不是黄金标准,但它产生了图像。
figure
s(11) = subplot(6,2,1) % n = 1
histogram(Sn(1,:),'Normalization','pdf')
title(s(11),'n = 1')
s(12) = subplot(6,2,2)
cdfplot(Sn(1,:))
title(s(12),'n = 1')
s(21) = subplot(6,2,3) % n = 2
histogram(Sn(2,:),'Normalization','pdf')
title(s(21),'n = 2')
s(22) = subplot(6,2,4)
cdfplot(Sn(2,:))
title(s(22),'n = 2')
s(31) = subplot(6,2,5) % n = 5
histogram(Sn(5,:),'Normalization','pdf')
title(s(31),'n = 5')
s(32) = subplot(6,2,6)
cdfplot(Sn(5,:))
title(s(32),'n = 5')
s(41) = subplot(6,2,7) % n = 10
histogram(Sn(10,:),'Normalization','pdf')
title(s(41),'n = 10')
s(42) = subplot(6,2,8)
cdfplot(Sn(10,:))
title(s(42),'n = 10')
s(51) = subplot(6,2,9) % n = 20
histogram(Sn(20,:),'Normalization','pdf')
title(s(51),'n = 20')
s(52) = subplot(6,2,10)
cdfplot(Sn(20,:))
title(s(52),'n = 20')
s(61) = subplot(6,2,11) % n = 40
histogram(Sn(40,:),'Normalization','pdf')
title(s(61),'n = 40')
s(62) = subplot(6,2,12)
cdfplot(Sn(40,:))
title(s(62),'n = 40')
sgtitle({'PDF (left) and CDF (right) for Sn with n \in \{1, 2, 5, 10, 20, 40\}';'note different axis scales'})
for tgt = [11:10:61 12:10:62]
xlabel(s(tgt),'Sn')
if rem(tgt,2) == 1
ylabel(s(tgt),'pdf')
else % rem(tgt,2) == 0
ylabel(s(tgt),'cdf')
end
end
Run Code Online (Sandbox Code Playgroud)
用于绘图的关键函数: 来自 MATLAB 基础的histogram()和来自统计工具箱的cdfplot() 。请注意,这可以手动完成,不需要统计工具箱用几行代码来获取 cdf,然后只需调用plot().
评论中有人对 的差异表示担忧Sn。
注意 的方差Sn由(下面的推导)给出(n/12)*(UB-LB)^2。蒙特卡罗模拟显示我们的样本Sn确实具有正确的方差;事实上,n随着变大,它会收敛到这一点。只需致电var(Sn(40,:)).
% with n = 10000
var(Sn(40,:)) % var(S_40) = 30 (will vary slightly depending on random seed)
(40/12)*((UB-LB)^2) % 29.9505
Run Code Online (Sandbox Code Playgroud)
可以看到S_40收敛得非常好:
step = 0.01;
Domain = 40:step:80;
mu = 40*(LB+UB)/2;
sigma = sqrt((40/12)*((UB-LB)^2));
figure, hold on
histogram(Sn(40,:),'Normalization','pdf')
plot(Domain,normpdf(Domain,mu,sigma),'r-','LineWidth',1.4)
ylabel('pdf')
xlabel('S_n')
Run Code Online (Sandbox Code Playgroud)
Sn 均值和方差的推导:

对于期望(均值),第二个等式通过期望的线性成立。第三个等式成立,因为X_i同分布。
此处发布了该版本的离散版本。