同样是保存模型,model.save()和model. save_weights ()有何区别

简介: 同样是保存模型,model.save()和model. save_weights ()有何区别

model.save()保存了模型的图结构和模型的参数,保存模型的后缀是.hdf5。


model. save_weights ()只保存了模型的参数,并没有保存模型的图结构,保存模型的后缀使用.h5。


所以使用save_weights保存的模型比使用save() 保存的模型的大小要小。同时加载模型时的方法也不同。model.save()保存了模型的图结构,直接使用load_model()方法就可加载模型然后做测试,例:


from  tensorflow.keras.models import load_model


model=load_model("my_model_.hdf5")

加载save_weights保存的模型就稍微复杂了一些,还需要再次描述模型结构信息才能加载模型。例:



def bn_prelu(x):


   x = BatchNormalization(epsilon=1e-5)(x)


   x = PReLU()(x)


   return x



def build_model(out_dims, input_shape=(norm_size, norm_size, 3)):


   inputs_dim = Input(input_shape)


   x = Conv2D(32, (3, 3), strides=(2, 2), padding='same')(inputs_dim)


   x = bn_prelu(x)


   x = Conv2D(32, (3, 3), strides=(1, 1), padding='same')(x)


   x = bn_prelu(x)


   x = MaxPooling2D(pool_size=(2, 2))(x)


   x = Conv2D(64, (3, 3), strides=(1, 1), padding='same')(x)


   x = bn_prelu(x)


   x = Conv2D(64, (3, 3), strides=(1, 1), padding='same')(x)


   x = bn_prelu(x)


   x = MaxPooling2D(pool_size=(2, 2))(x)


   x = Conv2D(128, (3, 3), strides=(1, 1), padding='same')(x)


   x = bn_prelu(x)


   x = Conv2D(128, (3, 3), strides=(1, 1), padding='same')(x)


   x = bn_prelu(x)


   x = MaxPooling2D(pool_size=(2, 2))(x)


   x = Conv2D(256, (3, 3), strides=(1, 1), padding='same')(x)


   x = bn_prelu(x)


   x = Conv2D(256, (3, 3), strides=(1, 1), padding='same')(x)


   x = bn_prelu(x)


   x = GlobalAveragePooling2D()(x)


   dp_1 = Dropout(0.5)(x)


   fc2 = Dense(out_dims)(dp_1)


   fc2 = Activation('softmax')(fc2) #此处注意,为sigmoid函数


   model = Model(inputs=inputs_dim, outputs=fc2)


   return model


model=build_model(labelnum)


model. load_weights(“my_model_.h5”);


目录
相关文章
|
3月前
|
PyTorch 算法框架/工具
pytorch - swa_model模型保存的问题
pytorch - swa_model模型保存的问题
24 0
|
14天前
添加数据:(model.py)
添加数据:(model.py)。
14 2
|
30天前
|
机器学习/深度学习 PyTorch 算法框架/工具
通过实例学习Pytorch加载权重.load_state_dict()与保存权重.save()
通过实例学习Pytorch加载权重.load_state_dict()与保存权重.save()
13 0
|
3月前
|
JavaScript
v-model和:model的区别
v-model和:model的区别
35 0
|
API 数据格式
TensorFlow2._:model.summary() Output Shape为multiple解决方法
TensorFlow2._:model.summary() Output Shape为multiple解决方法
185 0
TensorFlow2._:model.summary() Output Shape为multiple解决方法
|
存储 测试技术
测试模型时,为什么要with torch.no_grad(),为什么要model.eval(),如何使用with torch.no_grad(),model.eval(),同时使用还是只用其中之一
在测试模型时,我们通常使用with torch.no_grad()和model.eval()这两个方法来确保模型在评估过程中的正确性和效率。
580 0
|
机器学习/深度学习 PyTorch 算法框架/工具
model是一个模型网络,model.eval() 、model.train()是什么意思?
在PyTorch中,model.eval()是一个模型对象的方法,用于将模型设置为评估模式。当模型处于评估模式时,它会在前向传递期间禁用某些操作,如丢弃(dropout)和批量归一化(batch normalization),以确保模型的输出稳定性。
611 0
|
图形学
错误提示: "InfraWorks is unable to render your model" when trying to load a model
错误提示: "InfraWorks is unable to render your model" when trying to load a model
错误提示: "InfraWorks is unable to render your model" when trying to load a model