全球FlexSim系统仿真中文论坛

搜索
查看: 23884|回复: 5
打印 上一主题 下一主题

关于统计分布中“随机数流stream”的解释

[复制链接]
跳转到指定楼层
1#
zorsite 发表于 2013-3-25 13:54:54 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
资料来自《实用系统仿真建模与分析——使用Flexsim》,作者秦天保 周向阳
5 ]+ w3 u0 |- _* i* W/ ]3 g! ]第四章 随机数和随机变数的生成0 B" y3 X* R# u; R
* k* s* T3 D. p4 j6 w# w
仿真软件一般会将整个随机数序列分成若干段,例如100000个数为一段。7 ~* _9 J3 Q# d. n6 n- y0 h8 d
每段成为一个随机数流(stream),每个流会指定一个编号,如0号流,1号流等等。
7 A+ X! ^3 V; O  b) `0 r
( S+ M2 W' l5 }: K! O0 m* j在Flexsim中调用指数分布函数的形式为exponential(location,scal,stream),其中第3个参数stream就是指定从哪一个流求取下一个随机数,如果省略参数流,则默认使用0号随机数流。# L/ F) ]; T  t/ `. T/ K
8 Q+ h, n4 {7 j/ ]
Flexsim系统已经初始化了100个随机数流(0~99号),可供直接使用。* j. y6 g; m% j. Y0 p

5 j. G$ D0 E( ^# L如果一个流的随机数在模型运行过程中,经过不断调用耗净了,根据递推公式下一个随机数就会侵入下一个流中去了,这会导致不想要的相关性。为了提高模型输出数据的准确性和精度,建议为模型中的每个对象甚至每个随机因素指定不同的流号。  O: \& S1 w; b9 ^+ H9 z

/ H6 a1 A% t# ~: ?; \参考文献:% H! f& p( O7 y. O6 m4 ]; ^$ ?

& |3 z* p2 \  n6 `' v1 d* a
7 `) W; E" t* r
) t* r: f8 }" F7 L1 {: B

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
2#
king 发表于 2013-3-28 23:37:47 | 只看该作者
学习学习
3#
嗜血黑猫 发表于 2013-4-24 22:45:44 | 只看该作者
非常需要这方面知识啊谢谢
4#
lisa527 发表于 2013-11-18 13:26:51 | 只看该作者
本帖最后由 lisa527 于 2013-11-18 13:39 编辑 5 ~6 d1 E5 _% }' k# m7 H: s! t7 N
6 D4 R, r, m( Q( O" |/ J/ X) t
这个问题困扰我好久了,现在一次性了结' M% T/ o" D$ `- T
---------------------------------------------------------------------------------------------------
( ^1 ~+ D; {" y5 q" D/ `) c-随机数是怎么生成的  T3 R( o( w. o. b4 ^) q# |% ^5 h: C
基于计算机方法生成的随机数称为伪随机数,因为其计算方法已知,不是完全的随机。现在比较流行的生产伪随机数的方法是 Linear Congruential Generation (混合同余法).# q( J; C! a" a* n" u
Linear Congruential Generation (LCG)[1]方法如下:
) v( f& e. B9 `9 s: B5 |# ~X_i=(aX_(i-1)+c)mod m                            (1)4 R/ t1 b8 {: h& U
R_i= X_i/m- ]; j# O1 I7 ]2 G4 G7 w
Seed: X_0
8 P6 n- @  F, h  m, Z0 d
+ v% k4 ]: q; `" T6 H-什么是stream?9 K/ A0 U. k+ e" P" t+ v% Y
基于m的限制,生成的随机数都是循环的,而且最大的循环周期是m。假设生成的随机数周期为P,随机数序列可以写作: X_0,X_1,…X_P,X_0,X_1…* R) `; w' [4 Z4 c. @
正因为它的循环性,取0-P之间任何一个数做seed都可以生成整个随机数列。
* J" {4 \1 ^2 {为了方便起见,我们把长度为P的随机数分为若干个随机数流(stream),比如说,分成b个,每个stream的长度为P/b: {X_0,X_1,…X_(P/b-1)}, {X_(P/b),…X_(2P/b-1)}…
2 N7 ~1 ^8 e" @0 q; a, t- w: k. ]9 x, ^) O1 @" |2 m, q+ e5 n
-Stream有什么用?" y, B5 H- `) Z/ X# U! f4 k
通过观察(1)式可以得知,X_i  和 X_(i-1)是相关的。为了避免这种相关性,仿真时常常会选取不同的stream产生各个过程的随机数。: F6 F+ ?/ D; u
' p1 a9 \+ l3 k$ L7 ?
为此专门写了篇blog在http://blog.sina.com.cn/sui5277
5#
加油陶陶 发表于 2014-7-11 09:30:48 | 只看该作者
学习一下 谢谢分享
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|手机版|Archiver|全球FlexSim系统仿真中文论坛 ( 京ICP备14043114号-2 )

GMT+8, 2025-6-30 13:23 , Processed in 0.074452 second(s), 14 queries .

Powered by Discuz! X3.3© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表