-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtraining_model2.py
70 lines (38 loc) · 1.56 KB
/
training_model2.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
import h5py
import numpy as np
import os, sys, shutil
from PIL import Image
from pathlib import Path
import h5py
from Imageprocessor import imgprcwithpath
import csv
def train_file(path):
return(imgprcwithpath(path + ".png", Path(path).stem))
def train_directory(path, r):
DIR = path
files = os.listdir(path)
for fil in files:
fullPath = os.path.join(path, fil)
if os.path.isdir(fullPath):
categ, name = (Path(DIR).stem, Path(fullPath).stem)
for f in os.listdir(fullPath):
f = f.split('.')
passPath = fullPath +"\\" + f[0]
s = train_file((passPath))
lab = f[0].split("_")
data_p = np.concatenate((s, np.broadcast_to(np.array([int(lab[0])])[:, None, None], s.shape[:-1] + (1,))), axis = -1)
if name in (list(r.keys())):
dataset_name = Path(passPath).stem
r[name].create_dataset(dataset_name, data = data_p)
def train_model():
DIR = "A:\\Arima\\PROJECTS\\Outbox\\PRJ\\HoneyBee\\bee\\"
DIRS = ["train\\", "test\\", "validate\\"]
#for j in DIRS:
Full_path = os.path.join(DIR,DIRS[0])
h5 = h5py.File('data.h5', 'w') #.format(Path(Full_path).stem), 'w')
for i in os.listdir(Full_path):
h5.create_group(i)
train_directory(Full_path, h5)
print("TRAINING DATASETS CREATED")
if __name__ == "__main__":
sys.exit(0)