forked from rishavpramanik/CervicalFuzzyDistanceEnsemble
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
30 lines (23 loc) · 1.34 KB
/
main.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
import numpy as np
from utils.generate_csv import generate_csv
from utils.k_fold_splits import k_fold_splits
from utils.k_fold_separate import k_fold_separate
import argparse
parser = argparse.ArgumentParser()
parser.add_argument('--num_epochs', type=int, default = 70, help='Number of Epochs for training')
parser.add_argument('--path', type=str, default = './', help='Path where the image data is stored')
parser.add_argument('--batch_size', type=int, default = 16, help='Batch Size for Mini Batch Training')
parser.add_argument('--lr', type=float, default = 1e-4, help='Learning rate for training')
args = parser.parse_args()
df = generate_csv(args.path)
y = np.array([i for i in df["class"]])
x = np.array([i for i in df["path"]])
files_for_train_x = []
files_for_validation_x = []
files_for_train_y = []
files_for_validation_y = []
k_fold_splits(x,y, files_for_train_x , files_for_validation_x , files_for_train_y , files_for_validation_y ) # n_splits = 5
#n is the number of folds
n = len(files_for_train_x)
for i in range(0,n):
k_fold_separate(files_for_train_x[i] , files_for_train_y[i] , files_for_validation_x[i] ,files_for_validation_y[i] , "InceptionV3" , "MobileNetV2" ,"InceptionResNetV2" ,i+1 , NUM_EPOCHS = args.num_epochs , train_batch=args.batch_size , validation_batch = args.batch_size, lr=args.lr)