Metadata-Version: 2.1
Name: pyefd
Version: 1.6.0
Summary: Python implementation of "Elliptic Fourier Features of a Closed Contour"
Home-page: UNKNOWN
Author: Henrik Blidh
Author-email: henrik.blidh@nedomkull.com
License: MIT
Keywords: elliptic fourier descriptors,fourier descriptors,shape descriptors,image analysis
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Operating System :: OS Independent
Classifier: Intended Audience :: Science/Research
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Topic :: Software Development
Classifier: Topic :: Scientific/Engineering
Classifier: Programming Language :: Python :: 2
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: Implementation :: CPython
Classifier: Programming Language :: Python :: Implementation :: PyPy
Requires-Python: >=2.7.10
Description-Content-Type: text/markdown
License-File: LICENSE


PyEFD
=====

[![Build and Test](https://github.com/hbldh/pyefd/workflows/Build%20and%20Test/badge.svg)](https://github.com/hbldh/pyefd/actions?query=workflow%3A%22Build+and+Test%22)
[![Documentation Status](https://readthedocs.org/projects/pyefd/badge/?version=latest)](http://pyefd.readthedocs.org/en/latest/?badge=latest)
[![image](http://img.shields.io/pypi/v/pyefd.svg)](https://pypi.python.org/pypi/pyefd/)
[![image](http://img.shields.io/pypi/l/pyefd.svg)](https://pypi.python.org/pypi/pyefd/)
[![image](https://coveralls.io/repos/github/hbldh/pyefd/badge.svg?branch=master)](https://coveralls.io/github/hbldh/pyefd?branch=master)

An Python/NumPy implementation of a method for approximating a contour with a Fourier series, as described in [1].

Installation
------------

```bash
pip install pyefd
```

Usage
-----

Given a closed contour of a shape, generated by e.g. [scikit-image](http://scikit-image.org/) or
 [OpenCV](http://opencv.org/), this package can fit a 
 [Fourier series](https://en.wikipedia.org/wiki/Fourier_series) approximating the shape of the contour.

### General usage examples

This section describes the general usage patterns of `pyefd`.

```python
from pyefd import elliptic_fourier_descriptors
coeffs = elliptic_fourier_descriptors(contour, order=10)
```

The coefficients returned are the `a_n`, `b_n`, `c_n` and `d_n` of the following Fourier series 
representation of the shape.

The coefficients returned are by default normalized so that they are rotation and size-invariant. 
This can be overridden by calling:

```python
from pyefd import elliptic_fourier_descriptors
coeffs = elliptic_fourier_descriptors(contour, order=10, normalize=False)
```

Normalization can also be done afterwards:

```python
from pyefd import normalize_efd
coeffs = normalize_efd(coeffs)
```

### OpenCV example

If you are using [OpenCV](http://opencv.org/) to generate contours, this example shows how to 
connect it to `pyefd`.

```python
import cv2 
import numpy
from pyefd import elliptic_fourier_descriptors

# Find the contours of a binary image using OpenCV.
contours, hierarchy = cv2.findContours(
    im, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)

# Iterate through all contours found and store each contour's 
# elliptical Fourier descriptor's coefficients.
coeffs = []
for cnt in contours:
    # Find the coefficients of all contours
    coeffs.append(elliptic_fourier_descriptors(
        numpy.squeeze(cnt), order=10))
```

### Using EFD as features

To use these as features, one can write a small wrapper function:

```python
from pyefd import elliptic_fourier_descriptors

def efd_feature(contour):
    coeffs = elliptic_fourier_descriptors(contour, order=10, normalize=True)
    return coeffs.flatten()[3:]
```

If the coefficients are normalized, then `coeffs[0, 0] = 1.0`, `coeffs[0, 1] = 0.0` and 
`coeffs[0, 2] = 0.0`, so they can be disregarded when using the elliptic Fourier descriptors as features.

See [1] for more technical details.

Testing
-------

Run tests with with [Pytest](http://pytest.org/latest/):

```bash
py.test tests.py
```

The tests include a single image from the MNIST dataset of handwritten digits ([2]) as a contour to use for testing.

Documentation
-------------

See [ReadTheDocs](http://pyefd.readthedocs.org/).

References
----------

[1]: [Frank P Kuhl, Charles R Giardina, Elliptic Fourier features of a closed contour, Computer Graphics and Image Processing, Volume 18, Issue 3, 1982, Pages 236-258, ISSN 0146-664X, <http://dx.doi.org/10.1016/0146-664X(82)90034-X>.](http://www.sci.utah.edu/~gerig/CS7960-S2010/handouts/Kuhl-Giardina-CGIP1982.pdf)

[2]: [LeCun et al. (1999): The MNIST Dataset Of Handwritten Digits](http://yann.lecun.com/exdb/mnist/)


# Changelog
All notable changes to this project will be documented in this file.

The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).

## [1.6.0] (2021-12-09)

### Added

- Added a demo for 3D surfaces with cylindrical symmetries. (`examples/example1.py`)

### Fixes

- Fixes incorrectly plotted curves when no `imshow` has been called.
- Fixes ugly coefficient calculation code.

## [1.5.1] (2021-01-22)

### Added

- `return_transformation` keyword on `elliptic_fourier_descriptors` method. Merged #11. Fixes #5.

### Fixes

- Documentation correction. Merged #12.

### Removed

- Deleted broken example script `scikit_image.py`.

## [1.4.1] (2020-09-28)

### Added

- Added `CHANGELOG.md`

### Changed

- Change CI from Azure Devops to Github Actions

## [1.4.0] (2019-07-27)

### Changed

- Merged PR #4: Vectorized contour reconstruction function

## [1.3.0] (2019-06-18)

### Changed

- Merged PR #2: Numpy vectorized efd
- Moved from Travis CI to Azure Pipelines
- Replaced rst with markdown

## [1.2.0] (2018-06-14)

### Changed

- Updated setup.py
- Updated numpy requirement

### Added

- Added Pipfile
- Ran Black on code
- Testing on 3.6

## [1.1.0] (2018-06-13)

### Added

- New example for OpenCV
- Updated documentation

## [1.0.0] (2016-04-19)

### Changed

- Deemed stable enough for version 1.0 release

### Added

- Created documentation.

## [0.1.2] (2016-02-29)

### Changed

- Testing with pytest instead of nosetests.

### Added

- Added Coveralls use.

## [0.1.1] (2016-02-17)

### Fixed

- Fixed MANIFEST

### Added

- Added LICENSE file that was missing.

## 0.1.0 (2016-02-09)

### Added

- Initial release

[Unreleased]: https://github.com/hbldh/pyefd/compare/v1.6.0...HEAD
[1.6.0]: https://github.com/hbldh/pyefd/compare/v1.5.1...v1.6.0
[1.5.1]: https://github.com/hbldh/pyefd/compare/v1.4.1...v1.5.1
[1.4.1]: https://github.com/hbldh/pyefd/compare/v1.4.0...v1.4.1
[1.4.0]: https://github.com/hbldh/pyefd/compare/v1.3.0...v1.4.0
[1.3.0]: https://github.com/hbldh/pyefd/compare/v1.2.0...v1.3.0
[1.2.0]: https://github.com/hbldh/pyefd/compare/v1.1.0...v1.2.0
[1.1.0]: https://github.com/hbldh/pyefd/compare/v1.0.0...v1.1.0
[1.0.0]: https://github.com/hbldh/pyefd/compare/v0.1.2...v1.0.0
[0.1.2]: https://github.com/hbldh/pyefd/compare/v0.1.1...v0.1.2
[0.1.1]: https://github.com/hbldh/pyefd/compare/v0.1.0...v0.1.1


