************
Installation
************
Requirements
============
Photutils has the following strict requirements:
* `Python `_ 3.10 or later
* `NumPy `_ 1.23 or later
* `Astropy`_ 5.1 or later
Photutils also optionally depends on other packages for some features:
* `SciPy `_ 1.8 or later: To power a variety of
features in several modules (strongly recommended).
* `Matplotlib `_ 3.5 or later: To power a
variety of plotting features (e.g., plotting apertures).
* `scikit-image `_ 0.20 or later: Used for
deblending segmented sources.
* `scikit-learn `_ 1.1 or later: Used in the
deprecated `~photutils.psf.DBSCANGroup` class to create star groups.
* `GWCS `_ 0.18 or later:
Used in `~photutils.datasets.make_gwcs` to create a simple celestial
gwcs object.
* `Bottleneck `_: Improves the
performance of sigma clipping and other functionality that may require
computing statistics on arrays with NaN values.
* `tqdm `_: Used to display optional progress
bars.
* `Rasterio `_: Used for converting
source segments into polygon objects.
* `Shapely `_: Used for converting
source segments into polygon objects.
Photutils depends on `pytest-astropy
`_ (0.11 or later) to run
the test suite.
Installing the latest released version
======================================
The latest released (stable) version of Photutils can be installed
either with `pip`_ or `conda`_.
Using pip
---------
To install Photutils with `pip`_, run::
pip install photutils
If you want to install Photutils along with all of its optional
dependencies, you can instead do::
pip install "photutils[all]"
In most cases, this will install a pre-compiled version (called a wheel)
of Photutils, but if you are using a very recent version of Python
or if you are installing Photutils on a platform that is not common,
Photutils will be installed from a source file. In this case you will
need a C compiler (e.g., ``gcc`` or ``clang``) to be installed for the
installation to succeed (see :ref:`building_source` prerequisites).
If you get a ``PermissionError``, this means that you do not have the
required administrative access to install new packages to your Python
installation. In this case you may consider using the ``--user``
option to install the package into your home directory. You can read
more about how to do this in the `pip documentation
`_.
Do **not** install Photutils or other third-party packages using
``sudo`` unless you are fully aware of the risks.
Using conda
-----------
Photutils can be installed with `conda`_ if you have installed
`Anaconda `_ or
`Miniconda `_. To
install Photutils using the `conda-forge Anaconda channel
`_, run::
conda install -c conda-forge photutils
.. _building_source:
Building from Source
====================
Prerequisites
-------------
You will need a compiler suite and the development headers for Python
and Numpy in order to build Photutils from the source distribution. You
do not need to install any other specific build dependencies (such as
Cython) since these will be automatically installed into a temporary
build environment by `pip`_.
On Linux, using the package manager for your distribution will usually be
the easiest route.
On macOS you will need the `XCode`_ command-line tools, which can be
installed using::
xcode-select --install
Follow the onscreen instructions to install the command-line tools
required. Note that you do not need to install the full `XCode`_
distribution (assuming you are using MacOS X 10.9 or later).
Installing the development version
----------------------------------
Photutils is being developed on `GitHub`_. The latest development
version of the Photutils source code can be retrieved using git::
git clone https://github.com/astropy/photutils.git
Then to build and install Photutils (with all of its optional
dependencies), run::
cd photutils
pip install ".[all]"
If you wish to install the package in "editable" mode, instead include
the "-e" option::
pip install -e ".[all]"
Alternatively, `pip`_ can be used to retrieve, build, and install the
latest development version from `GitHub`_::
pip install "photutils[all] @ git+https://github.com/astropy/photutils.git"
Testing an installed Photutils
==============================
The easiest way to test your installed version of Photutils is running
correctly is to use the :func:`photutils.test` function:
.. doctest-skip::
>>> import photutils
>>> photutils.test()
Note that this may not work if you start Python from within the
Photutils source distribution directory.
The tests should run and report any failures, which you can report to
the `Photutils issue tracker
`_.
.. _pip: https://pip.pypa.io/en/latest/
.. _conda: https://docs.conda.io/en/latest/
.. _GitHub: https://github.com/astropy/photutils
.. _Xcode: https://developer.apple.com/xcode/