|  View source on GitHub | 
The TPUEmbedding mid level API running on CPU for serving.
tf.tpu.experimental.embedding.TPUEmbeddingForServing(
    feature_config: Union[tf.tpu.experimental.embedding.FeatureConfig, Iterable],
    optimizer: Optional[tpu_embedding_v2_utils._Optimizer]
)
You can first train your model using the TPUEmbedding class and save the checkpoint. Then use this class to restore the checkpoint to do serving.
First train a model and save the checkpoint.
model = model_fn(...)
strategy = tf.distribute.TPUStrategy(...)
with strategy.scope():
  embedding = tf.tpu.experimental.embedding.TPUEmbedding(
      feature_config=feature_config,
      optimizer=tf.tpu.experimental.embedding.SGD(0.1))
# Your custom training code.
checkpoint = tf.train.Checkpoint(model=model, embedding=embedding)
checkpoint.save(...)
Then restore the checkpoint and do serving.
# Restore the model on CPU.
model = model_fn(...)
embedding = tf.tpu.experimental.embedding.TPUEmbeddingForServing(
      feature_config=feature_config,
      optimizer=tf.tpu.experimental.embedding.SGD(0.1))
checkpoint = tf.train.Checkpoint(model=model, embedding=embedding)
checkpoint.restore(...)
result = embedding(...)
table = embedding.embedding_table
| Args | |
|---|---|
| feature_config | A nested structure of tf.tpu.experimental.embedding.FeatureConfigconfigs. | 
| optimizer | An instance of one of tf.tpu.experimental.embedding.SGD,tf.tpu.experimental.embedding.Adagradortf.tpu.experimental.embedding.Adam. When not created under TPUStrategy
may be set to None to avoid the creation of the optimizer slot
variables, useful for optimizing memory consumption when exporting the
model for serving where slot variables aren't needed. | 
| Raises | |
|---|---|
| RuntimeError | If created under TPUStrategy. | 
| Attributes | |
|---|---|
| embedding_tables | Returns a dict of embedding tables, keyed by TableConfig. | 
Methods
build
build()
Create variables and slots variables for TPU embeddings.
embedding_lookup
embedding_lookup(
    features: Any, weights: Optional[Any] = None
) -> Any
Apply standard lookup ops on CPU.
| Args | |
|---|---|
| features | A nested structure of tf.Tensors,tf.SparseTensors ortf.RaggedTensors, with the same structure asfeature_config. Inputs
will be downcast totf.int32. Only one type out oftf.SparseTensorortf.RaggedTensoris supported per call. | 
| weights | If not None, a nested structure oftf.Tensors,tf.SparseTensors ortf.RaggedTensors, matching the above, except
that the tensors should be of float type (and they will be downcast totf.float32). Fortf.SparseTensors we assume theindicesare the
same for the parallel entries fromfeaturesand similarly fortf.RaggedTensors we assume the row_splits are the same. | 
| Returns | |
|---|---|
| A nested structure of Tensors with the same structure as input features. | 
__call__
__call__(
    features: Any, weights: Optional[Any] = None
) -> Any
Call the mid level api to do embedding lookup.