Transcript PPT
亂數函數(Random-Number Function)
Rung-Shiang Cheng
Department of Computer and Communication, Kun Shan University
[email protected]
Outline
介紹亂數函數的使用方法
相關範例
產生亂數和模擬生活中的隨機資料
何時會用到亂數函數呢? 統計實驗…網路模擬…
ANSI C <stdlib.h>
產生10個亂數,同時印出RAND_MAX的值
(1/2)
Example
把時間當成亂
數的種子
產生10個亂數,同時印出RAND_MAX的值
(2/2)
執行結果
取特定的值當作亂數種子(以"0"為例)
第1次實驗….
第2次實驗….
第n次實驗
產生10個範圍從1到6的亂數
Example: 丟骰子….
產生10個範圍從1到6的亂數
執行結果
產生0 ~ 1之間的浮點數亂數
Example
產生0 ~ 1之間的浮點數亂數
執行結果
產生m 到n之間的整數亂數
Example: 公式: m + (rand() % (n − m + 1) )
產生m 到n之間的整數亂數
執行結果
用指令列引數指定亂數的最小值m和最大值n
用指令列引數指定亂數的最小值m和最大值n
執行結果
產生m 到n之間的浮點數亂數
公式:m + (rand() / RAND_MAX) × (n − m)
產生m 到n之間的浮點數亂數
Case 1: random (20, 60)
產生m 到n之間的浮點數亂數
Case 2: random (0, 1)
利用NS-2網路模擬器的亂數產生器模擬封包
遺失
NS-2是什麼?
– Network Simulator, version 2
•
•
•
•
物件導向網路模擬器
C++, OTCL
Router, Link, End point, TCP/IP protocols
Ethernet, WiFi, Sensor Networks
網路模擬的應用實例
使用網路模擬器模擬封包遺失
統計與量測模擬結果
如何在網路模擬器中使用亂數產生器
設定種子(seed)
設定分佈 (distribution)
– E.g. Pareto、Constant、Uniform、Exponential、
HyperExponentail
20
Uniform Distribution
• 參數
– 最小值: min_
– 最大值: max_
• 範例
這個例子在NS-2中產生一個亂數產生器,並把種
子的值設定為2(若種子的值為0的話,則亂數產生
器會在每次程式被執行時使用不同的種子 )
• 執行結果
21
模擬在網路上使用FTP傳送資料
網路拓撲
執行結果
Error Model (Uniform Distribution)(1/2)
修改TCL Script加入下列程式碼
在node0和node1之間
( SimpleLink object)加入error
rate : Specify error rate
unit : Specify the unit of error (time, pkt, bits)
– Default: packet
ranvar : Specify the random variable for generating errors
Error Model (Uniform Distribution)(1/2)
執行結果
和前一個例子相比,goodput下降了…
量測Error rate (1/2)
AWK程式碼(修改自sent_drop.awk)
計算送出的封包
計算收到的封包
在這裡略做修改…
量測Error rate (1/2)
模擬&量測結果
模擬時間: 5秒
如何找到這份講義?
就這麼簡單 (Report)
http://teachers.ksu.edu.tw/rscheng/illus/report.htm