NAME

PDL::FuncND - N dimensional version of functions

VERSION

version 0.13

SYNOPSIS

use PDL::FuncND;

DESCRIPTION

This module provides multi-dimensional implementations of common functions.

INTERNALS

FUNCTIONS

cauchyND

Evaluate the multi-variate Cauchy function on an N-dimensional grid or at a set of locations.

$a = cauchyND( [OPTIONAL TYPE], $nx, $ny, ..., \%options );
$b = cauchyND( $a, \%options );
cauchyND( inplace $a, \%options );
$a->inplace->cauchyND( \%options );

cauchyND can evaluate the function either on a grid or at discrete locations:

  • evaluation on a grid

    Either specify the output piddle dimensions explicitly,

    $f = cauchyND( [ OPTIONAL TYPE], $nx, $ny, ..., \%options );

    or specify a template piddle without specifying the vectors option:

    $f = cauchyND( $piddle, \%options );

    By default cauchyND will evaluate the function at the indices of the points in the input piddle. These may be mapped to other values by specifying a transform with the transform option. cauchyND is inplace aware, and will use $piddle as the output piddle if its inplace flag is set.

    cauchyND( inplace $f, \%options );
    $f->inplace->cauchyND( \%options );
  • evaluation at a set of locations

    The input piddle should represent a set of vectors and should have a shape of (N,m), where m is the number of vectors in the set. The vectors option must also be set:

    $piddle = pdl( [2,1], [3,1], [4,2]  );
    $f = cauchyND( $piddle, { vectors => 1 } );

    The vectors may be transformed before use via the transform option.

The following options are available:

center | centre

The center of the distribution. If not specified it defaults to the origin.

This may take one of the following forms

  • A vector of shape (N).

    The location of the center. This may be either a Perl arrayref or a one dimensional piddle. If the input coordinates are transformed, this is in the transformed space.

  • the string auto

    If the PDF is calculated on a grid, this will center the distribution on the grid. It is an error to use this for explicit locations.

  • An arrayref

    The first element of the array is a string indicating the meaning of the rest of the array. The following are supported:

    • offset

      The second element of the array is a piddle indicating an offset from an automatically generated center. This allows easily accumulating multiple offset offsets. For example:

      $img  = cauchyND( double, 32, 32, { %attr, center => 'auto' } );
      $img += moffatND( $img, { %moffat_attr,
                                center => [ offset => [ 5.24, 0.3 ] ] } );
transform

A PDL::Transform object to be applied to the input coordinates.

scale

The scale. If the input coordinates are transformed via the transform option, the units of scale are those in the transformed space. This may be specified as:

  • a scalar (Perl or piddle)

    This results in a symmetric distribution with the given scale along each coordinate.

  • a vector of shape (N) (piddle or Perl arrayref)

    This results in a distribution with the specified scales for each coordinate.

  • a matrix (piddle of shape (N,N))

    This should be a positive-definite matrix containing squared scales.

theta (Perl scalar)

Only for 2D! Applies a rotation (clockwise, e.g. +X rotates towards -Y) by the specified angle (specified in radians).

log (Boolean)

If true, return the logarithm of the function. Defaults to false.

gaussND

Evaluate the sampled multi-dimensional Gaussian PDF on an N-dimensional grid or at a set of locations.

$f = gaussND( [OPTIONAL TYPE], $nx, $ny, ..., \%options );
$f = gaussND( $piddle, \%options );
gaussND( inplace $piddle, \%options );
$a->inplace->gaussND( \%options );

gaussND can evaluate the function either on a grid or at discrete locations:

  • evaluation on a grid

    Either specify the output piddle dimensions explicitly,

    $f = gaussND( [ OPTIONAL TYPE], $nx, $ny, ..., \%options );

    or specify a template piddle without specifying the vectors option:

    $f = gaussND( $piddle, \%options );

    By default gaussND will evaluate the function at the indices of the points in the input piddle. These may be mapped to other values by specifying a transform with the transform option. gaussND is inplace aware, and will use $piddle as the output piddle if its inplace flag is set.

    gaussND( inplace $f, \%options );
    $f->inplace->gaussND( \%options );
  • evaluation at a set of locations

    The input piddle should represent a set of vectors and should have a shape of (N,m), where m is the number of vectors in the set. The vectors option must also be set:

    $piddle = pdl( [2,1], [3,1], [4,2]  );
    $f = gaussND( $piddle, { vectors => 1 } );

    The vectors may be transformed before use via the transform option.

The following options are available:

center | centre

The center of the distribution. If not specified it defaults to the origin.

This may take one of the following values:

  • A vector of shape (N).

    The location of the center. This may be either a Perl arrayref or a one dimensional piddle. If the input coordinates are transformed, this is in the transformed space.

  • the string auto

    If the PDF is calculated on a grid, this will center the distribution on the grid. It is an error to use this for explicit locations.

transform

