日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

UA STAT675 统计计算I 随机数生成2 线性递归模m与Multiple Recursive Generator (MRG)

發布時間:2025/4/14 编程问答 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 UA STAT675 统计计算I 随机数生成2 线性递归模m与Multiple Recursive Generator (MRG) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

UA STAT675 統計計算I 隨機數生成2 線性遞歸模m

    • Multiple Recursive Generator (MRG)
    • MRG設計方法

線性遞歸模m是最常用的一種算法RNG(random number generator),它的工作原理基礎是下面的遞歸式子
xi=(a1xi?1+?+akxi?k)modmx_i = (a_1x_{i-1}+\cdots+a_kx_{i-k}) \mod m xi?=(a1?xi?1?+?+ak?xi?k?)modm

其中m,km,km,k均是自然數,mmm被稱為模數(modulus),kkk被稱為階,a1,?,ak∈Zm={0,1,?,m?1}a_1,\cdots,a_k \in \mathbb{Z}_m=\{0,1,\cdots,m-1\}a1?,?,ak?Zm?={0,1,?,m?1},環Zm\mathbb{Z}_mZm?上的運算在關于mmm同余的意義下封閉,當mmm是素數時,Zm=GL(m)\mathbb{Z}_m=GL(m)Zm?=GL(m) (Galois域)。

上一講我們定義RNG的抽象結構:
RNG=(S,μ,f,U,g)RNG=(S,\mu,f,U,g)RNG=(S,μ,f,U,g)

這里SSS是狀態集,fff是狀態轉移函數,f:S→Sf:S \to Sf:SSUUU是輸出集,U(0,1)U(0,1)U(0,1)的RNG滿足U=(0,1)U=(0,1)U=(0,1)g:S→Ug:S \to Ug:SU是輸出函數,f,gf,gf,g都是確定性的函數,不產生隨機性,μ\muμSSS的概率分布,是用來選擇初始狀態(initial state或者seed)的,記選擇的seed為s0s_0s0?,則RNG的狀態轉移序列滿足:
st=f(st?1)s_t = f(s_{t-1})st?=f(st?1?)

從而輸出的隨機數為{ut:ut=g(ut)}\{u_t:u_t = g(u_t)\}{ut?:ut?=g(ut?)}

Multiple Recursive Generator (MRG)

Knuth (1998)證明了當mmm是素數時,最大的周期為ρ=mk?1\rho = m^k-1ρ=mk?1,當且僅當線性遞歸
xi=(a1xi?1+?+akxi?k)modmx_i = (a_1x_{i-1}+\cdots+a_kx_{i-k}) \mod m xi?=(a1?xi?1?+?+ak?xi?k?)modm

的特征多項式
P(z)=zk?a1zk?1??akP(z)=z^k-a_1z^{k-1}-\cdots a_kP(z)=zk?a1?zk?1??ak?

是Galois域GL(m)GL(m)GL(m)上的primitive polynomial;另一種等價敘述是
inf?ν∈Z+{(zνmodP(z))modm=1}=mk?1\inf_{\nu \in \mathbb{Z}^+}\{(z^{\nu}\mod P(z))\mod m=1\}=m^k-1νZ+inf?{(zνmodP(z))modm=1}=mk?1

Knuth (1998)敘述了一種尋找primitive polynomial的簡化方法,如果P(z)P(z)P(z)是primitive polynomial,則遞歸的系數中除了aka_kak?非零外,至少還有一個系數非零(記為ara_rar?);于是線性遞歸可以簡化為
xn=(arxn?r+akxn?k)modmx_n = (a_rx_{n-r}+a_kx_{n-k}) \mod m xn?=(ar?xn?r?+ak?xn?k?)modm

即我們只需要確定ar,aka_r,a_kar?,ak?兩個系數的值,使得
P(z)=zk?arzk?r?akP(z)=z^k-a_rz^{k-r}-a_kP(z)=zk?ar?zk?r?ak?

是primitive polynomial即可。

根據這些結果,我們來構造隨機數生成器,為此我們需要確定狀態集、狀態轉移規則、輸出函數:

nnn步的狀態集為
sn={xn?k,xn?r,xn}s_n = \{x_{n-k},x_{n-r},x_n\}sn?={xn?k?,xn?r?,xn?}

狀態轉移規則
xn=(arxn?r+akxn?k)modmx_n = (a_rx_{n-r}+a_kx_{n-k}) \mod m xn?=(ar?xn?r?+ak?xn?k?)modm

輸出函數
un=xnmu_n = \frac{x_n}{m}un?=mxn??

這樣的隨機數生成器叫做Multiple Recursive Generator (MRG)。

一種特例是k=1k=1k=1時,

nnn步的狀態集為
sn={xn?1,xn}s_n = \{x_{n-1},x_n\}sn?={xn?1?,xn?}

狀態轉移規則
xn=(a1xn?1)modmx_n = (a_1x_{n-1}) \mod m xn?=(a1?xn?1?)modm

輸出函數
un=xnmu_n = \frac{x_n}{m}un?=mxn??

這樣的隨機數生成器叫做linear congruential generator (LCG)。

MRG設計方法

要設計一個MRG,我們只需要確定系數a1,?,ak,ma_1,\cdots,a_k,ma1?,?,ak?,m即可。注意到xnx_nxn?mmm都是整數,所以unu_nun?是有理數,我們希望un~iidU(0,1)u_n \sim_{iid} U(0,1)un?iid?U(0,1),就需要mmm越大越好。另外,MRG涉及的主要計算就是在模mmm的意義下做線性遞歸,所以MRG的實現細節主要就是討論遞歸取模的計算。

