|  line  | 
 stmt  | 
 bran  | 
 cond  | 
 sub  | 
 pod  | 
 time  | 
 code  | 
| 
1
 | 
  
 
  
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 =head1 NAME  | 
| 
2
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
3
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 PDLA::Lvalue - declare PDLA lvalue subs  | 
| 
4
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
5
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 =head1 DESCRIPTION  | 
| 
6
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
7
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 Declares a subset of PDLA functions so that they  | 
| 
8
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 can be used as lvalue subs. In particular, this allows  | 
| 
9
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 simpler constructs such as  | 
| 
10
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
11
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
   $x->slice(',(0)') .= 1;  | 
| 
12
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
13
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 instead of the clumsy  | 
| 
14
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
15
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
   (my $tmp = $x->slice(',(0)')) .= 1;  | 
| 
16
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
17
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 This will only work if your perl supports lvalue subroutines  | 
| 
18
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 (i.e. versions  >= v5.6.0). Note that lvalue subroutines  | 
| 
19
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 are currently regarded experimental.  | 
| 
20
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
21
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 =head1 SYNOPSIS  | 
| 
22
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
23
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
  use PDLA::Lvalue; # automatically done with all PDLA loaders  | 
| 
24
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
25
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 =head1 FUNCTIONS  | 
| 
26
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
27
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 =cut  | 
| 
28
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
29
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 package PDLA::Lvalue;  | 
| 
30
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
31
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 # list of functions that can be used as lvalue subs  | 
| 
32
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 # extend as necessary  | 
| 
33
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 my @funcs = qw/ clump diagonal dice dice_axis dummy flat  | 
| 
34
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
                 index index2d indexND indexNDb mslice mv  | 
| 
35
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
                 nslice nslice_if_pdl nnslice polyfillv px  | 
| 
36
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
                 range rangeb reorder reshape sever slice  | 
| 
37
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
                 where whereND xchg /;  | 
| 
38
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
39
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 my $prots = join "\n", map {"use attributes 'PDLA', \\&PDLA::$_, 'lvalue';"}  | 
| 
40
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
   @funcs;  | 
| 
41
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
42
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 =head2 subs  | 
| 
43
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
44
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 =for ref  | 
| 
45
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
46
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 test if routine is a known PDLA lvalue sub  | 
| 
47
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
48
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 =for example  | 
| 
49
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
50
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
   print "slice is an lvalue sub" if PDLA::Lvalue->subs('slice');  | 
| 
51
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
52
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 returns the list of PDLA lvalue subs if no routine name is given, e.g.  | 
| 
53
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
54
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
   @lvfuncs = PDLA::Lvalue->subs;  | 
| 
55
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
56
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 It can be used in scalar context to find out if your  | 
| 
57
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 PDLA has lvalue subs:  | 
| 
58
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
59
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
   print 'has lvalue subs' if PDLA::Lvalue->subs;  | 
| 
60
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
61
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 =cut  | 
| 
62
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
63
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 sub subs {  | 
| 
64
 | 
1
 | 
 
 | 
 
 | 
  
1
  
 | 
  
1
  
 | 
63
 | 
   my ($type,$func) = @_;  | 
| 
65
 | 
1
 | 
  
 50
  
 | 
 
 | 
 
 | 
 
 | 
12
 | 
   if (defined $func) {  | 
| 
66
 | 
  
0
  
 | 
 
 | 
 
 | 
 
 | 
 
 | 
0
 | 
     $func =~ s/^.*:://;  | 
| 
67
 | 
0
 | 
 
 | 
  
  0
  
 | 
 
 | 
 
 | 
0
 | 
     return ($^V and $^V >= 5.006007) && scalar grep {$_ eq $func} @funcs;  | 
| 
68
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
   } else {  | 
| 
69
 | 
1
 | 
  
 50
  
 | 
  
 33
  
 | 
 
 | 
 
 | 
27
 | 
     return ($^V and $^V >= 5.006007) ? @funcs : ();  | 
| 
70
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
   }  | 
| 
71
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 }  | 
| 
72
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
73
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 # print "defining lvalue subs:\n$prots\n";  | 
| 
74
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
75
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
700
 | 
 eval << "EOV" if ($^V and $^V >= 5.006007);  | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
195
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
5383
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
44474
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
95373
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
597
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
18457
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
195
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
414
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
11055
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
198
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
403
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
10788
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
180
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
384
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
10793
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
202
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
467
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
11179
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
197
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
378
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
11678
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
199
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
490
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
7002
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
192
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
  
77
  
 | 
 
 | 
447
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
6672
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
209
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
421
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
11458
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
196
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
398
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
6538
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
199
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
455
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
11068
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
242
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
411
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
6675
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
207
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
450
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
11065
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
225
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
490
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
11532
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
256
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
452
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
6953
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
236
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
525
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
6880
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
267
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
486
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
7817
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
192
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
466
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
11163
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
209
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
457
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
6688
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
215
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
455
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
11364
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
196
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
479
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
11694
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
212
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
404
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
6553
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
235
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
397
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
11219
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
197
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
496
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
11587
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
198
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
392
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
6680
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
220
 | 
    | 
| 
 
 | 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
461
 | 
    | 
| 
76
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 { package PDLA;  | 
| 
77
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
   no warnings qw(misc);  | 
| 
78
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
   $prots  | 
| 
79
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 }  | 
| 
80
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 EOV  | 
| 
81
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
82
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 =head1 AUTHOR  | 
| 
83
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
84
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 Copyright (C) 2001 Christian Soeller (c.soeller@auckland.ac.nz). All  | 
| 
85
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 rights reserved. There is no warranty. You are allowed to redistribute  | 
| 
86
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 this software / documentation under certain conditions. For details,  | 
| 
87
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 see the file COPYING in the PDLA distribution. If this file is  | 
| 
88
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 separated from the PDLA distribution, the copyright notice should be  | 
| 
89
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 included in the file.  | 
| 
90
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
91
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 =cut  | 
| 
92
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
    | 
| 
93
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 
 | 
 1;  |