forked from aidan-dc/L1BTag
-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathqkerasModel.py
114 lines (104 loc) · 4.08 KB
/
qkerasModel.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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
import h5py
import numpy as np
import tensorflow
import matplotlib.pyplot as plt
from tensorflow.keras.models import Model
from tensorflow.keras.layers import Conv1D, Dense, Flatten, Input, GlobalAveragePooling1D
from dataForgeScripts.dataForge import N_FEAT, N_PART_PER_JET
from qkeras import *
from tensorflow.keras.regularizers import l1
# Load in the datasets for training and compiling the sample weights
with h5py.File("dataForgeScripts/newTrainDataST30.h5", "r") as hf:
dataset = hf["Training Data"][:]
with h5py.File("dataForgeScripts/trainingDataQCD30.h5", "r") as hf:
datasetQCD = hf["Training Data"][:]
with h5py.File("dataForgeScripts/sampleDataSTop30.h5", "r") as hf:
sampleData = hf["Sample Data"][:]
dataset = np.concatenate((dataset, datasetQCD))#Put datasets on top of one another
#dataset = np.load("AugTrainingDataPt30.npy")
np.random.shuffle(dataset) #randomize QCD and Stop samples
# Separate datasets into inputs and outputs, expand the dimensions of the inputs to be used with Conv1D layers
X = dataset[:, 0 : len(dataset[0]) - 1]
y = dataset[:, len(dataset[0]) - 1]
X = X.reshape((X.shape[0], N_PART_PER_JET, N_FEAT))
# Establish the sample weights
thebins = np.linspace(0, 200, 100)
bkgPts = []
sigPts = []
for i in range(len(sampleData)):
if y[i] == 1:
sigPts.append(sampleData[i][0])
if y[i] == 0:
bkgPts.append(sampleData[i][0])
bkg_counts, binsbkg = np.histogram(bkgPts, bins=thebins)
sig_counts, binssig = np.histogram(sigPts, bins=thebins)
a = []
for i in range(len(bkg_counts)):
tempSig = float(sig_counts[i])
tempBkg = float(bkg_counts[i])
if tempBkg != 0:
a.append(tempSig / tempBkg)
if tempBkg == 0:
a.append(0)
# Normalize the sample weights above a certain pT
for i in range(42, len(a)):
a[i] = 0.7
# Compile the network
x = inputs = Input(shape=(N_PART_PER_JET, N_FEAT))
x = QConv1D(
filters=50,
kernel_size=4,
strides=2
)(x)
x = QActivation(activation=quantized_relu(8))(x)
x = QConv1D(filters=50, kernel_size=4, strides=1)(x)
x = QActivation(activation=quantized_relu(8))(x)
#x = QGlobalAveragePooling2D()(x)
x = Flatten()(x)
x = QDense(50, kernel_quantizer=quantized_bits(8,0,alpha=1), bias_quantizer=quantized_bits(8,0,alpha=1),
kernel_initializer='lecun_uniform', kernel_regularizer=l1(0.0001))(x)
x = QActivation(activation=quantized_relu(8))(x)
x = QDense(10, kernel_quantizer=quantized_bits(8,0,alpha=1), bias_quantizer=quantized_bits(8,0,alpha=1),
kernel_initializer='lecun_uniform', kernel_regularizer=l1(0.0001))(x)
x = QActivation(activation=quantized_relu(8))(x)
x = QDense(1, kernel_quantizer=quantized_bits(8,0,alpha=1), bias_quantizer=quantized_bits(8,0,alpha=1),
kernel_initializer='lecun_uniform', kernel_regularizer=l1(0.0001))(x)
outputs = QActivation("sigmoid")(x)
#outputs = Dense(1, activation="sigmoid")(x) #For 2qkL1JeTagModel.h5
model = Model(inputs=inputs, outputs=outputs)
model.compile(loss="binary_crossentropy", optimizer="adam", metrics=["binary_accuracy"])
# Add in the sample weights, 1-to-1 correspondence with training data
# Sample weight of all signal events being equal to 1
# Sample weight of all background events being equal to the sig/bkg ratio at that jet's pT
#weights = []
#for i in range(len(sampleData)):
# if y[i] == 1:
# weights.append(1)
# if y[i] == 0:
# jetPt = sampleData[i][0]
# tempPt = int(jetPt / 2)
# if tempPt > 98:
# tempPt = 98
#weights.append(a[tempPt])
# Train the network
callback = tensorflow.keras.callbacks.EarlyStopping(monitor="val_loss", verbose=1, patience=5)
history=model.fit(
X,
y,
epochs=50,
batch_size=50,
verbose=2,
#sample_weight=np.asarray(weights),
validation_split=0.20,
callbacks=[callback],
)
plt.figure(figsize=(7,5), dpi=120)
plt.plot(history.history['loss'], label = 'Train')
plt.plot(history.history['val_loss'], label = 'Validation')
plt.title('Model Loss', fontsize=25)
plt.ylabel('loss')
plt.xlabel('epoch')
plt.legend(loc='best')
plt.savefig("qkModelLoss.png")
# Save the network
model.save("qkL1JetTagModel.h5")