当前位置: 首页
AI
昇腾杯-变化检测赛道复赛方案分享——PaddleCD

昇腾杯-变化检测赛道复赛方案分享——PaddleCD

热心网友 时间:2025-07-22
转载
PaddleCD是基于PaddleSeg2.2修改的变化检测工具集,支持双时相并行输入/Siamese结构与变化标注,含OCR-CD等4种模型,曾用于昇腾杯(复赛TOP14)和PRCV2024(决赛TOP7)。现有训练中inf/nan的bug,原因不明。介绍了项目背景、数据集、方案及完整代码流程,后续将补充模型。

昇腾杯-变化检测赛道复赛方案分享——paddlecd - 游乐网

简述

基于PaddleSeg2.2,修改dataset、model、train、val等,实现变化检测功能,使用过程与PaddleSeg完全一致,便于快速进行网络训练、推理基于PaddleCD使用OCR-CD(魔改OCR-Net),在昇腾杯-变化检测赛道复赛排名TOP14,PRCV2024决赛排名TOP7目前仅实现了OCR-CD、SNUNet、DSAMNet、CDNet,后续会补充模型目前存在bug,训练一段时间后Found inf or nan, current scale is: 0.0, decrease to: 0.0 * 0.5,出现原因不详、出现时间不固定;且仅在前期收敛

更新

v2:更新部分表述v3:更新项目背景、数据集说明

1.项目背景

1.1 PaddleCD

之前对变化检测有过一些接触,今年下半年在参加PRCV2024遥感图像智能解译技术挑战赛时,为便于对代码进行调整,基于PaddleSeg2.2进行修改,实现了变化检测工具集——PaddleCD

       

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

变化检测的数据格式较多样(按标注类型大概分为变化标注、增加标注+减少标注、time1 gt+time2 gt+变化标注等,按网络结构的影像可以分双时相并行输入/Siamese结构、双时相叠加后输入/分割网络)

       

目前PaddleCD支持的是最简单的双时相并行输入/Siamese结构,标注类型——变化标注。其他结构可以在此项目基础上微调得到,后续如有接触相关内容也会更新。

       

现有网络OCR-CD——自己魔改结构,SNUNet——ppcd中网络的搬运、DSAMNet——DSAMNet的Paddle复现、CDNet——SenseEarth2020冠军方案Paddle复现

       

1.2 比赛介绍

变化检测是从不同时期的遥感数据中定量分析和确定地表变化的特征与过程;遥感变化检测是一个确定和评价各种地表现象随时间发生变化的过程;遥感变化检测是遥感瞬时视场中地表特征随时间发生的变化引起两个时期影像像元光谱响应的变化。[ * ]

PRCV2024遥感图像智能解译技术挑战赛链接:https://captain-whu.github.io/PRCV2024_RS/index.html

昇腾杯-变化检测赛道链接:http://rsipac.whu.edu.cn/subject_two

       

1.3 本项目内容

本项目为昇腾杯-变化检测赛道复赛排名TOP14方案代码实现,PRCV2024项目方案也采用了同样网络结构

2.数据集介绍

原始影像:影像格式为tif,包含R、G、B三个波段, 初赛数据集影像尺寸为512 * 512像素,共3194对样本

标签数据:标签格式为单通道的png,每个像素的标签值由一个数值表示, 使用‘uint8’数据类型存储,该数值表示是否为变化,“0”代表未变化,“1”代表变化。

3.项目方案——OCR-CD

OCR-CD根据OCRNet与Siamese结构设计得到,

OCR-CD设计有OCR、OCR_M、OCR_P共3种结构,3种结构精度无太大差异,OCR_M、OCR_P由于结构原因占用显存大,训练慢,因此常使用OCR结构

网络结构

backbone——使用HRNet分别对双时相影像进行特征提取,得到f1、f2特征处理OCR: 取f1、f2差值的绝对值fbOCR_M: 将f1、f2在通道维度合并得到fbOCR_P: 取f1、f2差值的绝对值fb,将f1、f2在通道维度合并得到fa输出头OCR、OCR_M:1个OCRHeadOCR_P:2个OCRHead分别处理fb,fa

