Compare commits

...

2 Commits

Author SHA1 Message Date
JHV
6bbef46224
Merge d2da7e56ab3de5377b890ecd98ce4949e7b3ebd4 into fb54d8b54984f89f7dba90a18e7c3048421464c3 2023-05-22 17:36:53 -05:00
Jhv
d2da7e56ab Function TFModelInitializerBuilder._set_discretized_features refactored with the following changes:
removes a pair of brackets, making the intent slightly clearer
 Convert for loop into dictionary comprehension (dict-comprehension)
2023-04-04 21:30:15 +08:00

View File

@ -3,89 +3,90 @@ from .parsers import LollyModelFeaturesParser
class TFModelInitializerBuilder: class TFModelInitializerBuilder:
def __init__(self, model_features_parser=LollyModelFeaturesParser()): def __init__(self, model_features_parser=LollyModelFeaturesParser()):
self._model_features_parser = model_features_parser self._model_features_parser = model_features_parser
def build(self, lolly_model_reader): def build(self, lolly_model_reader):
''' '''
:param lolly_model_reader: LollyModelReader instance :param lolly_model_reader: LollyModelReader instance
:return: tf_model_initializer dictionary of the following format: :return: tf_model_initializer dictionary of the following format:
{ {
"features": { "features": {
"bias": 0.0, "bias": 0.0,
"binary": { "binary": {
# (feature name : feature weight) pairs # (feature name : feature weight) pairs
"feature_name_1": 0.0, "feature_name_1": 0.0,
... ...
"feature_nameN": 0.0 "feature_nameN": 0.0
}, },
"discretized": { "discretized": {
# (feature name : index aligned lists of bin_boundaries and weights # (feature name : index aligned lists of bin_boundaries and weights
"feature_name_1": { "feature_name_1": {
"bin_boundaries": [1, ..., inf], "bin_boundaries": [1, ..., inf],
"weights": [0.0, ..., 0.0] "weights": [0.0, ..., 0.0]
} }
... ...
"feature_name_K": { "feature_name_K": {
"bin_boundaries": [1, ..., inf], "bin_boundaries": [1, ..., inf],
"weights": [0.0, ..., 0.0] "weights": [0.0, ..., 0.0]
}
}
} }
} }
'''
tf_model_initializer = {
"features": {}
} }
}
'''
tf_model_initializer = {
"features": {}
}
features = self._model_features_parser.parse(lolly_model_reader) features = self._model_features_parser.parse(lolly_model_reader)
tf_model_initializer["features"]["bias"] = features["bias"] tf_model_initializer["features"]["bias"] = features["bias"]
self._set_discretized_features(features["discretized"], tf_model_initializer) self._set_discretized_features(features["discretized"], tf_model_initializer)
self._dedup_binary_features(features["binary"], features["discretized"]) self._dedup_binary_features(features["binary"], features["discretized"])
tf_model_initializer["features"]["binary"] = features["binary"] tf_model_initializer["features"]["binary"] = features["binary"]
return tf_model_initializer return tf_model_initializer
def _set_discretized_features(self, discretized_features, tf_model_initializer): def _set_discretized_features(self, discretized_features, tf_model_initializer):
if len(discretized_features) == 0: if len(discretized_features) == 0:
return return
num_bins = max([len(bins) for bins in discretized_features.values()]) num_bins = max(len(bins) for bins in discretized_features.values())
bin_boundaries_and_weights = {} bin_boundaries_and_weights = {
for feature_name in discretized_features: feature_name: self._extract_bin_boundaries_and_weights(
bin_boundaries_and_weights[feature_name] = self._extract_bin_boundaries_and_weights( discretized_features[feature_name], num_bins)
discretized_features[feature_name], num_bins) for feature_name in discretized_features
}
tf_model_initializer["features"]["discretized"] = bin_boundaries_and_weights tf_model_initializer["features"]["discretized"] = bin_boundaries_and_weights
def _dedup_binary_features(self, binary_features, discretized_features): def _dedup_binary_features(self, binary_features, discretized_features):
[binary_features.pop(feature_name) for feature_name in discretized_features] [binary_features.pop(feature_name) for feature_name in discretized_features]
def _extract_bin_boundaries_and_weights(self, discretized_feature_buckets, num_bins): def _extract_bin_boundaries_and_weights(self, discretized_feature_buckets, num_bins):
bin_boundary_weight_pairs = [] bin_boundary_weight_pairs = []
for bucket in discretized_feature_buckets: for bucket in discretized_feature_buckets:
bin_boundary_weight_pairs.append([bucket[0], bucket[2]]) bin_boundary_weight_pairs.append([bucket[0], bucket[2]])
# The default DBv2 HashingDiscretizer bin membership interval is (a, b] # The default DBv2 HashingDiscretizer bin membership interval is (a, b]
# #
# The Earlybird Lolly prediction engine discretizer bin membership interval is [a, b) # The Earlybird Lolly prediction engine discretizer bin membership interval is [a, b)
# #
# Thus, convert (a, b] to [a, b) by inverting the bin boundaries. # Thus, convert (a, b] to [a, b) by inverting the bin boundaries.
for bin_boundary_weight_pair in bin_boundary_weight_pairs: for bin_boundary_weight_pair in bin_boundary_weight_pairs:
if bin_boundary_weight_pair[0] < float("inf"): if bin_boundary_weight_pair[0] < float("inf"):
bin_boundary_weight_pair[0] *= -1 bin_boundary_weight_pair[0] *= -1
while len(bin_boundary_weight_pairs) < num_bins: while len(bin_boundary_weight_pairs) < num_bins:
bin_boundary_weight_pairs.append([float("inf"), float(0)]) bin_boundary_weight_pairs.append([float("inf"), float(0)])
bin_boundary_weight_pairs.sort(key=lambda bin_boundary_weight_pair: bin_boundary_weight_pair[0]) bin_boundary_weight_pairs.sort(key=lambda bin_boundary_weight_pair: bin_boundary_weight_pair[0])
bin_boundaries, weights = list(zip(*bin_boundary_weight_pairs)) bin_boundaries, weights = list(zip(*bin_boundary_weight_pairs))
return { return {
"bin_boundaries": bin_boundaries, "bin_boundaries": bin_boundaries,
"weights": weights "weights": weights
} }