神经网络模型的加载与保存(基于tensorflow)

神经网络模型的加载与保存

方式一:只保存权重,save/load weights

注:只保存权重,不保存模型,轻量级,要求复现的模型与原模型完全相同
// 模型的保存与下载步骤
// save the weights
model.save_weights("./checkpoints/my_checkpoint")
//restore the weights
model = create_model()
model.load_weights("./checkpoints/my_checkpoint")
//evaluate model
loss, acc = model.evaluate(test_images, test_labels)
print( "Restored model,accuracy: {:5.2f}%".format( 100*acc))

// 方法一示例
network.save_weights( 'weights.ckpt ')print( 'saved weights.')
del network
network = Sequential([layers.Dense(256,activation='relu'),
					  layers.Dense(128,activation='relu'),
					  layers.Dense(64,activation='relu'),
					  layers.Dense(32,activation='relu '),
					  layers.Dense(10)])
network.compile(optimizer=optimizers.Adam(lr=0.01),
	       loss=tf.losses.CategoricalCrossentropy(from_logits=True),
	       metrics=['accuracy'])
network.load_weights('weights.ckpt')
network.evaluate(ds_val)

方式二: 将权重与模型一同保存,save/load total model

注:模型与权重均保存,占用空间大,不需要复现原模型
// 模型的保存与下载步骤:
network.save('model.h5')
print('saved total model.')
del network
print('load model from file')
network = tf.keras.models.load_model('model.h5 ')
network.evaluate(x_val, y_val)

方式三: 可用于工业部署的方法,saved_model

注:很常用,用于工业环境的部署,可以被其他语言使用
// 模型的保存与下载步骤:
tf.saved_model.save(m,'/tmp/saved_model/')
imported = tf.saved_model.load(path)
f = imported.signatures["serving_default"]
print(f(x=tf.ones([128283])))
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是基于 Tensorflow神经网络 GPU 数据并行计算的详细步骤: 1. 确保你的系统支持 GPU 计算。你需要有一个支持 CUDA 的 NVIDIA GPU 以及安装了相应的 CUDA 和 cuDNN 库。 2. 安装 Tensorflow GPU 版本。在安装 Tensorflow 之前,你需要先安装 CUDA 和 cuDNN 库。然后,你可以通过 pip install tensorflow-gpu 命令来安装 Tensorflow GPU 版本。 3. 构建模型。构建你的神经网络模型并将其保存在一个文件中。 4. 指定 GPU 设备。在 Tensorflow 中,你可以使用 with tf.device('/gpu:0') 语句来指定 GPU 设备。这里的 0 表示使用第一个 GPU 设备。如果你有多个 GPU 设备,可以使用 '/gpu:1'、'/gpu:2' 等来指定不同的设备。 5. 定义损失函数和优化器。通常,你需要定义一个损失函数来评估模型的性能,并使用一个优化器来最小化损失函数。你可以使用 Tensorflow 中的各种损失函数和优化器来定义它们。 6. 定义训练操作。在 Tensorflow 中,你可以使用 tf.train.Optimizer.minimize() 方法来定义训练操作。该方法将自动计算损失函数的梯度,并使用优化器来更新模型参数。 7. 定义会话。在 Tensorflow 中,你需要使用一个会话来运行你的模型。你可以使用 tf.Session() 方法来创建一个会话。 8. 运行训练操作。在会话中,你需要运行训练操作来训练你的模型。你可以使用 Session.run() 方法来运行训练操作。在运行之前,你需要使用 Session.run() 方法来初始化所有变量。 9. 保存模型。在训练完成后,你可以使用 tf.train.Saver() 方法来保存模型参数。你可以将它们保存到一个文件中,以便在以后使用。 10. 加载模型。在以后,你可以使用 tf.train.Saver() 方法来加载保存模型参数。你可以将它们加载到一个新的会话中,并使用该会话来进行预测。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值