0

0

【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验!

P粉084495128

P粉084495128

发布时间:2025-07-22 13:57:42

|

1112人浏览过

|

来源于php中文网

原创

本文介绍基于paddle训练的rcan模型用于遥感图像四倍超分辨率重建的项目。涵盖项目背景,说明超分在遥感影像应用中的意义,还详述准备工作(克隆代码、准备数据、安装依赖等)、模型训练与预测过程,以及如何快速体验模型对图像的重建效果。

☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

【ai达人创造营第二期】以rcan模型对遥感图像超分辨率重建,可以直接体验! - php中文网

以RCAN模型对遥感图像超分辨率重建,可以直接体验!

一、项目背景

  • 意义与应用场景:单幅影像超分辨率重建一直是low-level视觉领域中一个比较热门的任务,其可以成为修复老电影、老照片的技术手段,也可以为图像分割、目标检测等下游任务提供质量较高的数据。应用的场景也比较广泛,例如:在船舶检测和分类等诸多遥感影像应用中,提高遥感影像分辨率具有重要意义。

    人民网AIGC-X
    人民网AIGC-X

    国内科研机构联合推出的AI生成内容检测工具

    下载
  • 如下表所示,当你需要对遥感图像中的车辆进行检测时,哪一种图像更好呢?当你要进行车道线提取时,哪一种的图像你更喜欢呢?

低分辨率 高分辨率
@@##@@                     @@##@@                    
@@##@@                     @@##@@                    
  • 答案是显而易见的,但如果你只有左边这列的低分辨率影像呢? 你该何去何从(手动狗头)?不要怕,可以尝试用超分辨率重建来帮你!本项目将展示用paddle训练的RCAN模型来重建四倍的遥感影像,先上效果图!
低分辨率 RCAN重建 高分辨率
@@##@@                     @@##@@                     @@##@@                    
@@##@@                     @@##@@                     @@##@@                    
  • 效果是不是不错呢?那就往下看看这怎么训练和预测的吧。注意:本项目不涉及paddlel复现RCAN模型的原理,若感兴趣的小伙伴可以去这个基于PaddleGAN框架复现超分辨率网络RCAN并对遥感影像超分项目看看

二、准备工作

  • 在进行训练之前首先要克隆代码、准备数据以及安装环境依赖
  • 之前我已经在github以及gitee上上传了相应的代码,做成了paddle复现RCAN模型的仓库
    • github地址:https://github.com/kongdebug/RCAN-Paddle
    • gitee地址:https://gitee.com/jia_jianghao_gege/RCAN-Paddle
  • 项目所用数据集地址:https://aistudio.baidu.com/aistudio/datasetdetail/129011 ,简介有介绍该数据集如何产生
In [2]
# 从码云上克隆仓库!git clone https://gitee.com/jia_jianghao_gege/RCAN-Paddle.git
       
正克隆到 'RCAN-Paddle'...
remote: Enumerating objects: 457, done.
remote: Total 457 (delta 0), reused 0 (delta 0), pack-reused 457
接收对象中: 100% (457/457), 25.47 MiB | 2.07 MiB/s, 完成.
处理 delta 中: 100% (77/77), 完成.
检查连接... 完成。
       
In [ ]
# 解压数据集到指定文件夹中,大概一分钟!unzip -oq data/data129011/RSdata_for_SR.zip -d RCAN-Paddle/data/
   
  • 同时还需要设置训练的配置文件,我已经写好放在work文件夹里,可以执行下面的命令复制文件到指定文件夹
In [4]
# 运行下列命令,将准备好的配置文件复制到RCAN-Paddle/configs文件夹下!cp work/rcan_x4_rssr.yaml RCAN-Paddle/configs/
   
In [ ]
# 安装依赖%cd RCAN-Paddle/
!pip install -r requirements.txt
   

三、模型训练与预测

  • 由于RCAN模型很难训练,很容易崩,所以使用我预训练好的checkpoint来接着训练,checkpoint保存在work/checkpoint文件夹里
  • 运行下列命令即可训练,训练的模型权重文件保存在RCAN-Paddle/output_dir/的文件夹下
