forked from ctherien/pysptools
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsetup.py
109 lines (94 loc) · 4.82 KB
/
setup.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
from setuptools import setup, find_packages
setup(name = "pysptools",
version = "0.13.5",
description = "A hyperspectral imaging tools box",
author = "Christian Therien",
author_email = "ctherien@users.sourceforge.net",
url = "http://pysptools.sourceforge.net/",
license = "Apache License Version 2.0",
keywords = "python, telops, hyperspectral imaging, signal processing, library, endmembers, unmixing, pysptools, sam, sid, atgp, N-FINDR, NFINDR, spectroscopy, target detection, georessources, geoimaging, chemical imaging, pharmaceutical, pharma, minerals, spectral, remote sensing",
install_requires=[
'numpy',
'scipy',
'scikit-learn',
'spectral>=0.17',
'matplotlib'
],
packages=[ 'pysptools',
'pysptools/abundance_maps',
'pysptools/classification',
'pysptools/detection',
'pysptools/distance',
'pysptools/eea',
'pysptools/examples',
'pysptools/material_count',
'pysptools/noise',
'pysptools/tests',
'pysptools/sigproc',
'pysptools/spectro',
'pysptools/util'],
package_data={'pysptools': ['*.txt'],
'pysptools/doc': ['*'],
'pysptools/doc/bur': ['*'],
'pysptools/doc/chull': ['*'],
'pysptools/doc/hem': ['*'],
'pysptools/doc/pic': ['*'],
'pysptools/doc/smk': ['*'],
'pysptools/doc/source': ['*'],
'pysptools/eea': ['*.*']},
long_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 science articles.
Functionality
*************
The functions and classes are organized by topics:
* abundance maps: FCLS, NNLS, UCLS
* classification: AbundanceClassification, NormXCorr, KMeans SAM, SID, SVC
* 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
* 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
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
************
Since version 0.12.2, PySptools can run under Python 2.7 and 3.x. It has been tested for 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
* SPy (spectral), required, version >= 0.17
* Matplotlib, required
* CVXOPT, optional, to run FCLS
* IPython, optional, if you want to use the display feature
""",
classifiers=[
"Development Status :: 4 - Beta",
"Environment :: Console",
"Intended Audience :: Science/Research",
"License :: OSI Approved :: Apache Software License",
"Natural Language :: English",
"Operating System :: OS Independent",
"Programming Language :: Python :: 2.7",
"Programming Language :: Python :: 3",
"Topic :: Scientific/Engineering :: GIS",
"Topic :: Scientific/Engineering :: Image Recognition",
"Topic :: Scientific/Engineering :: Information Analysis",
"Topic :: Scientific/Engineering :: Visualization"
],
)