Exact representation Method
第一種設計思路是讓遞歸式能夠被計算機準確表達,考慮在64-bit計算機IEEE float-point standard下的雙精度浮點數下進行模mmm計算,所有不超過2532^{53}253的整數都可以被準備表示,因此只要我們在設計參數時保證:
(∣a1∣+?+∣ak∣)(m?1)≤253(|a_1|+\cdots+|a_k|)(m-1) \le 2^{53}(a1?+?+ak?)(m?1)253

a1xi?1+?+akxi?ka_1x_{i-1}+\cdots+a_kx_{i-k}a1?xi?1?+?+ak?xi?k?就可以被準確表示。

以遞歸中的一項為例,記zj=∣aj∣xi?jz_j=|a_j|x_{i-j}zj?=aj?xi?j?,則zjmodmz_j \mod mzj?modm用下面的算法計算:
y=∣aj∣xi?jzj=y?m?y/m?y = |a_j|x_{i-j} \\ z_j = y - m\lfloor y/m \rfloory=aj?xi?j?zj?=y?m?y/m?

Approximate Factoring Method
以遞歸中的一項為例,記zj=∣aj∣xi?jz_j=|a_j|x_{i-j}zj?=aj?xi?j?,取∣aj∣=i,i<m|a_j|=i,i<\sqrt{m}aj?=i,i<m?或者∣aj∣=?m/i?|a_j|=\lfloor m/i \rflooraj?=?m/i?,則zjmodmz_j \mod mzj?modm用下面的算法計算:
qj=?m/∣aj∣?rj=mmod∣aj∣z=∣aj∣(xi?j?yqj)?yrjq_j = \lfloor m/|a_j| \rfloor \\ r_j = m \mod |a_j| \\ z = |a_j|(x_{i-j}-yq_j)-yr_jqj?=?m/aj??rj?=mmodaj?z=aj?(xi?j??yqj?)?yrj?

如果z<0z<0z<0,取zj=m+zz_j=m+zzj?=m+z,否則zj=zz_j=zzj?=z

關于MRG的設計方法還有很多其他的觀點,感興趣的同學可以參考handbook of computational statistics chapter 3.

總結

以上是生活随笔為你收集整理的UA STAT675 统计计算I 随机数生成2 线性递归模m与Multiple Recursive Generator (MRG)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 综合亚洲视频 | 亚洲av毛片一区二二区三三区 | 国产一区免费在线 | 四虎网址大全 | 日皮视频免费观看 | 国产精品污视频 | 91麻豆精品国产午夜天堂 | 欧美精品一区二区成人 | 污污网站免费 | 欧美一区二区成人 | 国产免费专区 | 日产精品久久久 | 亚洲爱色 | 久久久久久高清 | 99re8在线精品视频免费播放 | 自拍偷拍亚洲天堂 | 黄色一毛片 | 欧美日韩亚洲一区 | 91手机在线观看 | 亚洲欧美成人一区二区三区 | 亚洲国产精品久久 | 国产热热 | 超碰在97| av噜噜色 | 九月婷婷 | 欧美黑人多人双交 | 日本理论视频 | 日本在线黄色 | 欧美日韩一区二区三区视频 | 中文字幕四区 | 中文字幕va | 国产精品自产拍在线观看 | 亚洲国产无码精品 | 黄色三级三级三级三级 | 久久久久久久久久久91 | 爱露出| 中文字幕欧美另类精品亚洲 | 老色鬼在线 | 男人的天堂国产 | 免费看黄色一级视频 | 国内精品久久久 | 国产成人无码精品久在线观看 | 女人喷潮完整视频 | 亚洲天天做 | 日韩欧美视频一区二区 | 亚洲av中文无码乱人伦在线视色 | 婷婷开心激情 | 99热伊人 | 亚洲精品视频在线免费 | 久久99精品国产 | 探花系列在线观看 | 日韩国产精品一区二区三区 | av视屏| 国产成人啪精品午夜在线观看 | 青青草小视频 | 成人黄色在线免费观看 | 色噜噜亚洲 | 欧美日韩在线成人 | 久久乐国产精品 | 午夜av一区二区三区 | 国产欧美久久久精品免费 | 男女那个视频 | 六月婷婷中文字幕 | 福利电影一区 | 国产精品久久9 | 日日摸夜夜添狠狠添久久精品成人 | 国产精品理论在线观看 | 国产精品玖玖玖 | 性视频一区 | 午夜精品久久久内射近拍高清 | 中文字幕日韩三级片 | 四虎网站在线 | 免费av导航 | 精品久久一二三区 | 国产亚洲欧美一区二区 | 新婚之夜玷污岳丰满少妇在线观看 | 黑白配高清国语在线观看 | ass大乳尤物肉体pics | 国产精品suv一区二区三区 | 香蕉视频二区 | 久久久青| 天天射夜夜 | 巨胸挤奶视频www网站 | 高清毛片aaaaaaaaa片 | 日韩骚片 | 日本强好片久久久久久aaa | 捆绑凌虐一区二区三区 | 亚洲精品免费视频 | 韩国av不卡 | 久久久久久久久久久久久久久久久 | 女人叫床很黄很污句子 | 无套内谢的新婚少妇国语播放 | 国产精品美女在线观看 | 国产伦精品一区二区三区照片 | 日本一区视频在线 | 香蕉视频在线免费播放 | 日本一区二区三区免费看 | 在线欧美日韩国产 | 热热热热色 |