cityscapes.md 5.85 KB
Newer Older
yukun's avatar
yukun committed
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
# Running DeepLab on Cityscapes Semantic Segmentation Dataset

This page walks through the steps required to run DeepLab on Cityscapes on a
local machine.

## Download dataset and convert to TFRecord

We have prepared the script (under the folder `datasets`) to convert Cityscapes
dataset to TFRecord. The users are required to download the dataset beforehand
by registering the [website](https://www.cityscapes-dataset.com/).

```bash
# From the tensorflow/models/research/deeplab/datasets directory.
sh convert_cityscapes.sh
```

The converted dataset will be saved at ./deeplab/datasets/cityscapes/tfrecord.

## Recommended Directory Structure for Training and Evaluation

```
+ datasets
  + cityscapes
    + leftImg8bit
    + gtFine
    + tfrecord
    + exp
      + train_on_train_set
        + train
        + eval
        + vis
```

where the folder `train_on_train_set` stores the train/eval/vis events and
results (when training DeepLab on the Cityscapes train set).

## Running the train/eval/vis jobs

A local training job using `xception_65` can be run with the following command:

```bash
# From tensorflow/models/research/
python deeplab/train.py \
    --logtostderr \
lcchen's avatar
lcchen committed
45
<<<<<<< HEAD
lcchen's avatar
lcchen committed
46
47
48
49
<<<<<<< HEAD
=======
    --training_number_of_steps=90000 \
>>>>>>> origin/master
lcchen's avatar
lcchen committed
50
51
52
=======
    --training_number_of_steps=90000 \
>>>>>>> origin/master
yukun's avatar
yukun committed
53
54
55
56
57
58
59
60
61
62
    --train_split="train" \
    --model_variant="xception_65" \
    --atrous_rates=6 \
    --atrous_rates=12 \
    --atrous_rates=18 \
    --output_stride=16 \
    --decoder_output_stride=4 \
    --train_crop_size=769 \
    --train_crop_size=769 \
    --train_batch_size=1 \
lcchen's avatar
lcchen committed
63
<<<<<<< HEAD
lcchen's avatar
lcchen committed
64
65
66
67
68
<<<<<<< HEAD
=======
    --dataset="cityscapes" \
    --train_split="train" \
>>>>>>> origin/master
lcchen's avatar
lcchen committed
69
70
71
72
=======
    --dataset="cityscapes" \
    --train_split="train" \
>>>>>>> origin/master
yukun's avatar
yukun committed
73
74
75
76
77
78
79
80
81
82
    --tf_initial_checkpoints=${PATH_TO_INITIAL_CHECKPOINT} \
    --train_logdir=${PATH_TO_TRAIN_DIR} \
    --dataset_dir=${PATH_TO_DATASET}
```

where ${PATH_TO_INITIAL_CHECKPOINT} is the path to the initial checkpoint
(usually an ImageNet pretrained checkpoint), ${PATH_TO_TRAIN_DIR} is the
directory in which training checkpoints and events will be written to, and
${PATH_TO_DATASET} is the directory in which the Cityscapes dataset resides.

lcchen's avatar
lcchen committed
83
<<<<<<< HEAD
lcchen's avatar
lcchen committed
84
<<<<<<< HEAD
yukun's avatar
yukun committed
85
86
87
88
89
Note that for {train,eval,vis}.py:

1.  We use small batch size during training. The users could change it based on
    the available GPU memory and also set `fine_tune_batch_norm` to be False or
    True depending on the use case.
lcchen's avatar
lcchen committed
90
=======
lcchen's avatar
lcchen committed
91
92
=======
>>>>>>> origin/master
lcchen's avatar
lcchen committed
93
94
95
96
97
98
99
100
**Note that for {train,eval,vis}.py**:

1.  In order to reproduce our results, one needs to use large batch size (> 8),
    and set fine_tune_batch_norm = True. Here, we simply use small batch size
    during training for the purpose of demonstration. If the users have limited
    GPU memory at hand, please fine-tune from our provided checkpoints whose
    batch norm parameters have been trained, and use smaller learning rate with
    fine_tune_batch_norm = False.
lcchen's avatar
lcchen committed
101
102
103
<<<<<<< HEAD
>>>>>>> origin/master
=======
lcchen's avatar
lcchen committed
104
>>>>>>> origin/master
yukun's avatar
yukun committed
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127

2.  The users should change atrous_rates from [6, 12, 18] to [12, 24, 36] if
    setting output_stride=8.

3.  The users could skip the flag, `decoder_output_stride`, if you do not want
    to use the decoder structure.

A local evaluation job using `xception_65` can be run with the following
command:

```bash
# From tensorflow/models/research/
python deeplab/eval.py \
    --logtostderr \
    --eval_split="val" \
    --model_variant="xception_65" \
    --atrous_rates=6 \
    --atrous_rates=12 \
    --atrous_rates=18 \
    --output_stride=16 \
    --decoder_output_stride=4 \
    --eval_crop_size=1025 \
    --eval_crop_size=2049 \
lcchen's avatar
lcchen committed
128
<<<<<<< HEAD
lcchen's avatar
lcchen committed
129
130
131
132
133
<<<<<<< HEAD
=======
    --dataset="cityscapes" \
    --eval_split="val" \
>>>>>>> origin/master
lcchen's avatar
lcchen committed
134
135
136
137
=======
    --dataset="cityscapes" \
    --eval_split="val" \
>>>>>>> origin/master
yukun's avatar
yukun committed
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
    --checkpoint_dir=${PATH_TO_CHECKPOINT} \
    --eval_logdir=${PATH_TO_EVAL_DIR} \
    --dataset_dir=${PATH_TO_DATASET}
```

where ${PATH_TO_CHECKPOINT} is the path to the trained checkpoint (i.e., the
path to train_logdir), ${PATH_TO_EVAL_DIR} is the directory in which evaluation
events will be written to, and ${PATH_TO_DATASET} is the directory in which the
Cityscapes dataset resides.

A local visualization job using `xception_65` can be run with the following
command:

```bash
# From tensorflow/models/research/
python deeplab/vis.py \
    --logtostderr \
    --vis_split="val" \
    --model_variant="xception_65" \
    --atrous_rates=6 \
    --atrous_rates=12 \
    --atrous_rates=18 \
    --output_stride=16 \
    --decoder_output_stride=4 \
    --vis_crop_size=1025 \
    --vis_crop_size=2049 \
lcchen's avatar
lcchen committed
164
<<<<<<< HEAD
lcchen's avatar
lcchen committed
165
166
167
168
169
<<<<<<< HEAD
=======
    --dataset="cityscapes" \
    --vis_split="val" \
>>>>>>> origin/master
lcchen's avatar
lcchen committed
170
171
172
173
=======
    --dataset="cityscapes" \
    --vis_split="val" \
>>>>>>> origin/master
yukun's avatar
yukun committed
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
    --colormap_type="cityscapes" \
    --checkpoint_dir=${PATH_TO_CHECKPOINT} \
    --vis_logdir=${PATH_TO_VIS_DIR} \
    --dataset_dir=${PATH_TO_DATASET}
```

where ${PATH_TO_CHECKPOINT} is the path to the trained checkpoint (i.e., the
path to train_logdir), ${PATH_TO_VIS_DIR} is the directory in which evaluation
events will be written to, and ${PATH_TO_DATASET} is the directory in which the
Cityscapes dataset resides. Note that if the users would like to save the
segmentation results for evaluation server, set also_save_raw_predictions =
True.

## Running Tensorboard

Progress for training and evaluation jobs can be inspected using Tensorboard. If
using the recommended directory structure, Tensorboard can be run using the
following command:

```bash
tensorboard --logdir=${PATH_TO_LOG_DIRECTORY}
```

where `${PATH_TO_LOG_DIRECTORY}` points to the directory that contains the
train, eval, and vis directories (e.g., the folder `train_on_train_set` in the
above example). Please note it may take Tensorboard a couple minutes to populate
with data.