The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

ObjStore::Lib::PDL - Persistent PDL-compatible matrices

SYNOPSIS

    use PDL::Lite;
    use ObjStore::Lib::PDL;

    begin 'update', sub {
      my $pdl = ObjStore::Lib::PDL->new($near,
                          { Datatype => PDL::float(), Dims => [3,3] });

      $pdl->slice(":,4")->clump(2) *= 2;  #or whatever
    };
    die if $@;

DESCRIPTION

The main thing of interest is that dimensions are arranged in memory such that the last dimension is the most packed. For example, in a PDL of dimensions [3,3,3] the following locations are sequential in memory:

  [2,1,0]
  [2,1,1]
  [2,1,2]

Whereas the follow three elements are separated by relatively large gaps:

  [0,2,1]
  [1,2,1]
  [2,2,1]

Be aware that this memory layout convention is dependent on the implementation of PDL. However, it is very unlikely to change.