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

### Tensorflow

5
6
[![TensorFlow 2.1](https://img.shields.io/badge/tensorflow-2.1-brightgreen)](https://github.com/tensorflow/tensorflow/releases/tag/v2.1.0)

7
8
9
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
10
11
12

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

18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
### 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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
### 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
54
pip install matplotlib numpy scikit-image scipy
55
sudo apt-get install python-tk
Andre Araujo's avatar
Andre Araujo committed
56
57
58
59
60
61
62
63
64
65
```

### `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
66
git clone git@github.com:tensorflow/models.git
Andre Araujo's avatar
Andre Araujo committed
67

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

74
75
76
77
78
79
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
80
81
82
83
84
85
86
87
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=.
```

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

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

At this point, running

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

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

### 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
111
112
to use `pip3` instead of `pip`, `python3-tk` instead of `python-tk`, and all
should work.
113
114
115
116
117

#### `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,
118
119
120
121
122
123
124
125
126
127
128
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.