-
Notifications
You must be signed in to change notification settings - Fork 14
/
test.py
71 lines (59 loc) · 2.36 KB
/
test.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
import os
import sys
import datetime
import math
import dataset
import argparse
import cv2
import torch
import numpy as np
from torch.utils.data import DataLoader
from model.CamoFormer import CamoFormer
import matplotlib.pyplot as plt
plt.ion()
sys.path.insert(0, '../')
sys.dont_write_bytecode = True
os.environ["CUDA_VISIBLE_DEVICES"] = '0'
def test(dataset,parser):
args = parser.parse_args()
_TESTDATASET_ = args.test_dataset
_CKPT_ = args.ckpt
for path in ['CHAMELEON','COD10K','NC4K','CAMO']:
path=_TESTDATASET_+'/'+path
t = Valid(dataset, path, 0, 'CamoFormer', _CKPT_, mode='test')
t.save()
class Valid(object):
def __init__(self, Dataset, Path, epoch, model_name, checkpoint_path, mode='Valid'):
## dataset
if mode == 'test':
self.cfg = Dataset.Config(datapath=Path, snapshot=checkpoint_path, mode='test')
else:
self.cfg = Dataset.Config(datapath=Path, snapshot=checkpoint_path+model_name+str(epoch+1), mode='test')
self.mode = mode
self.data = Dataset.Data(self.cfg, model_name)
self.loader = DataLoader(self.data, batch_size=1, shuffle=False, num_workers=8)
## network
self.net = CamoFormer(self.cfg)
self.net.train(False)
self.net.cuda()
self.epoch = epoch
def save(self):
with torch.no_grad():
for image, (H, W), name in self.loader:
image, shape = image.cuda().float(), (H, W)
P5, P4, P3, P2, P1 = self.net(image, shape)
pred = torch.sigmoid(P1[0,0]).cpu().numpy()*255
if self.mode == 'test':
head = 'output/Prediction/CamoFormer-test'+'/'+ self.cfg.datapath.split('/')[-1]
else:
head = 'output/Prediction/CamoFormer-epoch'+str(self.epoch+1)+'/'+ self.cfg.datapath.split('/')[-1]
if not os.path.exists(head):
os.makedirs(head)
cv2.imwrite(head+'/'+name[0].replace('.jpg','')+'.png', np.round(pred))
if __name__=='__main__':
parser = argparse.ArgumentParser()
parser.add_argument("--model", default='CamoFormer')
parser.add_argument("--test_dataset", default='dataset/TestDataset')
parser.add_argument("--ckpt", default='CamoFormer.pth')
args = parser.parse_args()
test(dataset, parser)