Source code for easy_rec.python.model.multi_tower

# -*- encoding:utf-8 -*-
# Copyright (c) Alibaba, Inc. and its affiliates.

import tensorflow as tf

from easy_rec.python.layers import dnn
from easy_rec.python.model.rank_model import RankModel

from easy_rec.python.protos.multi_tower_pb2 import MultiTower as MultiTowerConfig  # NOQA

if tf.__version__ >= '2.0':
  tf = tf.compat.v1


[docs]class MultiTower(RankModel):
[docs] def __init__(self, model_config, feature_configs, features, labels=None, is_training=False): super(MultiTower, self).__init__(model_config, feature_configs, features, labels, is_training) assert self._model_config.WhichOneof('model') == 'multi_tower', ( 'invalid model config: %s' % self._model_config.WhichOneof('model')) self._model_config = self._model_config.multi_tower assert isinstance(self._model_config, MultiTowerConfig) self._tower_features = [] self._tower_num = len(self._model_config.towers) for tower_id in range(self._tower_num): tower = self._model_config.towers[tower_id] tower_feature, _ = self._input_layer(self._feature_dict, tower.input) self._tower_features.append(tower_feature)
[docs] def build_predict_graph(self): tower_fea_arr = [] for tower_id in range(self._tower_num): tower_fea = self._tower_features[tower_id] tower = self._model_config.towers[tower_id] tower_name = tower.input tower_fea = tf.layers.batch_normalization( tower_fea, training=self._is_training, trainable=True, name='%s_fea_bn' % tower_name) tower_dnn_layer = dnn.DNN(tower.dnn, self._l2_reg, '%s_dnn' % tower_name, self._is_training) tower_fea = tower_dnn_layer(tower_fea) tower_fea_arr.append(tower_fea) all_fea = tf.concat(tower_fea_arr, axis=1) final_dnn_layer = dnn.DNN(self._model_config.final_dnn, self._l2_reg, 'final_dnn', self._is_training) all_fea = final_dnn_layer(all_fea) output = tf.layers.dense(all_fea, self._num_class, name='output') self._add_to_prediction_dict(output) return self._prediction_dict