A PDL::Transform object to be applied to the input coordinates.

scale

The scale. If the input coordinates are transformed via the transform option, the units of scale are those in the transformed space. This may be specified as:

  • a scalar (Perl or piddle)

    This results in a symmetric distribution with the given scale along each coordinate.

  • a vector of shape (N) (piddle or Perl arrayref)

    This results in a distribution with the specified scales for each coordinate.

  • the full covariance matrix (piddle of shape (N,N))

    This results in a distribution with correlated scales. At present this matrix is not verified to be a legitimate covariance matrix.

theta (Perl scalar)

Only for 2D! Applies a rotation (clockwise, e.g. +X rotates towards -Y) by the specified angle (specified in radians).

log (Boolean)

If true, return the logarithm of the function. Defaults to false.

lorentzND

Evaluate the multi-dimensional Lorentz function on an N-dimensional grid or at a set of locations.

$f = lorentzND( [OPTIONAL TYPE], $nx, $ny, ..., \%options );
$f = lorentzND( $piddle, \%options );
lorentzND( inplace $piddle, \%options );
$a->inplace->lorentzND( \%options );

The Lorentz function is usually defined in one dimension as.

                     2
                    g
f(x; x0, g) = --------------
                     2    2
              (x - x0)  + g

where g is the half-width at half-max (HWHM). The two dimensional symmetric analogue (sometimes called the "radial Lorentz function") is

                                  2
                                 g
f(x, y; x0, y0, g) = --------------------------
                             2           2    2
                     (x - x0)  + (y - y0)  + g

One can extend this to an asymmetric form by writing it as

                          1
f(x; u, S) = ---------------------------
                    T    -1
             (x - u)  . S  . (x - u) + 1

where x is now a vector, u is the expectation value of the distribution, and S is a matrix describing the N-dimensional scale of the distribution akin to (but not the same as!) a covariance matrix.

For example, a symmetric 2D Lorentz with HWHM of g has

     [  2     ]
     [ g   0  ]
S =  [        ]
     [      2 ]
     [ 0   g  ]

while an elliptical distribution elongated twice as much along the X axis as the Y axis would be:

     [     2      ]
     [ (2*g)   0  ]
S =  [            ]
     [          2 ]
     [ 0       g  ]

lorentzND extends the Lorentz function to N dimensions by treating x and u as vectors of length N, and S as an NxN matrix.

Please note! While the one dimensional Lorentz function is equivalent to the one-dimensional Cauchy (aprt from, in this formulation, the normalization constant), this formulation of the multi-dimensional Lorentz function is not equivalent to the multi-dimensional Cauchy!

It can evaluate the function either on a grid or at discrete locations:

  • evaluation on a grid

    Either specify the output piddle dimensions explicitly,

    $f = lorentzND( [ OPTIONAL TYPE], $nx, $ny, ..., \%options );

    or specify a template piddle without specifying the vectors option:

    $f = lorentzND( $piddle, \%options );

    By default lorentzND will evaluate the function at the indices of the points in the input piddle. These may be mapped to other values by specifying a transform with the transform option. lorentzND is inplace aware, and will use $piddle as the output piddle if its inplace flag is set.

    lorentzND( inplace $f, \%options );
    $f->inplace->lorentzND( \%options );
  • evaluation at a set of locations

    The input piddle should represent a set of vectors and should have a shape of (N,m), where m is the number of vectors in the set. The vectors option must also be set:

    $piddle = pdl( [2,1], [3,1], [4,2]  );
    $f = lorentzND( $piddle, { vectors => 1 } );

    The vectors may be transformed before use via the transform option.

The following options are available:

center | centre

The center of the distribution. If not specified it defaults to the origin.

This may take one of the following values:

  • A vector of shape (N).

    The location of the center. This may be either a Perl arrayref or a one dimensional piddle. If the input coordinates are transformed, this is in the transformed space.

  • the string auto

    If the PDF is calculated on a grid, this will center the distribution on the grid. It is an error to use this for explicit locations.

transform

A PDL::Transform object to be applied to the input coordinates.

scale

The scale. If the input coordinates are transformed via the transform option, the units of scale are those in the transformed space. This may be specified as:

  • a scalar (Perl or piddle)

    This results in a symmetric distribution with the given scale along each coordinate.

  • a vector of shape (N) (piddle or Perl arrayref)

    This results in a distribution with the specified scales for each coordinate.

  • a matrix (piddle of shape (N,N))

    This should be a positive-definite matrix containing squared scales.

theta (Perl scalar)

Only for 2D! Applies a rotation (clockwise, e.g. +X rotates towards -Y) by the specified angle (specified in radians).

moffatND

Evaluate the multi-dimensional Moffat distribution on an N-dimensional grid or at a set of locations.

$f = moffatND( [OPTIONAL TYPE], $nx, $ny, ..., \%options );
$f = moffatND( $piddle, \%options );
moffatND( inplace $piddle, \%options );
$a->inplace->moffatND( \%options );

