INSTALL_INSTRUCTIONS.md 3.81 KB
Newer Older
Andre Araujo's avatar
Andre Araujo committed
1
2
3
4
## DELF installation

### Tensorflow

5
6
7
For detailed steps to install Tensorflow, follow the
[Tensorflow installation instructions](https://www.tensorflow.org/install/). A
typical user can install Tensorflow using one of the following commands:
Andre Araujo's avatar
Andre Araujo committed
8
9
10

```bash
# For CPU:
11
pip install 'tensorflow'
Andre Araujo's avatar
Andre Araujo committed
12
# For GPU:
13
pip install 'tensorflow-gpu'
Andre Araujo's avatar
Andre Araujo committed
14
15
```

16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
### TF-Slim

Note: currently, we need to install the latest version from source, to avoid
using previous versions which relied on tf.contrib (which is now deprecated).

```bash
git clone git@github.com:google-research/tf-slim.git
cd tf-slim
pip install .
```

Note that these commands assume you are cloning using SSH. If you are using
HTTPS instead, use `git clone https://github.com/google-research/tf-slim.git`
instead. See
[this link](https://help.github.com/en/github/using-git/which-remote-url-should-i-use)
for more information.

Andre Araujo's avatar
Andre Araujo committed
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
### Protobuf

The DELF library uses [protobuf](https://github.com/google/protobuf) (the python
version) to configure feature extraction and its format. You will need the
`protoc` compiler, version >= 3.3. The easiest way to get it is to download
directly. For Linux, this can be done as (see
[here](https://github.com/google/protobuf/releases) for other platforms):

```bash
wget https://github.com/google/protobuf/releases/download/v3.3.0/protoc-3.3.0-linux-x86_64.zip
unzip protoc-3.3.0-linux-x86_64.zip
PATH_TO_PROTOC=`pwd`
```

### Python dependencies

Install python library dependencies:

```bash
52
pip install matplotlib numpy scikit-image scipy
53
sudo apt-get install python-tk
Andre Araujo's avatar
Andre Araujo committed
54
55
56
57
58
59
60
61
62
63
```

### `tensorflow/models`

Now, clone `tensorflow/models`, and install required libraries: (note that the
`object_detection` library requires you to add `tensorflow/models/research/` to
your `PYTHONPATH`, as instructed
[here](https://github.com/tensorflow/models/blob/master/research/object_detection/g3doc/installation.md))

```bash
64
git clone git@github.com:tensorflow/models.git
Andre Araujo's avatar
Andre Araujo committed
65

66
# Setup the object_detection module by editing PYTHONPATH.
Andre Araujo's avatar
Andre Araujo committed
67
68
69
70
71
cd ..
# From tensorflow/models/research/
export PYTHONPATH=$PYTHONPATH:`pwd`
```

72
73
74
75
76
77
Note that these commands assume you are cloning using SSH. If you are using
HTTPS instead, use `git clone https://github.com/tensorflow/models.git` instead.
See
[this link](https://help.github.com/en/github/using-git/which-remote-url-should-i-use)
for more information.

Andre Araujo's avatar
Andre Araujo committed
78
79
80
81
82
83
84
85
Then, compile DELF's protobufs. Use `PATH_TO_PROTOC` as the directory where you
downloaded the `protoc` compiler.

```bash
# From tensorflow/models/research/delf/
${PATH_TO_PROTOC?}/bin/protoc delf/protos/*.proto --python_out=.
```

86
87
Finally, install the DELF package. This may also install some other dependencies
under the hood.
Andre Araujo's avatar
Andre Araujo committed
88
89
90

```bash
# From tensorflow/models/research/delf/
91
pip install -e . # Install "delf" package.
Andre Araujo's avatar
Andre Araujo committed
92
93
94
95
96
97
98
99
100
101
```

At this point, running

```bash
python -c 'import delf'
```

should just return without complaints. This indicates that the DELF package is
loaded successfully.
102
103
104
105
106
107
108

### Troubleshooting

#### Python version

Installation issues may happen if multiple python versions are mixed. The
instructions above assume python2.7 version is used; if using python3.X, be sure
109
110
to use `pip3` instead of `pip`, `python3-tk` instead of `python-tk`, and all
should work.
111
112
113
114
115

#### `pip install`

Issues might be observed if using `pip install` with `-e` option (editable
mode). You may try out to simply remove the `-e` from the commands above. Also,
116
117
118
119
120
121
122
123
124
125
126
depending on your machine setup, you might need to run the `sudo pip install`
command, that is with a `sudo` at the beginning.

#### Cloning github repositories

The default commands above assume you are cloning using SSH. If you are using
HTTPS instead, use for example `git clone
https://github.com/tensorflow/models.git` instead of `git clone
git@github.com:tensorflow/models.git`. See
[this link](https://help.github.com/en/github/using-git/which-remote-url-should-i-use)
for more information.