[6a4082]: / MI-DESS_IWTSE / ModelDCB.py

Download this file

60 lines (41 with data), 2.4 kB

 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
# ==============================================================================
# Copyright (C) 2023 Haresh Rengaraj Rajamohan, Tianyu Wang, Kevin Leung,
# Gregory Chang, Kyunghyun Cho, Richard Kijowski & Cem M. Deniz
#
# This file is part of OAI-MRI-TKR
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published
# by the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
# ==============================================================================
#!/usr/bin/env python3
from keras.models import Sequential,Model
from keras.optimizers import SGD, Adam
from keras.layers import Input#, Dropout, Dense, Conv3D, MaxPooling3D, GlobalMaxPooling3D ,GlobalAveragePooling3D, Activation, BatchNormalization,Flatten
#from keras.models import Sequential
#from keras.layers import Dropout, Dense, Conv3D, MaxPooling3D,GlobalMaxPooling3D, GlobalAveragePooling3D, Activation, BatchNormalization,Flatten
from resnet3d import Resnet3DBuilder
#from keras.regularizers import l2
def generate_model(learning_rate = 1 * 10 **(-4)):
print('**************************')
model = Resnet3DBuilder.build_resnet_18((48, 96, 18, 32), 1)
model.compile(loss='binary_crossentropy',
metrics = ['accuracy'],
optimizer = Adam(lr=learning_rate,beta_1=0.99, beta_2=0.999))#SGD(lr=1e-2, momentum = 0.9))
return model
#input1 = Input(shape=(384, 384, 36, 1))
#input2 = Input(shape=(352, 352, 144, 1))
#out = Resnet3DBuilder.build_resnet_18((48, 96, 18, 32),input1,input2,1)
#merged_model = Model([input1, input2], out)
merged_model.compile(loss='binary_crossentropy',
metrics = ['accuracy'],
optimizer = Adam(lr=learning_rate,beta_1=0.99, beta_2=0.999))#SGD(lr=1e-2, momentum = 0.9))
#loss='categorical_crossentropy'
return merged_model