• <tr id="yyy80"></tr>
  • <sup id="yyy80"></sup>
  • <tfoot id="yyy80"><noscript id="yyy80"></noscript></tfoot>
  • 99热精品在线国产_美女午夜性视频免费_国产精品国产高清国产av_av欧美777_自拍偷自拍亚洲精品老妇_亚洲熟女精品中文字幕_www日本黄色视频网_国产精品野战在线观看 ?

    考慮開(kāi)發(fā)者興趣遷移的開(kāi)源項(xiàng)目推薦方法

    2021-03-21 05:12:00趙佳斌趙海燕陳慶奎
    關(guān)鍵詞:開(kāi)發(fā)者開(kāi)源建模

    趙佳斌,趙海燕,曹 健,陳慶奎

    1(上海理工大學(xué) 光電信息與計(jì)算機(jī)工程學(xué)院 上海市現(xiàn)代光學(xué)系統(tǒng)重點(diǎn)實(shí)驗(yàn)室光學(xué)儀器與系統(tǒng)教育部工程研究中心,上海 200093) 2(上海交通大學(xué) 計(jì)算機(jī)科學(xué)與技術(shù)系,上海 200030)

    1 引 言

    開(kāi)源軟件已經(jīng)成為軟件開(kāi)發(fā)與應(yīng)用中的重要模式.隨著開(kāi)源項(xiàng)目托管系統(tǒng)如GitHub等的發(fā)展和普及,使得開(kāi)源項(xiàng)目的數(shù)量大幅增加,開(kāi)源社區(qū)也隨之受益.在開(kāi)源項(xiàng)目托管系統(tǒng)中,開(kāi)發(fā)者可以對(duì)感興趣的項(xiàng)目關(guān)注、分叉[1],在完成了一個(gè)功能的開(kāi)發(fā)或者漏洞的修復(fù)后可進(jìn)行提交.開(kāi)源社區(qū)通過(guò)分叉和pull-request將項(xiàng)目的修改與整合功能分開(kāi),這樣的模式吸引了大量的開(kāi)發(fā)者,也便于他們參與貢獻(xiàn)[2,3].開(kāi)發(fā)者也可以創(chuàng)建自己的公共倉(cāng)庫(kù),吸引其他的開(kāi)發(fā)者參與貢獻(xiàn).因此,開(kāi)發(fā)者的積極參與造就了許多繁榮的開(kāi)源社區(qū).

    開(kāi)發(fā)者參與開(kāi)源項(xiàng)目有著不同的需求和目的,例如專業(yè)的軟件開(kāi)發(fā)人員會(huì)尋找新的編程挑戰(zhàn)或者是商業(yè)機(jī)會(huì),而初學(xué)者會(huì)利用社區(qū)中的優(yōu)質(zhì)資源來(lái)學(xué)習(xí)新的技能、提高能力等[4].為了尋找適合自己并有興趣的項(xiàng)目,開(kāi)發(fā)者需要花費(fèi)時(shí)間在大量的項(xiàng)目中進(jìn)行尋找和決策.為了給這些開(kāi)發(fā)者提供幫助,開(kāi)源項(xiàng)目推薦系統(tǒng),它能幫助開(kāi)發(fā)人員有效地發(fā)現(xiàn)那些潛在的、他們感興趣的開(kāi)源項(xiàng)目.近年來(lái),不少研究者提出了針對(duì)開(kāi)源項(xiàng)目的推薦方法,如基于協(xié)同過(guò)濾的方法[6].然而,區(qū)別于傳統(tǒng)的電子商務(wù)推薦系統(tǒng),開(kāi)發(fā)者通常不會(huì)對(duì)大量的開(kāi)源項(xiàng)目貢獻(xiàn),這就使得開(kāi)發(fā)者-項(xiàng)目的關(guān)聯(lián)矩陣較為稀疏.因此,研究者提出了根據(jù)開(kāi)發(fā)者的行為對(duì)開(kāi)發(fā)者的興趣進(jìn)行建模的方法[7,8],考慮項(xiàng)目的編程語(yǔ)言、主題等對(duì)開(kāi)發(fā)者興趣建模的方法[9,10]等.這些方法的核心是基于開(kāi)發(fā)者的歷史項(xiàng)目來(lái)對(duì)開(kāi)發(fā)者進(jìn)行興趣建模.

    然而,開(kāi)發(fā)者在開(kāi)源社區(qū)中的興趣是發(fā)生變化的.例如,出于能力拓展的需要,開(kāi)發(fā)者可能會(huì)在小規(guī)模的開(kāi)源項(xiàng)目中得到鍛煉后,切換到更大規(guī)模的項(xiàng)目.又如,新的編程語(yǔ)言出現(xiàn)后,開(kāi)發(fā)者可能會(huì)進(jìn)入該語(yǔ)言的開(kāi)源項(xiàng)目.目前提出的方法通過(guò)對(duì)一個(gè)開(kāi)發(fā)者的歷史項(xiàng)目進(jìn)行分析難以反映其興趣遷移.

    本文提出了一種混合方法來(lái)揭示開(kāi)發(fā)者群體中存在的興趣遷移,首先對(duì)開(kāi)源項(xiàng)目采用概率主題模型的方法進(jìn)行主題建模,其次對(duì)其中存在的主題順序模式進(jìn)行挖掘從而形成開(kāi)發(fā)者群體的興趣遷移模式.在此基礎(chǔ)上,可以根據(jù)開(kāi)發(fā)者的歷史項(xiàng)目信息預(yù)測(cè)其感興趣的項(xiàng)目,然后結(jié)合開(kāi)發(fā)者的社交關(guān)系及項(xiàng)目流行度這兩項(xiàng)特征對(duì)候選池中的項(xiàng)目做排序進(jìn)而實(shí)現(xiàn)最相關(guān)的前N個(gè)開(kāi)源項(xiàng)目的推薦.

    2 相關(guān)工作

    推薦系統(tǒng)已經(jīng)存在了很長(zhǎng)一段時(shí)間了,軟件工程中的推薦系統(tǒng)近年來(lái)也逐漸得到了重視,為開(kāi)發(fā)者推薦開(kāi)源項(xiàng)目也引起了研究者的興趣.

    協(xié)同過(guò)濾是推薦系統(tǒng)的重要算法之一,它基于如下假設(shè):如果兩個(gè)用戶執(zhí)行相似的操作,那么他們也更有可能以相同的方式執(zhí)行其他操作.文獻(xiàn)[5]就采用了協(xié)同過(guò)濾的推薦思想,他們根據(jù)開(kāi)發(fā)者行為構(gòu)建了用戶行為矩陣,如果開(kāi)發(fā)者參與過(guò)該項(xiàng)目則評(píng)分為1,否則為0.然后,基于項(xiàng)目協(xié)同過(guò)濾方法進(jìn)行TopN推薦.由于該矩陣的高度稀疏性,其實(shí)際性能不高.

    為了揭示什么類型的行為數(shù)據(jù)適合用于項(xiàng)目推薦,文獻(xiàn)[6]中分析了在GitHub開(kāi)源社區(qū)中開(kāi)發(fā)者的多種不同行為,這些行為主要包括了分叉、關(guān)注、問(wèn)題評(píng)論、推拉請(qǐng)求、成員等.在經(jīng)定量和定性的實(shí)驗(yàn)分析后,他們發(fā)現(xiàn)分叉行為適合推薦相關(guān)項(xiàng)目.文獻(xiàn)[7]進(jìn)一步研究了開(kāi)發(fā)者的分叉行為.分叉行為主要用于對(duì)原項(xiàng)目進(jìn)行貢獻(xiàn),調(diào)查結(jié)果顯示42%的開(kāi)發(fā)者表示自動(dòng)化推薦功能能夠有效幫助他們選擇項(xiàng)目進(jìn)行分叉操作;分叉的主要原因是開(kāi)發(fā)者想要修改項(xiàng)目發(fā)起推拉請(qǐng)求并對(duì)項(xiàng)目做貢獻(xiàn);分叉行為不會(huì)產(chǎn)生不正當(dāng)競(jìng)爭(zhēng)以及版本兼容性問(wèn)題.他們的工作為開(kāi)源社區(qū)中的項(xiàng)目個(gè)性化推薦提供了新的見(jiàn)解.文獻(xiàn)[8]采用了一種結(jié)合開(kāi)發(fā)人員行為以及項(xiàng)目特征的推薦方法,從項(xiàng)目所包含的描述文件在內(nèi)的多種不同文件中提取項(xiàng)目特征進(jìn)而構(gòu)建項(xiàng)目相似矩陣,通過(guò)開(kāi)發(fā)者行為構(gòu)建開(kāi)發(fā)者項(xiàng)目關(guān)聯(lián)矩陣,同時(shí)還考慮了開(kāi)發(fā)者反饋來(lái)提高推薦的準(zhǔn)確率.

    開(kāi)源項(xiàng)目的內(nèi)容特征也可以用于揭示開(kāi)發(fā)者的興趣.文獻(xiàn)[9]使用了協(xié)同主題回歸的方式即結(jié)合用戶矩陣的傳統(tǒng)協(xié)同過(guò)濾與文本語(yǔ)料庫(kù)上的概率主題建模.文中提到的方法還為開(kāi)發(fā)者和項(xiàng)目提供了高度可解釋的潛在結(jié)構(gòu).文獻(xiàn)[10]考慮了開(kāi)源項(xiàng)目中出現(xiàn)的編程語(yǔ)言、主題和自述文檔,提出了一種混合方法來(lái)生成開(kāi)源項(xiàng)目的推薦,最終的項(xiàng)目相似性為3種不同相似性的線性組合.具體做法是分別構(gòu)建語(yǔ)言向量、主題向量和項(xiàng)目自述文件向量,同時(shí)也為開(kāi)發(fā)者構(gòu)建在這3個(gè)特征上的向量,然后計(jì)算得到最終的項(xiàng)目排序.文獻(xiàn)[11,12]主要關(guān)注項(xiàng)目的描述及源代碼來(lái)推薦開(kāi)源項(xiàng)目,忽略了開(kāi)發(fā)者的個(gè)性化需求.文獻(xiàn)[13]則用到了關(guān)聯(lián)規(guī)則挖掘的思想并結(jié)合了協(xié)同過(guò)濾,使用關(guān)聯(lián)規(guī)則挖掘共同參與的項(xiàng)目,而協(xié)同過(guò)濾被用于確定相似的項(xiàng)目.文獻(xiàn)[14]提出了一種基于深度學(xué)習(xí)的項(xiàng)目推薦方法,采用自動(dòng)編碼器來(lái)學(xué)習(xí)開(kāi)發(fā)者與開(kāi)源項(xiàng)目的向量表示.

    不同于上述的工作,本文關(guān)注開(kāi)發(fā)者在參與不同開(kāi)源項(xiàng)目中存在的興趣遷移模式,提出了一種基于項(xiàng)目主題遷移頻繁模式挖掘的推薦算法.

    3 基于項(xiàng)目主題遷移頻繁模式挖掘的推薦算法

    3.1 算法思想

    本文提出的算法關(guān)注了開(kāi)發(fā)者參與不同開(kāi)源項(xiàng)目的行為序列,在選擇項(xiàng)目的過(guò)程中會(huì)存在一定的規(guī)律和模式,通過(guò)主題建模的方式將開(kāi)發(fā)者所參與的開(kāi)源項(xiàng)目映射到不同的主題,由此開(kāi)發(fā)者參與的項(xiàng)目序列轉(zhuǎn)化為主題序列;對(duì)不同的主題序列進(jìn)行順序模式挖掘,找到社區(qū)中開(kāi)發(fā)者在選擇項(xiàng)目時(shí)的順序頻繁主題模式;然后用一種打分機(jī)制對(duì)產(chǎn)生的候選項(xiàng)目進(jìn)行打分,具體來(lái)說(shuō)就是融合開(kāi)發(fā)者社交關(guān)聯(lián)和項(xiàng)目流行度對(duì)項(xiàng)目進(jìn)行綜合打分,最后將得分最高的前N個(gè)項(xiàng)目作為最終的推薦結(jié)果.方法框架如圖1所示.

    圖1 算法框架Fig.1 Algorithm framework

    3.2 項(xiàng)目主題抽取

    在該方法中,首先對(duì)開(kāi)源項(xiàng)目的主題進(jìn)行挖掘,將類似的項(xiàng)目映射到同一個(gè)主題.用到的方法是LDA(Latent Dirichlet Allocation)概率主題模型,它是對(duì)文本隱含主題的一種建模方法,其主要功能是將文檔-詞匯矩陣轉(zhuǎn)化成文檔-主題分布和主題-詞匯分布.3層貝葉斯主題模型通過(guò)無(wú)監(jiān)督的學(xué)習(xí)方法發(fā)現(xiàn)文本所含主題,其基本思想就是文檔可以表示成一系列主題的混合分布.LDA模型的生成過(guò)程如圖2所示:1)對(duì)每篇文檔,從主題分布中提取一個(gè)主題;2)從該主題所對(duì)應(yīng)的單詞分布中抽取一個(gè)單詞;3)重復(fù)上述操作,直至遍歷整篇文檔.算法的輸入:分詞后為文檔集,超參數(shù)α,η.算法的輸出為:1)文檔中每個(gè)詞被分配的主題編號(hào);2)文檔的概率概率主題分布;3)每個(gè)主題下詞的概率分布;4)每個(gè)主題下概率從高到低排序的特征詞.

    圖2 LDA概率主題生成模型Fig.2 LDA probabilistic topic generation model

    圖2中α,η為分布的超參數(shù),θd表示對(duì)于任意文檔d的主題分布,βk對(duì)任意主題k的詞分布,文檔主題的先驗(yàn)分布和主題中詞的先驗(yàn)分布均為Dirichlet分布.Zd,n表示對(duì)文檔d中的第n個(gè)詞在θd下得到的主題編號(hào),wd,n表示在Zd,n主題編號(hào)下詞的概率分布.其中的核心公式如公式(1)所示,公式中以主題t作為中間層,通過(guò)當(dāng)前的θd和βk給出了文檔d中出現(xiàn)單詞w的概率,用θd計(jì)算得到p(t|d),用βk計(jì)算得到p(w|t).

    p(w|d)=p(w|t)*p(t|d)

    (1)

    為了抽取開(kāi)源項(xiàng)目的主題,對(duì)融合了開(kāi)源項(xiàng)目描述、標(biāo)簽和開(kāi)發(fā)語(yǔ)言的文本文檔做基于LDA的概率主題建模,從而將項(xiàng)目對(duì)應(yīng)的文本轉(zhuǎn)化成了若干主題的分布.首先對(duì)文本做預(yù)處理,包括分詞、去除標(biāo)點(diǎn)、去停用詞、詞干還原等;其次,將經(jīng)過(guò)預(yù)處理的文本用TF-IDF做文本向量化,然后進(jìn)行LDA主題建模,輸出項(xiàng)目對(duì)應(yīng)的概率主題分布.

    LDA是一個(gè)概率主題模型,為了更多地保留項(xiàng)目的特征信息,本文在選出了每個(gè)項(xiàng)目最貼切的一個(gè)主題的基礎(chǔ)上,設(shè)置了一個(gè)閾值.具體做法是,將項(xiàng)目所對(duì)應(yīng)的多個(gè)主題分布按概率大小做排序保留大于該閾值的主題.如此,一個(gè)項(xiàng)目可能只對(duì)應(yīng)一個(gè)主題,也可能對(duì)應(yīng)多個(gè)主題.

    3.3 主題順序頻繁模式挖掘

    數(shù)據(jù)集中頻繁出現(xiàn)的項(xiàng)集、序列或子結(jié)構(gòu)稱之為頻繁模式,經(jīng)常被用于購(gòu)物籃分析、網(wǎng)頁(yè)日志分析等.本文采用順序頻繁模式挖掘的方法對(duì)項(xiàng)目的主題的序列模式進(jìn)行挖掘.開(kāi)發(fā)者的偏好變化通過(guò)參與項(xiàng)目的行為序列來(lái)凸顯,通過(guò)對(duì)開(kāi)發(fā)者參與項(xiàng)目序列的主題的挖掘可以預(yù)計(jì)開(kāi)發(fā)者在參與了某一主題的項(xiàng)目后會(huì)接著參與哪個(gè)主題對(duì)應(yīng)的項(xiàng)目.

    對(duì)開(kāi)源項(xiàng)目完成主題建模后,開(kāi)發(fā)者原本參與項(xiàng)目的行為序列由轉(zhuǎn)化為<{topic11,topic12, …,topic1k1},{topic21,topic22, …,topic2k2},…,{topicn1,topicn2, …,topicnkn}>,其中repoi表示開(kāi)發(fā)者參與的項(xiàng)目名,topicij表示項(xiàng)目i對(duì)應(yīng)的第j個(gè)主題,并且假設(shè)每個(gè)項(xiàng)目取kn個(gè)主題.本文對(duì)其中存在的順序頻繁主題模式進(jìn)行

    圖3 GSP算法流程Fig.3 GSP algorithm flow

    挖掘.順序頻繁模式挖掘的主要任務(wù)是找到數(shù)據(jù)庫(kù)中存在的所有順序模式,即在序列集合中出現(xiàn)頻率超過(guò)最小支持度的子序列.常用到的算法是GSP(Generalized Sequential Pattern mining algorithm)[16]算法,該算法增加了掃描過(guò)程中的條件約束包括時(shí)間、滑動(dòng)窗口和分類層次,是一種基于優(yōu)先級(jí)原則的算法,其中用來(lái)存儲(chǔ)的數(shù)據(jù)結(jié)構(gòu)為哈希樹(shù).算法的輸入是主題序列數(shù)據(jù)、最小支持度閾值,輸出是順序頻繁模式.

    GSP算法的主要流程如圖3所示.

    但是,本文需要挖掘的序列是由數(shù)量不等的主題構(gòu)成的集合序列.因此,結(jié)合本文所涉及問(wèn)題的特點(diǎn),對(duì)GSP算法進(jìn)行修改.在其基礎(chǔ)上本文提出了GSP-SS(GSP for Set Sequences)算法.在主題建模的過(guò)程中,一個(gè)項(xiàng)目對(duì)應(yīng)了多個(gè)主題,例如項(xiàng)目i,在經(jīng)閾值篩選后它的第1主題為topic52,第2主題為topic16,第3主題為topic44,采用GSP-SS算法在得到順序頻繁模式的同時(shí)也會(huì)得到該頻繁模式所對(duì)應(yīng)的重要度.

    GSP-SS算法偽代碼如下:

    輸入:項(xiàng)目所對(duì)應(yīng)的主題序列數(shù)據(jù),最小支持度閾值;

    輸出:主題順序模式Li及其重要度.

    1.C1←init-pass(S);//遍歷輸入數(shù)據(jù)并產(chǎn)生1頻繁模式

    2.topicSupportArray=[repo1:[0,0,…,0k1],repo2:[0,0, …,0k2], … ,repon:[0,0,…,0kn].]

    //空數(shù)組topicSupportArray保存重要度

    3.L1←{<{l}>|l∈C1,Count(l)/n≥min_sup};

    //最小支持度閾值的判斷

    4.for(i=2,Li-1≠Φ,i++)do

    5.Ci←generate-candidate-SPM(Ci-1)

    //產(chǎn)生k-頻繁序列模式

    6.foreachs∈Sdo

    7.foreachc∈Cido

    8.ifcis contained insthen

    9. Count(c)++;//c的支持度

    10.fortopicinc:

    11.topicSupportArray[s.index][c′sindexins]++ //每出現(xiàn)一次重要度計(jì)數(shù)加1

    12.endfor

    13.endfor

    14.Li={c∈Ci|Count(c)≥min_sup};

    15.endfor

    16. sort(topicSupportArray[data sequence index:])

    //交換key,value;key填回topic

    函數(shù)generate-candidate-SPM(Ci-1)偽代碼如下:

    To generateCk//產(chǎn)生大小為k的候選項(xiàng)

    1. Join step.

    si′=si-1st //-1st,表示去掉第一個(gè)元素項(xiàng)

    sj′=sj-Last //-Last,表示去掉最后一個(gè)元素項(xiàng)

    ifsi′==sj′do

    s←Joinsi′ andsj′ // 做連接操作

    2. Prune step

    ifany subsequence ofck-1is not infrequent

    deleteck-1//做剪枝操作

    S為主題序列數(shù)據(jù),Ck為候選k-頻繁序列模式,Lk為候選k-頻繁序列模式.

    GSP-SS算法說(shuō)明:對(duì)產(chǎn)生的主題序列S數(shù)據(jù)庫(kù)進(jìn)行掃描,得到長(zhǎng)為1-主題順序模式L1并做最小支持度判斷將其作為初始種子集;對(duì)L1做連接操作并判斷是否滿足最小支持度,產(chǎn)生2-主題順序模式;用L2做連接操作產(chǎn)生3-主題順序模式,其中會(huì)有剪枝操作和最小支持度判斷;然后用3-順序主題模式L3挖掘直到不產(chǎn)生候選項(xiàng).在挖掘的過(guò)程中設(shè)置了數(shù)組topicSupportArray來(lái)存放所挖掘出主題模式的重要度,最后在得到主題順序模式的同時(shí)附帶將其重要度一并輸出.其中完成連接操作和剪切操作的generate-candiate-SPM是該算法的核心.連接階段:對(duì)于兩個(gè)順序模式Si和Sj,如果刪除Si的第一個(gè)項(xiàng)目得到序列與刪掉Sj的最后一個(gè)項(xiàng)目所得序列相同.那么對(duì)Si和Sj做連接操作.剪切階段:對(duì)于任意一個(gè)序列模式,如若它的子序列不是序列模式,那么這個(gè)序列模式就不可能成為序列模式,將其剪切即刪除掉.

    3.4 開(kāi)發(fā)者社交特征及項(xiàng)目流行度建模

    3.4.1 開(kāi)發(fā)者社交關(guān)聯(lián)

    不同于企業(yè)有組織的軟件開(kāi)發(fā)團(tuán)隊(duì),開(kāi)源軟件團(tuán)隊(duì)具有多樣性和流動(dòng)性,通常以自組織[17]的方式參與到軟件項(xiàng)目開(kāi)發(fā)中.Github開(kāi)源社區(qū)提供了包括@、關(guān)注和評(píng)論等多種方式方便開(kāi)發(fā)人員溝通和交流.

    通過(guò)使用關(guān)注功能,開(kāi)發(fā)者能關(guān)注自己感興趣的開(kāi)發(fā)者,關(guān)注開(kāi)發(fā)者能看到他們以往及近期的實(shí)踐工作,了解他們?cè)谙嚓P(guān)領(lǐng)域的貢獻(xiàn)以及研究.通過(guò)評(píng)論功能,開(kāi)發(fā)者們能夠在不同問(wèn)題下展開(kāi)討論進(jìn)而解決問(wèn)題.對(duì)自組織網(wǎng)絡(luò)的研究表明,相較于新的合作,人們更喜歡重復(fù)合作,因?yàn)樗麄冋J(rèn)為這樣的合作往往更有凝聚性.文獻(xiàn)[18]研究了社會(huì)化因素對(duì)GitHub這個(gè)新興生態(tài)系統(tǒng)的影響,包括開(kāi)發(fā)團(tuán)隊(duì)的形成已經(jīng)開(kāi)發(fā)人員的遷移等.其中社交關(guān)系的強(qiáng)度會(huì)影響開(kāi)發(fā)者的選擇,開(kāi)發(fā)人員會(huì)優(yōu)先加入存在社交聯(lián)系的項(xiàng)目.有社交關(guān)聯(lián)的開(kāi)發(fā)者們往往具有類似的興趣點(diǎn),同時(shí)基于先前的互動(dòng)或合作,開(kāi)發(fā)人員對(duì)彼此的技能和社交習(xí)慣都有更多地了解.因此,本文將開(kāi)發(fā)者的社交關(guān)系作為開(kāi)源項(xiàng)目推薦過(guò)程中考慮的因素之一.

    GitHub中所提供的項(xiàng)目issue功能是一種輕量級(jí)的協(xié)作系統(tǒng),在issue comment下可以進(jìn)行內(nèi)容豐富的交流,主要針對(duì)問(wèn)題解決、項(xiàng)目存在的Bug和下一項(xiàng)功能的增加等展開(kāi)討論.GitHub定義了pull-request為一種通知機(jī)制即你修改了他人的代碼希望原作者能合并你的修改,用pull-request來(lái)通知作者.它是一種軟件開(kāi)發(fā)合作方式,將不同功能的代碼通過(guò)這一流程納入到項(xiàng)目主干.通過(guò)其自帶的評(píng)論功能對(duì)所提交的修改進(jìn)行討論、測(cè)試并決定是否將其合并.根據(jù)社區(qū)中的參與同一個(gè)issue問(wèn)題評(píng)論、同一個(gè)pull-request評(píng)論來(lái)構(gòu)建每位開(kāi)發(fā)者的社交關(guān)系.對(duì)于開(kāi)發(fā)者u,其候選項(xiàng)目池中的項(xiàng)目i的社交關(guān)系計(jì)算如公式(2)所示:

    Social(u,i)=n(uinteract)

    (2)

    其中n(uinteract)表示在項(xiàng)目i中與之有過(guò)互動(dòng)的開(kāi)發(fā)者數(shù)量.

    3.4.2 項(xiàng)目流行度

    在開(kāi)源社區(qū)中,也存在“馬太效應(yīng)”,相比于那些冷門的項(xiàng)目,活躍的、受關(guān)注度高的開(kāi)源項(xiàng)目更容易吸引開(kāi)發(fā)者.在每個(gè)GitHub項(xiàng)目頁(yè)面的右上方有watch、star、fork這3個(gè)不同的按鈕.其中的star更像是“點(diǎn)贊”,因此本文選擇了關(guān)注和分叉的數(shù)量來(lái)評(píng)價(jià)一個(gè)項(xiàng)目的流行與否.

    Watch(關(guān)注)的數(shù)量,對(duì)于他人的項(xiàng)目默認(rèn)都是Not watching的狀態(tài),當(dāng)開(kāi)發(fā)者對(duì)該項(xiàng)目感興趣時(shí)就能選擇關(guān)注該項(xiàng)目的所有動(dòng)態(tài),例如該項(xiàng)目有開(kāi)發(fā)者提交pull request、提出了issue等,便能從系統(tǒng)推送中了解該項(xiàng)目發(fā)生的一切動(dòng)態(tài)變化.所以項(xiàng)目擁有的關(guān)注者數(shù)量能反應(yīng)其受用戶關(guān)注程度.

    Fork(分叉)的數(shù)量,當(dāng)你有了對(duì)一個(gè)項(xiàng)目做貢獻(xiàn)的想法包括增加新功能、漏洞修復(fù)或者在該項(xiàng)目的基礎(chǔ)上開(kāi)發(fā)一個(gè)自己的版本,可以點(diǎn)擊fork按鈕得到一份原項(xiàng)目的副本.

    結(jié)合關(guān)注和分叉這兩者的數(shù)量來(lái)計(jì)算項(xiàng)目的流行度,對(duì)兩者者的數(shù)量歸一化后進(jìn)行求和.對(duì)于項(xiàng)目i的流行度,計(jì)算公式如公式(3)所示:

    pop(i)=nor(n(iwatch))+nor(n(ifork))

    (3)

    其中n(iwatch)表示項(xiàng)目i關(guān)注者的數(shù)量,n(ifork)表示項(xiàng)目i分叉者的數(shù)量,nor()表示歸一化計(jì)算函數(shù).

    3.5 推薦方法

    通過(guò)概率主題建模的方法將開(kāi)發(fā)者參與的開(kāi)源項(xiàng)目映射成主題序列,將訓(xùn)練集中的開(kāi)發(fā)者參與主題序列事務(wù)集記作C={C1,C2,C3,…,Cu}其中u為開(kāi)發(fā)者人數(shù),Cu表示開(kāi)發(fā)者參與項(xiàng)目經(jīng)過(guò)主題泛化后得到的主題序列.將主題順序模式記作P,min_supp是最小支持度閾值,當(dāng)模式P的支持度大于min_supp則P為順序主題模式.采用GSP-SS算法對(duì)順序主題序列模式做挖掘,將開(kāi)發(fā)者參與的主題序列事物集作為GSP-SS算法的輸入,設(shè)置min_supp,運(yùn)行GSP-SS程序輸出主題頻繁順序模式項(xiàng),記作P={P1,P2,P3,…,Pj}其中j為產(chǎn)生的模式數(shù)量.

    采用一個(gè)多叉樹(shù)的數(shù)據(jù)結(jié)構(gòu)來(lái)存儲(chǔ)主題模式與模式庫(kù)中的模式項(xiàng)的對(duì)應(yīng)關(guān)系.將模式的候選集記作H={HP1,HP2,HP3, …,HPj}.

    對(duì)于測(cè)試集中的數(shù)據(jù),給定開(kāi)發(fā)者參與的歷史項(xiàng)目,將其映射為對(duì)應(yīng)的主題即,將其與多叉樹(shù)中存儲(chǔ)的主題模式做匹配,重復(fù)該操作得到候選推薦項(xiàng)目集合H(ri).對(duì)于產(chǎn)生的集合中的項(xiàng)目用計(jì)算評(píng)分的方法為其打分,將集合H中的項(xiàng)目按照分值做降序排列得到Top-N個(gè)推薦項(xiàng)目列表,開(kāi)發(fā)者u對(duì)項(xiàng)目ri的得分計(jì)算如公式(4)所示:

    S(u,ri)=α*nor(pop(i))+(1-α)*nor(social(u,i))

    (4)

    其中pop(i)表示項(xiàng)目的流行度,social(u,i)表示社交關(guān)聯(lián)度,α表示權(quán)重參數(shù),nor()表示歸一化函數(shù).

    算法描述如下:

    輸入:開(kāi)發(fā)者參與的歷史項(xiàng)目集合X,順序模式P;

    輸出:Top-N推薦項(xiàng)目列表.

    1.使用LDA主題模型將X轉(zhuǎn)化為C={C1,C2,C3,…,Cu};

    2.forj=1 tojdo

    3.foreachCu∈Cdo

    4.ifPjinCudo

    5.Pj在Cu中的末尾位置記作l,從X中的第l+1個(gè)位置得到ri

    6.endif

    7.endfor

    8.H←H∪HPj

    9.endfor

    10.用公式(4)為H中的項(xiàng)目打分并做降序排序

    11.returnTop-N 推薦項(xiàng)目列表

    4 實(shí)驗(yàn)與討論

    4.1 數(shù)據(jù)集

    本文使用的數(shù)據(jù)集是從GHTorrent[15]中轉(zhuǎn)儲(chǔ)得到的,GHTorrent項(xiàng)目提供了GitHub 的API數(shù)據(jù)的鏡像,可以離線查詢.它旨在用于與軟件存儲(chǔ)倉(cāng)庫(kù)有關(guān)的研究與發(fā)現(xiàn).本文選取了2016-2018年間的數(shù)據(jù),為了讓實(shí)驗(yàn)數(shù)據(jù)更具有代表性,篩選出的開(kāi)發(fā)者和開(kāi)源項(xiàng)目滿足如下條件:1)開(kāi)發(fā)者至少參與了5個(gè)不同的開(kāi)源項(xiàng)目;2)與其他開(kāi)發(fā)者有過(guò)互動(dòng)即在同一個(gè)問(wèn)題或推拉請(qǐng)求下有過(guò)討論;3)開(kāi)源項(xiàng)目為原始項(xiàng)目即不是從其他項(xiàng)目分叉而來(lái);4)開(kāi)源項(xiàng)目至少有5名開(kāi)發(fā)者參與過(guò).開(kāi)發(fā)者參與項(xiàng)目數(shù)據(jù)格式如:開(kāi)發(fā)者編號(hào)-項(xiàng)目編號(hào)-時(shí)間戳.開(kāi)源項(xiàng)目信息包含:項(xiàng)目編號(hào)、項(xiàng)目開(kāi)發(fā)語(yǔ)言、項(xiàng)目描述和項(xiàng)目標(biāo)簽.經(jīng)篩選后得到了開(kāi)發(fā)者數(shù)量18399個(gè),開(kāi)源項(xiàng)目數(shù)量23076個(gè).根據(jù)開(kāi)發(fā)者參與項(xiàng)目的時(shí)間戳的先后順序來(lái)創(chuàng)建開(kāi)發(fā)者參與項(xiàng)目序列數(shù)據(jù),根據(jù)項(xiàng)目開(kāi)發(fā)語(yǔ)言、項(xiàng)目描述和項(xiàng)目標(biāo)簽來(lái)創(chuàng)建項(xiàng)目文檔數(shù)據(jù)用作主題建模.

    關(guān)于訓(xùn)練集和測(cè)試集的劃分.本文將開(kāi)發(fā)者近一年參與的項(xiàng)目作為測(cè)試集用作實(shí)驗(yàn)的預(yù)測(cè)數(shù)據(jù),剩余的其他數(shù)據(jù)用作實(shí)驗(yàn)?zāi)P偷挠?xùn)練數(shù)據(jù).

    4.2 評(píng)價(jià)指標(biāo)采用召回率

    考慮到本文的推薦場(chǎng)景為Top-N的前N個(gè)項(xiàng)目的推薦即向開(kāi)發(fā)者提供一個(gè)推薦的列表讓其進(jìn)行選擇,故采用了召回率Recall來(lái)評(píng)價(jià)所提算法的推薦效果.召回率表示用戶感興趣的項(xiàng)目被推薦系統(tǒng)成功推薦的概率,計(jì)算公式如公式(5)所示:

    (5)

    其中R(u)為根據(jù)開(kāi)發(fā)者u在訓(xùn)練集上的表現(xiàn)向其推薦的項(xiàng)目集,T(u)為開(kāi)發(fā)者u在測(cè)試集上參與過(guò)的項(xiàng)目集.

    4.3 基準(zhǔn)推薦算法

    本文選擇了3種常見(jiàn)的推薦算法作為對(duì)比方法.

    1)基于項(xiàng)目流行度的推薦方法,該方法圍繞項(xiàng)目“熱度”展開(kāi),將對(duì)用戶有著強(qiáng)吸引力的項(xiàng)目推薦給其他開(kāi)發(fā)者.采用這一方法做推薦的主要工作就是計(jì)算每個(gè)項(xiàng)目的流行度,推薦列表為開(kāi)發(fā)者未曾參與過(guò)的流行的Top-N個(gè)開(kāi)源項(xiàng)目;

    2)基于用戶的協(xié)同過(guò)濾推薦[19],這個(gè)算法通常分為兩個(gè)步驟,首先找到與目標(biāo)開(kāi)發(fā)者相似的若干開(kāi)發(fā)者,然后將這個(gè)集合中開(kāi)發(fā)者參與過(guò)的但目標(biāo)開(kāi)發(fā)者未曾參與的項(xiàng)目作為推薦列表.設(shè)置最相似的開(kāi)發(fā)者數(shù)量K=20,相似度計(jì)算采用余弦相似性;

    3)基于內(nèi)容的推薦算法,根據(jù)開(kāi)發(fā)者做過(guò)的項(xiàng)目描述、開(kāi)發(fā)語(yǔ)言及標(biāo)簽來(lái)推薦類似的開(kāi)源項(xiàng)目,采用文本處理方法:詞頻-逆文檔頻率(TF-IDF)將文本向量化隨后計(jì)算項(xiàng)目之間的余弦相似度,推薦列為與其最相似的Top-N個(gè)項(xiàng)目.

    本文所提推薦的推薦算法,將主題個(gè)數(shù)K設(shè)置為90,主題模式挖掘中的最小支持度min_supp設(shè)置為5.

    4.4 實(shí)驗(yàn)結(jié)果分析

    不同推薦方法下實(shí)驗(yàn)結(jié)果如表1所示,采用的評(píng)價(jià)方法為召回率.

    表1 實(shí)驗(yàn)結(jié)果表Table 1 Experiment resultTable

    開(kāi)發(fā)者社交特征及項(xiàng)目流行度建模中的公式(4),不同α的取值對(duì)推薦結(jié)果的影響如圖4所示.實(shí)驗(yàn)中本文將α值設(shè)置為0.3.

    圖4 α的取值對(duì)推薦結(jié)果的影響Fig.4 Value of α versus the recommended result

    實(shí)驗(yàn)結(jié)果表明,當(dāng)推薦項(xiàng)目數(shù)量N值增大的時(shí)候,四種不同推薦方法的召回率均逐漸增大,說(shuō)明在推薦列表中開(kāi)發(fā)者感興趣的項(xiàng)目數(shù)量增多了.本文提出的基于主題模式挖掘的推薦方法在召回率上優(yōu)于其余3種對(duì)比方法,對(duì)項(xiàng)目的主題模式挖掘考慮到了開(kāi)源項(xiàng)目的內(nèi)容特征,引入的評(píng)分機(jī)制兼顧了開(kāi)發(fā)者的社交情況以及項(xiàng)目自身的流行度特點(diǎn),進(jìn)而提高了推薦效果.

    5 總結(jié)與展望

    近年來(lái),分布式軟件開(kāi)發(fā)與社交化編程得到了人們的廣泛認(rèn)可,GitHub開(kāi)源社區(qū)更是引領(lǐng)了新的開(kāi)源文化.GitHub“去中心化”的開(kāi)源模式,不斷彰顯和強(qiáng)調(diào)作為個(gè)體的開(kāi)發(fā)者的作用,鼓勵(lì)他們對(duì)他人的項(xiàng)目做修復(fù)和改進(jìn).開(kāi)源社區(qū)的壯大也使得開(kāi)源項(xiàng)目的數(shù)量大幅增加,開(kāi)源項(xiàng)目推薦系統(tǒng)能幫助開(kāi)發(fā)者找到他們有意愿參與的項(xiàng)目.

    本文提出了一種基于項(xiàng)目主題模式挖掘的推薦方法,關(guān)注了開(kāi)發(fā)者在項(xiàng)目遷移過(guò)程中存在的規(guī)律,用開(kāi)源項(xiàng)目的內(nèi)容特征為項(xiàng)目進(jìn)行主題建模,開(kāi)發(fā)者參與項(xiàng)目的項(xiàng)目序列轉(zhuǎn)化為主題序列;隨后對(duì)其中存在的主題順序模式進(jìn)行挖掘;接著融合開(kāi)發(fā)者的社交關(guān)聯(lián)和項(xiàng)目自身的流行度這兩個(gè)特點(diǎn)實(shí)現(xiàn)了Top-N個(gè)開(kāi)源項(xiàng)目推薦;最后在實(shí)驗(yàn)數(shù)據(jù)集上與傳統(tǒng)推薦方法進(jìn)行對(duì)比,推薦效果得到了有效的提升.未來(lái)的工作可以關(guān)注對(duì)項(xiàng)目的主題建模和開(kāi)發(fā)者在項(xiàng)目遷移過(guò)程中是選擇下一個(gè)項(xiàng)目的其他因素,考慮更多的文本內(nèi)容比如代碼所蘊(yùn)含的注釋、函數(shù)名等,有助于提高項(xiàng)目與主題的契合程度.

    猜你喜歡
    開(kāi)發(fā)者開(kāi)源建模
    聯(lián)想等效,拓展建?!浴皫щ娦∏蛟诘刃?chǎng)中做圓周運(yùn)動(dòng)”為例
    五毛錢能買多少頭牛
    基于PSS/E的風(fēng)電場(chǎng)建模與動(dòng)態(tài)分析
    電子制作(2018年17期)2018-09-28 01:56:44
    不對(duì)稱半橋變換器的建模與仿真
    大家說(shuō):開(kāi)源、人工智能及創(chuàng)新
    開(kāi)源中國(guó)開(kāi)源世界高峰論壇圓桌會(huì)議縱論開(kāi)源與互聯(lián)網(wǎng)+創(chuàng)新2.0
    16%游戲開(kāi)發(fā)者看好VR
    CHIP新電腦(2016年3期)2016-03-10 13:06:42
    開(kāi)源計(jì)算機(jī)輔助翻譯工具研究
    iOS開(kāi)發(fā)者調(diào)查
    電腦迷(2015年8期)2015-05-30 12:27:10
    iOS開(kāi)發(fā)者調(diào)查
    電腦迷(2015年4期)2015-05-30 05:24:09
    熟妇人妻不卡中文字幕| 十分钟在线观看高清视频www| 免费高清在线观看视频在线观看| 国产精品一国产av| 天天躁夜夜躁狠狠久久av| av网站免费在线观看视频| 国产永久视频网站| 国产精品一国产av| av免费在线看不卡| 免费av中文字幕在线| 中文精品一卡2卡3卡4更新| 日韩大片免费观看网站| 在线观看三级黄色| av天堂久久9| 久久国产亚洲av麻豆专区| 91精品国产国语对白视频| 午夜福利影视在线免费观看| 亚洲欧美日韩另类电影网站| 夜夜骑夜夜射夜夜干| av电影中文网址| 在线观看www视频免费| 国产无遮挡羞羞视频在线观看| 国产黄色视频一区二区在线观看| 韩国高清视频一区二区三区| 香蕉精品网在线| 丝袜喷水一区| tube8黄色片| h视频一区二区三区| 久久精品国产亚洲av涩爱| 国产高清不卡午夜福利| 亚洲精品乱码久久久久久按摩| 3wmmmm亚洲av在线观看| 成人国产麻豆网| 精品午夜福利在线看| 大码成人一级视频| 亚洲内射少妇av| 9色porny在线观看| 国产成人免费无遮挡视频| 国精品久久久久久国模美| 91久久精品国产一区二区成人| 午夜福利视频精品| 久久韩国三级中文字幕| 亚洲婷婷狠狠爱综合网| 插阴视频在线观看视频| av电影中文网址| 亚洲国产色片| a级毛片黄视频| 亚洲精品第二区| 亚洲精品456在线播放app| 在线观看人妻少妇| 亚洲国产色片| 国产成人a∨麻豆精品| 国精品久久久久久国模美| 最后的刺客免费高清国语| 色吧在线观看| 免费看光身美女| 男人添女人高潮全过程视频| 日日啪夜夜爽| 国产精品蜜桃在线观看| 天堂俺去俺来也www色官网| 亚洲人与动物交配视频| 特大巨黑吊av在线直播| 亚洲性久久影院| 日韩av不卡免费在线播放| 国产男人的电影天堂91| 熟女人妻精品中文字幕| 免费黄频网站在线观看国产| 秋霞伦理黄片| 热99久久久久精品小说推荐| av在线app专区| 精品一区二区三卡| 我的老师免费观看完整版| 久久久久久久久大av| 啦啦啦视频在线资源免费观看| 国产无遮挡羞羞视频在线观看| 免费看不卡的av| 国产精品久久久久久久电影| 国产成人精品无人区| 精品国产露脸久久av麻豆| 亚洲性久久影院| 人人妻人人澡人人爽人人夜夜| 国产成人freesex在线| 一本一本久久a久久精品综合妖精 国产伦在线观看视频一区 | 久久久久精品性色| av黄色大香蕉| 免费看光身美女| 人成视频在线观看免费观看| av免费观看日本| 亚洲欧洲精品一区二区精品久久久 | 久久午夜综合久久蜜桃| 狂野欧美激情性xxxx在线观看| 天美传媒精品一区二区| 王馨瑶露胸无遮挡在线观看| 精品一区二区三区视频在线| 另类精品久久| 亚洲美女搞黄在线观看| 久久精品国产鲁丝片午夜精品| 免费少妇av软件| 人妻一区二区av| 制服丝袜香蕉在线| 只有这里有精品99| 亚洲伊人久久精品综合| 97超视频在线观看视频| 成人国产av品久久久| 美女cb高潮喷水在线观看| 青青草视频在线视频观看| 色婷婷久久久亚洲欧美| 日本黄色片子视频| 韩国av在线不卡| 国产黄色视频一区二区在线观看| 香蕉精品网在线| 国产日韩欧美亚洲二区| a级片在线免费高清观看视频| 亚洲人成网站在线观看播放| 人妻一区二区av| 欧美最新免费一区二区三区| 精品酒店卫生间| 欧美日韩综合久久久久久| 性高湖久久久久久久久免费观看| 91aial.com中文字幕在线观看| 一级二级三级毛片免费看| 99热全是精品| 亚洲精品美女久久av网站| 91aial.com中文字幕在线观看| 天堂8中文在线网| 亚洲国产最新在线播放| av电影中文网址| 亚洲欧美日韩卡通动漫| 最后的刺客免费高清国语| av在线app专区| 肉色欧美久久久久久久蜜桃| 国产亚洲午夜精品一区二区久久| 亚洲五月色婷婷综合| 精品久久久噜噜| 我的老师免费观看完整版| 日本vs欧美在线观看视频| 色吧在线观看| 少妇的逼好多水| 成人18禁高潮啪啪吃奶动态图 | 亚洲国产毛片av蜜桃av| 国产精品久久久久久久电影| 亚洲精品国产色婷婷电影| 久久久久国产精品人妻一区二区| 日韩电影二区| 国产成人一区二区在线| 少妇高潮的动态图| 精品国产露脸久久av麻豆| 国产黄色免费在线视频| av天堂久久9| 日本黄色片子视频| 欧美最新免费一区二区三区| 精品久久蜜臀av无| a级毛色黄片| 午夜福利,免费看| 日本黄大片高清| 日韩一本色道免费dvd| 纵有疾风起免费观看全集完整版| 18在线观看网站| av天堂久久9| 成人二区视频| 精品熟女少妇av免费看| 久久影院123| 久久精品国产亚洲网站| 一个人看视频在线观看www免费| freevideosex欧美| 少妇人妻久久综合中文| 国产 一区精品| 菩萨蛮人人尽说江南好唐韦庄| 亚洲精品久久午夜乱码| 国产爽快片一区二区三区| 成人免费观看视频高清| 在线观看三级黄色| 成人二区视频| 大话2 男鬼变身卡| 色视频在线一区二区三区| a 毛片基地| 欧美 日韩 精品 国产| 久久精品国产亚洲av天美| 秋霞伦理黄片| 国产精品 国内视频| 国产高清国产精品国产三级| 久久精品国产a三级三级三级| 精品国产一区二区三区久久久樱花| 草草在线视频免费看| 99久国产av精品国产电影| 人妻 亚洲 视频| 99国产综合亚洲精品| 日韩av在线免费看完整版不卡| 亚洲精品日韩在线中文字幕| 国产女主播在线喷水免费视频网站| 免费观看在线日韩| 亚洲天堂av无毛| 亚洲av福利一区| 黑人欧美特级aaaaaa片| 91精品国产国语对白视频| 人妻少妇偷人精品九色| 亚洲三级黄色毛片| 高清视频免费观看一区二区| 狠狠婷婷综合久久久久久88av| 亚洲精品视频女| 久久久久精品久久久久真实原创| 爱豆传媒免费全集在线观看| 国精品久久久久久国模美| 春色校园在线视频观看| 亚洲精品第二区| 丰满饥渴人妻一区二区三| 91成人精品电影| 久久99热6这里只有精品| 亚洲性久久影院| 亚洲怡红院男人天堂| 色婷婷久久久亚洲欧美| 新久久久久国产一级毛片| 伊人久久精品亚洲午夜| 久久国产精品大桥未久av| 久久99一区二区三区| 99久久中文字幕三级久久日本| 午夜激情av网站| 99国产精品免费福利视频| 亚洲伊人久久精品综合| 国产精品国产三级国产专区5o| 精品少妇黑人巨大在线播放| 国产成人免费观看mmmm| 最后的刺客免费高清国语| 天堂俺去俺来也www色官网| 亚洲精品乱码久久久v下载方式| 美女中出高潮动态图| 欧美日韩综合久久久久久| 色哟哟·www| 999精品在线视频| 国产有黄有色有爽视频| 免费大片18禁| 精品一区二区三卡| 搡女人真爽免费视频火全软件| 在线 av 中文字幕| 午夜影院在线不卡| 久久精品人人爽人人爽视色| 亚洲一区二区三区欧美精品| 国产精品人妻久久久影院| 欧美 亚洲 国产 日韩一| 考比视频在线观看| 搡女人真爽免费视频火全软件| 亚洲国产色片| 夫妻性生交免费视频一级片| 18禁在线播放成人免费| 在线观看一区二区三区激情| 五月伊人婷婷丁香| 亚洲,一卡二卡三卡| 国产成人aa在线观看| 精品亚洲乱码少妇综合久久| 久久毛片免费看一区二区三区| 午夜日本视频在线| 丝袜美足系列| 人人妻人人爽人人添夜夜欢视频| 日韩三级伦理在线观看| 午夜精品国产一区二区电影| 亚洲精品亚洲一区二区| 一本久久精品| 国产成人精品福利久久| 亚洲天堂av无毛| 一级a做视频免费观看| 在线观看免费高清a一片| 麻豆乱淫一区二区| 国产精品久久久久久久电影| 日日摸夜夜添夜夜爱| 欧美97在线视频| 边亲边吃奶的免费视频| av卡一久久| 黄色欧美视频在线观看| 国产一区二区在线观看av| 国精品久久久久久国模美| 国产精品嫩草影院av在线观看| 精品一区二区三区视频在线| 中文字幕亚洲精品专区| 天天操日日干夜夜撸| 日日爽夜夜爽网站| a级片在线免费高清观看视频| 十分钟在线观看高清视频www| 青春草国产在线视频| 日本免费在线观看一区| 一二三四中文在线观看免费高清| 99久久精品一区二区三区| 久久久亚洲精品成人影院| 最近最新中文字幕免费大全7| 久久青草综合色| 青春草国产在线视频| 大香蕉久久网| 一级二级三级毛片免费看| tube8黄色片| 69精品国产乱码久久久| 人妻系列 视频| 人体艺术视频欧美日本| 天美传媒精品一区二区| 亚洲精品一二三| 99久久中文字幕三级久久日本| 亚洲欧美清纯卡通| 中文字幕亚洲精品专区| kizo精华| 国产女主播在线喷水免费视频网站| 国产精品女同一区二区软件| 久久精品国产鲁丝片午夜精品| 日本黄大片高清| 五月玫瑰六月丁香| xxxhd国产人妻xxx| 99久久人妻综合| 制服丝袜香蕉在线| 精品久久国产蜜桃| 九色亚洲精品在线播放| 熟女av电影| 久久久久久久久大av| 国内精品宾馆在线| 少妇被粗大的猛进出69影院 | 特大巨黑吊av在线直播| 国产毛片在线视频| 国产极品粉嫩免费观看在线 | 又黄又爽又刺激的免费视频.| 高清午夜精品一区二区三区| 女人精品久久久久毛片| 久久精品夜色国产| 久久国产精品男人的天堂亚洲 | 国产有黄有色有爽视频| 91久久精品国产一区二区三区| 国产欧美日韩一区二区三区在线 | 又粗又硬又长又爽又黄的视频| 亚洲国产最新在线播放| 久久国产精品男人的天堂亚洲 | 18在线观看网站| 日韩成人av中文字幕在线观看| 如何舔出高潮| 欧美三级亚洲精品| 国产片内射在线| 国产乱人偷精品视频| 一级毛片电影观看| 久久99热6这里只有精品| 久久精品人人爽人人爽视色| a级毛片免费高清观看在线播放| 内地一区二区视频在线| 插逼视频在线观看| 又粗又硬又长又爽又黄的视频| 一级黄片播放器| 欧美日本中文国产一区发布| 十分钟在线观看高清视频www| 2021少妇久久久久久久久久久| av在线老鸭窝| 成人免费观看视频高清| 97超视频在线观看视频| 简卡轻食公司| 日韩电影二区| 亚洲精品亚洲一区二区| 久久久国产一区二区| 久久久久国产精品人妻一区二区| 免费观看av网站的网址| av卡一久久| 国产在线视频一区二区| 久久人人爽av亚洲精品天堂| 91精品一卡2卡3卡4卡| 国产亚洲欧美精品永久| 精品人妻一区二区三区麻豆| www.色视频.com| 亚洲精品成人av观看孕妇| 日日摸夜夜添夜夜添av毛片| 超色免费av| 国产综合精华液| 丝瓜视频免费看黄片| 一级,二级,三级黄色视频| 日本欧美国产在线视频| 欧美日韩一区二区视频在线观看视频在线| 一级毛片我不卡| 成人免费观看视频高清| 校园人妻丝袜中文字幕| 亚洲在久久综合| 97在线视频观看| 精品久久久噜噜| 草草在线视频免费看| 久久久久网色| 精品一品国产午夜福利视频| 这个男人来自地球电影免费观看 | 99热6这里只有精品| 人成视频在线观看免费观看| a 毛片基地| 成人毛片60女人毛片免费| 婷婷色综合www| 老司机影院毛片| 亚洲成人手机| 日本黄色日本黄色录像| 精品国产一区二区久久| av国产久精品久网站免费入址| 亚洲av在线观看美女高潮| 日本-黄色视频高清免费观看| 一本—道久久a久久精品蜜桃钙片| 如何舔出高潮| 黄片无遮挡物在线观看| 国产亚洲一区二区精品| 蜜臀久久99精品久久宅男| 美女国产高潮福利片在线看| 寂寞人妻少妇视频99o| 午夜福利影视在线免费观看| 亚洲第一区二区三区不卡| 高清不卡的av网站| 男女无遮挡免费网站观看| 国产黄色免费在线视频| 亚洲精品久久午夜乱码| 亚洲av在线观看美女高潮| 亚洲精品日韩av片在线观看| 在线亚洲精品国产二区图片欧美 | 欧美3d第一页| 午夜福利网站1000一区二区三区| 天堂8中文在线网| 特大巨黑吊av在线直播| 国产在线视频一区二区| 亚洲av男天堂| 老熟女久久久| 最近最新中文字幕免费大全7| 涩涩av久久男人的天堂| 精品午夜福利在线看| 日本欧美视频一区| 免费久久久久久久精品成人欧美视频 | 亚洲综合精品二区| 人妻制服诱惑在线中文字幕| 2018国产大陆天天弄谢| 亚洲精品国产av蜜桃| 欧美xxⅹ黑人| 人人妻人人添人人爽欧美一区卜| 内地一区二区视频在线| 免费高清在线观看视频在线观看| 亚洲精品国产色婷婷电影| 亚洲国产成人一精品久久久| 狠狠婷婷综合久久久久久88av| 一级a做视频免费观看| 天天影视国产精品| 免费久久久久久久精品成人欧美视频 | 久久久久精品性色| 男女边摸边吃奶| 国产日韩欧美视频二区| 亚洲天堂av无毛| 国产欧美日韩一区二区三区在线 | 美女国产高潮福利片在线看| 一本一本久久a久久精品综合妖精 国产伦在线观看视频一区 | 久久精品久久精品一区二区三区| 伦理电影大哥的女人| 亚洲高清免费不卡视频| 肉色欧美久久久久久久蜜桃| 丝袜脚勾引网站| 亚洲精品自拍成人| 啦啦啦啦在线视频资源| 欧美人与性动交α欧美精品济南到 | 国产免费又黄又爽又色| 亚洲精品久久久久久婷婷小说| 狠狠婷婷综合久久久久久88av| 22中文网久久字幕| 亚洲成人手机| 国产一区有黄有色的免费视频| 日本午夜av视频| av女优亚洲男人天堂| 国产在线免费精品| 多毛熟女@视频| 久久精品国产a三级三级三级| 亚洲欧美成人综合另类久久久| 久久精品国产a三级三级三级| 女人精品久久久久毛片| av黄色大香蕉| 伊人亚洲综合成人网| 大片免费播放器 马上看| 两个人免费观看高清视频| 少妇的逼好多水| 亚洲人成网站在线观看播放| 国产综合精华液| www.av在线官网国产| 久久午夜福利片| 精品熟女少妇av免费看| 大片免费播放器 马上看| 久久久久久久久久人人人人人人| 免费观看的影片在线观看| 最近中文字幕2019免费版| 视频中文字幕在线观看| 成人综合一区亚洲| 午夜av观看不卡| av不卡在线播放| 国产探花极品一区二区| 日韩成人av中文字幕在线观看| 伦理电影大哥的女人| 精品久久久精品久久久| 中文天堂在线官网| 国产无遮挡羞羞视频在线观看| 99热国产这里只有精品6| 涩涩av久久男人的天堂| 男女边吃奶边做爰视频| 精品少妇黑人巨大在线播放| av国产久精品久网站免费入址| 亚洲国产精品一区二区三区在线| 好男人视频免费观看在线| 欧美激情国产日韩精品一区| 大片电影免费在线观看免费| 亚洲精品456在线播放app| 三级国产精品欧美在线观看| 18禁在线无遮挡免费观看视频| 波野结衣二区三区在线| 五月天丁香电影| 最新的欧美精品一区二区| 晚上一个人看的免费电影| 亚洲av男天堂| 欧美变态另类bdsm刘玥| 亚洲精品av麻豆狂野| 九九在线视频观看精品| a级毛片黄视频| 超色免费av| 熟妇人妻不卡中文字幕| av福利片在线| 国产69精品久久久久777片| 成人毛片60女人毛片免费| 久久韩国三级中文字幕| 亚洲精品久久成人aⅴ小说 | 亚洲欧美中文字幕日韩二区| 国产一区二区三区av在线| 亚洲美女搞黄在线观看| 一区二区av电影网| 国产深夜福利视频在线观看| 成人国产av品久久久| 国产老妇伦熟女老妇高清| 不卡视频在线观看欧美| 男女高潮啪啪啪动态图| 精品一品国产午夜福利视频| 黄色怎么调成土黄色| 精品国产一区二区三区久久久樱花| 欧美日韩av久久| 亚洲精品日韩av片在线观看| 免费黄频网站在线观看国产| 精品一区在线观看国产| 亚洲在久久综合| 午夜福利影视在线免费观看| freevideosex欧美| 亚洲图色成人| 欧美国产精品一级二级三级| 国产精品一区二区三区四区免费观看| 亚洲精品久久午夜乱码| 国产成人一区二区在线| 男女边吃奶边做爰视频| 老女人水多毛片| 日韩中字成人| 国产精品蜜桃在线观看| 国产欧美日韩综合在线一区二区| 又黄又爽又刺激的免费视频.| 搡老乐熟女国产| 久久精品人人爽人人爽视色| 黄色视频在线播放观看不卡| 3wmmmm亚洲av在线观看| 在线观看一区二区三区激情| 人人澡人人妻人| 99精国产麻豆久久婷婷| 久久人人爽人人片av| 日本wwww免费看| 夜夜爽夜夜爽视频| 少妇的逼好多水| 久久国产精品男人的天堂亚洲 | 亚洲精品视频女| 国产精品久久久久成人av| 国产成人精品在线电影| 王馨瑶露胸无遮挡在线观看| 日韩av不卡免费在线播放| 中文字幕免费在线视频6| 亚洲av福利一区| 99国产精品免费福利视频| 高清欧美精品videossex| 免费人妻精品一区二区三区视频| 新久久久久国产一级毛片| 成人影院久久| 国产av精品麻豆| 国产精品国产三级国产专区5o| 久久久久久伊人网av| 亚洲欧美成人精品一区二区| 日本av手机在线免费观看| 黄色一级大片看看| 人人妻人人添人人爽欧美一区卜| 日韩在线高清观看一区二区三区| 国产精品欧美亚洲77777| 在线观看免费视频网站a站| 一级a做视频免费观看| 久久精品国产亚洲av涩爱| 热99国产精品久久久久久7| 亚洲熟女精品中文字幕| 国产亚洲av片在线观看秒播厂| 亚洲国产精品一区三区| 夜夜看夜夜爽夜夜摸| 在线观看www视频免费| 成人国产av品久久久| 能在线免费看毛片的网站| videosex国产| 人妻人人澡人人爽人人| 亚洲第一区二区三区不卡| 国产亚洲一区二区精品| 黑人高潮一二区| 国产一区二区三区综合在线观看 | 亚洲av成人精品一区久久| 校园人妻丝袜中文字幕| 永久免费av网站大全| 亚洲精品国产av蜜桃| 欧美另类一区| 美女脱内裤让男人舔精品视频| 啦啦啦啦在线视频资源| 欧美精品国产亚洲| 色5月婷婷丁香| 亚洲色图综合在线观看| 国产免费现黄频在线看| 好男人视频免费观看在线| 国产av精品麻豆| 国产在视频线精品| 大话2 男鬼变身卡| 最近的中文字幕免费完整| 久久久久久伊人网av| 麻豆成人av视频| 老司机影院成人| 国产极品粉嫩免费观看在线 | 十分钟在线观看高清视频www| 99国产精品免费福利视频| 久久久久精品性色| 亚洲伊人久久精品综合|