Skip to main content
This is a pre-production deployment of Warehouse. Changes made here affect the production instance of PyPI (pypi.python.org).
Help us improve Python packaging - Donate today!

A hyperspectral imaging tools box

Project Description

PySptools is a hyperspectral and spectral imaging library that provides spectral algorithms for the Python programming language. Specializations of the library are the endmembers extraction, unmixing process, supervised classification, target detection, noise reduction, convex hull removal and features extraction at spectrum level.

The library is designed to be easy to use and almost all functionality has a plot function to save you time with the data analysis process. The actual sources of the algorithms are the Matlab Hyperspectral Toolbox of Isaac Gerg, the pwctools of M. A. Little, the Endmember Induction Algorithms toolbox (EIA), the HySime Matlab module of José Bioucas-Dias and José Nascimento and research papers.

The current version introduce a scikit-learn bridge. The bridge is partial and alpha.

Functionalities

The functions and classes are organized by topics:

  • abundance maps: FCLS, NNLS, UCLS
  • classification: AbundanceClassification, NormXCorr, SAM, SID
  • detection: ACE, CEM, GLRT, MatchedFilter, OSP
  • distance: chebychev, NormXCorr, SAM, SID
  • endmembers extraction: ATGP, FIPPI, NFINDR, PPI
  • material count: HfcVd, HySime
  • noise: Savitzky Golay, MNF, whiten
  • sigproc: bilateral
  • sklearn: HyperEstimatorCrossVal, HyperSVC, HyperGradientBoostingClassifier, HyperRandomForestClassifier, HyperKNeighborsClassifier, HyperLogisticRegression and others
  • spectro: convex hull quotient, features extraction (tetracorder style), USGS06 lib interface
  • util: load_ENVI_file, load_ENVI_spec_lib, corr, cov, plot_linear_stretch, display_linear_stretch, convert2D, convert3D, normalize, InputValidation, ROIs and others

The library do an extensive use of the numpy numeric library and can achieve good speed for some functions. The library is mature enough and is very usable even if the development is at a beta stage.

Installation

PySptools can run under Python 2.7 and 3.5. It was tested with these versions but can probably run under others Python versions.

Manual installation

To install download the sources, expand it in a directory and add the path of the pysptools-0.xx.x directory to the PYTHONPATH system variable.

Distutils installation

You can use Distutils. Expand the sources in a directory, go to the pysptools-0.xx.x directory and at the command prompt type ‘python setup.py install’. To uninstall the library, you have to do it manually. Go to your python installation. In the Lib/site-packages folder simply removes the associated pysptools folder and files.

Dependencies

  • Python 2.7 or 3.x
  • Numpy, required
  • Scipy, required
  • scikit-learn, required, version >= 0.18
  • SPy, required, version >= 0.17
  • Matplotlib, required, version 1.5.3 or less (not working with 2.0.x)
  • CVXOPT, optional, to run FCLS, version 1.1.8
  • IPython, optional, if you want to use the display feature
Release History

Release History

This version
History Node

0.14.2

History Node

0.14.1

History Node

0.14.0

History Node

0.13.5

History Node

0.13.4

History Node

0.13.3

Download Files

Download Files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

File Name & Checksum SHA256 Checksum Help Version File Type Upload Date
pysptools-0.14.2.tar.gz (6.1 MB) Copy SHA256 Checksum SHA256 Source May 28, 2017

Supported By

WebFaction WebFaction Technical Writing Elastic Elastic Search Pingdom Pingdom Monitoring Dyn Dyn DNS Sentry Sentry Error Logging CloudAMQP CloudAMQP RabbitMQ Heroku Heroku PaaS Kabu Creative Kabu Creative UX & Design Fastly Fastly CDN DigiCert DigiCert EV Certificate Rackspace Rackspace Cloud Servers DreamHost DreamHost Log Hosting