女人被狂躁到高潮视频免费无遮挡,内射人妻骚骚骚,免费人成小说在线观看网站,九九影院午夜理论片少妇,免费av永久免费网址

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

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

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

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

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


二.代碼實現(xiàn):
現(xiàn)在我們來看看levelDB里隨機數(shù)Random類是如何實現(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
????????//?表達式s?&?0x7fffffffu,確保結(jié)果值在[0,2147483647]范圍內(nèi)
????????explicit?Random(uint32_t?s)?:?seed_(s?&?0x7fffffffu)??
????????{
????????????//?Avoid?bad?seeds.
????????????//?seed_不能為零或M,否則所有的后續(xù)計算的值將為零或M
????????????if?(seed_?==?0?||?seed_?==?2147483647L)
????????????{
????????????????seed_?=?1;
????????????}
????????}
????????//?16807隨機數(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è)置為隨機數(shù)生成器product,注意到product是64位的。
????????????//?那么seed_=product?%?M就相當于得到大小在[1,M-1]之間的隨機數(shù)。
????????????uint64_t?product?=?seed_?*?A;
????????????//?Compute?(product?%?M)?using?the?fact?that?((x?<<?31)?%?M)?==?x.
????????????//?對于product?%?M,使用(product?>>?31)?+?(product?&?M)進行運算優(yōu)化,
????????????//?考慮到右移和與操作的代價遠小于取余操作。
????????????//?下面等式用到了((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
計算表達式左邊(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
因為product類型是uint64_t,可以將product從左到右分解成高33位和低31位,如下:
? ? ? ?高33位 ? ? ? ? ? ? ? ? ? ? ?低31
(product>>31)<<31+product&M
(product>>31)<


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

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設(shè)備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設(shè)計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設(shè)計成為提升電機驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設(shè)備的使用壽命。然而,在實際應(yīng)用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設(shè)計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設(shè)中,街道及停車場照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設(shè)計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