具有Tensorflow.keras的项目组织。应该是一个子类tf.keras.Model吗?

问题描述 投票:0回答:2

我正在使用Tensorflow 1.14和tf.keras API来构建许多(> 10)的differnet神经网络。 (我也对使用Tensorflow 2回答这个问题感兴趣)。我想知道如何组织我的项目。

我使用tf.keras.estimator.model_to_estimator和Tensorboard将keras模型转换为估计量以进行可视化。我有时也使用model.summary()。我的每个模型都有许多(> 20)超参数,并以三种输入数据中的一种作为输入。有时,我会使用超参数优化,以便经常尝试删除下一组超参数之前手动删除模型并使用tf.keras.backend.clear_session()

当前,我正在使用以超参数作为参数并返回相应的已编译keras模型以转换为估计量的函数。我使用三种不同的“ Main_Datatype.py”脚本来训练三种不同输入数据类型的模型。所有数据都是从.tfrecord文件加载的,每种数据类型都有一个输入函数,所有将该类型的数据作为输入的估算器都使用该函数。我在Main脚本之间切换模型(即返回模型的函数)。我还拥有一些构建模块,这些构建模块是多个模型的一部分,为此我使用辅助函数将其返回,并使用Keras功能API将最终结果拼凑在一起。

不同模型之间的轻微不兼容性开始使我感到困惑,我决定使用类来组织项目。我打算为每个模型创建一个类,以跟踪超参数并正确命名每个模型及其模型目录。但是,我想知道Tensorflow中是否存在建立或推荐的方法。

问题:我应该继承tf.keras.Model的子类,而不是使用函数来构建封装它们的模型或python类吗?子类化keras.Model是否会破坏(或需要大量工作来启用)我与keras估计器和张量板一起使用的任何功能?我已经看到人们在使用自定义Model类时遇到了许多问题,并且有些不情愿仅仅为了发现它不适合我而投入工作。您还有其他建议来更好地组织我的项目吗?

非常感谢。

python tensorflow tensorflow-estimator tf.keras
2个回答

0
投票

仅在绝对需要时才子类化。我个人更喜欢遵循以下执行顺序。如果使用前两个选项无法实现您正在设计的模型的复杂性,那么子类化当然是剩下的唯一选择。

  1. tf.keras顺序API
  2. tf.keras功能API
  3. 子类tf.keras.Model
© www.soinside.com 2019 - 2024. All rights reserved.