This commit is contained in:
Glenn Jocher 2019-07-24 19:02:24 +02:00
parent e1425b7288
commit 4fb7fbf4bc
2 changed files with 30 additions and 32 deletions

View File

@ -73,7 +73,7 @@ def train(cfg,
img_size=416,
epochs=100, # 500200 batches at bs 16, 117263 images = 273 epochs
batch_size=16,
accumulate=4): # effective bs = batch_size * accumulate = 8 * 8 = 64
accumulate=4): # effective bs = batch_size * accumulate = 16 * 4 = 64
# Initialize
init_seeds()
weights = 'weights' + os.sep
@ -365,11 +365,7 @@ if __name__ == '__main__':
opt = parser.parse_args()
print(opt)
if opt.evolve:
opt.notest = True # only test final epoch
opt.nosave = True # only save final checkpoint
# Train
if not opt.evolve: # Train normally
results = train(opt.cfg,
opt.data,
img_size=opt.img_size,
@ -377,10 +373,14 @@ if __name__ == '__main__':
batch_size=opt.batch_size,
accumulate=opt.accumulate)
# Evolve hyperparameters (optional)
if opt.evolve:
print_mutation(hyp, results) # Write mutation results
else: # Evolve hyperparameters (optional)
opt.notest = True # only test final epoch
opt.nosave = True # only save final checkpoint
if opt.bucket:
os.system('gsutil cp gs://%s/evolve.txt .' % opt.bucket) # download evolve.txt if exists
for _ in range(1000): # generations to evolve
if os._exists('evolve.txt'): # if evolve.txt exists: select best hyps and mutate
# Get best hyperparameters
x = np.loadtxt('evolve.txt', ndmin=2)
x = x[fitness(x).argmax()] # select best fitness hyps

View File

@ -37,14 +37,12 @@ def fuse_conv_and_bn(conv, bn):
# https://tehnokv.com/posts/fusing-batchnorm-and-conv/
with torch.no_grad():
# init
fusedconv = torch.nn.Conv2d(
conv.in_channels,
fusedconv = torch.nn.Conv2d(conv.in_channels,
conv.out_channels,
kernel_size=conv.kernel_size,
stride=conv.stride,
padding=conv.padding,
bias=True
)
bias=True)
# prepare filters
w_conv = conv.weight.clone().view(conv.out_channels, -1)