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

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>
            蜜臀91精品一区二区三区| 国产精品久久一区二区三区| 亚洲自拍偷拍网址| 午夜免费日韩视频| 欧美有码在线观看视频| 美女国内精品自产拍在线播放| 免费一级欧美片在线播放| 欧美视频免费| 1000部精品久久久久久久久| 日韩亚洲欧美一区二区三区| 亚洲影院色无极综合| 欧美一区二区久久久| 美脚丝袜一区二区三区在线观看 | 影音先锋久久久| 99精品国产福利在线观看免费| 亚洲激情另类| 亚洲午夜激情网页| 久久这里只有| 一本色道**综合亚洲精品蜜桃冫| 欧美一区高清| 国产区在线观看成人精品| 激情久久久久久久| 欧美一区二区三区视频在线观看 | 久久免费的精品国产v∧| 亚洲日产国产精品| 久久久久久9999| 国产精品午夜电影| 亚洲一区二区三区在线播放| 亚洲一区中文| 欧美色精品天天在线观看视频| 欧美在线一二三四区| 宅男噜噜噜66国产日韩在线观看| 欧美日韩激情网| 亚洲精品久久久久久久久久久| 欧美一区亚洲二区| 免费亚洲一区二区| 久久国产99| 欧美日本一区二区视频在线观看| 亚洲国产精品一区二区第四页av| 久久视频精品在线| 欧美日韩精品一区视频| 麻豆成人在线| 欧美高清视频一区二区| 亚洲免费电影在线| 亚洲理伦在线| 国产精品欧美久久久久无广告| 欧美大片一区二区| 久久久久国产精品一区三寸| 在线视频亚洲欧美| 一区二区三区欧美视频| 在线观看亚洲视频| 欧美一区激情视频在线观看| 亚洲一区二区高清| 欧美精品免费在线| 亚洲欧美经典视频| 欧美一区二区视频97| 亚洲少妇诱惑| 欧美在线精品免播放器视频| 亚洲午夜精品国产| 欧美日韩午夜在线视频| 久久aⅴ国产欧美74aaa| 欧美日韩精品免费| 亚洲国产另类久久精品| 欧美视频在线观看免费网址| 亚洲激情亚洲| 99国产精品自拍| 欧美韩日视频| 亚洲精品乱码久久久久久蜜桃麻豆| 亚洲电影免费观看高清完整版在线观看| 午夜国产欧美理论在线播放| 亚洲国产精品嫩草影院| 久久噜噜噜精品国产亚洲综合| 久久久久久久综合色一本| 国产精品自在欧美一区| 欧美国产一区二区在线观看| 欧美精品三级日韩久久| 亚洲人成网站在线观看播放| 亚洲人成网站在线观看播放| 亚洲一区在线看| 欧美在线精品免播放器视频| 国产午夜久久久久| 亚洲国产精品国自产拍av秋霞| 在线 亚洲欧美在线综合一区| 久久精品一区二区三区不卡| 亚洲欧美韩国| 国产午夜精品美女毛片视频| 欧美一区二区三区精品电影| 麻豆国产精品va在线观看不卡| 在线看日韩av| 欧美欧美全黄| 亚洲欧美国产精品专区久久| 久久久综合精品| 亚洲国产经典视频| 欧美日韩三区四区| 亚洲欧美日韩精品久久奇米色影视 | 欧美人与禽性xxxxx杂性| 亚洲作爱视频| 亚洲精品日韩激情在线电影| 欧美日韩国产黄| 亚洲欧美日韩精品一区二区| 蜜桃久久av一区| 亚洲永久免费观看| 原创国产精品91| 欧美午夜视频网站| 日韩午夜在线播放| 亚洲另类在线一区| 国产精品永久入口久久久| 久久免费国产精品| 米奇777超碰欧美日韩亚洲| 亚洲免费观看| 精品96久久久久久中文字幕无| 欧美激情中文字幕乱码免费| 亚洲一区二区毛片| 亚洲欧洲一区二区在线播放| 欧美一区在线视频| 一区二区三区国产在线观看| 国产一区二区三区精品欧美日韩一区二区三区| 亚洲一区免费网站| 亚洲国产免费看| 久久综合影视| 欧美一区日韩一区| 亚洲天堂黄色| 亚洲人屁股眼子交8| 国产亚洲一区二区三区在线观看 | 国产精品视频大全| 欧美激情视频网站| 久久久久免费视频| 欧美一区二区精品| 夜夜爽夜夜爽精品视频| 亚洲国产一区二区三区a毛片| 欧美一级日韩一级| 黄色国产精品一区二区三区| 久久国产婷婷国产香蕉| 猫咪成人在线观看| 久久国产精品久久久久久电车| 欧美天天视频| 欧美日韩精品在线观看| 免费看黄裸体一级大秀欧美| 久久久久www| 亚洲欧美综合一区| 亚洲欧美视频在线观看| 亚洲欧美国产视频| 亚洲免费在线视频一区 二区| 一区二区电影免费在线观看| 日韩视频不卡中文| 中文精品视频| 亚洲线精品一区二区三区八戒| 久久久久久9| 亚洲精品人人| 亚洲毛片在线看| 亚洲精品免费在线播放| 日韩视频在线一区二区| 91久久极品少妇xxxxⅹ软件| 最新国产乱人伦偷精品免费网站| 一区二区三区在线观看视频| 亚洲第一福利视频| 亚洲精品免费在线| 亚洲视频中文| 性色av一区二区三区在线观看| 欧美中在线观看| 乱码第一页成人| 亚洲国产精品久久久久| 最新国产成人在线观看| 亚洲人成网站在线观看播放| 亚洲麻豆国产自偷在线| 亚洲尤物精选| 久久免费观看视频| 欧美日韩国产高清| 国产麻豆日韩| 亚洲激情电影中文字幕| 国产日韩综合| 最新高清无码专区| 亚洲图片在线观看| 久久人人97超碰人人澡爱香蕉| 农村妇女精品| 理论片一区二区在线| 欧美激情亚洲综合一区| aⅴ色国产欧美| 欧美在线观看网址综合| 美国十次了思思久久精品导航| 欧美日韩亚洲一区二| 国内精品久久久久影院色| 国产精品捆绑调教| 亚洲高清在线播放| 亚洲在线视频观看| 欧美成人四级电影| 亚洲综合色噜噜狠狠| 美女成人午夜| 国产网站欧美日韩免费精品在线观看| 亚洲国产91色在线| 欧美一级淫片播放口| 欧美二区视频| 性欧美大战久久久久久久免费观看 | 亚洲香蕉伊综合在人在线视看| 久久精品女人| 国产精品一区二区你懂得 | 欧美午夜精品理论片a级按摩| 国语精品一区| 亚洲欧美国产精品桃花| 亚洲高清视频在线|