Skip to content
Snippets Groups Projects
Commit 53ba3604 authored by Nikolai.Hartmann's avatar Nikolai.Hartmann
Browse files

apply class weights for adversarial targets

parent 0bd404e7
No related branches found
No related tags found
No related merge requests found
...@@ -2062,11 +2062,12 @@ class ClassificationProjectDecorr(ClassificationProject): ...@@ -2062,11 +2062,12 @@ class ClassificationProjectDecorr(ClassificationProject):
@property @property
def class_weight_target(self): def class_weight_target(self):
"to weight the adversarial target to have equal sum of weights per bin"
if self._class_weight_target is None: if self._class_weight_target is None:
self._class_weight_target = [] self._class_weight_target = []
for var_i, binning in enumerate(self.decorr_binnings, 1): for var_i, binning in enumerate(self.decorr_binnings, 1):
sumw = self.w_train[self.l_train==0].sum() sumw = self.w_train[self.l_train==0].sum()
class_weight = [ class_weight = np.array([
sumw/( sumw/(
len(binning) len(binning)
* self.w_train[ * self.w_train[
...@@ -2075,7 +2076,7 @@ class ClassificationProjectDecorr(ClassificationProject): ...@@ -2075,7 +2076,7 @@ class ClassificationProjectDecorr(ClassificationProject):
].sum() ].sum()
) )
for label in range(len(binning)) for label in range(len(binning))
] ])
self._class_weight_target.append(class_weight) self._class_weight_target.append(class_weight)
return self._class_weight_target return self._class_weight_target
...@@ -2099,6 +2100,11 @@ class ClassificationProjectDecorr(ClassificationProject): ...@@ -2099,6 +2100,11 @@ class ClassificationProjectDecorr(ClassificationProject):
w_list[i] = np.array(w_list[i]) w_list[i] = np.array(w_list[i])
# set signal weights to 0 for decorr target # set signal weights to 0 for decorr target
w_list[i][y[:,0]==1] = 0. w_list[i][y[:,0]==1] = 0.
bin_labels = np.argmax(
self.get_output_list(y[y[:,0]==0])[1],
axis=1
)
w_list[i][y[:,0]==0] *= self.class_weight_target[i-1][bin_labels]
return w_list return w_list
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment