超分辨率SRCNN理解(附pytorch代码)

本文介绍基于PyTorch的SRCNN模型,用于图像超分辨率处理。通过三层卷积网络,提取特征、非线性映射及重构图像,显著提升图像清晰度。对比双三次插值,SRCNN生成的图像更细腻。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

代码:基于Pytorch的SRCNN

图像会先经过预处理,进行缩小,然后放大。使用的是双三次插值法。这样生成的图,虽然大小相同,但是还是称它为LR低分辨率图像。
在这里插入图片描述
在这里插入图片描述

def __init__(self, num_channels=1):
        super(SRCNN, self).__init__()
        self.conv1 = nn.Conv2d(num_channels, 64, kernel_size=9, padding=9 // 2)
        self.conv2 = nn.Conv2d(64, 32, kernel_size=1, padding=1 // 2)
        self.conv3 = nn.Conv2d(32, num_channels, kernel_size=5, padding=5 // 2)
        self.relu = nn.ReLU(inplace=True)

三层的卷积作用分别为:
1.提取图像特征:从低分辨率图像中提取多个patch图像块,每个块被卷积操作表示为多维的向量(维数等于filter的数量),所有的特征向量组成特征矩阵(feature maps)
2.非线性映射:将n1维特征矩阵,通过卷积操作实现非线性映射,变成另一n2维特征矩阵。
3.重构图像:等于是个反卷积的过程,将n2的特征矩阵还原为超分辨图像。

结果:
在这里插入图片描述
在原图的基础上生成了两幅图,一幅是经过bicubic(双三次插值)的低分辨率图像,一幅是经过SRCNN的图像。可以明显感觉到srcnn生成的图比bicubic的那张图清晰很多。
在这里插入图片描述
在这里插入图片描述

评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值