Latin超立方抽样学习报告

上传人:re****.1 文档编号:468020516 上传时间:2023-07-13 格式:DOC 页数:12 大小:210KB
返回 下载 相关 举报
Latin超立方抽样学习报告_第1页
第1页 / 共12页
Latin超立方抽样学习报告_第2页
第2页 / 共12页
Latin超立方抽样学习报告_第3页
第3页 / 共12页
Latin超立方抽样学习报告_第4页
第4页 / 共12页
Latin超立方抽样学习报告_第5页
第5页 / 共12页
点击查看更多>>
资源描述

《Latin超立方抽样学习报告》由会员分享,可在线阅读,更多相关《Latin超立方抽样学习报告(12页珍藏版)》请在金锄头文库上搜索。

1、Latin超立方采样技术及其在结构可靠性分析中的应用二、 拉丁超立方采样通过第一部分前言对拉丁超立方抽样概念的理解,结合第二部分对其原理的介绍,用matlab编辑拉丁超立方抽样的程序,具体如下:function s=lhsamp(n,k)%产生一个n行k列的拉丁超立方抽样矩阵%s:元素介于(0.0,1.0)之间n*k的拉丁超立方抽样矩阵%k:输入变量数(维数)%n:每个输入变量抽取的样本数(每一维的采样数)s=zeros(n,k);for i=1:k; s(:,i)=rand(1,n)/n+(randperm(n)-1)/n;%rand(1,n):产生n个值介于0.0到1.0的随机数%rand

2、perm(n):产生正整数1,2,3,.n的随机排列end%得到拉丁超立方抽样矩阵后,根据每个变量的分布函数,根据Xnk=f-1(Un)之间的关系,由每个变量对应的抽样结果Un反算出对该变量的真实抽样点Xk三、 统计相关的减小方程1、Latin超立方抽样可能随机的引进了一定的统计相关,所以用文中采用的Spearman系数法来减小统计相关性。首先,根据Spearman相关系数的计算公式,用matlab编辑程序如下:function coeff = Spearman(X , Y) % 本函数用于实现Spearman相关系数的计算操作 % X:输入的数值序列 % Y:输入的数值序列 % coeff:

3、两个输入数值序列X,Y的相关系数 if length(X) = length(Y) error(两个数值数列的维数不相等); endN = length(X); %得到序列的长度 Xrank = zeros(1 , N); %存储X中各元素的排行 Yrank = zeros(1 , N); %存储Y中各元素的排行 %计算Xrank中的各个值 for i = 1 : N count = 1; for j = 1 : N if X(i) X(j) count = count + 1; end end Xrank(i) = count ;end %计算Yrank中的各个值 for i = 1 : N

4、 count = 1; for j = 1 : N if Y(i) Y(j) count = count + 1; end end Yrank(i) = count; end %利用X,Y的序数排列计算Spearman相关系数 A = 6 * sum(Xrank - Yrank).2); B = N*(N-1)*(N+1); coeff = 1-A/B; end 2、 仿照文中例子做一个K=5个输入变量和N=10个模拟的算例,以验证上述程序的正确性及Spearman系数对统计相关性的减小作用。3、 首先用sample.m函数生成一个K=5个输入变量和N=10个模拟的秩数随机排列表,见表1:fu

5、nction R=sample(n,k)%产生一个n行k列的随机抽样矩阵%k:输入变量数(维数)%n:每个输入变量抽取的样本数(每一维的采样数)R=zeros(n,k);for i=1:k; R(:,i)=randperm(n);%randperm(n):产生正整数1,2,3,.n的随机排列end表1 K=5个输入变量和N=10个模拟的秩数随机排列表 未修正表 模拟 变量 1 2 3 4 5 1 6 6 2 2 5 2 3 1 10 10 2 3 7 7 8 4 1 4 8 4 9 5 7 5 5 9 1 3 6 6 1 5 5 8 8 7 2 8 7 7 9 8 4 3 6 1 10 9 9

6、 10 3 6 3 10 10 2 4 9 4 修正表 模拟 变量 1 2 3 4 5 1 6 6 1 2 3 2 3 1 7 8 2 3 7 7 10 3 1 4 8 4 9 4 10 5 5 9 2 5 4 6 1 5 4 9 6 7 2 8 8 6 9 8 4 3 5 1 8 9 9 10 6 7 5 10 10 2 3 10 7 矩阵各列间的统计相关由序相关矩阵T描述,其元素Tij是R的i列和j列间的Spearman系数。在matlab命令窗口执行T.m脚本文件,调用前述计算Spearman系数的Spearman.m程序得到秩相关矩阵T:脚本文件T.m:for j=1:5; for i

7、=1:5; T(i,j)=Spearman(R(:,i),R(:,j); end end 表2 表1秩数随机排列表的秩相关矩阵 未修正表 变量 变量 1 2 3 4 5 1 1.0000 0.0667 -0.2121 -0.0909 -0.4909 2 0.0667 1.0000 -0.5152 -0.3455 -0.0182 3 -0.2121 -0.5152 1.0000 0.3697 -0.0909 4 -0.0909 -0.3455 0.3697 1.0000 -0.2970 5 -0.4909 -0.0182 -0.0909 -0.2970 1.0000 修正表变量 变量 1 2 3

8、 4 5 1 1.0000 0.0667 0.0061 -0.0061 -0.0061 2 0.0667 1.0000 -0.0061 -0.1758 -0.1152 3 0.0061 -0.0061 1.0000 -0.0909 0.1152 4 -0.0061 -0.1758 -0.0909 1.0000 0.0424 5 -0.0061 -0.1152 0.1152 0.0424 1.0000T是正定的对称矩阵,可用Choiesky分解将T分解为T=Q*QT 在matlab命令运行窗口运行Q=chol(T),得到Q:Q = 1.0000 0.0667 -0.2121 -0.0909 -0

9、.4909 0 0.9978 -0.5021 -0.3402 0.0146 0 0 0.8384 0.2142 -0.2239 0 0 0 0.9111 -0.3168 0 0 0 0 0.7799修正后的RB=R*Q-1,在matlab中运行RB=R*inv(Q),得到RB: RB= 6.0000 5.6125 7.2651 3.1808 13.4605 3.0000 0.8018 13.1671 8.4781 11.6619 7.0000 6.5479 15.2351 3.9508 11.5447 8.0000 3.4744 14.8401 4.0936 19.8692 5.0000 8.6860 7.6601 5.2331 15.0029 1.0000 4.9443 9.1782 8.5679 16.9100 2.0000 7.8842 13.5776 7.6332 19.6500 4.0000 2.7394 9.8095 0.2128 18.1910 9.0000 9.4210 11.4980 8.2968 16.0068 10.0000 1.3363 8.1016 9.4696 17.5709按矩阵RB列中次序重新排列输入矩阵R中的值,则序数随机排列表各列间统计相关性便减小了,得到修正后的R,见表1。然后根据修正后的R,验证

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号