首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >tensorflow警告-发现未跟踪的函数,如lstm_cell_6_layer_call_and_return_conditional_losses

tensorflow警告-发现未跟踪的函数,如lstm_cell_6_layer_call_and_return_conditional_losses
EN

Stack Overflow用户
提问于 2021-01-13 15:49:22
回答 3查看 6K关注 0票数 11

我正在使用tensorflow2.4,并且是tensorflow的新手

下面是代码

代码语言:javascript
复制
model = Sequential()
model.add(LSTM(32, input_shape=(X_train.shape[1:])))
model.add(Dropout(0.2))
model.add(Dense(1, activation='linear'))

model.compile(optimizer='rmsprop', loss='mean_absolute_error', metrics='mae')
model.summary()

save_weights_at = 'basic_lstm_model'
save_best = ModelCheckpoint(save_weights_at, monitor='val_loss', verbose=0,
                        save_best_only=True, save_weights_only=False, mode='min',
                        period=1)
history = model.fit(x=X_train, y=y_train, batch_size=16, epochs=20,
         verbose=1, callbacks=[save_best], validation_data=(X_val, y_val),
         shuffle=True)

在某些时期,得到了这样的警告:

你知道为什么我会收到这个警告吗?

EN

回答 3

Stack Overflow用户

发布于 2021-09-08 18:25:45

我认为可以安全地忽略这个警告,因为即使在tensorflow给出的tutorial中也可以找到相同的警告。我经常在保存自定义模型时看到此警告。只要你不想访问那些不可调用的函数,你就可以继续使用了。

但是,如果您对这一大段文本感到恼火,可以通过在代码顶部添加以下代码来取消此警告。

代码语言:javascript
复制
import absl.logging
absl.logging.set_verbosity(absl.logging.ERROR)
票数 7
EN

Stack Overflow用户

发布于 2021-03-24 18:53:15

将模型保存为H5格式似乎对我很有效。

代码语言:javascript
复制
model.save(filepath, save_format="h5")

以下是如何将H5与模型检查点一起使用(我还没有对此进行过广泛的测试,注意占用者!)

代码语言:javascript
复制
from tensorflow.keras.callbacks import ModelCheckpoint

class ModelCheckpointH5(ModelCheckpoint):
    # There is a bug saving models in TF 2.4
    # https://github.com/tensorflow/tensorflow/issues/47479
    # This forces the h5 format for saving
    def __init__(self,
               filepath,
               monitor='val_loss',
               verbose=0,
               save_best_only=False,
               save_weights_only=False,
               mode='auto',
               save_freq='epoch',
               options=None,
               **kwargs):
        super(ModelCheckpointH5, self).__init__(filepath,
               monitor='val_loss',
               verbose=0,
               save_best_only=False,
               save_weights_only=False,
               mode='auto',
               save_freq='epoch',
               options=None,
               **kwargs)
    def _save_model(self, epoch, logs):
        from tensorflow.python.keras.utils import tf_utils
   
        logs = logs or {}

        if isinstance(self.save_freq,
                      int) or self.epochs_since_last_save >= self.period:
          # Block only when saving interval is reached.
          logs = tf_utils.to_numpy_or_python_type(logs)
          self.epochs_since_last_save = 0
          filepath = self._get_file_path(epoch, logs)

          try:
            if self.save_best_only:
              current = logs.get(self.monitor)
              if current is None:
                logging.warning('Can save best model only with %s available, '
                                'skipping.', self.monitor)
              else:
                if self.monitor_op(current, self.best):
                  if self.verbose > 0:
                    print('\nEpoch %05d: %s improved from %0.5f to %0.5f,'
                          ' saving model to %s' % (epoch + 1, self.monitor,
                                                   self.best, current, filepath))
                  self.best = current
                  if self.save_weights_only:
                    self.model.save_weights(
                        filepath, overwrite=True, options=self._options)
                  else:
                    self.model.save(filepath, overwrite=True, options=self._options,save_format="h5") # NK edited here
                else:
                  if self.verbose > 0:
                    print('\nEpoch %05d: %s did not improve from %0.5f' %
                          (epoch + 1, self.monitor, self.best))
            else:
              if self.verbose > 0:
                print('\nEpoch %05d: saving model to %s' % (epoch + 1, filepath))
              if self.save_weights_only:
                self.model.save_weights(
                    filepath, overwrite=True, options=self._options)
              else:
                self.model.save(filepath, overwrite=True, options=self._options,save_format="h5") # NK edited here

            self._maybe_remove_file()
          except IOError as e:
            # `e.errno` appears to be `None` so checking the content of `e.args[0]`.
            if 'is a directory' in six.ensure_str(e.args[0]).lower():
              raise IOError('Please specify a non-directory filepath for '
                            'ModelCheckpoint. Filepath used is an existing '
                            'directory: {}'.format(filepath))
            # Re-throw the error for any other causes.
            raise 
票数 2
EN

Stack Overflow用户

发布于 2021-09-23 15:14:01

尝试将扩展名附加到文件。

代码语言:javascript
复制
save_weights_at = 'basic_lstm_model'

适用于:

代码语言:javascript
复制
save_weights_at = 'basic_lstm_model.h5'
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65697623

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档