[发明专利]基于GPU计算的字符串匹配方法和系统有效
申请号: | 201310509249.0 | 申请日: | 2013-10-23 |
公开(公告)号: | CN103559018A | 公开(公告)日: | 2014-02-05 |
发明(设计)人: | 侯智瀚;杨枭 | 申请(专利权)人: | 东软集团股份有限公司 |
主分类号: | G06F9/38 | 分类号: | G06F9/38 |
代理公司: | 北京鸿元知识产权代理有限公司 11327 | 代理人: | 陈英俊 |
地址: | 110179 辽*** | 国省代码: | 辽宁;21 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | 本发明提供一种基于GPU计算的字符串匹配方法及系统,其方法包括CPU预处理阶段和GPU匹配阶段;CPU预处理阶段包括:对特征字符串进行预处理和对待匹配数据进行预处理;分别在CPU主存和GPU全局存储器上分配待匹配数据缓存和结果缓存,将预处理后的待匹配数据从CPU主存中的待匹配数据缓存中复制到GPU全局存储器中的结果缓存中保存;GPU匹配阶段包括:采用GPU多线程任务并行执行方式对每个GPU线程中的预处理后的待匹配数据分别与预处理后的特征字符串前缀和特征字符串后缀进行匹配,将匹配成功的待匹配数据与相应的特征字符串逐字进行确认。利用本发明,能够解决Cache利用率低、启动线程数量多和访存开销大等问题,提升字符串匹配过程的性能。 | ||
搜索关键词: | 基于 gpu 计算 字符串 匹配 方法 系统 | ||
【主权项】:
一种基于GPU计算的字符串匹配方法,包括CPU预处理阶段和GPU匹配阶段;其中, 在所述CPU预处理阶段的过程中: 对所述特征字符串进行预处理;其中,首先构建位向量掩码表,并根据所述位向量掩码表生成快速过滤子表;然后将所述位向量掩码表和所述快速过滤子表拷贝到GPU全局存储器; 分别在CPU主存和所述GPU全局存储器上分配待匹配数据缓存和结果缓存; 对待匹配数据进行预处理,并将预处理后的待匹配数据从所述CPU主存中的所述待匹配数据缓存中复制到所述GPU全局存储器中的所述待匹配数据缓存中保存; 在所述GPU匹配阶段的过程中, 根据对所述特征字符串进行预处理所构建的位相量掩码表以及生成的快速过滤子表,采用GPU多线程任务并行执行方式对每个GPU线程中的预处理后的待匹配数据分别与预处理后的所述特征字符串前缀和所述特征字符串后缀进行匹配; 将匹配成功的待匹配数据与相应的所述特征字符串逐字进行确认,并保存在所述结果缓存中,最后将结果缓存的数据拷贝到所述CPU主存中的所述结果缓存中。
下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于东软集团股份有限公司,未经东软集团股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/patent/201310509249.0/,转载请声明来源钻瓜专利网。