Path: blob/master/site/zh-cn/guide/migrate/tpu_embedding.ipynb
25118 views
Copyright 2021 The TensorFlow Authors.
从 TPU embedding_column 迁移到 TPUEmbedding 层
本指南演示了如何将 TPU 上的嵌入向量训练从 TensorFlow 1 带有 TPUEstimator
的 embedding_column
API 迁移到 TensorFlow 2 带有 TPUStrategy
的 TPUEmbedding
层 API。
嵌入向量是(大型)矩阵。它们是从稀疏特征空间映射到密集向量的查找表。嵌入向量提供高效和密集表示,可以捕捉特征之间复杂的相似度和关系。
TensorFlow 包括对在 TPU 上训练嵌入向量的专门支持。这种特定于 TPU 的嵌入向量支持可让您训练大于单个 TPU 设备内存的嵌入向量,并在 TPU 上使用稀疏和不规则输入。
在 TensorFlow 1 中,
tf.compat.v1.estimator.tpu.TPUEstimator
是一个高级 API,它封装了适用于 TPU 的训练、评估、预测和导出。它对tf.compat.v1.tpu.experimental.embedding_column
有特殊支持。要在 TensorFlow 2 中实现此目标,可以使用 TensorFlow Recommenders 的
tfrs.layers.embedding.TPUEmbedding
层。对于训练和评估,可以使用 TPU 分布策略tf.distribute.TPUStrategy
,例如,它与用于模型构建 (tf.keras.Model
)、优化器 (tf.keras.optimizers.Optimizer
) 的 Keras API 兼容,支持使用Model.fit
或者自定义训练循环(使用tf.function
和tf.GradientTape
)进行训练。
有关详情,请参阅 tfrs.layers.embedding.TPUEmbedding
层的 API 文档,以及 tf.tpu.experimental.embedding.TableConfig
和 tf.tpu.experimental.embedding.FeatureConfig
文档。有关 tf.distribute.TPUStrategy
的概述,请查看分布式训练指南和使用 TPU 指南。如果您要从 TPUEstimator
迁移到 TPUStrategy
,请查看 TPU 迁移指南。
安装
首先,安装 TensorFlow Recommenders 并导入一些必要的软件包:
然后,准备一个用于演示目的的简单数据集:
TensorFlow 1:使用 TPUEstimator 在 TPU 上训练嵌入
在 TensorFlow 1 中,使用 tf.compat.v1.tpu.experimental.embedding_column
API 设置 TPU 嵌入向量,并使用 tf.compat.v1.estimator.tpu.TPUEstimator
在 TPU 上训练/评估模型。
输入是整数,范围从零到 TPU 嵌入向量表的词汇量大小。首先使用 tf.feature_column.categorical_column_with_identity
将输入编码为分类 ID。将 "sparse_feature"
用于 key
参数,因为输入特征是整数值,而 num_buckets
是嵌入向量表的词汇量大小 (10
)。
接下来,使用 tpu.experimental.embedding_column
将稀疏分类输入转换为密集表示,其中 dimension
是嵌入向量表的宽度。它将为每个 num_buckets
存储一个嵌入向量。
现在,通过 tf.estimator.tpu.experimental.EmbeddingConfigSpec
定义特定于 TPU 的嵌入向量配置。稍后,您会将其作为 embedding_config_spec
参数传递给 tf.estimator.tpu.TPUEstimator
。
接下来,要使用 TPUEstimator
,请定义:
用于训练数据的输入函数
用于评估数据的评估输入函数
用于指示
TPUEstimator
如何使用特征和标签定义训练运算的模型函数
定义这些函数后,创建一个提供聚簇信息的 tf.distribute.cluster_resolver.TPUClusterResolver
和一个 tf.compat.v1.estimator.tpu.RunConfig
对象。
连同您已定义的模型函数,现在您可以创建一个 TPUEstimator
。在这里,您将通过跳过检查点保存来简化流程。随后,您将为 TPUEstimator
的训练和评估指定批次大小。
调用 TPUEstimator.train
以开始训练模型:
然后,调用 TPUEstimator.evaluate
以使用评估数据评估模型:
TensorFlow 2:使用 TPUStrategy 在 TPU 上训练嵌入向量
接下来,准备您的数据。这类似于您在 TensorFlow 1 示例中创建数据集的方式,不同之处在于数据集函数现在传递一个 tf.distribute.InputContext
对象而不是 params
字典。可以使用此对象来确定本地批次大小(以及此流水线用于哪个主机,以便可以正确对数据分区)。
使用
tfrs.layers.embedding.TPUEmbedding
API 时,务必在使用Dataset.batch
对数据集进行批处理时包含drop_remainder=True
选项,因为TPUEmbedding
需要固定的批批次大小。此外,如果在同一组设备上进行评估和训练,则必须使用相同的批次大小。
最后,您应当将
tf.keras.utils.experimental.DatasetCreator
与tf.distribute.InputOptions
中的特殊输入选项experimental_fetch_to_device=False
(保存特定于策略的配置)一起使用。下面的代码对此进行了演示:
接下来,准备好数据后,将创建一个 TPUStrategy
,然后在此策略的范围 (Strategy.scope
) 下定义模型、指标和优化器。
您应当为 Model.compile
中的 steps_per_execution
选择一个数字,因为它指定了每次 tf.function
调用期间要运行的批次数,并且对性能至关重要。此参数类似于 TPUEstimator
中使用的 iterations_per_loop
。
TensorFlow 1 中通过 tf.tpu.experimental.embedding_column
(和 tf.tpu.experimental.shared_embedding_column
)指定的特征和表配置可以通过一对配置对象在 TensorFlow 2 中直接指定:
tf.tpu.experimental.embedding.FeatureConfig
tf.tpu.experimental.embedding.TableConfig
(请参阅相关的 API 文档,了解更多详细信息。)
这样,您就可以使用训练数据集训练模型了:
最后,使用评估数据集评估模型:
后续步骤
在 API 文档中详细了解如何设置特定于 TPU 的嵌入向量:
tfrs.layers.embedding.TPUEmbedding
:特别介绍了特征和表配置、设置优化器、创建模型(使用 Keras 函数式 API 或通过子类化tf.keras.Model
)、训练/评估以及使用tf.saved_model
应用模型tf.tpu.experimental.embedding.TableConfig
tf.tpu.experimental.embedding.FeatureConfig
要详细了解 TensorFlow 2 中的 TPUStrategy
,请查看以下资源:
指南:使用 TPU(涵盖使用 Keras
Model.fit
进行训练/使用tf.distribute.TPUStrategy
进行自定义训练循环,以及使用tf.function
提升性能的技巧)
要详细了解如何自定义训练,请参阅:
TPUs(Google 用于机器学习的专用 ASIC)可通过 Google Colab、TPU Research Cloud 和 Cloud TPU 获得。