青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

string

string
posts - 27, comments - 177, trackbacks - 0, articles - 0
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理
 SSE4.2指令集提供了字符串處理指令,詳細用法可參閱intel開發手冊。現簡單說明一下幾個指令的用法,因為我們一般用c接口來開發程序,所以我們主要關注C接口的用法。 
首先看int _mm_cmpistri ( __m128i a, __m128i b, const int mode); 因為本文講述串匹配,所以我們把mode的值設為0xc0. 輸入a,b是以0結尾的字符串。這條指令將返回[0, 16]之間的一個整數。如果在b的后綴中發現了a的前綴,這個整數用來表示這個后綴的位置; 如果沒發現,返回值為16. 例如 a="EFGHX", b="abcdefghABCDEFGH"
     0123456789ABCDEF(index)
b = abcdefghABCDEFGH
a =                    EFGHX
返回值為12.
再比如 a="abcde"
0123456789ABCDEF(index)
b = abcdefghABCDEFGH
a = abcde  
返回值為0.
如果a="ABCE",則返回值為16.

 __m128i _mm_cmpistrm ( __m128i a, __m128i b, const int mode); 這條指令返回的是mask,不像_mm_cmpistri那樣返回一個值。

例如 a="abcd", b="abcdefghABCDEabc"
0123456789ABCDEF(index)
b = abcdefghABCDEabc
a = abcd  
abc
ret=1000000000000100(1表示本字節所有位都是1, 即本字節為0xFF)

一個很自然的想法就是根據返回值在文本串中移動(返回n則往后移動n個字符),直到返回值為0. 仔細閱讀glibc中用SSE4.2指令集做的strstr函數,就會發現他采用了此種方法。 此方法的問題在于每次從文本串中加載16個字節到sse寄存器時,地址是不對齊的,極大的影響了執行效率。怎樣才能保證每次加載時的地址都是對齊的呢?
我的方法是每次移動16字節,然后從前一個塊(16字節塊)中找后綴,從后一個塊中找前綴,然后看前面塊的后綴和后面塊的前綴能不能組合成我們要查找的字串。實驗表明此算法要優于前一種算法.
alignStart:
    {
        if(plen <= 16){
            shf_indexV = SIMD_LOAD(IndexVector[plen]);
            __attribute__ ((aligned (16))) char pbuf[16];
            int i=0, j=0;
            for(i =0;i<16-plen ;i++){
                pbuf[i] = 0xff;
            }
            for(;i<16;i++)
                pbuf[i] = pattern[j++];
            sseiPattern2 = SIMD_LOAD(pbuf);
        }
    }

    sseiPattern = SIMD_LOADU(pattern);
    sseiWord0 = SIMD_LOAD(sseiPtr) ;
    pref = SEARCH_PRE_F(sseiPattern, sseiWord0);
    ret_z = has_byte_null(sseiWord0); 
    while(!ret_z){
        //! find out the prefix
        __m128i postmV2;
        __m128i flagV;
        u32 flag16;
        while(( pref==16)&&( ret_z ==0)){
            sseiPtr ++;
            sseiWord0 = SIMD_LOAD(sseiPtr) ;
            ret_z = has_byte_null(sseiWord0); 
            pref = SEARCH_PRE_F(sseiPattern, sseiWord0);
        }
        if(pref <= 16 - plen){
            REPORT((((char*)sseiPtr)+pref));
        }
        premV = SEARCH_PRE_M(sseiPattern, sseiWord0);
        sseiPtr ++;
        sseiWord0 = SIMD_LOAD(sseiPtr) ;
        postmV = SEARCH_PRE_M(sseiWord0, sseiPattern2);
        postmV2= bit_reverse(postmV);
        flagV  = SS_XAND(premV, postmV2);
        flag16 = SS_GET_MASK(flagV);

        if(flag16){
            int idx = bsf(flag16);
            REPORT((((char*)sseiPtr)-16+idx));
        }

        pref = SEARCH_PRE_F(sseiPattern, sseiWord0);
        ret_z = has_byte_null(sseiWord0); 
    }
相關宏的定義如下