OCR、OCR_M、OCR_P的config文件分别在PaddleCD-cd_config下的ocrnet.yml、ocrnet_m.yml、ocrnet_p.yml

4.PaddleCD必要结构说明

cd_config:存放配置文件paddleseg:核心代码core:包含具体的train、val、infer、predict代码,seg与cd有所不同transforms:数据预处理部分,seg与cd有所不同models:模型存放路径,cd部分——ocrnet、snunet、dsamnet、cdnet_parallel、cdnet_fusion,其余部分未修改,仍是seg功能datasets:存放数据集格式代码,本项目使用的是rscd中自定义的数据,可根据输入输出的不同进行修改cvlibs: 相关代码库,未修改utils: 相关代码库,未修改train.py: 调用核心代码的train过程val.py: 调用核心代码的val过程predict.py: 调用核心代码的predict过程

5.项目完整代码

数据预处理

In [ ]
# 清除cell输出结果def clear_output():    """    clear output for both jupyter notebook and the console    """    import os    os.system('cls' if os.name == 'nt' else 'clear')    from IPython.display import clear_output as clear    clear()
登录后复制    In [ ]
# 解压数据!unzip -oq /home/aistudio/data/data107059/train_png.zip -d /home/aistudio/data/src/!unzip -oq /home/aistudio/data/data107059/test_AB_png.zip -d /home/aistudio/data/src/
登录后复制    In [ ]
# 安装依赖库!pip install -r /home/aistudio/PaddleCD/requirements.txtclear_output()
登录后复制    In [ ]
# 生成数据集train.txt val.txt# !python /home/aistudio/work/data_generate.py# 直接拷贝已有的数据集划分文件,保证每次训练评价指标相同!cp /home/aistudio/work/train.txt /home/aistudio/data/src/train.txt!cp /home/aistudio/work/val.txt /home/aistudio/data/src/val.txt
登录后复制    

网络训练

In [9]
# 模型训练!python /home/aistudio/PaddleCD/train.py \       --config /home/aistudio/PaddleCD/cd_config/ocrnet.yml \       --do_eval \       --use_vdl \       --iters 8000 \       --save_interval 200 \       --save_dir /home/aistudio/data/output \       --batch_size=8 \       --log_iters 20 \       --fp16# 后台训练时,需要清空输出,保证notebook正常导入;notebook训练时,可以不用# clear_output()
登录后复制    In [ ]
# 将最优模型拷贝到/home/aistudio/best_model路径下!mkdir /home/aistudio/best_model/!cp /home/aistudio/data/output/best_model/model.pdparams /home/aistudio/best_model/model.pdparams!find /home/aistudio/data/output -name '*.log' -exec cp -t /home/aistudio/best_model/ "{}" +
登录后复制    

测试

In [7]
# 普通测试!python /home/aistudio/PaddleCD/val.py \       --config /home/aistudio/PaddleCD/cd_config/ocrnet.yml \       --batch_size 16 \       --model_path /home/aistudio/best_model/model.pdparams
登录后复制    In [8]
# 增强测试!python /home/aistudio/PaddleCD/val.py \       --config /home/aistudio/PaddleCD/cd_config/ocrnet.yml \       --aug_eval \       --flip_vertical \       --batch_size 16 \       --model_path /home/aistudio/best_model/model.pdparams
登录后复制    In [ ]
!python /home/aistudio/work/data_sta.py
登录后复制    

推理

In [ ]
# 增强推理, 推理结果保存在/home/aistudio/data/src/result下!python /home/aistudio/PaddleCD/predict.py \       --config /home/aistudio/PaddleCD/cd_config/ocrnet.yml \       --model_path /home/aistudio/best_model2/model.pdparams \       --image_path /home/aistudio/data/src/test_AB_png/A \       --image_path2 /home/aistudio/data/src/test_AB_png/B \       --aug_pred \       --flip_vertical \       --batch_size 32 \       --save_dir /home/aistudio/data/src
登录后复制    