The Moffat distribution is usually defined in two dimensions as.

                                                         2    2
                                            2  -1       x  + y  -beta
f(x, y, alpha, beta) := (beta - 1) (pi alpha  )    (a + -------)
                                                              2
                                                         alpha

In astronomy this is also known (confusingly) as the beta function, and is often expressed in radial form:

                                             2
                      2 r (beta - 1)        r    -beta
fr(r, alpha, beta) := -------------- (1 + ------)
                               2               2
                          alpha           alpha

One can extend the Cartesion expression to an n-dimensional asymmetric form by writing it as

fn(x, u, S, alpha, beta) :=

     gamma(beta)        n/2    1/2  -1              T   -1         -beta
  ----------------- ( pi    |S|    )    (1 + (x - u) . S . (x - u))
        2 beta - n
  gamma(----------)
            2

where n is the number of dimensions, x is now a vector, u is the expectation value of the distribution, and S is a matrix describing the N-dimensional scale of the distribution akin to (but not the same as!) a covariance matrix.

Note that the integral of the distribution diverges for beta <= n/2.

moffatND extends the Moffat function to N dimensions by treating x and u as vectors of length N, and S as an NxN matrix.

It can evaluate the function either on a grid or at discrete locations:

  • evaluation on a grid

    Either specify the output piddle dimensions explicitly,

    $f = moffatND( [ OPTIONAL TYPE], $nx, $ny, ..., \%options );

    or specify a template piddle without specifying the vectors option:

    $f = moffatND( $piddle, \%options );

    By default moffatND will evaluate the function at the indices of the points in the input piddle. These may be mapped to other values by specifying a transform with the transform option. moffatND is inplace aware, and will use $piddle as the output piddle if its inplace flag is set.

    moffatND( inplace $f, \%options );
    $f->inplace->moffatND( \%options );
  • evaluation at a set of locations

    The input piddle should represent a set of vectors and should have a shape of (N,m), where m is the number of vectors in the set. The vectors option must also be set:

    $piddle = pdl( [2,1], [3,1], [4,2]  );
    $f = moffatND( $piddle, { vectors => 1 } );

    The vectors may be transformed before use via the transform option.

The following options are available:

beta

The Moffat beta parameter. Required.

center | centre

The center of the distribution. If not specified it defaults to the origin.

This may take one of the following values:

  • A vector of shape (N).

    The location of the center. This may be either a Perl arrayref or a one dimensional piddle. If the input coordinates are transformed, this is in the transformed space.

  • the string auto

    If the PDF is calculated on a grid, this will center the distribution on the grid. It is an error to use this for explicit locations.

transform

A PDL::Transform object to be applied to the input coordinates.

scale

The scale. If the input coordinates are transformed via the transform option, the units of scale are those in the transformed space. This may be specified as:

  • a scalar (Perl or piddle)

    This results in a symmetric distribution with the given scale along each coordinate.

  • a vector of shape (N) (piddle or Perl arrayref)

    This results in a distribution with the specified scales for each coordinate.

  • a matrix (piddle of shape (N,N))

    This should be a positive-definite matrix containing squared scales.

theta (Perl scalar)

Only for 2D! Applies a rotation (clockwise, e.g. +X rotates towards -Y) by the specified angle (specified in radians).

mahalanobis

Calculate the Mahalanobis distance for one or more vectors

Signature: ( x(n,m), s(n,n), [o]d(m), \%options )
$d = mahalanobis( $v, $S, \%options );
mahalanobis( $v, $S, $d, \%options );

The Mahalanobis distance of a multivariate vector (v) from a location (u) with a covariance matrix (S) is defined as

dm(x,u) = sqrt( (v-u)T S^-1 (v-u) )

The input piddle representing the vectors ($v) must have shape (N,m), where N is the dimension of the vector space and m is the number of vectors.

The input covariance matrix ($S) must have shape (N,N). It is not checked for validity.

The available options are:

center | centre

The vector from which the distance is to be calculated. It must have shape (N). It defaults to the origin.

inverted

If true, the input matrix is the inverse of the covariance matrix. Defaults to false.

squared

if true, the returned values are the distances squared.

SUPPORT

Bugs

Please report any bugs or feature requests to bug-pdl-funcnd@rt.cpan.org or through the web interface at: https://rt.cpan.org/Public/Dist/Display.html?Name=PDL-FuncND

Source

Source is available at

https://gitlab.com/djerius/pdl-funcnd

and may be cloned from

https://gitlab.com/djerius/pdl-funcnd.git

AUTHOR

Diab Jerius <djerius@cpan.org>

COPYRIGHT AND LICENSE

This software is Copyright (c) 2025 by Smithsonian Astrophysical Observatory.

This is free software, licensed under:

The GNU General Public License, Version 3, June 2007