Anaconda
The Anaconda Distribution provides a popular method of installing Python, R and associated libraries and packages.
The Anaconda Distribution (https://www.anaconda.com/) is available for Linux, Windows and Apple systems, and will install all files within your home directory by default, and as such, installation does not require any elevated / administrative permissions.
Installation
There are various different Anaconda installers available, with the default installation containing Python version 2 or version 3 and many useful packages (https://www.anaconda.com/distribution/). However, it is worth noting that the installation can require several Gigabytes of disk space.
As an alternative the Miniconda installer (https://docs.conda.io/en/latest/miniconda.html) provides a minimal base installation which can be used to create environments and install required packages.
For Linux systems, the Miniconda 64 bit version 3 installer is recommended, which can be used to create Python version 2 and version 3 as well as R environments:
https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh
As mentioned, Anaconda installations can get quite large, and will
install in the home directory by default, so it is worth checking your
quota (quota -s
) or selecting a suitable location (for example, if you
have access to some large volume disk space) before installation.
The Miniconda installer can be downloaded and made executable with the following commands:
$ wget 'https://repo.anaconda.com/miniconda/Miniconda3-latest-Linux-x86_64.sh'
$ chmod +x Miniconda3-latest-Linux-x86_64.sh
The installer can then be run:
$ ./Miniconda3-latest-Linux-x86_64.sh
The installation process will ask for the terms of the license to be
accepted, and then ask for an installation directory, defaulting to a
directory named miniconda3
in the home directory. If you wish to
select an alternative location, enter the full path to the required
location. If installing in your home directory, a sensible path to
choose might be /home/username/conda
, replacing username
with your
own username.
After the installer has finished extracting the files in to the selected
location, it will ask whether you wish to run conda init
to initialise
the installation. Selecting yes will update the ~/.bashrc
so that the
Anaconda programs will be available in future sessions.
Once the installation process has been completed, the installer is no longer required, and can be removed:
$ rm Miniconda3-latest-Linux-x86_64.sh
Initial Configuration
Once the installation is complete, if the ~/.bashrc
file was updated
successfully, the Miniconda installation will be active when you either
run source ~/.bashrc
, or open a new shell. You should see that the
prompt is now prefixed with (base)
, to indicate that the base
environment in the Miniconda installation is active:
(base) [see1-234:earxyz:1]$
At this point the python
command will now default the version of
Python installed with Miniconda, and the conda
command can be used to
install packages in the base
environment:
(base) [see1-234:earxyz:3]$ which python
/home/earxyz/conda/bin/python
(base) [see1-234:earxyz:3]$ python -V
Python 3.7.4
(base) [see1-234:earxyz:4]$ conda install numpy
However, an alternative method may be more advisable. Anaconda environments can include a large number of different programs and libraries which can cause conflicts with system versions of the same files, so it can be better to create environments for specific purposes, activating and deactivating the environments as required.
To stop the base
environment being automatically activated when a
shell is opened, the following command can be run:
$ conda config --set auto_activate_base false
It may also be worth adding the conda-forge
channel to configuration.
The conda-forge
channel is an additional repository from which
packages can be installed, and includes many popular scientific
packages, such as iris. The following commands will add the
conda-forge
channel:
$ conda config --add channels conda-forge
These changes update the file ~/.condarc
, and after they have been run,
and a new shell is opened, the base
channel will no longer be
activated by default, but the conda
command will be available to allow
creating new environments:
$ which python
/usr/bin/python
$ which conda
/home/earxyz/conda/condabin/conda
$ cat ~/.condarc
auto_activate_base: false
channels:
- conda-forge
- defaults
Creating Environments
The command conda create
can be used to create environments containing
the required packages. For example, to create an environment containing
Python version 3 and the Spyder graphical development environment:
$ conda create -n py3_spyder python=3 spyder
Environments are created within the envs
directory of the installation
folder, and the environments can be activated and deactivated with the
conda activate
and conda deactivate
commands:
[see1-234:earxyz:12]$ ls conda/envs/
py3_spyder
[see1-234:earxyz:12]$ conda activate py3_spyder
(py3_spyder) [see1-234:earxyz:13]$ which python
/home/earxyz/conda/envs/py3_spyder/bin/python
(py3_spyder) [see1-234:earxyz:14]$ python -V
Python 3.7.3
(py3_spyder) [see1-234:earxyz:15]$ which spyder
/home/earxyz/conda/envs/py3_spyder/bin/spyder
(py3_spyder) [see1-234:earxyz:16]$ conda deactivate
[see1-234:earxyz:18]$
To create a Python version 2 environment containing the numpy
and
scipy
packages:
$ conda create -n py2_scipy python=2 numpy scipy
The available environments can be listed with conda env list
:
$ conda env list
# conda environments:
#
base * /home/earxyz/conda
py2_scipy /home/earxyz/conda/envs/py2_spyder
py3_spyder /home/earxyz/conda/envs/py3_spyder
Installing Packages
Once an environment has been activated, additional packages can be
installed within that environment with the conda install
command:
(py3_spyder) [see1-234:earxyz:24]$ conda install iris
The conda search
command can be used to search for available packages:
(py3_spyder) [see1-234:earxyz:25]$ conda search 'obsp*'
Loading channels: done
# Name Version Build Channel
obspy 1.0.2 py27_0 conda-forge
obspy 1.0.2 py27_1 conda-forge
...
To install a specific version of a package, the version can be specified
with ==
:
(py3_spyder) [see1-234:earxyz:26]$ conda install obspy==1.0.3
It is also possible to install packages using the pip
command, if a
package is available in the PyPi repositories, but not available in the
Anaconda channels (pip install packagename
).
The packages which are currently installed in an environment, their version information and installation source can be viewed by running:
(py3_spyder) [see1-234:earxyz:27]$ conda list
Updating Packages
The conda update
command can be used to update packages. For example,
to update spyder
:
(py3_spyder) [see1-234:earxyz:28]$ conda update spyder
To update all packages in an environment:
(py3_spyder) [see1-234:earxyz:29]$ conda update --all
If an environment is not updated for some time, changes to the environment (such as installing a new package) may cause version conflicts, so it may be wise to either create a new environment, or update all packages in the environment when making changes.
Installing R
As well as Python environments, the conda create
command can also be
used to create environments for running the R
program.
To create an environment containing R
and rstudio
:
$ conda create -n R R rstudio-desktop
This will create an environment named R
, which can be activated with
conda activate R
, and once the environment is active the R
and
rstudio
programs will be available.