-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathINSTALL.html
148 lines (142 loc) · 13.4 KB
/
INSTALL.html
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
<h1 id="installation-instructions">Installation Instructions</h1>
<p>This document provides instructions for installing this replication package and is split into two parts: (a) the installation of ROSDiscover, its dependencies, and the executable harness that are used to run the experiments; and (b) the installation of the Docker images used in the evaluation dataset. Users should follow the instructions for installing (a) before proceeding to install (b).</p>
<h2 id="prerequisites">1. Prerequisites</h2>
<p><strong>This replication package is known to work with several Linux distributions, including Ubuntu and Arch, but is untested on Windows and macOS.</strong></p>
<h3 id="docker">1.1. Docker</h3>
<p>Before continuing, <a href="https://www.docker.com">Docker</a> 17.05 or higher must be installed on your machine. The following command can be used to check the version of Docker that you have installed:</p>
<pre class=""><code>$ docker --version
Docker version 20.10.11, build dea9396</code></pre>
<p>Older versions of Docker do not support <a href="https://docs.docker.com/develop/develop-images/multistage-build/">multi-stage builds</a> and will be unable to build the images provided by this repository. See the following for platform-specific instructions for installing Docker:</p>
<ul>
<li><a href="https://docs.docker.com/engine/install/ubuntu">Installing Docker Engine on Ubuntu</a></li>
<li><a href="https://docs.docker.com/engine/install/fedora">Installing Docker Engine on Fedora</a></li>
</ul>
<p>After installation, be sure to follow the <a href="https://docs.docker.com/engine/install/linux-postinstall">post-installation instructions</a> (e.g., adding your user account to the <span class="title-ref">docker</span> group) to avoid common issues (e.g., requiring <span class="title-ref">sudo</span> to run <span class="title-ref">docker</span> commands).</p>
<h3 id="command-line-utilities">1.2. Command-Line Utilities</h3>
<ul>
<li><a href="https://stedolan.github.io/jq">jq</a> (can be installed via, e.g., <code>apt install jq</code> on Ubuntu).</li>
</ul>
<h3 id="disk-space">1.3. Disk Space</h3>
<p>Note that to install the replication package in its entirety, you will require approximately 240 GB of disk space.</p>
<h2 id="software-experiment-harness">2. Software & Experiment Harness</h2>
<p>ROSDiscover, its dependencies, and the scripts used to conduct the experiments can be installed either via Docker (2.1), the preferred method for replication of results, or natively (2.2) via pipenv. We provide instructions for both of these approaches below.</p>
<h3 id="approach-a-preferred-method-docker">2.1. Approach A (Preferred Method): Docker</h3>
<p>To install the Docker-based experiment harness, which includes ROSDiscover and all other necessary software, you should run:</p>
<pre class=""><code>$ docker/setup.sh</code></pre>
<h3 id="approach-b-native-pipenv">2.2. Approach B: Native (pipenv)</h3>
<p>Alternatively, to install the necessary software and experiment harness natively, you will first need to install both (a) Python 3.9 or greater and (b) pipenv. Since Python 3.9 or greater is not provided as the system Python installation on many distributions, we optionally recommend using pyenv to automatically install a standalone Python 3.9 without interfering with the rest of your system.</p>
<p><a href="https://github.com/pyenv/pyenv">pyenv</a> is a tool for managing multiple Python installations. Be careful to ensure that you have installed all of pyenv's prequisites by following these instructions: <a href="https://github.com/pyenv/pyenv/wiki/Common-build-problems">https://github.com/pyenv/pyenv/wiki/Common-build-problems</a>. Once you have installed the dependencies for pyenv, you can install pyenv itself by executing the following:</p>
<pre class="command"><code>$ curl https://pyenv.run | bash</code></pre>
<p>You should then check that your <code>~/.profile</code> sources <code>~/.bashrc</code>. Once you have ensured that is the case, you should add the following lines to <code>~/.profile</code> immediately prior to the point where <code>~/.bashrc</code> is sourced.</p>
<pre class="command"><code>export PYENV_ROOT="$HOME/.pyenv"
export PATH="$PYENV_ROOT/bin:$PATH"
eval "$(pyenv init --path)"</code></pre>
<p>Additionally, you should add the following lines to your <code>~/.bashrc</code>:</p>
<pre class="command"><code>eval "$(pyenv init -)"
eval "$(pyenv virtualenv-init -)"</code></pre>
<p>After making the above changes, you should restart your shell so that the changes in <code>~/.profile</code> and <code>~/.bashrc</code> take effect. You can then install Python 3.9.5 via the following:</p>
<pre class="command"><code>$ pyenv install 3.9.5</code></pre>
<p>Once Python 3.9.5 has been installed, you should install pipenv. <a href="https://pypi.org/project/pipenv">Pipenv</a> is a package manager for Python that allows you to install dependencies into a virtual environment without interfering with your system's Python installation. To install pipenv, you can execute the following:</p>
<pre class="command"><code>$ python -m pip install --user pipenv</code></pre>
<p>Once installed, ensure that <code>~/.local/bin</code> is added to your path (e.g., by editing your <code>~/.bashrc</code> or <code>~/.profile</code>).</p>
<p>Next, you can install ROSDiscover, its dependencies, and the experiment runner via pipenv by executing the following at the root of the replication package:</p>
<pre class="command"><code>$ pyenv local 3.9.5
$ pipenv install --python 3.9.5</code></pre>
<p>Finally, you will need to install the ROSDiscover C++ static analysis tool by executing the following at the root of the replication package:</p>
<pre class="command"><code>$ make -C deps/rosdiscover-cxx-recover/docker</code></pre>
<h2 id="evaluation-dataset">3. Evaluation Dataset</h2>
<p>Once you have installed the experiment harness according to the instructions above, you will need to install the Docker images for each of the subject systems.
Note that this step will require a peak of approximately 240 GB of disk space during installation.
After completing the installation, 100 GB of disk space will be used permanently after the original image archive has been deleted.
Below we present two methods for installing the evaluation dataset: (3.1) installing prebaked images, the preferred method for replication; and (3.2) building images from scratch.</p>
<h3 id="approach-a-preferred-method-installing-prebuilt-images">3.1. Approach A (Preferred Method): Installing prebuilt images</h3>
<p>The preferred approach to installing the evaluation dataset is to install the Docker images using the <code>images.tar.gz</code> file included in this replication package. Using this approach will ensure that you run the experiments using exactly the same images that were used in the original paper submission. In comparison, building the images from scratch may lead to slightly different images for reasons that are difficult to control (e.g., changes to <code>apt/rosdep</code> packages, etc.).</p>
<p>The prebuilt Docker images can be installed on Linux using the command below.</p>
<pre class="command"><code>$ gunzip -c images.tar.gz | docker load</code></pre>
<p>After this step, you may wish to delete the <code>images.tar.gz</code> to save disk space (after validating your installation following the instructions at the end of this document).</p>
<pre class=""><code>$ rm images.tar.gz</code></pre>
<h3 id="approach-b-building-images-from-scratch">3.2. Approach B: Building images from scratch</h3>
<p>To build all of the Docker images for the replication package from scratch, you can execute the appropriate commands shown below. If you installed the experiment harness via Docker, you should follow the commands prefixed with <code>(docker)</code>. Alternatively, if you installed the experiment harness natively via pipenv, you should follow the commands prefixed with <code>(native)</code>.</p>
<p>Be aware that building all images from scratch will take several hours depending on your compute hardware and network connection.</p>
<pre class="command"><code>(docker) $ docker/run.sh build recovery all
(docker) $ docker/run.sh build detection all
(native) $ pipenv run build recovery all
(native) $ pipenv run build detection all</code></pre>
<p>Instead, you may also build the image for an individual experiment as shown below. <code>build recovery husky</code> will build the Docker image used in RQ1 and RQ2 for Husky. <code>build detection autoware-01</code> will build the Docker image used in RQ3 for Autoware-01.</p>
<pre class="command"><code>(docker) $ docker/run.sh build recovery husky
(docker) $ docker/run.sh build detection autoware-01
(native) $ pipenv run build recovery husky
(native) $ pipenv run build detection autoware-01</code></pre>
<p>A list of all of the available systems can be obtained using the <code>list</code> command as follows:</p>
<pre class="command"><code>(docker) $ docker/run.sh list
(native) $ pipenv run list</code></pre>
<h2 id="confirming-your-installation">4. Confirming your installation</h2>
<p>The <code>check-install</code> command, shown below, can be used to perform some basic checks of your installation, as shown below.</p>
<pre class="command"><code>(docker) $ docker/run.sh check-install
(native) $ pipenv run check-install
Is jq installed? Yes (/usr/bin/jq)
Is rosdiscover-cxx-recover installed? Yes
The following evaluation dataset images have been successfully installed:
* rosdiscover-experiments/autoware:84169473a3f72aea8a400464f5b673f3c77c6b8c
* rosdiscover-experiments/autoware:fc8f691c70bf62a3de0f7448d9490b2e9385e6c4
* rosdiscover-experiments/autoware:842990d9aca4f09004f3e88402d94ec2bbd339ee
* rosdiscover-experiments/autoware:939ef1836bcdf0ff2a6c98d1c1ced940b0e242dd
* rosdiscover-experiments/fetch:v0.8.3
* rosdiscover-experiments/autorally:7b36814b5b2938345028a26381f96b5b625d0219
* rosdiscover-experiments/husky:dc8169b6b7b9cfe37497f222adbe5f20bb83495a
* rosdiscover-experiments/autoware:5f30cabe3aea301a211951cd288357bb170199de
* rosdiscover-experiments/autoware:216269d752f232634acca6c3307c9af5c97cb17e
* rosdiscover-experiments/autorally:5366f48da3ff6b19bf493d3aed39f37a02c950e6
* rosdiscover-experiments/autorally:autorally-02-buggy
* rosdiscover-experiments/husky:dc6750e916cfecc0fbb943183a5a671950f593a3
* rosdiscover-experiments/autorally:7a49fbf584d5d14700d10a7a5d6226fa76ab30ee
* rosdiscover-experiments/autoware:86f74272b0d933abb4b5d4e0a28802592843f4f1
* rosdiscover-experiments/autoware:47d36ea2c3eff9fb0161b3a14097b70450b2c1b6
* rosdiscover-experiments/autoware:4b2f608a2189f2284c6f9923ee88b983f28adb6f
* rosdiscover-experiments/autorally:6ddb07745dc93e62a6386c83f5304147a98a9696
* rosdiscover-experiments/husky:husky-02-fixed
* rosdiscover-experiments/husky:husky-02-buggy
* rosdiscover-experiments/autorally:autorally-02-fixed
* rosdiscover-experiments/autoware:2a3f292eb451ac946959a3a20490427f0d2f764d
* rosdiscover-experiments/husky:0.4.10
* rosdiscover-experiments/autorally:a47a173290a175fa9ed1eb2b635afda25574bc63
* rosdiscover-experiments/turtlebot:fc0e1b8d6e8b0f22a69d4958a5e073a48d87e291
* rosdiscover-experiments/autorally:autorally-01-fixed
* rosdiscover-experiments/autorally:3ae64dad2107baccac836b70f80c2bb4bc8669cd
* rosdiscover-experiments/autoware:30eed1453e97eb4beb7b696ff22f5312ad80f5f6
* rosdiscover-experiments/autoware:c2a090dec2101be2788ecb607102fa9210e24737
* rosdiscover-experiments/husky:23c259f3340fbab901d3fe5d8fd6577e99d6e430
* rosdiscover-experiments/autoware:f1fb9e205ca3d449a2e96f0f3409f9fd2d84ad8d
* rosdiscover-experiments/autorally:autorally-03-buggy
* rosdiscover-experiments/husky:husky-04-buggy
* rosdiscover-experiments/husky:husky-06-fixed
* rosdiscover-experiments/autoware:e9d6d6f8762457249ccb497680cf838b5a33d3e4
* rosdiscover-experiments/autoware:0583e6d128450b2c567732cb9a00b828af7cd93e
* rosdiscover-experiments/autorally:d1c56c0b11a35d573ef00c4276d5ba3e668728ac
* rosdiscover-experiments/husky:97c5280b151665704f8f8e3beecb3e6e89ea14ae
* rosdiscover-experiments/autorally:279c6642e5547876beeb536cced74661c8e46b50
* rosdiscover-experiments/autoware:2fbad6d64f9d71e4b1b5e1de9008ca63f3b44fa1
* rosdiscover-experiments/husky:3796317c73f184d767b1a74f7d58d0cc5b3f84fe
* rosdiscover-experiments/autorally:c2692f2
* rosdiscover-experiments/autoware:6a7d1b9f66fd353eb5c6ad8df942c433fff8e2a1
* rosdiscover-experiments/turtlebot:3e32933c829e308600707a9f971334d13d1cbe19
* rosdiscover-experiments/husky:husky-04-fixed
* rosdiscover-experiments/mavros:mavros-02-buggy
* rosdiscover-experiments/autoware:a2ab41dafe76579a76ad23f92f8f4992b701433b
* rosdiscover-experiments/turtlebot:e799e45abdfe3106ac105ce21dd43283381ba180
* rosdiscover-experiments/autorally:autorally-04-buggy
* rosdiscover-experiments/autorally:autorally-04-fixed
* rosdiscover-experiments/autoware:8bf1c47fbc18a0303fda23c601dfe959a3afbc41
* rosdiscover-experiments/autorally:autorally-03-fixed
* rosdiscover-experiments/autoware:static
* rosdiscover-experiments/autoware:37b9feba82e6a6fabfa689fcf9d210c3c8f287f6
* rosdiscover-experiments/autoware:6428d5fb34b961fd37da212bdb068f77ae99f25f
* rosdiscover-experiments/husky:husky-06-buggy
* rosdiscover-experiments/turtlebot:2.4.2
* rosdiscover-experiments/autoware:92d9732112467fb2e7d7f66da56be51ba746915b
* rosdiscover-experiments/autorally:autorally-01-buggy
* rosdiscover-experiments/mavros:mavros-02-fixed
* rosdiscover-experiments/turtlebot:b26d199a18d350e72495c4d8935e5b1ccc64d75a
* rosdiscover-experiments/autoware:3db7e153dc111682857ffd089018b92b2eed1786
* rosdiscover-experiments/husky:8afd94b417f33e6be6c8b7196ad9ca66260250c7
The following evaluation dataset images are missing:</code></pre>