In [ ]
# 运行该语句训练模型!python -u tools/main.py --config-file configs/rcan_x4_rssr.yaml --resume ../work/checkpoint/iter_270000_checkpoint.pdparams
   
  • 训练达到预期效果后,可以使用模型来测试。我已经提前将权重文件放在work/weight文件夹下,运行下行代码对测试集test_LR进行测试
  • 测试的结果也保存在output_dir文件夹下 测试的结果:PSNR:inf SSIM:0.9709,属于有点高了,应该是PaddleGAN的bug,但是本项目是为了展示对遥感影像重建的效果的,无伤大雅,要是想知道怎么解决,参照这个基于PaddleGAN框架复现超分辨率网络RCAN并对遥感影像超分项目,这里不做重复
In [36]
# 执行预测,注意,若要保存结果,将rcan_x4_rssr.yaml文件中的第84行设置为True%cd RCAN-Paddle/
!python -u tools/main.py --config-file configs/rcan_x4_rssr.yaml --evaluate-only --load ../work/weight/rcan_rssr_x4.pdparams
       
/home/aistudio/RCAN-Paddle
[02/22 16:23:07] ppgan INFO: Configs: {'total_iters': 400000, 'output_dir': 'output_dir/rcan_x4_rssr-2022-02-22-16-23', 'min_max': (0.0, 255.0), 'model': {'name': 'BaseSRModel', 'generator': {'name': 'RCAN'}, 'pixel_criterion': {'name': 'L1Loss'}}, 'dataset': {'train': {'name': 'SRDataset', 'gt_folder': 'data/RSdata_for_SR/trian_HR', 'lq_folder': 'data/RSdata_for_SR/train_LR/x4', 'num_workers': 4, 'batch_size': 16, 'scale': 4, 'preprocess': [{'name': 'LoadImageFromFile', 'key': 'lq'}, {'name': 'LoadImageFromFile', 'key': 'gt'}, {'name': 'Transforms', 'input_keys': ['lq', 'gt'], 'pipeline': [{'name': 'SRPairedRandomCrop', 'gt_patch_size': 192, 'scale': 4, 'keys': ['image', 'image']}, {'name': 'PairedRandomHorizontalFlip', 'keys': ['image', 'image']}, {'name': 'PairedRandomVerticalFlip', 'keys': ['image', 'image']}, {'name': 'PairedRandomTransposeHW', 'keys': ['image', 'image']}, {'name': 'Transpose', 'keys': ['image', 'image']}, {'name': 'Normalize', 'mean': [0.0, 0.0, 0.0], 'std': [1.0, 1.0, 1.0], 'keys': ['image', 'image']}]}]}, 'test': {'name': 'SRDataset', 'gt_folder': 'data/RSdata_for_SR/test_HR', 'lq_folder': 'data/RSdata_for_SR/test_LR/x4', 'scale': 4, 'preprocess': [{'name': 'LoadImageFromFile', 'key': 'lq'}, {'name': 'LoadImageFromFile', 'key': 'gt'}, {'name': 'Transforms', 'input_keys': ['lq', 'gt'], 'pipeline': [{'name': 'Transpose', 'keys': ['image', 'image']}, {'name': 'Normalize', 'mean': [0.0, 0.0, 0.0], 'std': [1.0, 1.0, 1.0], 'keys': ['image', 'image']}]}]}}, 'lr_scheduler': {'name': 'CosineAnnealingRestartLR', 'learning_rate': 0.0001, 'periods': [100000, 100000, 100000, 100000], 'restart_weights': [1, 1, 1, 1], 'eta_min': 1e-07}, 'optimizer': {'name': 'Adam', 'net_names': ['generator'], 'beta1': 0.9, 'beta2': 0.99}, 'validate': {'interval': 5000, 'save_img': True, 'metrics': {'psnr': {'name': 'PSNR', 'crop_border': 4, 'test_y_channel': True}, 'ssim': {'name': 'SSIM', 'crop_border': 4, 'test_y_channel': True}}}, 'log_config': {'interval': 100, 'visiual_interval': 500}, 'snapshot_config': {'interval': 5000}, 'export_model': [{'name': 'generator', 'inputs_num': 1}], 'is_train': False, 'profiler_options': None, 'timestamp': '-2022-02-22-16-23'}
W0222 16:23:07.502808  7250 device_context.cc:404] Please NOTE: device: 0, GPU Compute Capability: 7.0, Driver API Version: 10.1, Runtime API Version: 10.1
W0222 16:23:07.507916  7250 device_context.cc:422] device: 0, cuDNN Version: 7.6.
/opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages/paddle/tensor/creation.py:125: DeprecationWarning: `np.object` is a deprecated alias for the builtin `object`. To silence this warning, use `object` by itself. Doing this will not modify any behavior and is safe. 
Deprecated in NumPy 1.20; for more details and guidance: https://numpy.org/devdocs/release/1.20.0-notes.html#deprecations
  if data.dtype == np.object:
