data:image/s3,"s3://crabby-images/efd74/efd7461b735078fdfa2cd75695bb71514e90d731" alt="蔡文能 CC++ 程式設(shè)計 1課件_第1頁"
data:image/s3,"s3://crabby-images/01a6d/01a6dc43c028937cea925304489c3bce77c58887" alt="蔡文能 CC++ 程式設(shè)計 1課件_第2頁"
data:image/s3,"s3://crabby-images/5ef1f/5ef1fb303ce40cdb9b4d00fe9337e349bf691704" alt="蔡文能 CC++ 程式設(shè)計 1課件_第3頁"
data:image/s3,"s3://crabby-images/44001/44001b717bdeac82ba14efab3e8c2c253ea91448" alt="蔡文能 CC++ 程式設(shè)計 1課件_第4頁"
data:image/s3,"s3://crabby-images/bc3eb/bc3eb375f8c166ac2574a2448b60924b9db6185e" alt="蔡文能 CC++ 程式設(shè)計 1課件_第5頁"
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
1、Games, Random NumbersandIntroduction to simple statisticsPRNGPseudo Random Number Generator蔡文能tsaiwn.tw蔡文能 C/C+ 程式設(shè)計1AgendaWhat is random number(亂數(shù)) ?How the random numbers generated ?rand( ) in C languages: Linear Congruential Why call “Pseudo random” ? (P不發(fā)音)How to do “true random” ?Application of
2、 Rrandom number ?Other topics related to Random numbersIntroduction to simple statistics (統(tǒng)計簡介)蔡文能 C/C+ 程式設(shè)計2BATNUM game/basicgames/showpage.php?page=14An ancient game of two playersOne pile of match sticks (or stones)Takes turn to remove 1, maxTake(至少拿 1, 至多拿 maxTake)可規(guī)定拿到最後一個贏或輸 !Winning strategy
3、? Games 須用到 Random Number! Why?蔡文能 C/C+ 程式設(shè)計3Bulls and Cows Game http:/5ko.free.fr/en/bk.html /wiki/Bulls_and_cows/zh-hant/%E7%8C%9C%E6%95%B0%E5%AD%97/od/paperpencil/a/bulls_and_cows.htm/eng/play/bk.html/index.php/online-games/bulls-and-cows/index.phpGames 須用到 Random Number! Why?蔡文能 C/C+ 程式設(shè)計4What i
4、s random number ?Sequence of independent random numbers with a specified distribution such as uniform distribution (equally probable)Actually, the sequence generated is not random, but it appears to be. Sequences generated in a deterministic way are usually called Pseudo-Random sequences.參考 /softwar
5、e/gsl/manual/gsl-ref_19.htmlNormal distribution? exponential, gamma, Poisson, 蔡文能 C/C+ 程式設(shè)計6Turbo C+ 的 rand( )與srand( ) #define RAND_MAX 0 x7fffu static unsigned long seed=0; int rand( ) seed = seed * 1103515245 + 12345; return seed % (RAND_MAX+1); void srand(int newseed) seed = newseed; static glob
6、al 變數(shù)請參考K&R課本4.6節(jié)Pseudo random number就是15個 1的binary注意 C 語言的 rand( ) 生出的不是 Normal Distribution!static 使其它file裡的function 看不見這 seed蔡文能 C/C+ 程式設(shè)計7Random Number Generating AlgorithmsLinear Congruential GeneratorsSimple way to generate pseudo-random numbersEasily crackedProduce finite sequences of numbers
7、Each number is tied to the othersSome sequences of numbers will not ever be generatedCryptographic random number generatorsEntropy sensors (i.e., extracted randomness)蔡文能 C/C+ 程式設(shè)計9Linear Congruential Generator (LCG) for Uniform Random DigitsPreferred method: begin with a seed, x0, and successively
8、generate the next pseudo-random number by xi+1 = (axi + c) mod m, for i = 0,1,2, wherem is the largest prime less than largest integer computer can storea is relatively prime to mc is arbitraryLet A be largest integer less than A (就是只取整數(shù)部份), then N mod m = N N/T*TAccept LCG with m, a, and c which pa
9、sses tests which are also passed by know uniform digitsmod 在C/C+/Java 用 %蔡文能 C/C+ 程式設(shè)計10The use of random numbers1. Simulation2. Recreation (game programming)3. Sampling4. Numerical analysis5. Decision making randomness an essential part of optimal strategies( in the game theory)6. Game program, . .
10、 .蔡文能 C/C+ 程式設(shè)計11Uniform Distribution(齊一分配 )在 發(fā)生的機(jī)率皆相同蔡文能 C/C+ 程式設(shè)計12Normal Distribution (常態(tài)分配 )蔡文能 C/C+ 程式設(shè)計13Standard Normal Distribution(標(biāo)準(zhǔn)常態(tài)分配)N(0, 1)平均是 0標(biāo)準(zhǔn)差 1蔡文能 C/C+ 程式設(shè)計14Central Limit Theorem (CLT)(中央極限定理 )如果觀察值數(shù)目 n 增加,則 n 個獨(dú)立且具有相同分配(independent and identically distributed, I.I.D.)的隨機(jī)變數(shù)(Ran
11、dom variable)之平均數(shù)向常態(tài)分配收斂。 樣本大小n30時, 趨近於常態(tài)分配。 蔡文能 C/C+ 程式設(shè)計16如何用 C 生出常態(tài)分配的亂數(shù)?#include double randNormal( ) / 標(biāo)準(zhǔn)常態(tài)分配產(chǎn)生器 int i; double ans =0.0; for(i=1; i =30 observations are drawn from the same population where X ?(,), then 蔡文能 C/C+ 程式設(shè)計38 Central Limit Theorem (中央極限定理)For a population with a mean a
12、nd a variance , the sampling distribution of the means of all possible samples of size n generated from the population will be approximately normally distributed - with the mean of the sampling distribution equal to and the variance equal to assuming that the sample size is sufficiently large.蔡文能 C/
13、C+ 程式設(shè)計39The Normal DistributionDescribed by (mean) (standard deviation; 標(biāo)準(zhǔn)差)Variance 變異數(shù) = 標(biāo)準(zhǔn)差的平方Write as N( , ) 或 N( , 2) Area under the curve is equal to 1Standard Normal Distribution 蔡文能 C/C+ 程式設(shè)計40Why is the Normal Distribution important?It can be a good mathematical model for some distribution
14、s of real dataACT ScoresRepeated careful measurements of the same quantityIt is a good approximation for different types of chance outcomes (like tossing a coin)It is very useful distribution to use to model roughly symmetric distributionsMany statistical inference procedures are based on the normal
15、 distributionSampling Distributions are roughly normal (TBC)蔡文能 C/C+ 程式設(shè)計41Normal Distributions and the Standard DeviationNormal DistributionBlack line - MeanRed lines - 1 Std. Dev. from the mean (68.26% Interval)Green lines 2 Std. Dev. from the mean (95.44% Interval)What about 3 Std. Dev. from the
16、mean?95% Confidence interval 1.96 Std. Dev.蔡文能 C/C+ 程式設(shè)計4268-95-99.7 Rule for Normal Curves68.26%+-+3-399.74%+2-295.44%68.26% of the observations fall within of the mean 99.74% of the observations fall within 3 of the mean 95.44% of the observations fall within 2 of the mean 蔡文能 C/C+ 程式設(shè)計43Notations
17、It is important to distinguish between empirical and theoretical distributionsDifferent notation for each distribution蔡文能 C/C+ 程式設(shè)計44Density function of Normal DistributionThe exact density curve for a particular normal distribution is described by giving its mean () and its standard deviation ()den
18、sity at x = f(x) =蔡文能 C/C+ 程式設(shè)計45Confidence Intervals (CI) for ,from a single sample mean 蔡文能 C/C+ 程式設(shè)計46Confidence Interval? (1/2)當(dāng)我們使用軟體去模擬真實(shí)環(huán)境時,通常會用亂數(shù)(random number)模擬很多次,假設(shè)第一次模擬的結(jié)果數(shù)據(jù)是X1,第二次是X2,重覆了n次後,就有X1、X2Xn共n個數(shù)據(jù),這n個數(shù)據(jù)不盡相同,到底那個才是正確的? 直覺上,把得到的n個結(jié)果加總求平均,所得到的值應(yīng)該比較能相信。但是我們可以有多少程度的去相信這個平均值(sample m
19、ean)呢? 這個問題討論的就是所謂的Confidence Interval (信賴區(qū)間)與顯著水準(zhǔn)(significance level)。蔡文能 C/C+ 程式設(shè)計47Confidence Interval? (2/2)在實(shí)務(wù)上,想要在有限個模擬數(shù)據(jù)結(jié)果中得到一個較完美接近真實(shí)結(jié)果的數(shù)據(jù),其實(shí)是不可能的。因此我們能做的就是去求得一個機(jī)率範(fàn)圍(probability bound)。若我們可以得到一個機(jī)率範(fàn)圍的上限c1和一個範(fàn)圍的下限c2,則就有一個很高的機(jī)率1 ,會使得每次所得到的模擬結(jié)果平均值(sample mean)都落在c1到c2的範(fàn)圍之間。Probability c1 = = c2
20、= 1 我們把(c1, c2)這個範(fàn)圍稱為信賴區(qū)間(confidence interval);稱為顯著水準(zhǔn)(significance level);100(1-)%稱為信心水準(zhǔn)(confidence level),用百分比表示;1-稱為信心係數(shù)(confidence coefficient)。蔡文能 C/C+ 程式設(shè)計48為何簡單隨機(jī)抽樣是個合理的抽樣方法? 試想抽取16所醫(yī)院來預(yù)測393所醫(yī)院的平均出院病人數(shù)的例子,共有約1033種的不同樣本。依據(jù)中央極限定理,所得到的平均出院病人數(shù)分佈像個鐘形曲線,其中心位於所有醫(yī)院的平均出院病人數(shù),且大多數(shù)的16所醫(yī)院平均出院病人數(shù)都離中心(大數(shù)法則)不
21、遠(yuǎn)。 較有保障的抽樣辦法,被選取的樣本應(yīng)使用隨機(jī)的原理取得。蔡文能 C/C+ 程式設(shè)計49Hypothesis Testing假設(shè)之檢定The null hypothesis for the test is that all population means (level means) are the same. (H0)The alternative hypothesis is that one or more population means differ from the others. (H1)蔡文能 C/C+ 程式設(shè)計50PRNG 相關(guān)補(bǔ)充請用 打 “PRNG” 查看ANSI X9.
22、17 PRNG (PRNG = Pseudo Random Number Generator)Von Neumann 想出的 middle square methodVon Neumann architecture ?PRNG in RC4 (RC4用於 802.11 無線網(wǎng)路加解密)http:/www.wisdom.weizmann.ac.il/itsik/RC4/rc4.htmlWEP : RC4 Stream cipher蔡文能 C/C+ 程式設(shè)計51ANSI X9.17 PRNGUse 3DES and a key KTi = Ek(current timestamp)outputi
23、= Ek(Ti seedi)seedi+1 = Ek(Ti outputi)WeaknessesOnly 64 bits are used for Tiseedi+1 can be easily predicted if state compromise蔡文能 C/C+ 程式設(shè)計52Jon von Neumann 1946 suggested the production of random number using arithmetic operations of a computer, middle square, square a previousrandom number and ex
24、tract the middle digits, Example generate 10-digit numbers, was 5772156649, square 33317792380594909201the next number is 7923805949Middle squaremiddle square has proved to be a comparatively poor source of random numbers. If zero appear as a number of the sequence, it will continually perpetuate itself.蔡文能 C/C+ 程式設(shè)計53Von Neumann architecture (/)The term von Neumann architecture refers to a computer design model that uses a single storage structure to hold both programs and data. The term von Neumann machine can be used to descr
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 國家思政課題申報書
- 高職省級課題申報書
- 黨建雙創(chuàng)課題申報書
- 醫(yī)學(xué)婦科課題申報書范文
- 養(yǎng)殖設(shè)備銷售合同范本
- ai生成課題申報書
- 合同范本封面彩色設(shè)計
- 課題如何寫申報書
- 信用保證保險合同范本
- 印刷租賃合同范本
- 讀后續(xù)寫+摯友離別:不舍與成長交織的瞬間+講義 高一上學(xué)期期中聯(lián)考英語試題
- 地質(zhì)災(zāi)害預(yù)防培訓(xùn)課件
- 2024-2030年中國飾面板行業(yè)發(fā)展?fàn)顩r及前景趨勢研究報告
- 2025新譯林版英語七年級下單詞默寫表
- 部編版小學(xué)語文三年級下冊第六單元教材解讀及教學(xué)建議
- DB11T 1315-2015 綠色建筑工程驗(yàn)收規(guī)范
- 山東省2024年夏季普通高中學(xué)業(yè)水平合格考試地理試題02(解析版)
- 《ISO 41001-2018 設(shè)施管理- 管理體系 要求及使用指南》專業(yè)解讀與應(yīng)用指導(dǎo)材料之16:“8運(yùn)行”(雷澤佳編制-2024)
- 2024智慧城市數(shù)據(jù)分類標(biāo)準(zhǔn)規(guī)范
- 礦山挖機(jī)合作協(xié)議書范文
- Linux系統(tǒng)管理與服務(wù)器配置-基于CentOS 7(第2版) 課件 第1章CentOS Linux 7系統(tǒng)的安裝與介紹
評論
0/150
提交評論