in reply to N-Dimensional Arrays on the fly
The lvalue sub might be a tad too cutesy, but I think its usage at the bottom reads fairly well (since you want to use $a[x][x]..[x] as an lvalue)use Algorithm::Loops 'NestedLoops'; ## returns an alias to $_[0]->[ $_[1] ]...[ $_[-1] ] sub deref_many : lvalue { my $ptr = \shift; $ptr = \$$ptr->[$_] for @_; $$ptr; } my @array; my @size = (4, 5, 6); NestedLoops( [ map [0 .. $_-1], @size ], sub { deref_many(\@array, @_) = rand } );
While all of this might be cleaner, and it avoids eval, I would imagine that your initial eval solution is going to be fastest, since it doesn't involve any function call overhead.
blokhead
|
|---|