Metadata-Version: 2.1
Name: pclines
Version: 1.0.2
Summary: PCLines transform for python
Home-page: https://github.com/RomanJuranek/pclines-python
Author: Roman Juranek
Author-email: ijuranek@fit.vutbr.cz
License: BSD3
Project-URL: Bug reports, https://github.com/RomanJuranek/pclines-python/issues
Keywords: pclines,hough transform,line detection
Platform: UNKNOWN
Requires-Python: >=3.6
Description-Content-Type: text/markdown
Requires-Dist: numpy
Requires-Dist: numba
Requires-Dist: scikit-image

# `pclines` package for Python

![pclines](doc/pclines.svg)

This package implements a PCLines transform for line detection in images.

```bibtex
@INPROCEEDINGS{dubska2011pclines,
    author={M. {Dubská} and A. {Herout} and J. {Havel}},
    booktitle={CVPR 2011},
    title={PClines — Line detection using parallel coordinates},
    year={2011},
}
```

# Requrements

* Python 3.6+
* numpy
* numba
* scikit-image

# Installation

The package is on [PyPI](https://pypi.org/project/pclines/), so just run following command and install the package.

```shell
> pip install pclines
```

Alternatively, you can download this repository and install manually.


# Example

1. Import package

```python
import pclines as pcl
```

2. Data and observations
The observations are 2D weighted coordinates enclosed by a known bounding box. As an example we extract edge points from an image.

```python
image = imread("doc/test.png", as_gray=True)
edges = sobel(image)
r,c = np.nonzero(edges > 0.5)
x = np.array([c,r],"i").T
weights = edges[r,c]
```
![](doc/image.png) ![](doc/edges.png)

3. Accumulation in PCLines space

```python
h,w = image.shape[:2]
bbox=(0,0,w,h)  #  Bounding box of observations
d = 1024  # Accumulator resolution
P = PCLines(bbox, d) # Create new accumulator
P.insert(x, weights) # Insert observations
p, w = P.find_peaks(min_dist=10, prominence=1.3, t=0.1) # Find local maxima
```

![](doc/accumulator.png)

4. Detected lines

```python
h = P.inverse(p)  # (a,b,c) parameters of lines
X,Y = utils.line_segments_from_homogeneous(h, bbox)  # Convert to line segments for plotting
```

![](doc/lines.png)


# Contribute

If you have a suggestion for improvement, let us know by filling an issue. Or you can fork the project and submit a pull request.



