百度网盘AI大赛-图像处理挑战赛:文档检测优化赛 Baseline
该内容围绕百度网盘AI大赛文档检测优化赛展开,介绍用Resnet152+Linear网络结构回归文档拐角坐标的方案。包括获取数据、构造含预处理的读取器、定义网络,训练时经多轮训练及调学习率达0.89左右精度,还涉及打包提交文件的相关说明。

百度网盘AI大赛-图像处理挑战赛:文档检测优化赛
使用Resnet152回归图像中文档的拐角坐标完成百度网盘AI大赛-图像处理挑战赛:文档检测优化赛。
免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
比赛介绍
生活中人们使用手机进行文档扫描逐渐成为一件普遍的事情,为了提高人们的使用体验,我们期望通过算法技术去除杂乱的拍摄背景并精准框取文档边缘,选手需要通过深度学习技术训练模型,对给定的真实场景下采集得到的带有拍摄背景的文件图片进行边缘智能识别,并最终输出处理后的扫描结果图片。
评测方式说明
参赛选手提交的代码和模型只预测文档边缘的heatmap图,由后台评测脚本中预置的算法回归出文档区域的四个角的坐标点,并生成规则的四边形,与GT计算IoU值;参赛选手提交的代码和模型直接回归文档区域的四个角的坐标点,并生成规则的四边形,与GT计算IoU值。 注:两种评测方式的结果会放在一个排行榜内,评测脚本中预置的角点回归算法会存在一定的局限性,如果各位参赛选手希望获得更高的分数,建议采用第二种评测方式。任务分析
本次比赛要求选手设计算法在给定图片中划定一块四边形区域,以尽可能与图片中的文档部分重合。
因此,本次任务可以同时看作回归问题和分割问题。
作为回归问题,需要设计学习器/其他方法寻找四边形的四个拐角坐标作为分割问题,直接将数据中的segments作为标签训练对应的分割学习器即可本项目将本次任务看作回归问题来处理,使用Resnet152+Linear的网络结构回归四个角的坐标。
代码部分
获取数据
In [ ]! wget https://staticsns.cdn.bcebos.com/amis/2024-4/1649731549425/train_datasets_document_detection_0411.zip! unzip -oq /home/aistudio/train_datasets_document_detection_0411.zip! rm -rf __MACOSX! rm -rf /home/aistudio/train_datasets_document_detection_0411.zip登录后复制
构造数据读取器
通过paddle.io.dataset构造读取器,便于读取数据。
数据预处理包括:
根据data_info的边缘轮廓信息分别提取四个拐角的位置。对图片进行resize和数据增强(调整明暗对比度等参数)In [ ]import paddleimport numpy as npimport pandas as pdimport cv2class MyDateset(paddle.io.Dataset): def __init__(self, mode = 'train', train_imgs_dir = '/home/aistudio/train_datasets_document_detection_0411/images/', train_txt = '/home/aistudio/train_datasets_document_detection_0411/data_info.txt'): super(MyDateset, self).__init__() self.mode = mode self.train_imgs_dir = train_imgs_dir with open(train_txt,'r') as f: self.train_infor = f.readlines() def __getitem__(self, index): item = self.train_infor[index][:-1] splited = item.split(',') img_name = splited[0] img = cv2.imread(self.train_imgs_dir+img_name+'.webp') h, w, c = img.shape img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB) # 对图片进行resize,调整明暗对比度等参数 img = paddle.vision.transforms.resize(img, (512,512), interpolation='bilinear') if np.random.rand()<1/3: img = paddle.vision.transforms.adjust_brightness(img, np.random.rand()*2) else: if np.random.rand()<1/2: img = paddle.vision.transforms.adjust_contrast(img, np.random.rand()*2) else: img = paddle.vision.transforms.adjust_hue(img, np.random.rand()-0.5) img = img.transpose((2,0,1)) img = img/255 sites = [] for i in range(1,len(splited),2): sites.append([float(splited[i])/w,float(splited[i+1])/h]) label = [] for i in range(4): x, y = self.get_corner(sites, i+1) label.append(x) label.append(y) img = paddle.to_tensor(img).astype('float32') label = paddle.to_tensor(label).astype('float32') return img, label def get_corner(self, sites, corner_flag): # corner_flag 1:top_left 2:top_right 3:bottom_right 4:bottom_left if corner_flag == 1: target_sites = [0,0] elif corner_flag == 2 : target_sites = [1,0] elif corner_flag == 3 : target_sites = [1,1] elif corner_flag == 4 : target_sites = [0,1] min_dis = 3 best_x = 0 best_y = 0 for site in sites: if abs(site[0]-target_sites[0])+abs(site[1]-target_sites[1])登录后复制 定义网络结构
In [ ]class MyNet(paddle.nn.Layer): def __init__(self): super(MyNet,self).__init__() self.resnet = paddle.vision.models.resnet152(pretrained=True, num_classes=0) self.flatten = paddle.nn.Flatten() self.linear = paddle.nn.Linear(2048, 8) def forward(self, img): y = self.resnet(img) y = self.flatten(y) out = self.linear(y) return out
登录后复制 训练
第一次训练后参数为0.66左右,重复训练+调整学习率可以达到0.89左右。
In [ ]model = MyNet()model.train()train_dataset=MyDateset()# 需要接续之前的模型重复训练可以取消注释# param_dict = paddle.load('./model.pdparams')# model.load_dict(param_dict)train_dataloader = paddle.io.DataLoader( train_dataset, batch_size=16, shuffle=True, drop_last=False)max_epoch=10scheduler = paddle.optimizer.lr.CosineAnnealingDecay(learning_rate=0.0001, T_max=max_epoch)opt = paddle.optimizer.Adam(learning_rate=scheduler, parameters=model.parameters())now_step=0for epoch in range(max_epoch): for step, data in enumerate(train_dataloader): now_step+=1 img, label = data pre = model(img) loss = paddle.nn.functional.square_error_cost(pre,label).mean() loss.backward() opt.step() opt.clear_gradients() if now_step%100==0: print("epoch: {}, batch: {}, loss is: {}".format(epoch, step, loss.mean().numpy()))paddle.save(model.state_dict(), 'model.pdparams')登录后复制 打包提交
本题目提交需要提交对应的模型和预测文件。predict.py需要读取同目录下的模型信息,并预测坐标点-保存为json或预测分割后的图片-保存为图片形式。
想要自定义训练模型,只需要将predict.py中的模型和process函数中的do something 替换为自己的模型内容即可。
提交分割模型时,取消predict中52行的注释部分即可保存分割后的图片信息
如果不想自己反复训练模型可以直接从fork后就有的model.pdparams文件开始训练,这个模型精度为0.88~
In [ ]# 压缩可提交文件! zip submit.zip model.pdparams predict.py
登录后复制
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
逼AI当山顶洞人!Claude防话痨插件爆火,网友:受够了AI废话
新智元报道编辑:元宇【新智元导读】一个让AI像原始人一样说话的插件,在HN上一夜爆火,冲破2w星。它的核心只是一条简单粗暴的prompt:删掉冠词、客套和一切废话,号称能省下75%的输出token。
季度利润翻 8 倍,最赚钱的「卖铲人」财报背后,内存涨价狂潮如何收场?
AI 时代最赚钱的公司,可能从来不是做 AI 的那个。作者|张勇毅编辑|靖宇淘金热里最稳赚的人,从来不是淘金的,是卖铲子的。这句老话在 2026 年的科技行业又应验了一次。只不过这次卖铲子的不是英伟
Claude Code Harness+龙虾科研团来了!金字塔分层架构+多智能体
Claw AI Lab团队量子位 | 公众号 QbitAI你还在一个人做科研吗?科研最难的,从来不是问题本身,而是一个想法从文献到实验再到写作,只能靠自己一点点往前推。一个人方向偏了没人提醒,遇到歧
让离线强化学习从「局部描摹」变「全局布局」丨ICLR'26
面对复杂连续任务的长程规划,现有的生成式离线强化学习方法往往会暴露短板。它们生成的轨迹经常陷入局部合理但全局偏航的窘境。它们太关注眼前的每一步,却忘了最终的目的地。针对这一痛点,厦门大学和香港科技大
美国犹他州启动新试点项目:AI为患者开具精神类药物处方
IT之家 4 月 5 日消息,据外媒 PC Mag 当地时间 4 月 4 日报道,美国医疗机构 Legion Health 在犹他州获得监管批准,启动一项试点项目,允许 AI 系统为患者开具精神类药
- 日榜
- 周榜
- 月榜
1
2
3
4
5
6
7
8
9
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程
热门话题

