README
image izef_math_libgsl_digitalfiltering_math_libgsl_digitalfiltering_0_0_2_examples_04_impulse_svg not found
NAME
Math::Libgsl::DigitalFiltering - An interface to libgsl, the Gnu Scientific Library - Digital Filtering
SYNOPSIS
use Math::Libgsl::Vector;
use Math::Libgsl::DigitalFiltering;
my constant $N = 1000;
my constant $K = 21;
my Math::Libgsl::Vector $x .= new: :size($N);
$x.scanf('data.dat');
my Math::Libgsl::DigitalFiltering::Gaussian $gauss .= new: :size($K);
my $y = $gauss.filter(2.5, $x);
DESCRIPTION
Math::Libgsl::DigitalFiltering is an interface to the Digital Filtering functions of libgsl, the Gnu Scientific Library.
This module exports four classes:
Math::Libgsl::DigitalFiltering::Gaussian
Math::Libgsl::DigitalFiltering::Median
Math::Libgsl::DigitalFiltering::RMedian
Math::Libgsl::DigitalFiltering::Impulse
each encapsulates the methods and the buffers needed to create and use the filter on the data stored in a Math::Libgsl::Vector object.
Math::Libgsl::DigitalFiltering::Gaussian
This class encapsulate a Gaussian filter.
multi method new(Int $size!)
multi method new(Int :$size!)
The constructor accepts one simple or named argument: the kernel size.
filter(Num() x!, Int :endtype = GSL_MOVSTAT_END_PADZERO, Bool :$inplace? --> Math::Libgsl::Vector)
This method applies a Gaussian filter parameterized by x. The optional named argument :endtype specifies how the signal end points are handled. The symbolic names for this argument are listed in the Math::Libgsl::Constants module as follows:
GSL_MOVSTAT_END_PADZERO: inserts zeros into the window near the signal end points
GSL_MOVSTAT_END_PADVALUE: pads the window with the first and last sample in the input signal
GSL_MOVSTAT_END_TRUNCATE: no padding is performed: the windows are truncated as the end points are approached
The boolean named argument :$inplace directs the method to apply the filter in-place. This method returns the filter output as a Math::Libgsl::Vector object.
kernel(Num() size, Int :normalize = 0 --> Math::Libgsl::Vector)
This method constructs a Gaussian kernel parameterized by size. The optional named argument :normalize specifies if the kernel is to be normalized to sum to one on output. This method returns the filter output as a Math::Libgsl::Vector object.
Math::Libgsl::DigitalFiltering::Median
This class encapsulate a Median filter.
multi method new(Int $size!)
multi method new(Int :$size!)
The constructor accepts one simple or named argument: the kernel size.
filter(Math::Libgsl::Vector endtype = GSL_MOVSTAT_END_PADZERO, Bool :$inplace? --> Math::Libgsl::Vector)
This method applies a Median filter to the input vector endtype specifies how the signal end points are handled. The optional boolean named argument :$inplace directs the method to apply the filter in-place. This method returns the filter output as a Math::Libgsl::Vector object.
Math::Libgsl::DigitalFiltering::RMedian
This class encapsulate a recursive Median filter.
multi method new(Int $size!)
multi method new(Int :$size!)
The constructor accepts one simple or named argument: the kernel size.
filter(Math::Libgsl::Vector endtype = GSL_MOVSTAT_END_PADZERO, Bool :$inplace? --> Math::Libgsl::Vector)
This method applies a Median filter to the input vector endtype specifies how the signal end points are handled. The optional boolean named argument :$inplace directs the method to apply the filter in-place. This method returns the filter output as a Math::Libgsl::Vector object.
Math::Libgsl::DigitalFiltering::Impulse
This class encapsulate an Impulse detection filter.
multi method new(Int $size!)
multi method new(Int :$size!)
The constructor accepts one simple or named argument: the kernel size.
filter(Math::Libgsl::Vector tuning, Int :scaletype = GSL_FILTER_SCALE_MAD, Bool :$inplace? --> List)
This method applies an Impulse filter to the input vector tuning. The optional named argument :scaletype specifies how the scale estimate Sā of the window is calculated. The symbolic names for this argument are listed in the Math::Libgsl::Constants module as follows:
GSL_FILTER_SCALE_MAD: specifies the median absolute deviation (MAD) scale estimate
GSL_FILTER_SCALE_IQR: specifies the interquartile range (IQR) scale estimate
GSL_FILTER_SCALE_SN: specifies the so-called Sā statistic
GSL_FILTER_SCALE_QN: specifies the so-called Qā statistic
The optional boolean named argument :$inplace directs the method to apply the filter in-place. This method returns a List of values:
the window medians, as a Math::Libgsl::Vector object
the window Sā, as a Math::Libgsl::Vector object
the number of outliers as an Int
the location of the outliers as a Math::Libgsl::Vector::Int32 object
C Library Documentation
For more details on libgsl see https://www.gnu.org/software/gsl/. The excellent C Library manual is available here https://www.gnu.org/software/gsl/doc/html/index.html, or here https://www.gnu.org/software/gsl/doc/latex/gsl-ref.pdf in PDF format.
Prerequisites
This module requires the libgsl library to be installed. Please follow the instructions below based on your platform:
Debian Linux and Ubuntu 20.04+
sudo apt install libgsl23 libgsl-dev libgslcblas0
That command will install libgslcblas0 as well, since it's used by the GSL.
Ubuntu 18.04
libgsl23 and libgslcblas0 have a missing symbol on Ubuntu 18.04. I solved the issue installing the Debian Buster version of those three libraries:
http://http.us.debian.org/debian/pool/main/g/gsl/libgslcblas0_2.5+dfsg-6_amd64.deb
http://http.us.debian.org/debian/pool/main/g/gsl/libgsl23_2.5+dfsg-6_amd64.deb
http://http.us.debian.org/debian/pool/main/g/gsl/libgsl-dev_2.5+dfsg-6_amd64.deb
Installation
To install it using zef (a module management tool):
$ zef install Math::Libgsl::DigitalFiltering
AUTHOR
Fernando Santagata [email protected]
COPYRIGHT AND LICENSE
Copyright 2020 Fernando Santagata
This library is free software; you can redistribute it and/or modify it under the Artistic License 2.0.