pytorch 和 keras padding对比

一、pytorch 相关

torch.nn.Conv2d(in_channels, out_channels, kernel_size, stride=1, padding=0, dilation=1, groups=1, bias=True, padding_mode='zeros')

其中padding_mode 有两种。默认值是‘zeros’,另一个是‘circular’(这种模式貌似具有bug)

padding参数:默认是0.

首先pytorch里默认的padding模式对应tensorflow里的‘valid’。

>>> input = torch.randn(1, 1, 3, 4)
>>> input
tensor([[[[ 0.4678, -1.0943, -1.2298,  0.4754],
          [ 0.0947, -0.2931,  0.9009, -1.6302],
          [ 0.9096, -0.6130, -0.4638,  1.2094]]]])

>>> m=nn.Conv2d(1,1,(2,2),stride=(2,2),bias=False)
>>> m(input)
tensor([[[[ 0.3072, -1.0599]]]], grad_fn=<MkldnnConvolutionBackward>)

如果padding 设置为1,pytorch就会在矩阵四周补0.

>>> m=nn.Conv2d(1,1,(1,1),stride=(1,1),bias=False,padding=1)
>>> m(input)
tensor([[[[ 0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000],
          [ 0.0000, -0.0645,  0.1508,  0.1694, -0.0655,  0.0000],
          [ 0.0000, -0.0130,  0.0404, -0.1241,  0.2246,  0.0000],
          [ 0.0000, -0.1253,  0.0845,  0.0639, -0.1666,  0.0000],
          [ 0.0000,  0.0000,  0.0000,  0.0000,  0.0000,  0.0000]]]],
       grad_fn=<MkldnnConvolutionBackward>)

 

二、keras相关

tf.keras.layers.Convolution2D
__init__(
    filters,
    kernel_size,
    strides=(1, 1),
    padding='valid',
    data_format=None,
    dilation_rate=(1, 1),
    activation=None,
    use_bias=True,
    kernel_initializer='glorot_uniform',
    bias_initializer='zeros',
    kernel_regularizer=None,
    bias_regularizer=None,
    activity_regularizer=None,
    kernel_constraint=None,
    bias_constraint=None,
    **kwargs
)

keras里padding默认值也是‘valid’

keras padding设置为same的时候就会自动填充0.

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PyTorch模型转换为Keras模型代码是一项比较复杂的任务,因为PyTorchKeras在实现上有很大的不同。不过,可以通过以下步骤尝试进行转换: 1. 安装onnx和onnx-tf 首先,需要安装onnx和onnx-tf。onnx是一种跨平台的开放式格式,用于表示深度学习模型。onnx-tf是一个用于将onnx模型转换为TensorFlow模型的工具。 ``` pip install onnx onnx-tf ``` 2. 将PyTorch模型转换为onnx模型 使用PyTorch将模型保存为ONNX格式: ```python import torch import onnx # 加载PyTorch模型 model = torch.load('model.pth') # 转换为ONNX格式 dummy_input = torch.randn(1, 3, 224, 224) input_names = ['input'] output_names = ['output'] onnx.export(model, dummy_input, 'model.onnx', input_names=input_names, output_names=output_names) ``` 3. 将onnx模型转换为Keras模型 使用onnx-tf将onnx模型转换为Keras模型: ```python import onnx import onnx_tf import tensorflow as tf from tensorflow import keras # 加载ONNX模型 model = onnx.load('model.onnx') # 转换为Keras模型 tf_rep = onnx_tf.backend.prepare(model) graph_def = tf_rep.graph.as_graph_def() input_names = [i.name for i in tf_rep.inputs] output_names = [i.name for i in tf_rep.outputs] with tf.Graph().as_default() as graph: tf.import_graph_def(graph_def, name='') sess = tf.compat.v1.Session(graph=graph) keras_model = keras.models.Sequential() keras_model.add(keras.layers.Lambda(lambda x: x, input_shape=(None,) + input_shape)) for layer in sess.graph.get_operations(): layer_type = layer.type layer_name = layer.name layer_input_shape = layer.inputs[0].get_shape().as_list() layer_output_shape = layer.outputs[0].get_shape().as_list() if layer_type == 'Placeholder': continue elif layer_type == 'Conv2D': filters = layer.inputs[1].get_shape().as_list()[3] kernel_size = layer.inputs[1].get_shape().as_list()[0] strides = layer.get_attr('strides')[1] padding = layer.get_attr('padding').decode() keras_layer = keras.layers.Conv2D(filters=filters, kernel_size=kernel_size, strides=strides, padding=padding, name=layer_name) elif layer_type == 'MaxPool': pool_size = layer.get_attr('kernel_shape')[1] strides = layer.get_attr('strides')[1] padding = layer.get_attr('padding').decode() keras_layer = keras.layers.MaxPooling2D(pool_size=pool_size, strides=strides, padding=padding, name=layer_name) elif layer_type == 'Relu': keras_layer = keras.layers.Activation('relu', name=layer_name) elif layer_type == 'Reshape': target_shape = layer.outputs[0].get_shape().as_list()[1:] keras_layer = keras.layers.Reshape(target_shape, name=layer_name) else: raise ValueError('Unsupported layer type: {}'.format(layer_type)) keras_layer.build(layer_input_shape) keras_layer.set_weights(sess.run(layer.inputs[1:])) keras_model.add(keras_layer) keras_model.summary() ``` 以上是将PyTorch模型转换为Keras模型代码的基本步骤。但是,由于两种框架的实现有所不同,因此在实际应用中可能需要进行更深入的调整和修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值