2019-08-07 08:56:23 +00:00
.. _installation:
2019-06-07 08:34:36 +00:00
##########################################
Installation
##########################################
2019-08-10 20:46:26 +00:00
The subsequently described installation steps are demonstrated as shell commands, where the path before the `` % `` sign denotes the
directory in which the commands following the `` % `` should be entered.
2019-08-06 14:53:32 +00:00
Clone the Repository
====================
2019-08-10 20:46:26 +00:00
First of all, clone the `PyPSA-Eur repository <https://github.com/PyPSA/pypsa-eur> `_ using the version control system `` git `` .
The path to the directory into which the `` git repository `` is cloned, must **not** have any spaces!
2019-08-06 14:53:32 +00:00
.. code :: bash
/some/other/path % cd /some/path/without/spaces
/some/path/without/spaces % git clone https://github.com/PyPSA/pypsa-eur.git
.. note ::
2019-08-10 20:46:26 +00:00
If you do not have `` git `` installed, follow installation instructions `here <https://git-scm.com/book/en/v2/Getting-Started-Installing-Git> `_ .
2019-08-06 14:53:32 +00:00
2019-08-07 08:56:23 +00:00
.. _deps:
2019-08-06 14:53:32 +00:00
Install Python Dependencies
===============================
2019-08-10 20:46:26 +00:00
PyPSA-Eur relies on a set of other Python packages to function.
We recommend using the package manager and environment management system `` conda `` to install them.
Install `miniconda <https://docs.conda.io/en/latest/miniconda.html> `_ , which is a mini version of `Anaconda <https://www.anaconda.com/> `_ that includes only `` conda `` and its dependencies or make sure `` conda `` is already installed on your system.
For instructions for your operating system follow the `` conda `` `installation guide <https://docs.conda.io/projects/conda/en/latest/user-guide/install/> `_ .
2019-08-06 14:53:32 +00:00
2019-08-10 20:46:26 +00:00
The python package requirements are curated in the `environment.yaml <https://github.com/PyPSA/pypsa-eur/blob/master/environment.yaml> `_ file.
2019-08-06 14:53:32 +00:00
The environment can be installed and activated using
.. code :: bash
.../pypsa-eur % conda env create -f environment.yaml
.../pypsa-eur % conda activate pypsa-eur
.. note ::
Note that activation is local to the currently open shell!
2019-11-06 13:50:59 +00:00
After opening a new terminal window, one needs to reissue the second command!
2019-08-08 15:13:36 +00:00
Install a Solver
================
2019-08-10 20:46:26 +00:00
PyPSA passes the PyPSA-Eur network model to an external solver for performing a total annual system cost minimization with optimal power flow.
PyPSA is known to work with the free software
2019-10-03 14:13:44 +00:00
- `Ipopt <https://coin-or.github.io/Ipopt/INSTALL.html> `_
2019-08-10 20:46:26 +00:00
- `Cbc <https://projects.coin-or.org/Cbc#DownloadandInstall> `_
- `GLPK <https://www.gnu.org/software/glpk/> `_ (`WinGLKP <http://winglpk.sourceforge.net/> `_ )
and the non-free, commercial software (for which free academic licenses are available)
- `Gurobi <https://www.gurobi.com/documentation/8.1/remoteservices/installation.html> `_
- `CPLEX <https://www.ibm.com/products/ilog-cplex-optimization-studio> `_
2019-08-08 15:13:36 +00:00
2019-08-10 20:46:26 +00:00
and any other solver that works with the underlying modelling framework `Pyomo <http://www.pyomo.org/> `_ . For installation instructions of these solvers for your operating system, follow the links above.
.. seealso ::
`Getting a solver in the PyPSA documentation <https://pypsa.readthedocs.io/en/latest/installation.html#getting-a-solver-for-linear-optimisation> `_
.. note ::
Commercial solvers such as Gurobi and CPLEX currently significantly outperform open-source solvers for large-scale problems.
It might be the case that you can only retrieve solutions by using a commercial solver.
2019-10-03 10:37:23 +00:00
.. _defaultconfig:
Set Up the Default Configuration
================================
PyPSA-Eur has several configuration options that must be specified in a `` config.yaml `` file located in the root directory.
An example configuration `` config.default.yaml `` is maintained in the repository.
More details on the configuration options are in :ref: `config` .
Before first use, create a `` config.yaml `` by copying the example.
.. code :: bash
.../pypsa-eur % cp config.default.yaml config.yaml
Users are advised to regularly check their own `` config.yaml `` against changes in the `` config.default.yaml ``
when pulling a new version from the remote repository.
2019-10-03 14:13:44 +00:00
2019-10-03 15:09:25 +00:00
.. Using PyPSA-Eur with Docker Images
.. ==================================
2019-10-03 14:13:44 +00:00
2019-10-03 15:09:25 +00:00
.. If docker. Optional.
.. To run on cloud computing.
.. Gurobi license - floating token server - license must not be tied to a particular machine
.. Provide ``Dockerfile``.