#define SEARCH_PRE_F(s2,s1)   _mm_cmpistri(s2,s1,0x0c) 
#define SEARCH_PRE_M(s2,s1)   _mm_cmpistrm(s2,s1,_SIDD_UNIT_MASK|_SIDD_CMP_EQUAL_ORDERED)
#define SIMD_LOAD(p)   _mm_load_si128((__m128i*)(p))   
#define SIMD_LOADU(p)  _mm_loadu_si128((__m128i*)(p))   
#define SS_GET_MASK(V) _mm_movemask_epi8(V)
#define SS_XAND(s1,s2) _mm_and_si128(s1,s2)
#define bit_reverse(x)  _mm_shuffle_epi8(x,shf_indexV)
查看源代碼

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一区免费视频| 亚洲精品久久久久久久久久久久久 | 久久精品在线| 国产亚洲一区二区精品| 久久久亚洲成人| 麻豆av一区二区三区| 亚洲乱码国产乱码精品精可以看| 亚洲国产小视频| 欧美日韩免费高清一区色橹橹| 亚洲一区二区不卡免费| 亚洲欧美精品在线观看| 一区二区在线观看av| 亚洲人永久免费| 国产精品一区二区久久精品| 久久都是精品| 欧美成人精品在线播放| 亚洲宅男天堂在线观看无病毒| 午夜欧美大尺度福利影院在线看| 伊人久久男人天堂| 日韩视频在线你懂得| 国产欧美一区二区精品秋霞影院| 巨胸喷奶水www久久久免费动漫| 欧美刺激性大交免费视频| 亚洲一区二区伦理| 久久久久久69| 亚洲在线第一页| 裸体女人亚洲精品一区| 亚洲欧美精品伊人久久| 久久亚洲一区二区三区四区| 在线性视频日韩欧美| 久久免费视频在线观看| 亚洲欧美bt| 欧美激情在线免费观看| 久久久91精品国产| 欧美日韩免费观看中文| 另类国产ts人妖高潮视频| 欧美性猛交xxxx免费看久久久 | 久久亚洲一区二区| 欧美午夜不卡视频| 亚洲成色777777在线观看影院| 国产精品一区一区三区| 亚洲激情视频在线| 伊人成年综合电影网| 午夜免费在线观看精品视频| 一级日韩一区在线观看| 蜜臀久久99精品久久久久久9 | 亚洲天堂成人在线观看| 麻豆国产精品va在线观看不卡 | av不卡在线| 麻豆91精品| 美女久久一区| 国产在线播精品第三| 亚洲欧美激情在线视频| 亚洲影视在线播放| 欧美另类一区二区三区| 欧美激情一区二区三区| 在线成人国产| 久久久999国产| 久久精品一二三区| 国产日产高清欧美一区二区三区| 一本综合精品| 亚洲专区国产精品| 欧美性色综合| 一本高清dvd不卡在线观看| 一区二区三区成人精品| 欧美极品在线观看| 日韩视频三区| 亚洲欧美国产日韩天堂区| 欧美涩涩网站| 亚洲男同1069视频| 久久精品国产2020观看福利| 国产精品夜夜夜| 欧美一区二区三区在线视频| 欧美中文字幕精品| 禁久久精品乱码| 欧美成人精品三级在线观看| 91久久中文| 亚洲一卡二卡三卡四卡五卡| 国产精品日韩欧美一区二区三区| 亚洲欧美激情视频| 久久久久一区二区| 亚洲国产精品视频| 欧美女同视频| 亚洲欧美国产视频| 久热成人在线视频| 亚洲国产精品免费| 欧美日韩亚洲一区二区| 午夜精品久久久久影视| 美女黄毛**国产精品啪啪| 亚洲美女中出| 国产精品午夜在线| 久热精品在线视频| 99视频有精品| 老鸭窝91久久精品色噜噜导演| 亚洲国产一区二区三区在线播| 欧美日韩精品三区| 欧美一乱一性一交一视频| 欧美夫妇交换俱乐部在线观看| 一区二区黄色| 在线观看中文字幕不卡| 欧美日韩色综合| 久久精品国产欧美亚洲人人爽| 亚洲国内高清视频| 久久国产精品黑丝| 日韩视频免费大全中文字幕| 国产精品美女久久久久久2018| 久久久久一区二区三区四区| 99精品国产一区二区青青牛奶| 久久久久久午夜| 亚洲一区二区在线| 亚洲福利视频免费观看| 国产精品日韩一区二区| 欧美激情一区二区三区高清视频 | 蘑菇福利视频一区播放| 亚洲一区二区免费看| 亚洲第一网站免费视频| 国产精品黄视频| 欧美国产乱视频| 久久精品国产免费观看| 亚洲午夜成aⅴ人片| 亚洲二区视频在线| 久久综合九色欧美综合狠狠| 亚洲欧美日本另类| 一本久道久久综合婷婷鲸鱼| 亚洲高清视频在线观看| 国产精品视频999| 欧美日本在线一区| 美女视频网站黄色亚洲| 久久精品国产91精品亚洲| 亚洲一区图片| 中日韩美女免费视频网站在线观看| 免费看成人av| 久久久久久网| 久久精品国产清高在天天线| 午夜精品福利电影| 国产精品99久久久久久久女警| 亚洲国产精品999| 一区二区三区无毛| 精品1区2区3区4区| 国内精品久久久久久| 国产日韩欧美三级| 国产伦精品一区二区三| 国产精品日韩精品| 国产美女扒开尿口久久久| 欧美亚洲不卡| 国产精品国产一区二区| 国产精品豆花视频| 国产精品日韩欧美一区二区| 国产精品免费网站在线观看| 国产精品国产三级国产专播精品人| 欧美视频日韩| 国产精品视频免费一区| 国产欧美日韩亚洲精品| 国产性色一区二区| 伊人久久婷婷| 日韩视频久久| 亚洲专区一区二区三区| 欧美一级片久久久久久久| 久久久久久穴| 欧美高清在线一区二区| 亚洲精品国产精品国自产观看浪潮| 亚洲欧洲视频| 亚洲视频一二区| 欧美一区二区三区的| 久久在线免费视频| 欧美区高清在线| 国产精品日日摸夜夜添夜夜av| 国产欧美日韩视频| 亚洲国产毛片完整版| 亚洲午夜在线观看| 久久精品国产欧美激情 | 这里只有精品视频| 欧美亚洲视频在线看网址| 久久影视精品| 亚洲精品自在久久| 香蕉免费一区二区三区在线观看| 久久人人爽人人爽| 欧美日韩亚洲免费| 国产一区在线看| 一本大道久久精品懂色aⅴ| 欧美亚洲尤物久久| 欧美激情第9页| 亚洲一级一区| 老鸭窝亚洲一区二区三区| 国产精品国产三级国产普通话99| 国产一区二区精品| 亚洲午夜精品视频| 欧美3dxxxxhd| 亚洲一区二区精品视频| 免费在线观看精品| 国产精品一二三四区| 亚洲精品中文字| 久久综合久久88| 在线视频亚洲| 欧美激情一二三区| 在线观看福利一区| 久久se精品一区精品二区| 99re6热在线精品视频播放速度| 欧美一区亚洲| 国产精品尤物福利片在线观看|