當(dāng)前位置:首頁(yè) > 芯聞號(hào) > 充電吧
[導(dǎo)讀]一.原理:C語(yǔ)言中偽隨機(jī)數(shù)生成算法實(shí)際上是采用了"線性同余法"。具體的計(jì)算如下:?seed = (seed * A + C ) % M其中A,C,M都是常數(shù)(一般會(huì)取質(zhì)數(shù))。當(dāng)C=0時(shí),叫做乘同余法。

一.原理:
C語(yǔ)言中偽隨機(jī)數(shù)生成算法實(shí)際上是采用了"線性同余法"。具體的計(jì)算如下:?
seed = (seed * A + C ) % M
其中A,C,M都是常數(shù)(一般會(huì)取質(zhì)數(shù))。當(dāng)C=0時(shí),叫做乘同余法。
假設(shè)我們定義隨機(jī)數(shù)函數(shù):

void?rand(int?&seed)
{
????seed?=?(seed?*?A?+?C?)?%?M;
}

每次調(diào)用rand函數(shù)都會(huì)產(chǎn)生一個(gè)隨機(jī)值賦值給seed,可以看出實(shí)際上用rand函數(shù)生成的是一個(gè)遞推的序列,一切值都來(lái)源于最初的seed。所以當(dāng)初始的seed取一樣的時(shí)候,得到的序列都相同。

我們稱seed為種子,一個(gè)偽隨機(jī)數(shù)常用的原則就是M盡可能的大。例如,對(duì)于32位的機(jī)器來(lái)說(shuō),選擇M=2^31-1=2147483647, A=7^5=16807時(shí)可以取得最佳效果。


二.代碼實(shí)現(xiàn):
現(xiàn)在我們來(lái)看看levelDB里隨機(jī)數(shù)Random類是如何實(shí)現(xiàn)的:

在Random類中,A為16807,M為2147483647,C為0;


#ifndef?STORAGE_LEVELDB_UTIL_RANDOM_H_
#define?STORAGE_LEVELDB_UTIL_RANDOM_H_


#includenamespace?leveldb?{
????
????//?A?very?simple?random?number?generator.??Not?especially?good?at
????//?generating?truly?random?bits,?but?good?enough?for?our?needs?in?this
????//?package.
????
????class?Random
????{
????private:
????????uint32_t?seed_;
????public:
????????//?0x7fffffffu?==?2147483647L?==?2^31-1?==?01111111?11111111?11111111?11111111
????????//?表達(dá)式s?&?0x7fffffffu,確保結(jié)果值在[0,2147483647]范圍內(nèi)
????????explicit?Random(uint32_t?s)?:?seed_(s?&?0x7fffffffu)??
????????{
????????????//?Avoid?bad?seeds.
????????????//?seed_不能為零或M,否則所有的后續(xù)計(jì)算的值將為零或M
????????????if?(seed_?==?0?||?seed_?==?2147483647L)
????????????{
????????????????seed_?=?1;
????????????}
????????}
????????//?16807隨機(jī)數(shù)
????????uint32_t?Next()
????????{?
????????????//01111111?11111111?11111111?11111111
????????????static?const?uint32_t?M?=?2147483647L;???//?2^31-1
????????????//0100?0001?1010?0111
????????????static?const?uint64_t?A?=?16807;??//?bits?14,?8,?7,?5,?2,?1,?0
????????????//?We?are?computing
????????????//???????seed_?=?(seed_?*?A)?%?M,????where?M?=?2^31-1
????????????//
????????????//?seed_?must?not?be?zero?or?M,?or?else?all?subsequent?computed?values
????????????//?will?be?zero?or?M?respectively.??For?all?other?values,?seed_?will?end
????????????//?up?cycling?through?every?number?in?[1,M-1]
????????????//?這里將seed_*A設(shè)置為隨機(jī)數(shù)生成器product,注意到product是64位的。
????????????//?那么seed_=product?%?M就相當(dāng)于得到大小在[1,M-1]之間的隨機(jī)數(shù)。
????????????uint64_t?product?=?seed_?*?A;
????????????//?Compute?(product?%?M)?using?the?fact?that?((x?<<?31)?%?M)?==?x.
????????????//?對(duì)于product?%?M,使用(product?>>?31)?+?(product?&?M)進(jìn)行運(yùn)算優(yōu)化,
????????????//?考慮到右移和與操作的代價(jià)遠(yuǎn)小于取余操作。
????????????//?下面等式用到了((x?<<?31)?%?M)?==?x的技巧(等式的證明見第三節(jié))
????????????//?product%M?==?static_cast((product?>>?31)?+?(product?&?M))的證明見第四節(jié)
????????????seed_?=?static_cast((product?>>?31)?+?(product?&?M));?
????????????//?The?first?reduction?may?overflow?by?1?bit,?so?we?may?need?to
????????????//?repeat.??mod?==?M?is?not?possible;?using?>?allows?the?faster
????????????//?sign-bit-based?test.
????????????if?(seed_?>?M)
????????????{
????????????????seed_?-=?M;
????????????}
?????
????????????return?seed_;
????????}
????????//?Returns?a?uniformly?distributed?value?in?the?range?[0..n-1]
????????//?返回范圍[0..n-1]內(nèi)的均勻分布值。
????????//?REQUIRES:?n?>?0
????????uint32_t?Uniform(int?n)?{?return?Next()?%?n;?}
????????
????????//?Randomly?returns?true?~"1/n"?of?the?time,?and?false?otherwise.
????????//?REQUIRES:?n?>?0
????????bool?OneIn(int?n)?{?return?(Next()?%?n)?==?0;?}
????????
????????//?Skewed:?pick?"base"?uniformly?from?range?[0,max_log]?and?then
????????//?return?"base"?random?bits.??The?effect?is?to?pick?a?number?in?the
????????//?range?[0,2^max_log-1]?with?exponential?bias?towards?smaller?numbers.
????????//?偏態(tài):Uniform(max_log?+?1)取值范圍是[0,max_log],1左移[0,max_log]得到
????????//?范圍是[1,2^max_log],uniform([1,2^max_log])得到的范圍是[0,2^max_log-1]
????????uint32_t?Skewed(int?max_log)
????????{
????????????return?Uniform(1?<<?Uniform(max_log?+?1));
????????}
????};
????
}??//?namespace?leveldb

三.證明等式(x<<31)%M == x成立。其中M等于2^31-1
計(jì)算表達(dá)式左邊(x << 31) % M,由于x<<31等于x*2^31,
則(x << 31) % M=(x*2^31)%M=(x + x*(2^31-1))%M=(x + x*M)%M=x


四.證明等式(product%M) == (product>>31)+(product&M),其中M等于2^31-1
因?yàn)閜roduct類型是uint64_t,可以將product從左到右分解成高33位和低31位,如下:
? ? ? ?高33位 ? ? ? ? ? ? ? ? ? ? ?低31
(product>>31)<<31+product&M
(product>>31)<


本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來(lái)越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來(lái)越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