#image-processing #array #multi-dimensional #ndarray #matrix #image

ndarray-ndimage

Multidimensional image processing for ArrayBase, the n-dimensional array data structure provided by ndarray

9 unstable releases (3 breaking)

0.4.0 Aug 31, 2023
0.3.0 Dec 8, 2022
0.2.2 Nov 18, 2022
0.1.3 Oct 14, 2021

#765 in Data structures

Download history 373/week @ 2024-07-22 156/week @ 2024-07-29 269/week @ 2024-08-05 144/week @ 2024-08-12 87/week @ 2024-08-19 92/week @ 2024-08-26 99/week @ 2024-09-02 186/week @ 2024-09-09 101/week @ 2024-09-16 469/week @ 2024-09-23 365/week @ 2024-09-30 188/week @ 2024-10-07 155/week @ 2024-10-14 157/week @ 2024-10-21 241/week @ 2024-10-28 277/week @ 2024-11-04

832 downloads per month
Used in 2 crates

MIT/Apache

97KB
2K SLoC

ndarray-ndimage

This crate provides multidimensional image processing for ndarray's ArrayBase type. It is mainly focussed on 3D arrays/images for now, but some functions are available on on n-d arrays.

It aims to:

  • be a Rust replacement for scipy.ndimage with some other tools like numpy.pad and anything else relevant to image processing. We do not want all options and arguments offered by scipy.ndimage because some of them are incompatible with Rust. We hope to offer the most used ones.
  • be faster or as fast as scipy.ndimage. Most of it is cythonized so it's not as easy as it seems. In fact, I'm usually unable to be faster than SciPy but it does happen on some functions.
  • avoid using unsafe. This is not an unbreakable rule. Its usage will be evaluated and dicussed in the pull requests.

Currently available routines include:

  • Filters: convolve/1d, correlate/1d, gaussian_filter/1d, min/max_filter/1d, median_filter, prewitt, sobel
  • Fourier filters: none. Please use the excellent rustfft crate
  • Interpolation: shift, spline_filter/1d, zoom
  • Measurements: label, label_histogram, largest_connected_components, most_frequent_label
  • Morphology: binary_closing, binary_dilation, binary_erosion, binary_opening. Works on all kernels (structuring elements).
  • Padding: Almost all modes. Work for all dimensions and types.

This crate is a work-in-progress. Only a subset of the scipy.ndimage functions are provided and most of them offer less options than SciPy. Some are offered only in 3D, with less boundary modes, with only 2 types of structuring element, only for binary data, only for f64, etc.

Using with Cargo

[dependencies]
ndarray = "0.15"
ndarray-ndimage = "0.2"

Contributing

ndarray-ndimage needs your help to grow. Please feel free to create issues and submit PRs. Since it is based on scipy.ndimage, it is easy to port new functions and tests. Reading Cython code is highly unpleasant; the joy comes from porting it to Rust!

License

Licensed under the Apache License, Version 2.0 http://www.apache.org/licenses/LICENSE-2.0 or the MIT license http://opensource.org/licenses/MIT, at your option. This file may not be copied, modified, or distributed except according to those terms.

Dependencies

~3.5MB
~61K SLoC