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

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>
            国产精品视频免费| 久久精品国产第一区二区三区最新章节| 欧美专区第一页| 午夜久久美女| 精品999在线播放| 最新国产成人在线观看| 欧美成人a视频| 亚洲综合国产| 久久精品免费| 亚洲视频电影在线| 久久尤物电影视频在线观看| 亚洲视频精选在线| 久久综合精品国产一区二区三区| 亚洲一品av免费观看| 久久久久久久久久久成人| 亚洲一区二区在线看| 六月天综合网| 久久久久久九九九九| 国产午夜一区二区三区| 卡通动漫国产精品| 国产精品久久久久77777| 欧美bbbxxxxx| 国产一区二区三区黄| 99一区二区| 亚洲人成网站色ww在线| 欧美在线关看| 性欧美暴力猛交另类hd| 欧美精品久久久久久久| 欧美jjzz| 黄色一区二区三区四区| 亚洲视频成人| 一区二区精品在线观看| 欧美/亚洲一区| 久久综合伊人77777| 国产日韩精品入口| 亚洲在线播放电影| 亚洲午夜激情网站| 欧美日韩一区二区在线| 亚洲人体大胆视频| 亚洲精品久久久久久久久久久久久 | 一本色道久久综合亚洲精品小说| 在线播放亚洲一区| 久久国产精品第一页 | 欧美日韩在线一二三| 欧美电影在线免费观看网站 | 亚洲视频中文| 亚洲伊人伊色伊影伊综合网| 欧美日韩1区2区| 亚洲精品久久久久久久久| 亚洲国产美女精品久久久久∴| 久久精品国产免费| 久久一日本道色综合久久| 国内精品一区二区三区| 久久av资源网| 尤物99国产成人精品视频| 久久精品国产成人| 欧美高清不卡在线| 亚洲精品欧美激情| 欧美国产在线电影| 日韩写真在线| 性色av一区二区怡红| 国产精品视频久久久| 久久www成人_看片免费不卡| 欧美va天堂| 99这里有精品| 国产精品久久久久久久久久免费看 | 国产精品国产成人国产三级| 一本色道久久精品| 欧美一区二区女人| 激情久久久久久久| 欧美精品亚洲一区二区在线播放| 日韩一级精品视频在线观看| 午夜国产精品视频| 经典三级久久| 欧美日韩国产小视频在线观看| 一本久道久久综合中文字幕| 欧美一级成年大片在线观看| 国精品一区二区三区| 免费观看成人鲁鲁鲁鲁鲁视频 | 在线视频成人| 欧美区国产区| 午夜视频一区在线观看| 蜜臀av在线播放一区二区三区| 亚洲黄色成人| 欧美偷拍一区二区| 久久久久高清| 一本大道av伊人久久综合| 久久av最新网址| 亚洲国产一区二区在线| 国产精品大全| 另类激情亚洲| 亚洲天堂av在线免费| 免费视频最近日韩| 亚洲一区二区成人在线观看| 国产在线欧美| 欧美欧美全黄| 久久国产精品久久久久久久久久| 欧美大片免费久久精品三p| 亚洲欧美日韩国产另类专区| 在线播放亚洲一区| 国产精品一区二区三区免费观看| 久久这里只有| 性欧美videos另类喷潮| 亚洲日本一区二区三区| 久久嫩草精品久久久精品| 一本久久a久久免费精品不卡| 国产私拍一区| 国产精品盗摄一区二区三区| 免费在线视频一区| 午夜精品久久久久| 一本久道久久综合狠狠爱| 蜜月aⅴ免费一区二区三区| 欧美一级一区| 亚洲手机成人高清视频| 亚洲电影免费观看高清| 国产日韩欧美精品在线| 欧美日韩国产在线一区| 老色鬼精品视频在线观看播放| 亚洲欧美精品| 久久国产精品高清| 中日韩视频在线观看| 亚洲免费av片| 亚洲人成在线播放网站岛国| 国产一区亚洲一区| 国产伦精品一区二区三区免费| 欧美日韩免费高清一区色橹橹| 免费看成人av| 玖玖国产精品视频| 久久久综合网站| 欧美一区二区日韩一区二区| 亚洲视频观看| aa级大片欧美| 亚洲另类一区二区| 亚洲黄色在线视频| 欧美激情久久久久| 亚洲国产精品久久久久婷婷884| 鲁鲁狠狠狠7777一区二区| 久久经典综合| 久久精彩视频| 狂野欧美一区| 欧美~级网站不卡| 国产午夜精品全部视频播放| 国产欧美一区二区三区视频| 国产精品久久久久久久第一福利 | 久久综合亚洲社区| 免费成人毛片| 欧美freesex交免费视频| 毛片基地黄久久久久久天堂| 日韩视频在线你懂得| 亚洲国产视频直播| 亚洲三级电影全部在线观看高清 | 久久本道综合色狠狠五月| 欧美一区影院| 久久久精品国产免费观看同学| 欧美综合激情网| 久久免费视频网站| 欧美aⅴ99久久黑人专区| 欧美二区乱c少妇| 欧美日韩国产欧| 久久精品官网| 欧美电影资源| 国产精品国产三级欧美二区| 国产精品亚洲片夜色在线| 国产欧美日韩亚洲一区二区三区| 国产伦一区二区三区色一情| 国内成人精品一区| 亚洲国产三级在线| 亚洲欧美韩国| 久久久久久亚洲精品不卡4k岛国| 玖玖玖国产精品| 亚洲福利精品| 国产精品99久久久久久宅男| 欧美一区二区在线免费播放| 暖暖成人免费视频| 国产精品高潮呻吟久久av无限 | 日韩一区二区福利| 午夜精品一区二区三区电影天堂| 久久另类ts人妖一区二区| 欧美国产日韩一二三区| 国产精品白丝黑袜喷水久久久| 国内精品久久久久影院 日本资源| 亚洲国产你懂的| 午夜精品久久久久久久99黑人| 久久久视频精品| 亚洲精品久久久久| 久久九九国产| 欧美色中文字幕| 在线成人国产| 亚洲免费网址| 欧美国产日韩一区二区| 一区二区不卡在线视频 午夜欧美不卡在| 欧美一区二区视频观看视频| 欧美激情精品久久久久久变态| 国产精品永久免费| 亚洲毛片在线观看.| 久久久久久久尹人综合网亚洲| 亚洲美女区一区| 亚洲成人在线免费| 欧美成年网站| 亚洲欧美国产不卡|