line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
package Quantum::Superpositions::Lazy::Util; |
2
|
|
|
|
|
|
|
$Quantum::Superpositions::Lazy::Util::VERSION = '1.12'; |
3
|
15
|
|
|
15
|
|
124667
|
use v5.24; |
|
15
|
|
|
|
|
55
|
|
4
|
15
|
|
|
15
|
|
68
|
use warnings; |
|
15
|
|
|
|
|
26
|
|
|
15
|
|
|
|
|
361
|
|
5
|
15
|
|
|
15
|
|
66
|
use Exporter qw(import); |
|
15
|
|
|
|
|
24
|
|
|
15
|
|
|
|
|
411
|
|
6
|
15
|
|
|
15
|
|
76
|
use Scalar::Util qw(blessed); |
|
15
|
|
|
|
|
23
|
|
|
15
|
|
|
|
|
730
|
|
7
|
15
|
|
|
15
|
|
100
|
use List::Util qw(max); |
|
15
|
|
|
|
|
30
|
|
|
15
|
|
|
|
|
1628
|
|
8
|
15
|
|
|
15
|
|
6368
|
use Random::Any qw(rand); |
|
15
|
|
|
|
|
4193
|
|
|
15
|
|
|
|
|
79
|
|
9
|
|
|
|
|
|
|
|
10
|
|
|
|
|
|
|
our @EXPORT_OK = qw( |
11
|
|
|
|
|
|
|
is_collapsible |
12
|
|
|
|
|
|
|
is_state |
13
|
|
|
|
|
|
|
get_rand |
14
|
|
|
|
|
|
|
get_iterator |
15
|
|
|
|
|
|
|
); |
16
|
|
|
|
|
|
|
|
17
|
|
|
|
|
|
|
sub is_collapsible |
18
|
|
|
|
|
|
|
{ |
19
|
16838
|
|
|
16838
|
0
|
28455
|
my ($item) = @_; |
20
|
|
|
|
|
|
|
|
21
|
16838
|
|
66
|
|
|
220291
|
return blessed $item && $item->DOES("Quantum::Superpositions::Lazy::Role::Collapsible"); |
22
|
|
|
|
|
|
|
} |
23
|
|
|
|
|
|
|
|
24
|
|
|
|
|
|
|
sub is_state |
25
|
|
|
|
|
|
|
{ |
26
|
245819
|
|
|
245819
|
0
|
335921
|
my ($item) = @_; |
27
|
|
|
|
|
|
|
|
28
|
245819
|
|
66
|
|
|
737227
|
return blessed $item && $item->isa("Quantum::Superpositions::Lazy::State"); |
29
|
|
|
|
|
|
|
} |
30
|
|
|
|
|
|
|
|
31
|
|
|
|
|
|
|
# MUST return a value in range of [0, 1) |
32
|
35
|
|
|
35
|
0
|
136
|
sub get_rand { rand() } |
33
|
|
|
|
|
|
|
|
34
|
|
|
|
|
|
|
sub get_iterator |
35
|
|
|
|
|
|
|
{ |
36
|
146
|
|
|
146
|
0
|
308
|
my (@states) = @_; |
37
|
|
|
|
|
|
|
|
38
|
146
|
|
|
|
|
279
|
my @indexes = map { 0 } @states; |
|
299
|
|
|
|
|
485
|
|
39
|
146
|
|
|
|
|
242
|
my @max_indexes = map { $#$_ } @states; |
|
299
|
|
|
|
|
523
|
|
40
|
|
|
|
|
|
|
|
41
|
|
|
|
|
|
|
# we can't iterate if one of the elements do not exist |
42
|
146
|
|
|
|
|
234
|
my $finished = scalar grep { $_ < 0 } @max_indexes; |
|
299
|
|
|
|
|
582
|
|
43
|
|
|
|
|
|
|
return sub { |
44
|
122958
|
|
|
122958
|
|
192784
|
my ($with_indexes) = @_; |
45
|
122958
|
100
|
|
|
|
186909
|
return if $finished; |
46
|
|
|
|
|
|
|
|
47
|
122876
|
|
|
|
|
151616
|
my $i = 0; |
48
|
|
|
|
|
|
|
my @ret = |
49
|
245819
|
100
|
|
|
|
356368
|
map { is_state($_) ? $_->value : $_ } |
50
|
122876
|
|
|
|
|
174326
|
map { $states[$i++][$_] } |
|
245819
|
|
|
|
|
395189
|
|
51
|
|
|
|
|
|
|
@indexes; |
52
|
|
|
|
|
|
|
|
53
|
122876
|
100
|
|
|
|
204862
|
if ($with_indexes) { |
54
|
39529
|
|
|
|
|
101172
|
@ret = map { $indexes[$_], $ret[$_] } 0 .. max($#indexes, $#ret); |
|
79058
|
|
|
|
|
161973
|
|
55
|
|
|
|
|
|
|
} |
56
|
|
|
|
|
|
|
|
57
|
122876
|
|
|
|
|
151579
|
$i = 0; |
58
|
122876
|
|
100
|
|
|
348996
|
while ($i < @indexes && ++$indexes[$i] > $max_indexes[$i]) { |
59
|
16097
|
|
|
|
|
20470
|
$indexes[$i] = 0; |
60
|
16097
|
|
|
|
|
39104
|
$i += 1; |
61
|
|
|
|
|
|
|
} |
62
|
|
|
|
|
|
|
|
63
|
122876
|
|
|
|
|
177741
|
$finished = $i == @indexes; |
64
|
122876
|
|
|
|
|
327468
|
return @ret; |
65
|
146
|
|
|
|
|
922
|
}; |
66
|
|
|
|
|
|
|
} |
67
|
|
|
|
|
|
|
|
68
|
|
|
|
|
|
|
1; |
69
|
|
|
|
|
|
|
|