卷积在pytorch中有两种实现,一种是torch.nn.Conv2d(),一种是torch.nn.functional.conv2d(),这两种方式本质都是执行卷积操作,对输入的要求也是一样的,首先需要输入的是一个torch.autograd.Variable()的类型,大小是(batch,channel, H,W),其中batch表示输入的一批数据的数目,channel表示输入的通道数。
一般一张彩色的图片是3,灰度图片是1,而卷积网络过程中的通道数比较大,会出现几十到几百的通道数。H和W表示输入图片的高度和宽度,比如一个batch是32张图片,每张图片是3通道,高和宽分别是50和100,那么输入的大小就是(32,3,50,100)。
如下代码是卷积执行soble边缘检测算子的实现:
import torch import numpy as np from torch import nn from PIL import Image from torch.autograd import Variable import torch.nn.functional as F def nn_conv2d(im): # 用nn.Conv2d定义卷积操作 conv_op = nn.Conv2d(1, 1, 3, bias=False) # 定义sobel算子参数 sobel_kernel = np.array([[-1, -1, -1], [-1, 8, -1], [-1, -1, -1]], dtype='float32') # 将sobel算子转换为适配卷积操作的卷积核 sobel_kernel = sobel_kernel.reshape((1, 1, 3, 3)) # 给卷积操作的卷积核赋值 conv_op.weight.data = torch.from_numpy(sobel_kernel) # 对图像进行卷积操作 edge_detect = conv_op(Variable(im)) # 将输出转换为图片格式 edge_detect = edge_detect.squeeze().detach().numpy() return edge_detect def functional_conv2d(im): sobel_kernel = np.array([[-1, -1, -1], [-1, 8, -1], [-1, -1, -1]], dtype='float32') # sobel_kernel = sobel_kernel.reshape((1, 1, 3, 3)) weight = Variable(torch.from_numpy(sobel_kernel)) edge_detect = F.conv2d(Variable(im), weight) edge_detect = edge_detect.squeeze().detach().numpy() return edge_detect def main(): # 读入一张图片,并转换为灰度图 im = Image.open('./cat.jpg').convert('L') # 将图片数据转换为矩阵 im = np.array(im, dtype='float32') # 将图片矩阵转换为pytorch tensor,并适配卷积输入的要求 im = torch.from_numpy(im.reshape((1, 1, im.shape[0], im.shape[1]))) # 边缘检测操作 # edge_detect = nn_conv2d(im) edge_detect = functional_conv2d(im) # 将array数据转换为image im = Image.fromarray(edge_detect) # image数据转换为灰度模式 im = im.convert('L') # 保存图片 im.save('edge.jpg', quality=95) if __name__ == "__main__": main()
原图片:cat.jpg
结果图片:edge.jpg
以上这篇Pytorch 实现sobel算子的卷积操作详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持呐喊教程。
本文向大家介绍PyTorch上实现卷积神经网络CNN的方法,包括了PyTorch上实现卷积神经网络CNN的方法的使用技巧和注意事项,需要的朋友参考一下 一、卷积神经网络 卷积神经网络(ConvolutionalNeuralNetwork,CNN)最初是为解决图像识别等问题设计的,CNN现在的应用已经不限于图像和视频,也可用于时间序列信号,比如音频信号和文本数据等。CNN作为一个深度学习架构被提出的
我试图在PyTorch中执行静态训练后量化。对于这个例子,我尝试用偏置量化Conv2d层: PyTorch文档明确指出,偏差不是量子化的,而是保持为浮动张量。输出的整数表示产生: 但是,浮点表示法产生: 我搜索了关于这个问题的信息,得出的结论是,用于卷积输出再量化的刻度和零点考虑了偏差,并且在GEMM操作期间,偏差被量化为int32_t,然后被添加到GEMMint32_t结果中...从上述示例中,
主要内容:卷积神经网络深度学习是机器学习的一个分支,它是近几十年来研究人员突破的关键步骤。深度学习实现的示例包括图像识别和语音识别等应用。 下面给出了两种重要的深度神经网络 - 卷积神经网络 递归神经网络。 在本章中,我们将关注第一种类型,即卷积神经网络(CNN)。 卷积神经网络 卷积神经网络旨在通过多层阵列处理数据。这种类型的神经网络用于图像识别或面部识别等应用。 CNN与任何其他普通神经网络之间的主要区别在于CNN
本文向大家介绍详解PyTorch中Tensor的高阶操作,包括了详解PyTorch中Tensor的高阶操作的使用技巧和注意事项,需要的朋友参考一下 条件选取:torch.where(condition, x, y) → Tensor 返回从 x 或 y 中选择元素的张量,取决于 condition 操作定义: 举个例子: 把张量中的每个数据都代入条件中,如果其大于 0 就得出 a,其它情况就得出
本文向大家介绍Tensorflow实现卷积神经网络的详细代码,包括了Tensorflow实现卷积神经网络的详细代码的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Tensorflow实现卷积神经网络的具体代码,供大家参考,具体内容如下 1.概述 定义: 卷积神经网络(Convolutional Neural Network,CNN)是一种前馈神经网络,它的人工神经元可以响应一部分覆盖
本文向大家介绍TensorFlow tf.nn.conv2d实现卷积的方式,包括了TensorFlow tf.nn.conv2d实现卷积的方式的使用技巧和注意事项,需要的朋友参考一下 实验环境:tensorflow版本1.2.0,python2.7 介绍 惯例先展示函数: tf.nn.conv2d(input, filter, strides, padding, use_cudnn_on_gpu=