推理展示

In [ ]
from PIL import Imagefrom collections import namedtupleimport matplotlib.pyplot as pltCls = namedtuple('cls', ['name', 'id', 'color'])Clss = [    Cls('bg', 0, (0, 0, 0)),    Cls('change', 1, (255, 255, 255)),]def get_putpalette(Clss, color_other=[0, 0, 0]):    '''    灰度图转8bit彩色图    :param Clss:颜色映射表    :param color_other:其余颜色设置    :return:    '''    putpalette = []    for cls in Clss:        putpalette += list(cls.color)    putpalette += color_other * (255 - len(Clss))    return putpalettebin_colormap = get_putpalette(Clss)
登录后复制    In [ ]
%matplotlib inlineimg1_path = r'/home/aistudio/data/src/test_AB_png/A/1.webp'img2_path = r'/home/aistudio/data/src/test_AB_png/B/1.webp'pred_path = r'/home/aistudio/data/src/result/1.webp'img1 = Image.open(img1_path)plt.imshow(img1)plt.show()img2 = Image.open(img2_path)plt.imshow(img2)plt.show()pred = Image.open(pred_path)pred.putpalette(bin_colormap)plt.imshow(pred)plt.show
登录后复制        
登录后复制登录后复制登录后复制                
登录后复制登录后复制登录后复制                
登录后复制                
登录后复制登录后复制登录后复制                
来源:https://www.php.cn/faq/1422532.html

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

同类文章
更多
逼AI当山顶洞人!Claude防话痨插件爆火,网友:受够了AI废话

逼AI当山顶洞人!Claude防话痨插件爆火,网友:受够了AI废话

新智元报道编辑:元宇【新智元导读】一个让AI像原始人一样说话的插件,在HN上一夜爆火,冲破2w星。它的核心只是一条简单粗暴的prompt:删掉冠词、客套和一切废话,号称能省下75%的输出token。

时间:2026-04-07 14:55
季度利润翻 8 倍,最赚钱的「卖铲人」财报背后,内存涨价狂潮如何收场?

季度利润翻 8 倍,最赚钱的「卖铲人」财报背后,内存涨价狂潮如何收场?

AI 时代最赚钱的公司,可能从来不是做 AI 的那个。作者|张勇毅编辑|靖宇淘金热里最稳赚的人,从来不是淘金的,是卖铲子的。这句老话在 2026 年的科技行业又应验了一次。只不过这次卖铲子的不是英伟

时间:2026-04-07 14:49
Claude Code Harness+龙虾科研团来了!金字塔分层架构+多智能体

Claude Code Harness+龙虾科研团来了!金字塔分层架构+多智能体

Claw AI Lab团队量子位 | 公众号 QbitAI你还在一个人做科研吗?科研最难的,从来不是问题本身,而是一个想法从文献到实验再到写作,只能靠自己一点点往前推。一个人方向偏了没人提醒,遇到歧

时间:2026-04-07 14:43
让离线强化学习从「局部描摹」变「全局布局」丨ICLR'26

让离线强化学习从「局部描摹」变「全局布局」丨ICLR'26

面对复杂连续任务的长程规划,现有的生成式离线强化学习方法往往会暴露短板。它们生成的轨迹经常陷入局部合理但全局偏航的窘境。它们太关注眼前的每一步,却忘了最终的目的地。针对这一痛点,厦门大学和香港科技大

时间:2026-04-07 14:37
美国犹他州启动新试点项目:AI为患者开具精神类药物处方

美国犹他州启动新试点项目:AI为患者开具精神类药物处方

IT之家 4 月 5 日消息,据外媒 PC Mag 当地时间 4 月 4 日报道,美国医疗机构 Legion Health 在犹他州获得监管批准,启动一项试点项目,允许 AI 系统为患者开具精神类药

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