2013年数模B碎纸片拼接问题的解决方法

一直没时间写博客(其实是在咕咕咕),上周和队友完美解决了这个国赛题目,写下我们的方法

第一个问题,中文和英文的长条拼接。这是最简单的为题,首先建立一个图邻接矩阵,用一个纸片最右边的向量到另一个制片最左边向量的欧式距离当作这两个点的距离,然后跑旅行商问题,用模拟退火法优化,完美解决

第二个问题,中文文章和英文文章被分割成了11*19的碎片,要求拼接复原。首先将每个纸片的图像举证中的行中的所有元素进行或运算,这样就可以得到一个图片中字体的行的位置,然后将所有向量通过Kmean算法分类,然后再在每一类中经过第一问题的算法解决,中文完美解决,英文存在字母不等高的轻狂,所以我们需要给英文划四线三格,这里是一个瓶颈,卡了我们很长时间,最后通过众数的方法解决了这个问题

第三个问题,每个纸片有正反两面,并且哪个是正面,哪个是反面未知,需要复原,这道题的行高基本都差不多,没法去分类,我们写了一个手动分类器,每次计算机通过最优的匹配函数推荐,然后人工选正确的,看起来很蛮烦,418张图片15分钟人工就可做完,因为匹配函数的最优推荐经常是正确的,然后把每行拼起来后,再把每行根据旅行商算法还原。

代码放在了gayhub上:https://github.com/GipsyU/CUMCM2013B

讲的不是很清楚(其实是因为懒得写)

今年数模加油(其实我只想咕咕咕)

  • 3
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
根据引用\[1\]和引用\[2\]的内容,针对2013b纸片拼接问题,可以采用以下方法进行拼接。首先,通过数值化处理将每张纸片转化为数值化矩阵。然后,根据数值化矩阵的左右两侧进行分析,找到最左侧和最右侧的纸片序号。接下来,建立纸片之间的距离模型,并利用改良圈算法求解旅行商模型,得到纸片拼接复原图和纸片序列。这种方法可以简化边缘匹配的过程,提高拼接的准确性和效率。引用\[3\]中提到,针对问题二,可以通过将纸片的纵向向量进行聚类,然后利用改良圈算法将每一类的纸片拼接成一行,最终将11行纸片拼接成完整的原图。因此,对于2013b纸片拼接问题,可以采用数值化处理、距离模型和改良圈算法等方法进行拼接。 #### 引用[.reference_title] - *1* [纸片拼接复原](https://blog.csdn.net/z1143709608/article/details/60139479)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [数学建模2013B——纸片拼接复原](https://blog.csdn.net/HUANGliang_/article/details/119672674)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值