GithubHelp home page GithubHelp logo

cooperlees / python-pcl Goto Github PK

View Code? Open in Web Editor NEW

This project forked from strawlab/python-pcl

0.0 3.0 0.0 15.26 MB

Python bindings to the pointcloud library (pcl)

Home Page: http://strawlab.github.com/python-pcl/

License: Other

Makefile 0.01% C++ 0.51% C 0.04% PowerShell 0.53% Batchfile 0.06% Shell 0.01% Python 98.85%

python-pcl's Introduction

Fork me on GitHub

Introduction

This is a small python binding to the [pointcloud](http://pointclouds.org/) library. Currently, the following parts of the API are wrapped (all methods operate on PointXYZ) point types

  • I/O and integration; saving and loading PCD files
  • segmentation
  • SAC
  • smoothing
  • filtering
  • registration (ICP, GICP, ICP_NL)

The code tries to follow the Point Cloud API, and also provides helper function for interacting with NumPy. For example (from tests/test.py)

import pcl
import numpy as np
p = pcl.PointCloud(np.array([[1, 2, 3], [3, 4, 5]], dtype=np.float32))
seg = p.make_segmenter()
seg.set_model_type(pcl.SACMODEL_PLANE)
seg.set_method_type(pcl.SAC_RANSAC)
indices, model = seg.segment()

or, for smoothing

import pcl
p = pcl.load("C/table_scene_lms400.pcd")
fil = p.make_statistical_outlier_filter()
fil.set_mean_k (50)
fil.set_std_dev_mul_thresh (1.0)
fil.filter().to_file("inliers.pcd")

Point clouds can be viewed as NumPy arrays, so modifying them is possible using all the familiar NumPy functionality:

import numpy as np
import pcl
p = pcl.PointCloud(10)  # "empty" point cloud
a = np.asarray(p)       # NumPy view on the cloud
a[:] = 0                # fill with zeros
print(p[3])             # prints (0.0, 0.0, 0.0)
a[:, 0] = 1             # set x coordinates to 1
print(p[3])             # prints (1.0, 0.0, 0.0)

More samples can be found in the examples directory, and in the unit tests.

This work was supported by Strawlab.

Requirements

This release has been tested on Linux Ubuntu 14.04 with

  • Python 2.7.6, 3.4.0, 3.5.2
  • pcl 1.7.0
  • Cython <= 0.25.2

and MacOS with

  • Python 2.7.6, 3.4.0, 3.5.2
  • pcl 1.8.1(use homebrew)
  • Cython <= 0.25.2

and Windows with

  • (Miniconda/Anaconda) - Python 3.4
  • pcl 1.6.0(VS2010)
  • Cython <= 0.25.2
  • Gtk+

and Windows with

  • (Miniconda/Anaconda) - Python 3.5
  • pcl 1.8.1(VS2015)
  • Cython <= 0.25.2
  • Gtk+

Installation

Linux(Ubuntu)

before Install module

PCL 1.7.0 and Ubuntu14.04 (use apt-get)

  1. Install PCL Module.
sudo add-apt-repository ppa:v-launchpad-jochen-sprickerhof-de/pcl -y

sudo apt-get update -y

sudo apt-get install libpcl-all -y

PCL 1.7.2 and Ubuntu16.04 (use Debian package)

  1. Install PCL Module.?
sudo apt-get update -y

sudo apt-get install build-essential devscripts

dget -u https://launchpad.net/ubuntu/+archive/primary/+files/pcl_1.7.2-14ubuntu1.16.04.1.dsc

cd pcl-1.7.2

sudo dpkg-buildpackage -r -uc -b

sudo dpkg -i pcl_*.deb

* current add ppa 
  (sudo add-apt-repository -remove ppa:v-launchpad-jochen-sprickerhof-de/pcl -y)

Reference `here <https://launchpad.net/ubuntu/xenial/+package/pcl-tools>`_.

PCL 1.8.0 and Ubuntu16.04(build module)([CI Test Timeout])

  1. Build Module

    Reference here.

MacOSX

before Install module

Case1. use homebrew(PCL 1.8.1 - 2017/11/13 current)

  1. Install PCL Module.

    brew tap homebrew/science

    brew install pcl

Warning:

Current Installer (2017/10/02) Not generated pcl-2d-1.8.pc file.(Issue #119)

Reference PointCloudLibrary Issue.

Pull qequests 1679.

Issue 1978.

circumvent:

copy travis/pcl-2d-1.8.pc file to /usr/local/lib/pkgconfig folder.

Windows

before Install module

Case1. use PCL 1.6.0

Windows SDK 7.1

            PCL All-In-One Installer

            32 bit

64 bit

           OpenNI2[(PCL Install FolderPath)\3rdParty\OpenNI\OpenNI-(win32/x64)-1.3.2-Dev.msi]

Case2. use 1.8.1

            Visual Studio 2015 C++ Compiler Tools

            PCL All-In-One Installer

            32 bit

            64 bit

          OpenNI2[(PCL Install FolderPath)\3rdParty\OpenNI2\OpenNI-Windows-(win32/x64)-2.2.msi]

        Common setting            

Windows Gtk+ Download                  

Download file unzip. Copy bin Folder to pkg-config Folder                 

or execute powershell file [Install-GTKPlus.ps1].

Python Version use VisualStudio Compiler

set before Environment variable

   
  1. PCL_ROOT

    set PCL_ROOT=$(PCL Install FolderPath)

  2. PATH

    (pcl 1.6.0) set PATH=$(PCL_ROOT)/bin/;$(OPEN_NI_ROOT)/Tools;$(VTK_ROOT)/bin;%PATH%

    (pcl 1.8.1) set PATH=$(PCL_ROOT)/bin/;$(OPEN_NI2_ROOT)/Tools;$(VTK_ROOT)/bin;%PATH%

Common setting

  1. pip module install.
pip install --upgrade pip

pip install cython==0.25.2

pip install numpy
  1. instal python module
   python setup.py build_ext -i

   python setup.py install

Build & Test Status

windows(1.6.0/1.8.1)

  .. image:: https://ci.appveyor.com/api/projects/status/w52fee7j22q211cm/branch/master?svg=true
target

https://ci.appveyor.com/project/Sirokujira/python-pcl-iju42

Mac OSX(1.8.1)/Ubuntu14.04(1.7.0)

image

A note about types

Point Cloud is a heavily templated API, and consequently mapping this into Python using Cython is challenging.

It is written in Cython, and implements enough hard bits of the API (from Cythons perspective, i.e the template/smart_ptr bits) to provide a foundation for someone wishing to carry on.

API Documentation

For deficiencies in this documentation, please consult the PCL API docs, and the PCL tutorials.

python-pcl's People

Contributors

astraw avatar blootsvoets avatar ccordoba12 avatar chrisidefix avatar chriswl avatar colincsl avatar cooperlees avatar jabooth avatar jiskattema avatar larsmans avatar mys007 avatar nzjrs avatar psporysz avatar sirokujira avatar vlobanov avatar

Watchers

 avatar  avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.