1. Install the released version#
Check docker.md for more details on Docker container image usage, e.g. pulling the development version and running in a shell or Jupyter server. via conda / mamba
conda as:
or via conda install -c conda-forge mintpy
mamba as:
mamba install -c conda-forge mintpy
or via docker
docker pull ghcr.io/insarlab/mintpy:latest
or via apt (for Linux Debian)
The same procedure, in principle, can be used in Ubuntu and all the other Debian derivatives. Check the Debian GIS Project page for more detailed usage.
apt install mintpy
2. Install the development version#
Note: The installation note below is tested on Linux and macOS, and is still experimental on Windows (may have bugs).
MintPy is written in Python 3 and relies on several Python modules, check the requirements.txt file for details. We recommend using conda to install the python environment and the prerequisite packages, because of the convenient management and default performance setting with numpy/scipy and pyresample.
2.1 Install on Linux#
Click to expand for more details
a. Download source code
Run the following in your terminal to download the development version of MintPy:
cd ~/tools
git clone https://github.com/insarlab/MintPy.git
b. Install dependencies via conda / mamba
Install miniforge if you have not already done so. You may need to close and restart the shell for changes to take effect.
Install dependencies into a new environment, e.g. named "insar":
# use wget or curl to download in the command line or click from the web browser
# for macOS, use Miniforge3-MacOSX-x86_64.sh instead.
wget https://github.com/conda-forge/miniforge/releases/latest/download/Miniforge3-Linux-x86_64.sh
bash Miniforge3-Linux-x86_64.sh -b -p ~/tools/miniforge
~/tools/miniforge/bin/mamba init bash
or install dependencies into an existing environment:
# Add "isce2" below to install extra dependencies if you use ISCE-2
# Add "gdal" below to install extra dependencies if you use ARIA, FRInGE or HyP3
# Add "gdal'<3.9'" below to install extra dependencies if you use GMTSAR
mamba create --name insar --file ~/tools/MintPy/requirements.txt
# Add "isce2" below to install extra dependencies if you use ISCE-2
# Add "gdal" below to install extra dependencies if you use ARIA, FRInGE or HyP3
# Add "gdal'<3.9'" below to install extra dependencies if you use GMTSAR
mamba activate my-existing-env
mamba install --file ~/tools/MintPy/requirements.txt
c. Install MintPy
via pip [recommended]
site-packages directory), thus, one could "edit" the source code and have changes take effect immediately without having to rebuild and reinstall.
python -m pip install -e ~/tools/MintPy
or via path setup
\~/.bash_profile for bash users or \~/.cshrc for csh/tcsh users:
if [ -z ${PYTHONPATH+x} ]; then export PYTHONPATH=""; fi
export MINTPY_HOME=~/tools/MintPy
export PATH=${PATH}:${MINTPY_HOME}/src/mintpy/cli
export PYTHONPATH=${PYTHONPATH}:${MINTPY_HOME}/src
2.2 Install on macOS#
Install Xcode with command line tools, if you have not already done so. Install Install MintPy via conda [recommended], which is the same as the instruction for Linux.
Click to expand for more details
Xcode from App storecommand line tools within XCode and agree to the terms of license.xcode-select --install -s /Applications/Xcode.app/Contents/Developer/
sudo xcodebuild -licenseOr install MintPy via MacPorts [obsolete]
~/.bash_profile file:
Update the port tree with the following command. If your network prevents the use of rsync or svn via HTTP of the port tree, try Portfile Sync via a Snapshot Tarball.
# MacPorts Installer addition on 2017-09-02_at_01:27:12: adding an appropriate PATH variable for use with MacPorts.
export PATH=/opt/local/bin:/opt/local/sbin:${PATH}
export MANPATH=/opt/local/share/man:${MANPATH}
# Finished adapting your PATH environment variable for use with MacPorts.
Install the dependencies by running the following:
sudo port selfupdate
# install dependencies with macports
# use "port -N install" to use the safe default for prompt questions
sudo port install $(cat MintPy/docs/ports.txt)
# install dependencies not available on macports: pysolid, pykml, pykdtree, pyresample, cdsapi
sudo -H /opt/local/bin/pip install git+https://github.com/insarlab/PySolid.git
sudo -H /opt/local/bin/pip install git+https://github.com/insarlab/PyAPS.git
sudo -H /opt/local/bin/pip install git+https://github.com/tylere/pykml.git
sudo -H /opt/local/bin/pip install git+https://github.com/storpipfugl/pykdtree.git
sudo -H /opt/local/bin/pip install git+https://github.com/pytroll/pyresample.git
sudo -H /opt/local/bin/pip install git+https://github.com/ecmwf/cdsapi.git
2.3 Install on Windows#
Click to expand for more details
pip install approaches are recommended, as the path setup approach is not tested.
3. Post-Installation Setup#
a. ERA5 for tropospheric correction#
Set up an account for ERA5 to download weather re-analysis datasets for tropospheric delay correction as described in insarlab/PyAPS.
WEATHER_DIR: Optionally, if you defined an environment variable named WEATHER_DIR to contain the path to a directory, MintPy will download the GAM files into the indicated directory. Also, MintPy will look for the GAM files in the directory before downloading a new one to prevent downloading multiple copies if you work with different datasets that cover the same date/time.
b. Dask for parallel processing#
We recommend setting the temporary-directory in your Dask configuration file, e.g. ~/.config/dask/dask.yaml, by adding the following line, to avoid the potential workspace lock issue. Check the dask.md file for more details on parallel processing.
temporary-directory: /tmp # Directory for local disk like /tmp, /scratch, or /local
# If you share the same machine with others, use the following instead to avoid permission issues.
# temporary-directory: /tmp/{replace_this_with_your_user_name}
c. Extra environment variables setup#
We recommend setting the following environment variables, e.g. in your ~/.bash_profile file, to avoid occasional errors with GDAL VRT and HDF5 files I/O.
export VRT_SHARED_SOURCE=0 # do not share dataset while using GDAL VRT in a multi-threading environment
export HDF5_DISABLE_VERSION_CHECK=2 # suppress the HDF5 version warning message (0 for abort; 1/2 for printout/suppress warning message)
export HDF5_USE_FILE_LOCKING=FALSE # request that HDF5 file locks should NOT be used
d. Tab complete sub-commands#
We recommend activating the tab completion as below if you:
- Use bash or zsh shells
- On Linux or macOS
- Run MintPy in sub-commands style, e.g.
mintpy viewinstead ofview.py
activate-global-python-argcomplete --user
On macOS, there is a bash version compatibility issue, which can be fixed as below. If you use the default zsh shell, no fix is needed.
Click to expand for more details
echo $BASH_VERSION to check the version number), but argcomplete requires the newer version (>=4.2), which can be installed using Homebrew as:
You will also need to add the bash to brew install bash
/etc/shells and change your shell via chsh as:
Then run echo "/usr/local/bin/bash" | sudo tee -a /etc/shells
chsh -s "/usr/local/bin/bash"
activate-global-python-argcomplete --user again. You may need to add the following to your ~/.bash_profile file.
# bash completion
if [ -f ~/.bash_completion ]; then
. ~/.bash_completion
fi