-
Notifications
You must be signed in to change notification settings - Fork 85
/
Copy pathDEV_INSTALL.txt
88 lines (73 loc) · 4.08 KB
/
DEV_INSTALL.txt
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
ADVANCED INSTALLATION NOTES FOR DEVELOPERS AND ADVANCED USERS
If you are prone to work with more than one version of switch, you will
greatly benefit from python virtual environments which isolate your project's
python software from other versions that may be installed on the computer.
Software requirements and compatibilities change over time, sometimes in
incompatible ways. Virtual environments also help developers ensure they have
included all necessary dependencies in setup.py and aren't relying on
mannually installed system libraries. Using virtual environments to
encapsulate each project's customized software allows active and archived
projects to coexist on a single computer. These instructions assume you have
read INSTALL, have installed Anaconda (or equivalent), pip and solver
prerequisites.
INSTALLATION WITH PYTHON VIRTUAL ENVIRONMENTS FOR DEVELOPMENT
1. Open either a terminal or Anaconda command prompt (Start -> Anaconda ->
Anaconda Prompt)
2a. DEVELOPERS
Developers often work with switch example directories and don't necessarily
have a separate folder with inputs for analysis. In this case, the source
directory doubles as your project directory. Execute these commands, but
set PROJECT_DIR to the actual path you want to use.
PROJECT_DIR=/path/to/new/switch/checkout
SRC_DIR="$PROJECT_DIR"
2b. ANALYSTS
Analysts typically have a directory per project that stores data for their
input scenarios as well as a copy of the code they are using. Execute these
commands, but set PROJECT_DIR to the actual path you want to use.
PROJECT_DIR=/path/to/project/directory
SRC_DIR="$PROJECT_DIR"/switch_source
Note: If you are using one of Matthias's packaged scenarios with a
submodule or subtree, set SRC_DIR to that subfolder instead of doing a
fresh git checkout. In this case, skip step 3.
3. Download a copy of switch
git clone https://github.com/switch-model/switch.git "$SRC_DIR"
4. Create a virtual environment in your project directory, and install switch
and its prerequisites (if using Windows, replace "bin" with "Scripts"):
cd "$PROJECT_DIR"
pip install virtualenv
virtualenv venv
source venv/bin/activate
pip install --editable "$SRC_DIR"[extra_requirements]
Remember to replace "extra_requirements" with a comma-separated list with
the extra dependencies you will be using for your development:
database_access: Used to access Hawaii data from Matthias.
advanced: Used for advanced demand response and progressive
hedging modules.
plotting: Self explanatory.
dev: Used for debugging.
Note 1: The --editable flag ensures that any changes to your downloaded copy
of switch will be immediately reflected to your installed copy in the
virtual environment.
Note 2: If installing advanced dependencies in a Windows OS using pip, the
installation of r2py may raise an error. The simplest workaround is to
follow the steps outlined here: https://stackoverflow.com/a/32983656
After manually installing r2py, you can proceed to repeat the installation
of Switch with the advanced dependencies using:
pip install --editable "$SRC_DIR"[extra_requirements]
5. [Optional] Record the exact version of every library you are using so you can
precisely replicate this setup in the future.
pip freeze > requirements.txt
Without this step, you are at higher risk of not being able to readily
repeat or extend this analysis, especially if future releases of libraries
are not completely backwards compatible (this has happened a few times in
the past few years).
EXECUTION
1. Open either a terminal or Anaconda command prompt (Start -> Anaconda ->
Anaconda Prompt) and navigate to your project directory.
2. Activate your virtual environment with the following command:
source venv/bin/activate
3. Execute switch like normal
switch solve ...
4. When finished development work, remember to leave the virtual
environment with the following command:
deactivate