-
Notifications
You must be signed in to change notification settings - Fork 0
/
rbeta-test-speed.php
108 lines (102 loc) · 2.94 KB
/
rbeta-test-speed.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
<?php
require_once 'rbeta.php';
class RBetaTestSpeed extends PHPUnit_Framework_TestCase
{
private $member = null;
public function test_speed()
{
$rep = 100000;
$list = array(
array(2.7, 6.3),
array(1, 2),
array(1, 100),
array(5, 100),
array(10, 10000),
array(20, 10000),
array(1000, 10000),
);
print "\n";
foreach ($list as $pair) {
$alpha = $pair[0];
$beta = $pair[1];
$start = microtime(true);
for ($i=0; $i<$rep; $i++) {
$x = rbeta($alpha,$beta);
}
print 'time:'.(microtime(true)-$start)/$rep*1000 . "msec". '(alpha='.$alpha.', beta='.$beta.")\n";
}
}
public function test_speed_class()
{
$rep = 100000;
$list = array(
array(2.7, 6.3),
array(1, 1),
array(1, 2),
array(1, 100),
array(5, 100),
array(10, 10000),
array(20, 10000),
array(1000, 10000),
);
print "\n";
foreach ($list as $pair) {
$alpha = $pair[0];
$beta = $pair[1];
$start = microtime(true);
$rbeta = new RBeta($alpha, $beta);
for ($i=0; $i<$rep; $i++) {
$x = $rbeta->rand();
}
print 'class time:'.(microtime(true)-$start)/$rep*1000 . "msec". '(alpha='.$alpha.', beta='.$beta.")\n";
}
}
public function test_speed_classq()
{
$rep = 100000;
$list = array(
array(2.7, 6.3),
array(1, 1),
array(1, 2),
array(1, 100),
array(5, 100),
array(10, 10000),
array(20, 10000),
array(1000, 10000),
);
print "\n";
foreach ($list as $pair) {
$alpha = $pair[0];
$beta = $pair[1];
$start = microtime(true);
$rbeta = new RBetaQ($alpha, $beta);
for ($i=0; $i<$rep; $i++) {
$x = $rbeta->rand();
}
print 'classq time:'.(microtime(true)-$start)/$rep*1000 . "msec". '(alpha='.$alpha.', beta='.$beta.")\n";
}
}
public function test_speed_class_func()
{
$rep = 100000;
$list = array(
array(2.7, 6.3),
array(1, 2),
array(1, 100),
array(5, 100),
array(10, 10000),
array(20, 10000),
array(1000, 10000),
);
print "\n";
foreach ($list as $pair) {
$alpha = $pair[0];
$beta = $pair[1];
$start = microtime(true);
for ($i=0; $i<$rep; $i++) {
$x = rbeta_class($alpha,$beta);
}
print 'class func time:'.(microtime(true)-$start)/$rep*1000 . "msec". '(alpha='.$alpha.', beta='.$beta.")\n";
}
}
}