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

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

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

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

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

一、项目背景

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

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

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

二、准备工作

在进行训练之前首先要克隆代码、准备数据以及安装环境依赖之前我已经在github以及gitee上上传了相应的代码,做成了paddle复现RCAN模型的仓库github地址:https://github.com/kongdebug/RCAN-Paddlegitee地址: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-2024-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': '-2024-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.1W0222 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 + '.webp')            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('.webp')]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.webp
登录后复制        
登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制                
[02/22 19:38:34] ppgan INFO: Image saved to work/example/output/RCAN/harbor13.webp
登录后复制        
登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制                
[02/22 19:38:38] ppgan INFO: Image saved to work/example/output/RCAN/runway16.webp
登录后复制        
登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制                
[02/22 19:38:43] ppgan INFO: Image saved to work/example/output/RCAN/storagetanks37.webp
登录后复制        
登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制                
[02/22 19:38:47] ppgan INFO: Image saved to work/example/output/RCAN/intersection16.webp
登录后复制        
登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制                
[02/22 19:38:52] ppgan INFO: Image saved to work/example/output/RCAN/river23.webp
登录后复制        
登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制                
[02/22 19:38:57] ppgan INFO: Image saved to work/example/output/RCAN/parkinglot61.webp
登录后复制        
登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制                
[02/22 19:39:02] ppgan INFO: Image saved to work/example/output/RCAN/sparseresidential23.webp
登录后复制        
登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制                
[02/22 19:39:07] ppgan INFO: Image saved to work/example/output/RCAN/overpass63.webp
登录后复制        
登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制                
[02/22 19:39:12] ppgan INFO: Image saved to work/example/output/RCAN/tenniscourt19.webp
登录后复制        
登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制登录后复制                【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - 游乐网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - 游乐网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - 游乐网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - 游乐网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - 游乐网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - 游乐网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - 游乐网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - 游乐网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - 游乐网【AI达人创造营第二期】以RCAN模型对遥感图像超分辨率重建,可以直接体验! - 游乐网
来源:https://www.php.cn/faq/1422117.html

游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

同类文章
更多
AI语言模型纽约街头实测:哥本哈根大学研究揭示人机交互安全挑战

AI语言模型纽约街头实测:哥本哈根大学研究揭示人机交互安全挑战

这项由哥本哈根大学、IIIT兰契、ISI加尔各答、NIT安得拉邦、IGDTUW、IIT卡拉格普尔、谷歌DeepMind、谷歌以及南卡罗来纳大学AI研究所联合开展的研究,以预印本形式于2026年4月10日发布,论文编号为arXiv:2604 09746。 人工智能助手的能力日益强大,从撰写报告到规划行

时间:2026-05-15 14:06
字节跳动GRN模型革新AI绘画实现边生成边修改新方法

字节跳动GRN模型革新AI绘画实现边生成边修改新方法

在探讨AI图像与视频生成技术时,我们通常会想到扩散模型——它如同修复一张被雨水浸湿的照片,通过反复“去噪”从混沌中逐步显现清晰画面。尽管这种方法效果显著,却存在一个根本的效率瓶颈:无论生成内容的复杂程度如何,模型都需要执行固定且繁重的计算步骤,无法智能地分配算力资源。 另一条主流技术路径是自回归模型

时间:2026-05-15 14:06
斯坦福AI诊断师可自我评估短板并针对性优化

斯坦福AI诊断师可自我评估短板并针对性优化

这项由斯坦福大学主导的研究以预印本形式于2026年4月发表,论文编号为arXiv:2604 05336v1。研究提出了一个名为TRACE的系统,全称是“Turning Recurrent Agent failures into Capability-targeted training Environ

时间:2026-05-15 14:05
Meta AI新研究揭示旧数据复用如何提升40%训练效率

Meta AI新研究揭示旧数据复用如何提升40%训练效率

一项由Meta基础人工智能研究团队与纽约大学柯朗研究所联合开展的研究,于2026年4月9日以预印本形式发布,论文编号为arXiv:2604 08706v1。这项研究颠覆了AI训练领域一个长期被视为“金科玉律”的常识。 一、一个反直觉的发现:旧数据“回炉重造”,效果更佳? 在AI模型训练中,数据如同食

时间:2026-05-15 14:05
AI能否记住你?Kenotic Labs评估体系重新定义人工智能记忆边界

AI能否记住你?Kenotic Labs评估体系重新定义人工智能记忆边界

这项由Kenotic Labs开发的研究成果发表于2026年4月的第39届神经信息处理系统大会(NeurIPS 2025),论文编号为arXiv:2604 06710v1。 不知道你有没有过这样的体验:和一位朋友促膝长谈,分享了近期的压力、生活的变动,甚至一些私密的感受。可下次见面,对方却仿佛失忆了

时间:2026-05-15 14:05
热门专题
更多
刀塔传奇破解版无限钻石下载大全 刀塔传奇破解版无限钻石下载大全
洛克王国正式正版手游下载安装大全 洛克王国正式正版手游下载安装大全
思美人手游下载专区 思美人手游下载专区
好玩的阿拉德之怒游戏下载合集 好玩的阿拉德之怒游戏下载合集
不思议迷宫手游下载合集 不思议迷宫手游下载合集
百宝袋汉化组游戏最新合集 百宝袋汉化组游戏最新合集
jsk游戏合集30款游戏大全 jsk游戏合集30款游戏大全
宾果消消消原版下载大全 宾果消消消原版下载大全
  • 日榜
  • 周榜
  • 月榜
热门教程
更多
  • 游戏攻略
  • 安卓教程
  • 苹果教程
  • 电脑教程