[02/22 16:23:14] ppgan.engine.trainer INFO: Loaded pretrained weight for net generator
[02/22 16:23:14] ppgan.engine.trainer INFO: Test iter: [0/420]
[02/22 16:23:53] ppgan.engine.trainer INFO: Test iter: [100/420]
[02/22 16:24:33] ppgan.engine.trainer INFO: Test iter: [200/420]
[02/22 16:25:12] ppgan.engine.trainer INFO: Test iter: [300/420]
[02/22 16:25:52] ppgan.engine.trainer INFO: Test iter: [400/420]
[02/22 16:25:59] ppgan.engine.trainer INFO: Metric psnr: inf
[02/22 16:25:59] ppgan.engine.trainer INFO: Metric ssim: 0.9709
       

四、快速体验

  • 定义了使用RCAN模型的预测类,可以直接上传要预测的图像到指定的文件夹,然后运行代码,输出预测结果
  • 接下来的示例,是对work/example/inputs文件夹下的图像进行重建
In [ ]
# 定义使用RCAN模型预测的类RCANPredictor,需要输入参数:# output: 模型输出保存的文件夹# weight_path: 模型权重文件所在的路径import osimport cv2import globimport numpy as npfrom PIL import Imagefrom tqdm import tqdmimport paddle 
from ppgan.models.generators import RCANfrom ppgan.apps.base_predictor import BasePredictorfrom ppgan.utils.logger import get_loggerclass RCANPredictor(BasePredictor):
    def __init__(self, output='../work/example/output', weight_path=None):
        self.input = input
        self.output = os.path.join(output, 'RCAN')
        self.model = RCAN()
        state_dict = paddle.load(weight_path)
        state_dict = state_dict['generator'] 
        self.model.load_dict(state_dict)
        self.model.eval()    def norm(self, img):
        img = np.array(img).transpose([2, 0, 1]).astype('float32') / 1.0
        return img.astype('float32')    def denorm(self, img):
        img = img.transpose((1, 2, 0))        return (img * 1).clip(0, 255).astype('uint8')    def run_image(self, img):
        if isinstance(img, str):
            ori_img = Image.open(img).convert('RGB')        elif isinstance(img, np.ndarray):
            ori_img = Image.fromarray(img).convert('RGB')        elif isinstance(img, Image.Image):
            ori_img = img

        img = self.norm(ori_img)
        x = paddle.to_tensor(img[np.newaxis, ...])        with paddle.no_grad():
            out = self.model(x)

        pred_img = self.denorm(out.numpy()[0])
        pred_img = Image.fromarray(pred_img)        return pred_img    def run(self, input):
        if not os.path.exists(self.output):
            os.makedirs(self.output)

        pred_img = self.run_image(input)
        out_path = None
        if self.output:            try:
                base_name = os.path.splitext(os.path.basename(input))[0]            except:
                base_name = 'result'
            out_path = os.path.join(self.output, base_name + '.png')
            pred_img.save(out_path)
            logger = get_logger()
            logger.info('Image saved to {}'.format(out_path))        return pred_img, out_path
   
  • 定义好预测的类之后,接下来实例化预测类并对文件夹下的图像进行预测
  • 在预测的过程中,展示输入的低分辨率图像与预测的图像
  • 预测的结果保存在指定的文件夹的RCAN文件夹中
