`
十三月的
  • 浏览: 165029 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

打破思维断层之最优美的BNDM

阅读更多

 

 

 

 

 BNDM

 

目的:

 

本篇博客以BNDM算法为载体,意图在减少思维断层情况下了解算法思想。

 

目录:

 

       1:其他算法回顾

 

       2BNDM算法介绍

 

       3:构建辅助表B

 

       4:容器创建和更新

 

       5:过程展示

 

1:其他算法回顾

 

在众多单字符匹配算法BFKMPShift-And/OrBMHorspoolSunday,个人最喜欢Shift-And/Or,尽管它不是效率最高的,但是从今以后我更喜欢BNDM

 

其实,自己对BMHorspoolSunday算法并没有什么太多好感。如果唯一觉得好的,估计就是他们让大家的思维产生了跳跃,这个实际上是BM的功劳,但不得不说后两个对BM的简化,让这个跳跃思维更加有魅力。

 

BM中,它利用了两个启发性规则:好后缀规则和坏字符规则。这个过程其实很繁琐,这不要紧,关键是作者将好后缀和坏字符进行了拆分(其实KMP中也是拆分了),根据这两个个体分别建立规则,然后会发现在利用两个规则的时候总觉得不伦不类,缺少整体性,让人觉得不爽。

 

HorspoolSunday其实摒弃了两规则,但是他们采用的规则和坏字符规则类似,实则对字符的随机性进行了利用,当匹配失败的时候用最后一个字符或者最后一个字符的下一个字符进行匹配,但是这个对比较过的好后缀和坏字符并没有加以利用,其实是难以加以利用。

 

如果说Shfit-And/Or是对“位并行”的首次展示就让人惊讶,那么BNDM则利用“位并行”大放异彩令人叹服。

 

下面做一个简单回顾:

 

字符串匹配的时候,是在目标串中寻找是否包含模式串的过程。

 

BF算法最容易想到

 
查找的过程:指针ij首先分别指向了目标串和模式串的首字符。当ij分别指向了目标串和模式串的eu的时候,发现不等,此时BF采取简单的策略是:i回溯指向了nj指向了模式串的首字母i,再次从头开始匹配。这种算法思路最简单,效果当然也是很差,原因在于并没有好好利用已经匹配的结果

 

KMP实现了指针不回溯前进

    
当目标串指针i指向y(此时i=8),模式串指针j指向d的时候(此时j=8),发现不等;KMP算法并没有采取BF的策略只是简单的把i设为1j设为0,从头开始比较,而是移动了5步,i=8(不变),j=3,使得模式串的abc对准了目标串的abc,如上图。因为BF比较的时候中间4步是没必要的。实际上KMP利用了已经比较的字符abcttabc的特性:abc既是前缀又是后缀。效率得到改善。这样指针i就不用回溯了,算法效率是onKMP只是利用了已经匹配成功(abcttabc)的结果,并没有关心匹配失败的yd

 

 

 

Shift-And/Or利用神器“位并行”改善KMP

 

http://wlh0706-163-com.iteye.com/blog/1845919

 

BM首次实现指针跳跃前进

 

BM采取从后向前比较,

 
第一次FT比较,不等;F称为坏字符,检查模式串中发现没有F,移动7

 

第二次-T比较,不等;-称为坏字符,检查模式串中发现有-,移动4,对齐。

 

第三次当比较到LA的时候,L是坏字符,由于模式串中没有L,移动6T是已经匹配的好后缀,根据好后缀需要移动3;取两者中大的6.


 

第四次当比较-H的时候,根据坏字符-需要移动2步才能对齐;根据好后缀AT需要移动5才能将模式串中AT和目标串的AT对齐。


 

BM就是这样比较了14次就成功匹配了。

 

BM利用了已经匹配的结果(好后缀)和没有匹配成功的(坏字符),但是分开利用的。

        HorspoolSunday将指针跳跃前进的效率大大提高。下面以Horspool为例

 
此时并没像BM一样,而是直接就根据最后一个字符n来匹配,将模式串中的字符和n对齐,相当于移动了7步。

Horspool实际只关心是否匹配成功,只要没有成功则按照最后一个字符移动。但是他的效率真的很高,主要是利用了单词中的字符的很随机的性质。

 

       其实,最一般的想法是最好能够同时利用已经成功匹配(好后缀)和没有成功匹配的(坏字符)字符做些事情,当然BM中已经这样做了,但是他是分开利用的,总觉的不是很舒服。

 

BDM(不是BNDM)的出现则很好的解决了这个问题:基于子串进行匹配它把好后缀和坏字符当成一个整体来利用

 

BNDM则是利用了位并行提高了BDM的效率,就像Shift-And提高了KMP算法的效率一样,只是BNDM是基于后缀匹配,ShiftAnd基于前缀。

 

想要了解Shift-And/Or,请参看http://wlh0706-163-com.iteye.com/blog/1845919

 

算法介绍

       BNDM算法维护一个容器,里面记录的是已经成功匹配的所有字符用u表示在模式串中出现位置,这个容器同样是用一个位向量D=dmdm-1…d1来表示。

    
当读入u的第一个字符u1时,模式串中第2位,第6位(从左到右数,下标从0开始)含有u1,则容器的第26位相应设为1;当读入第二个字符u2的时候,如果第1位,第5位让就是u2,则此时设第1位和第5位为1,如果第1位不是u2,则此时只有第5位是1.(可以先看例子,明白的快些)

构建辅助表B

 

       同样,和Shift-And算法一样需要先构建一个辅助表B,B用位掩码记录了某个字符在模式串中出现的位置。

 
结果:


容器创建和更新

创建:

容器默认值是1m(m1m表示的是模式串的字符的个数)

    更新:
 
 
  1步:查询辅助表B,得到新字符tj的掩码B[tj]

2步:左移1

 

过程展示:

伪代码:

 

 

 

 第一次:

 第二次:

 第三次:

 

 

 

 

 

 

 

 当读取了8个字符后,发现D的值仍旧不是0,表明模式串中存在这由njection8个字符组成的子串,此时last=j=1。在读取下一个字符n前,D在更新操作:左移1位后,发现D变成了000000000 这表明匹配失败,模式串向后移动last位,即1位。

 

第四次:

其实,对于last的值,从本案例第三次匹配的时候用到了一次,

 
由于D100000000,这个的意思实际上就是KMP中既是前缀又是后缀的字符的判断。已经匹配的字符”injection”其实是目标串的后缀同时又是模式串的前缀,判断后last被赋值为j1.下一次移动不再是9步而是1步。

附上另外2个案例:第一个是作者论文中的案例

案例1

目标串Targetabbabaabbaab

模式串Patternaabbaab

 

 

 
案例2

 



    
同样运用“位并行”的算法Shift-And/or的出现是在1992年,它的出现将基于前缀匹配的KMP算法的效率大大提高,。但是和BNDM算法相比,不论是效率上还是优美程度上都不可相提并论。当然,Shift-And/or算法一样,这种基于位并行算法会和机器有一定联系(字长),还会有各种各样的算法来解决字长限制的问题,有兴趣可以自己研究BOM算法。

 

 

 

 

 

 

 

 

  • 大小: 7.1 KB
  • 大小: 6.5 KB
  • 大小: 6.4 KB
  • 大小: 8.8 KB
  • 大小: 8.9 KB
  • 大小: 5.9 KB
  • 大小: 6.8 KB
  • 大小: 11 KB
  • 大小: 120.2 KB
  • 大小: 1.8 KB
  • 大小: 6.1 KB
  • 大小: 1.3 KB
  • 大小: 236.3 KB
  • 大小: 11.3 KB
  • 大小: 19.1 KB
  • 大小: 12.4 KB
  • 大小: 12.1 KB
  • 大小: 2.6 KB
  • 大小: 15.5 KB
  • 大小: 31.1 KB
  • 大小: 23.6 KB
  • 大小: 13.8 KB
  • 大小: 404.9 KB
8
1
分享到:
评论
7 楼 JanFan_张过要学会坚持 2014-11-19  
楼主你好,我也写一篇关于字符串匹配的总结,其中受了不少你的启发,欢迎你来点评:-)

http://janfan.github.io/chinese/2014/11/16/string-algorithm.html
6 楼 chinaagan 2013-05-03  
好文章啊,不错
5 楼 十三月的 2013-05-02  
ansjsun 写道
楼主你好...我大概看了下..具体没太明白..但是你的举例是一个模式串..如果是tire树结构..同时应该是多个模式串的匹配..对于这种问题..您提出的这个算法是否依然有效 ...谢谢

是的,这个是单字符串匹配问题解决办法,当然对于多字符串匹配问题同样可以采用此种策略,算法是Mutiple BNDM.其实不只是这个方法,对于单字符串匹配算法3中策略:基于前缀、基于后缀、基于子串匹配,在处理多字符串也可以应用。只是自己能力有限,才刚写到单字符串匹配......
4 楼 ansjsun 2013-05-02  
楼主你好...我大概看了下..具体没太明白..但是你的举例是一个模式串..如果是tire树结构..同时应该是多个模式串的匹配..对于这种问题..您提出的这个算法是否依然有效 ...谢谢
3 楼 十三月的 2013-05-02  
smallbee 写道
看不懂 好像很牛逼样子  能不能有个入门或者使用场景?

你可以直接从“构建辅助表B”开始看这个案例,前面可以先不看,这个算法自己比较喜欢,希望你能够看懂
2 楼 十三月的 2013-05-02  
smallbee 写道
看不懂 好像很牛逼样子  能不能有个入门或者使用场景?

这个算法是解决字符串匹配问题,只是单纯的看bndm的案例应该还是比较简单的,需要自己按照上述例子画一遍,画完之后应该就容易理解。
1 楼 smallbee 2013-05-02  
看不懂 好像很牛逼样子  能不能有个入门或者使用场景?

相关推荐

    Surfer8.0 做断层的方法

    断层是一个难点,怎么做呢,这里是一个断层实例做的方法,初手就跳过,中级人员仔细看好了。

    弱导水性断层防水煤柱的留设

    为了防止断层底板水突出,需保留合适宽度的断层防水煤柱。以弱导水性F29断层为例,用已有的断层防水煤柱留设的计算方法及原则,计算出F29断层防水煤柱留设宽度。根据公式的来源与断层突水机理,讨论原计算公式的不合理性...

    基于回归模型的断层构造复杂度分析

    为了对矿区断层构造复杂度进行更加合理地评价,需要对断层多元信息进行综合分析。以徐州某煤矿为例,分析了断层的分形维数、落差及倾角等因素与矿井突水点涌水量的相关关系,建立断层信息与涌水量回归模型,通过Arc GIS...

    断层倾角对断层活化与底板突水影响的数值模拟研究

    为了研究断层附近矿井突水事故的发生机理,利用有限差分数值模拟软件FLAC3D模拟分析不同倾角的断层在采掘扰动影响下的地应力场和塑性区情况。结果表明:断层倾角越大,断层面上的剪应力和法向应力越大;采掘处以深断层...

    我国矿井断层防水煤(岩)柱留设研究现状与展望

    断层防水煤(岩)柱宽度留设涉及到许多因素,也是许多学者和工程技术人员研究的重点之一。截止到目前已有多种研究方法与手段得到了应用,主要包括理论计算、多元回归分析、BP和RBF、相似模拟、数值模拟等,针对不同...

    深部逆断层倾角对煤岩冲击失稳作用的数值模拟

    利用FLAC3D的强大数值模拟计算能力,以义马矿区为背景,建立了逆断层的简化数值模型,研究了不同断层倾角条件下的工作面超前支承压力与弹性能分布规律。研究表明:随着采掘面不断临近断层,工作面超前支承压力受断层影响...

    cnn+biaoqian_断层识别_断层人工智能_断层_CNN

    人工智能断层识别以及一部分标签制作流程,采用一般的卷积神经网络。

    不同倾角正断层附近应力分布规律数值模拟研究

    查明不同倾角正断层附近应力分布规律对瓦斯分布规律预测、煤与瓦斯突出预测具有重要的参考价值。以鹤壁四矿31052采煤工作面内不同倾角正断层参数为基础,结合实验室岩石力学测试,构建了正断层地质模型;借助ANSYS有限...

    小断层延伸长度定量化预测在王家塔井田的应用

    为准确掌握小断层的延伸规律,降低小断层对矿井采掘活动的影响,以王家塔井田3-1煤层在采掘活动中揭露的小断层资料为依据,选取断层走向延展长度、断层落差和断层倾角3个因素,采用多元线性回归的方法,分别建立NE向和NW...

    断层落差对逆断层活化规律影响的模拟研究

    以某煤矿F5逆断层实际地质资料为背景,采用FLAC3D软件,对逆断层上、下两盘工作面依次回采时断层带的应力演化规律及断层的活化规律进行研究,揭示了工作面采动中落差与逆断层活化之间的联系。研究可知,下盘煤层开采时,...

    顶板断层附近采动作用规律研究

    根据贵州某矿111013回采工作面的地质条件制作相似试验模型,模拟回采工作面从靠近到远离顶板断层过程。研究结果表明:随着回采工作面靠近断层,顶板断层附近煤岩体稳定性变差,周期来压步距变小;工作面距离顶板断层10 m...

    钱营孜煤矿过F22断层可行性研究

    钱营孜煤矿F22断层是井田内最大的正断层,为西二、西三采区边界断层。断层断距20~350 m,区内延伸长度6.50 km以上。根据钱营孜煤矿采区接替要求,接替的西三采区集中石门势必要穿越F22正断层。该断层落差大,延伸长,断层...

    3dmine断层建模

    3dmine断层建模研究,为矿山建立更贴近实际的矿体模型起到很好的作用!

    excel断层图表制作

    excel断层图表制作,教你如何使用excel断层图表制作

    浅析平煤股份二矿小断层发育特征

    以庚20煤层为例,对小断层发育特征进行了研究,认为区内小断层以正断层为主,井田东部小断层发育,断层密度大,其发育影响因素主要有两个:一是由大中型断层派生和伴生的,二是由于区域构造应力作用的不均匀性和岩石力学...

    含隐伏小断层底板采动突水机理数值模拟研究

    为得到含隐伏小断层的煤层底板开采中的突水机理,分析底板裂隙演化及渗流突水通道的形成规律。采用RFPA2D-Flow软件分析了含隐伏小断层底板在工作面开采中,底板岩层破坏、突水通道的形成及突水发生的整个动态发展过程,...

    龙永煤田滑脱断层特征及其控煤作用

    在福建煤田地质界将其称之为"滑脱断层"。这种断层的发育具一定的层位性,在剖面上沿多个固定的层位顺层发育,上下叠置,相互平行、成组出现。发育层位从老至新主要有:栖霞组灰岩与下伏上泥盆系—石炭系之间的F0下断层;...

    断层对煤层瓦斯赋存的控制作用

    为给矿井瓦斯综合防治提供指导,研究了断层对煤层瓦斯赋存的控制作用,采用瓦斯地质分析的方法,从断层力学性质、断层两盘岩性、断层规模、断层埋深和现代构造应力场等5个方面,研究了裴沟煤矿杨河井田边界走向正断层对...

    正断层活化诱发冲击地压危险性研究

    采用FLAC3.03D数值模拟软件,以接触面单元模拟断层上下盘构造关系,模拟在正断层地质构造下,工作面从断层下盘向断层面推进过程中,矿山压力分布规律以及断层带位移变化规律。研究结果表明,在正断层地质构造下,下盘工作...

    断层端部地应力分布规律影响因素的数值模拟

    通过数值模拟软件RFPA对正断层端部地应力的分布情况进行模拟。分别模拟了埋深、破碎带宽度、关键层泊松比、关键层弹性模量4个参数对断层端部水平和垂直方向应力分布规律的影响。研究表明:上述因素均对断层端部应力...

Global site tag (gtag.js) - Google Analytics