mirror of
https://github.com/twitter/the-algorithm.git
synced 2025-01-21 00:11:17 +01:00
ef4c5eb65e
Please note we have force-pushed a new initial commit in order to remove some publicly-available Twitter user information. Note that this process may be required in the future.
55 lines
1.5 KiB
Python
55 lines
1.5 KiB
Python
# pylint: disable=useless-super-delegation
|
|
"""
|
|
Implementing Stitch Layer
|
|
"""
|
|
|
|
|
|
from .layer import Layer
|
|
|
|
import tensorflow.compat.v1 as tf
|
|
|
|
|
|
class Stitch(Layer):
|
|
"""
|
|
This layer is responsible for stitching a partioned layer together.
|
|
|
|
Output:
|
|
A layer that performs stitching
|
|
"""
|
|
|
|
def compute_output_shape(self, input_shape):
|
|
"""Computes the output shape of the layer given the input shape.
|
|
|
|
Args:
|
|
input_shape: A (possibly nested tuple of) `TensorShape`. It need not
|
|
be fully defined (e.g. the batch size may be unknown).
|
|
|
|
Raises NotImplementedError.
|
|
|
|
"""
|
|
raise NotImplementedError
|
|
|
|
def call(self, partioned_val, partioned_keys,
|
|
partioned_indices, **kwargs): # pylint: disable=unused-argument, arguments-differ
|
|
"""
|
|
This layer is responsible for stitching a partioned layer together.
|
|
|
|
Input:
|
|
partioned_val:
|
|
a list of partioned Tensors which represent the vals of the hashmap
|
|
partioned_keys:
|
|
a list of partioned Tensors which represent the keys of the hashmap
|
|
partioned_indices:
|
|
a list of partioned Tensors which represent the indices of the hashmap
|
|
Output:
|
|
List which contains: [output_vals, output_keys]
|
|
output_vals:
|
|
Values of the HashMap (float)
|
|
output_keys:
|
|
Keys of HashMap (float)
|
|
"""
|
|
indices = [tf.to_int32(index) for index in partioned_indices]
|
|
concat_keys = tf.dynamic_stitch(indices, partioned_keys)
|
|
concat_vals = tf.dynamic_stitch(indices, partioned_val)
|
|
return [concat_vals, concat_keys]
|