MCPcopy
hub / github.com/microsoft/Swin-Transformer / validate

Function validate

main.py:235–279  ·  view source on GitHub ↗
(config, data_loader, model)

Source from the content-addressed store, hash-verified

233
234@torch.no_grad()
235def validate(config, data_loader, model):
236 criterion = torch.nn.CrossEntropyLoss()
237 model.eval()
238
239 batch_time = AverageMeter()
240 loss_meter = AverageMeter()
241 acc1_meter = AverageMeter()
242 acc5_meter = AverageMeter()
243
244 end = time.time()
245 for idx, (images, target) in enumerate(data_loader):
246 images = images.cuda(non_blocking=True)
247 target = target.cuda(non_blocking=True)
248
249 # compute output
250 with torch.cuda.amp.autocast(enabled=config.AMP_ENABLE):
251 output = model(images)
252
253 # measure accuracy and record loss
254 loss = criterion(output, target)
255 acc1, acc5 = accuracy(output, target, topk=(1, 5))
256
257 acc1 = reduce_tensor(acc1)
258 acc5 = reduce_tensor(acc5)
259 loss = reduce_tensor(loss)
260
261 loss_meter.update(loss.item(), target.size(0))
262 acc1_meter.update(acc1.item(), target.size(0))
263 acc5_meter.update(acc5.item(), target.size(0))
264
265 # measure elapsed time
266 batch_time.update(time.time() - end)
267 end = time.time()
268
269 if idx % config.PRINT_FREQ == 0:
270 memory_used = torch.cuda.max_memory_allocated() / (1024.0 * 1024.0)
271 logger.info(
272 f'Test: [{idx}/{len(data_loader)}]\t'
273 f'Time {batch_time.val:.3f} ({batch_time.avg:.3f})\t'
274 f'Loss {loss_meter.val:.4f} ({loss_meter.avg:.4f})\t'
275 f'Acc@1 {acc1_meter.val:.3f} ({acc1_meter.avg:.3f})\t'
276 f'Acc@5 {acc5_meter.val:.3f} ({acc5_meter.avg:.3f})\t'
277 f'Mem {memory_used:.0f}MB')
278 logger.info(f' * Acc@1 {acc1_meter.avg:.3f} Acc@5 {acc5_meter.avg:.3f}')
279 return acc1_meter.avg, acc5_meter.avg, loss_meter.avg
280
281
282@torch.no_grad()

Callers 1

mainFunction · 0.70

Calls 1

reduce_tensorFunction · 0.90

Tested by

no test coverage detected