forked from BBillot/SynthSeg
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path3-training.py
113 lines (92 loc) · 3.86 KB
/
3-training.py
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
"""
This script shows how we trained SynthSeg.
Importantly, it reuses numerous parameters seen in the previous tutorial about image generation
(i.e., 2-generation_explained.py), which we strongly recommend reading before this one.
If you use this code, please cite one of the SynthSeg papers:
https://github.com/BBillot/SynthSeg/blob/master/bibtex.bib
Copyright 2020 Benjamin Billot
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in
compliance with the License. You may obtain a copy of the License at
https://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is
distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
implied. See the License for the specific language governing permissions and limitations under the
License.
"""
# project imports
from SynthSeg.training import training
# path training label maps
path_training_label_maps = "../../data/training_label_maps"
path_model_dir = "./outputs_tutorial_3/"
batchsize = 1
# architecture parameters
n_levels = 5 # number of resolution levels
nb_conv_per_level = 2 # number of convolution per level
conv_size = 3 # size of the convolution kernel (e.g. 3x3x3)
unet_feat_count = 24 # number of feature maps after the first convolution
activation = "elu" # activation for all convolution layers except the last, which will use softmax regardless
feat_multiplier = 2 # if feat_multiplier is set to 1, we will keep the number of feature maps constant throughout the
# network; 2 will double them(resp. half) after each max-pooling (resp. upsampling);
# 3 will triple them, etc.
# training parameters
lr = 1e-4 # learning rate
wl2_epochs = 1 # number of pre-training epochs with wl2 metric w.r.t. the layer before the softmax
dice_epochs = 100 # number of training epochs
steps_per_epoch = 5000 # number of iteration per epoch
# ---------- Generation parameters ----------
# these parameters are from the previous tutorial, and thus we do not explain them again here
# generation and segmentation labels
path_generation_labels = "../../data/labels_classes_priors/generation_labels.npy"
n_neutral_labels = 18
path_segmentation_labels = (
"../../data/labels_classes_priors/synthseg_segmentation_labels.npy"
)
# shape and resolution of the outputs
target_res = None
output_shape = 160
n_channels = 1
# GMM sampling
prior_distributions = "uniform"
path_generation_classes = "../../data/labels_classes_priors/generation_classes.npy"
# spatial deformation parameters
flipping = True
scaling_bounds = 0.2
rotation_bounds = 15
shearing_bounds = 0.012
translation_bounds = False
nonlin_std = 4.0
bias_field_std = 0.7
# acquisition resolution parameters
randomise_res = True
# ------------------------------------------------------ Training ------------------------------------------------------
training(
path_training_label_maps,
path_model_dir,
generation_labels=path_generation_labels,
segmentation_labels=path_segmentation_labels,
n_neutral_labels=n_neutral_labels,
batchsize=batchsize,
n_channels=n_channels,
target_res=target_res,
output_shape=output_shape,
prior_distributions=prior_distributions,
generation_classes=path_generation_classes,
flipping=flipping,
scaling_bounds=scaling_bounds,
rotation_bounds=rotation_bounds,
shearing_bounds=shearing_bounds,
translation_bounds=translation_bounds,
nonlin_std=nonlin_std,
randomise_res=randomise_res,
bias_field_std=bias_field_std,
n_levels=n_levels,
nb_conv_per_level=nb_conv_per_level,
conv_size=conv_size,
unet_feat_count=unet_feat_count,
feat_multiplier=feat_multiplier,
activation=activation,
lr=lr,
wl2_epochs=wl2_epochs,
dice_epochs=dice_epochs,
steps_per_epoch=steps_per_epoch,
)