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

### Tensorflow

5
[![TensorFlow 2.1](https://img.shields.io/badge/tensorflow-2.1-brightgreen)](https://github.com/tensorflow/tensorflow/releases/tag/v2.1.0)
6
[![Python 3.6](https://img.shields.io/badge/python-3.6-blue.svg)](https://www.python.org/downloads/release/python-360/)
7

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

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

19
20
21
22
23
24
25
26
### 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
27
pip3 install .
28
29
30
31
32
33
34
35
```

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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
### 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
55
56
pip3 install matplotlib numpy scikit-image scipy
sudo apt-get install python3-tk
Andre Araujo's avatar
Andre Araujo committed
57
58
59
60
61
62
63
64
65
66
```

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

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

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

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

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

At this point, running

```bash
100
python3 -c 'import delf'
Andre Araujo's avatar
Andre Araujo committed
101
102
103
104
```

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

### Troubleshooting

108
#### `pip3 install`
109

110
Issues might be observed if using `pip3 install` with `-e` option (editable
111
mode). You may try out to simply remove the `-e` from the commands above. Also,
112
depending on your machine setup, you might need to run the `sudo pip3 install`
113
114
115
116
117
118
119
120
121
122
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.