In [7]
import matplotlib.pyplot as plt
%matplotlib inline
%cd ~ 

# 输出预测结果的文件夹output = r'work/example/output' # 模型路径weight_path = r"work/weight/rcan_rssr_x4.pdparams"# 待输入的低分辨率影像位置input_dir = r"work/example/inputs" paddle.device.set_device("gpu:0") # 若是cpu环境,则替换为 paddle.device.set_device("cpu")predictor = RCANPredictor(output, weight_path) # 实例化filenames = [f for f in os.listdir(input_dir) if f.endswith('.png')]for filename in filenames:
    imgPath = os.path.join(input_dir, filename)   
    outImg, _ = predictor.run(imgPath) # 预测
    # 可视化
    image = Image.open(imgPath)
    plt.figure(figsize=(10, 6))
    plt.subplot(1,2,1), plt.title('Input')
    plt.imshow(image), plt.axis('off')
    plt.subplot(1,2,2), plt.title('Output')
    plt.imshow(outImg), plt.axis('off') 
    plt.show()
       
/home/aistudio
[02/22 19:38:30] ppgan INFO: Image saved to work/example/output/RCAN/mediumresidential44.png
       
<Figure size 720x432 with 2 Axes>
               
[02/22 19:38:34] ppgan INFO: Image saved to work/example/output/RCAN/harbor13.png
       
<Figure size 720x432 with 2 Axes>
               
[02/22 19:38:38] ppgan INFO: Image saved to work/example/output/RCAN/runway16.png
       
<Figure size 720x432 with 2 Axes>
               
[02/22 19:38:43] ppgan INFO: Image saved to work/example/output/RCAN/storagetanks37.png
       
<Figure size 720x432 with 2 Axes>
               
[02/22 19:38:47] ppgan INFO: Image saved to work/example/output/RCAN/intersection16.png
       
<Figure size 720x432 with 2 Axes>
               
[02/22 19:38:52] ppgan INFO: Image saved to work/example/output/RCAN/river23.png
       
<Figure size 720x432 with 2 Axes>
               
[02/22 19:38:57] ppgan INFO: Image saved to work/example/output/RCAN/parkinglot61.png
       
<Figure size 720x432 with 2 Axes>
               
[02/22 19:39:02] ppgan INFO: Image saved to work/example/output/RCAN/sparseresidential23.png
       
<Figure size 720x432 with 2 Axes>
               
[02/22 19:39:07] ppgan INFO: Image saved to work/example/output/RCAN/overpass63.png
       
<Figure size 720x432 with 2 Axes>
               
[02/22 19:39:12] ppgan INFO: Image saved to work/example/output/RCAN/tenniscourt19.png
       
<Figure size 720x432 with 2 Axes>
               
【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - php中文网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - php中文网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - php中文网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - php中文网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - php中文网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - php中文网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - php中文网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - php中文网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - php中文网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - php中文网

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

38

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

83

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

97

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

223

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

458

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

169

2026.03.04

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

246

2026.03.03

C++高性能网络编程与Reactor模型实践
C++高性能网络编程与Reactor模型实践

本专题围绕 C++ 在高性能网络服务开发中的应用展开,深入讲解 Socket 编程、多路复用机制、Reactor 模型设计原理以及线程池协作策略。内容涵盖 epoll 实现机制、内存管理优化、连接管理策略与高并发场景下的性能调优方法。通过构建高并发网络服务器实战案例,帮助开发者掌握 C++ 在底层系统与网络通信领域的核心技术。

34

2026.03.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号