使用FCN进行原始指纹图像分割(Tensorflow)

2024-04-27 20:32

本文主要是介绍使用FCN进行原始指纹图像分割(Tensorflow),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        最近一直在尝试将FCN网络运用到指纹图像分割上,并将其与公司原有的指纹采集工具融合,改进原有工具在对非按压、带水区域的标记分割。学习一段时间了,有一些小小的心得,在此记录一下。

        FCN网络的Demo是使用GitHub上shekkizh提供的工程,具体可以参见我原先写的一篇博客ubuntu 18.04下搭建FCN Demo测试环境(Tensorflow)。

        原有的FCN Demo使用的是MIT_SceneParsing数据集,所以要将其替换为指纹数据图像。对于待分割指纹图像,考虑三种情况:按压不全的指纹图像、防水的指纹图像和正常的指纹图像。三种指纹实际图像如下图所示:

在收集到足够多的原始指纹数据后,制作对应的标签图,上面三种指纹图像的标签图如下图所示:

        

可以看出,在指纹图像分割运用中,实际只有两种分类:将指纹清晰区域标记为一类,将指纹不可辨别区域标记为另一类。在制作标签的时候,我将指纹清晰区域标记为像素值46,指纹不可辨别区域标记为像素值16。

         我实际收集到的数据大概有5W张数据图像(JPG),其中80%是正常的指纹图像,按压不全的指纹图像和防水的指纹图像各占10%。本任务是对按压不全的指纹图像和防水的指纹图像进行无效区域分割,因此对正常的指纹图像进行大量的删减,按压不全的指纹图像和防水的指纹图像则采用了flip、mirror、flip&mirror和resize&rect(缩放后截取部分区域)方法进行了扩充,最终数据的比例是按压不全的指纹图像和防水的指纹图像各占40%,正常的指纹图像占20%。获得源数据后将其随机分为三部分:train、validation和test,其中train图像2.2W张,validation图像2K张,testvalidation图像3K张。训练数据制作好以后放置到Data_zoo\MIT_SceneParsing文件夹下,并压缩生成一个zip压缩包,在mode参数中设置为train即可开始训练。(吐槽一下,为了制作对应的图像的标签图,手都快成鼠标手了)

        当模型训练完成以后,便需要考虑对模型进行固化和量化。因为训练保存的是CKPT文件,需要转换为pb文件进行参数固化。但是模型固化的研究了一个礼拜,生成的PB文件load以后预测输出都不正确,只能先放一下。

        原有的指纹采集工具是基于C++来写的,要把模型使用起来的话,需要将Python工程进行打包,打包使用pyinstaller,pyinstaller安装完成以后通过Anaconda Prompt进入到FCN.py文件目录,使用“pyinstaller -F --clean FCN.py”命令便会在FCN.py同目录下的dist文件夹下生成FCN.exe可执行程序,将其拷贝至FCN.py同目录下,双击运行检测exe是否打包成功。在打包exe程序时碰见出现说无法找到Qt相关dll的错误,使用pip命令安装Qt即可解决。之后将FCN.exe拷贝至无Python的环境中,运行会出现“运行程序无法定位程序输入点ucrtbase.abort于动态链接库api-ms-win-crt-runtime-|1-1-0.dll”的bug,解决此问题,安装vs2015运行库即可解决。由此Python程序打包步骤完成。

        在主程序中使用ShellExecuteEx函数来调用FCN.exe,需要注意的是,ShExecInfo.lpDirectory参数需要指定路径,不然调用运行会出错。以下是我调用exe可执行程序的函数:

void OpenExe()
{ShExecInfo.cbSize = sizeof(SHELLEXECUTEINFO);ShExecInfo.fMask = SEE_MASK_NOCLOSEPROCESS;ShExecInfo.hwnd = NULL;ShExecInfo.lpVerb = NULL;ShExecInfo.lpFile = _T("C:\\Users\\tuuzhang\\FCN_while\\FCN.exe");ShExecInfo.lpParameters = NULL;ShExecInfo.lpDirectory = _T("C:\\Users\\tuuzhang\\FCN_while\\");ShExecInfo.nShow = SW_SHOW;ShExecInfo.hInstApp = NULL;ShellExecuteEx(&ShExecInfo);
}

    指纹采集工具嵌入FCN需要考虑C++与FCN.exe的通信问题,在这里我使用两个txt文件来进行通信交互。通信命令如下:

cmd.txt :cmd_ini    --- 初始状态cmd_infer  --- FCN程序开始预测分割cmd_exit   --- FCN程序退出
infer_flag.txt :infer_ini    --- 初始状态infer_ready  --- FCN程序已装载好模型,可以开始分割infer_doing  --- FCN程序正在进行分割infer_finish --- FCN程序完成分割预测

        生成FCN.exe的Python文件是基于原作者FCN.py文件进行修改得到的。主要删除了一些train代码,并修改了main函数。main函数实现了CKPT模型的load,并告知C++程序load步骤完成,可以准备进行预测了。当接收到主程序cmd_infer命令时开始预测分割,预测分割结束后标志infer_finish表示完成了预测分割。main函数实现了一次load模型,多次run的功能。实际测试load的时间为6秒左右,run一张图的时间为0.6秒左右。这样便大大节省了于测的时间。

        因为FCN是逐像素点预测的,因此得到的输出图像会存在孤立的背景点和边缘毛刺,因此还需要进行中值滤波和open操作,以消除孤立背景点和边缘毛刺。输出图像和滤波后的图像如下图所示:

     

        最后,将输出图像与源图像进行mask即可得到分割后的图像。

这篇关于使用FCN进行原始指纹图像分割(Tensorflow)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/941460

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Nginx设置连接超时并进行测试的方法步骤

《Nginx设置连接超时并进行测试的方法步骤》在高并发场景下,如果客户端与服务器的连接长时间未响应,会占用大量的系统资源,影响其他正常请求的处理效率,为了解决这个问题,可以通过设置Nginx的连接... 目录设置连接超时目的操作步骤测试连接超时测试方法:总结:设置连接超时目的设置客户端与服务器之间的连接

Java中String字符串使用避坑指南

《Java中String字符串使用避坑指南》Java中的String字符串是我们日常编程中用得最多的类之一,看似简单的String使用,却隐藏着不少“坑”,如果不注意,可能会导致性能问题、意外的错误容... 目录8个避坑点如下:1. 字符串的不可变性:每次修改都创建新对象2. 使用 == 比较字符串,陷阱满

Python使用国内镜像加速pip安装的方法讲解

《Python使用国内镜像加速pip安装的方法讲解》在Python开发中,pip是一个非常重要的工具,用于安装和管理Python的第三方库,然而,在国内使用pip安装依赖时,往往会因为网络问题而导致速... 目录一、pip 工具简介1. 什么是 pip?2. 什么是 -i 参数?二、国内镜像源的选择三、如何

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本