我正在使用策略渐变方法实现RL代理。我为演员定义了一个密集网络,为评论家定义了另一个密集网络。例如,我的评论家网络是:
import win32com.client as win32
#send email with html in body
outlook = win32.Dispatch('outlook.application')
mail = outlook.CreateItem(0)
mail.To = #*email address*
mail.Subject = "HTML TEST"
mail.HTMLBody = html
mail.Send()
在训练阶段,我将调用tensorboard:
state_input = Input(shape=(self.num_states,))
x = Dense(self.hidden_size, activation='tanh')(state_input)
for _ in range(self.num_layers - 1):
x = Dense(self.hidden_size, activation='tanh')(x)
out_value = Dense(1)(x)
model = Model(inputs=[state_input], outputs=[out_value])
model.compile(optimizer=SGD(lr=self.learning_rate), loss='mse')
但是我遇到了这个错误:
from keras.callbacks import TensorBoard
tensorboard = TensorBoard(log_dir="/logs/{}".format(time()),
histogram_freq=1, batch_size=32,
write_graph=True, write_grads=True,
write_images=True, embeddings_freq=0,
embeddings_layer_names=None,
embeddings_metadata=None,
embeddings_data=None, update_freq='epoch')
critic_loss = self.critic.fit([obs, advantage, old_prediction], [action],
batch_size=self.batch_size,
shuffle=True, epochs=self.epochs, verbose=False,
callbacks=[tensorboard_actor])
答案 0 :(得分:2)
TypeError:“模块”对象不可调用 你的情况是由 时间 模块
我假设您将时间模块导入为
import time
并调用了函数time()
tensorboard = TensorBoard(log_dir="/logs/{}".format(time())
可以通过导入轻松解决:
from time import time