0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

FM和深度網(wǎng)絡DNN的結合成為了CTR預估問題中主流的方法

lviY_AI_shequ ? 來源:未知 ? 作者:李倩 ? 2018-08-30 10:46 ? 次閱讀

1、引言

在CTR預估中,為了解決稀疏特征的問題,學者們提出了FM模型來建模特征之間的交互關系。但是FM模型只能表達特征之間兩兩組合之間的關系,無法建模兩個特征之間深層次的關系或者說多個特征之間的交互關系,因此學者們通過Deep Network來建模更高階的特征之間的關系。

因此 FM和深度網(wǎng)絡DNN的結合也就成為了CTR預估問題中主流的方法。有關FM和DNN的結合有兩種主流的方法,并行結構和串行結構。兩種結構的理解以及實現(xiàn)如下表所示:

今天介紹的NFM模型(Neural Factorization Machine),便是串行結構中一種較為簡單的網(wǎng)絡模型。

2、NFM模型介紹

我們首先來回顧一下FM模型,F(xiàn)M模型用n個隱變量來刻畫特征之間的交互關系。這里要強調的一點是,n是特征的總數(shù),是one-hot展開之后的,比如有三組特征,兩個連續(xù)特征,一個離散特征有5個取值,那么n=7而不是n=3.

順便回顧一下化簡過程:

可以看到,不考慮最外層的求和,我們可以得到一個K維的向量。

對于NFM模型,目標值的預測公式變?yōu)椋?/p>

其中,f(x)是用來建模特征之間交互關系的多層前饋神經(jīng)網(wǎng)絡模塊,架構圖如下所示:

Embedding Layer和我們之間幾個網(wǎng)絡是一樣的,embedding 得到的vector其實就是我們在FM中要學習的隱變量v。

Bi-Interaction Layer名字挺高大上的,其實它就是計算FM中的二次項的過程,因此得到的向量維度就是我們的Embedding的維度。最終的結果是:

Hidden Layers就是我們的DNN部分,將Bi-Interaction Layer得到的結果接入多層的神經(jīng)網(wǎng)絡進行訓練,從而捕捉到特征之間復雜的非線性關系。

在進行多層訓練之后,將最后一層的輸出求和同時加上一次項和偏置項,就得到了我們的預測輸出:

是不是很簡單呢,哈哈。

3、代碼實戰(zhàn)

終于到了激動人心的代碼實戰(zhàn)環(huán)節(jié)了,本文的代碼有不對的的地方或者改進之處還望大家多多指正。

本文的github地址為:https://github.com/princewen/tensorflow_practice/tree/master/recommendation/Basic-NFM-Demo

本文的代碼根據(jù)之前DeepFM的代碼進行改進,我們只介紹模型的實現(xiàn)部分,其他數(shù)據(jù)處理的細節(jié)大家可以參考我的github上的代碼.

模型輸入

模型的輸入主要有下面幾個部分:

self.feat_index = tf.placeholder(tf.int32, shape=[None,None], name='feat_index') self.feat_value = tf.placeholder(tf.float32, shape=[None,None], name='feat_value') self.label = tf.placeholder(tf.float32,shape=[None,1],name='label') self.dropout_keep_deep = tf.placeholder(tf.float32,shape=[None],name='dropout_deep_deep')

feat_index是特征的一個序號,主要用于通過embedding_lookup選擇我們的embedding。feat_value是對應的特征值,如果是離散特征的話,就是1,如果不是離散特征的話,就保留原來的特征值。label是實際值。還定義了dropout來防止過擬合。

權重構建

權重主要分以下幾部分,偏置項,一次項權重,embeddings,以及DNN的權重

def _initialize_weights(self): weights = dict() #embeddings weights['feature_embeddings'] = tf.Variable( tf.random_normal([self.feature_size,self.embedding_size],0.0,0.01), name='feature_embeddings') weights['feature_bias'] = tf.Variable(tf.random_normal([self.feature_size,1],0.0,1.0),name='feature_bias') weights['bias'] = tf.Variable(tf.constant(0.1),name='bias') #deep layers num_layer = len(self.deep_layers) input_size = self.embedding_size glorot = np.sqrt(2.0/(input_size + self.deep_layers[0])) weights['layer_0'] = tf.Variable( np.random.normal(loc=0,scale=glorot,size=(input_size,self.deep_layers[0])),dtype=np.float32 ) weights['bias_0'] = tf.Variable( np.random.normal(loc=0,scale=glorot,size=(1,self.deep_layers[0])),dtype=np.float32 ) for i in range(1,num_layer): glorot = np.sqrt(2.0 / (self.deep_layers[i - 1] + self.deep_layers[i])) weights["layer_%d" % i] = tf.Variable( np.random.normal(loc=0, scale=glorot, size=(self.deep_layers[i - 1], self.deep_layers[i])), dtype=np.float32) # layers[i-1] * layers[i] weights["bias_%d" % i] = tf.Variable( np.random.normal(loc=0, scale=glorot, size=(1, self.deep_layers[i])), dtype=np.float32) # 1 * layer[i] return weights

Embedding Layer這個部分很簡單啦,是根據(jù)feat_index選擇對應的weights['feature_embeddings']中的embedding值,然后再與對應的feat_value相乘就可以了:

# Embeddings self.embeddings = tf.nn.embedding_lookup(self.weights['feature_embeddings'],self.feat_index) # N * F * K feat_value = tf.reshape(self.feat_value,shape=[-1,self.field_size,1]) self.embeddings = tf.multiply(self.embeddings,feat_value) # N * F * K

Bi-Interaction Layer我們直接根據(jù)化簡后的結果進行計算,得到一個K維的向量:

# sum-square-part self.summed_features_emb = tf.reduce_sum(self.embeddings, 1) # None * k self.summed_features_emb_square = tf.square(self.summed_features_emb) # None * K # squre-sum-part self.squared_features_emb = tf.square(self.embeddings) self.squared_sum_features_emb = tf.reduce_sum(self.squared_features_emb, 1) # None * K # second order self.y_second_order = 0.5 * tf.subtract(self.summed_features_emb_square, self.squared_sum_features_emb)

Deep Part將Bi-Interaction Layer層得到的結果經(jīng)過一個多層的神經(jīng)網(wǎng)絡,得到交互項的輸出:

self.y_deep = self.y_second_order for i in range(0, len(self.deep_layers)): self.y_deep = tf.add(tf.matmul(self.y_deep, self.weights["layer_%d" % i]), self.weights["bias_%d" % i]) self.y_deep = self.deep_layers_activation(self.y_deep) self.y_deep = tf.nn.dropout(self.y_deep, self.dropout_keep_deep[i + 1])

得到預測輸出為了得到預測輸出,我們還需要兩部分,分別是偏置項和一次項:

# first order term self.y_first_order = tf.nn.embedding_lookup(self.weights['feature_bias'], self.feat_index) self.y_first_order = tf.reduce_sum(tf.multiply(self.y_first_order, feat_value), 2) # bias self.y_bias = self.weights['bias'] * tf.ones_like(self.label)

而我們的最終輸出如下:

# out self.out = tf.add_n([tf.reduce_sum(self.y_first_order,axis=1,keep_dims=True), tf.reduce_sum(self.y_deep,axis=1,keep_dims=True), self.y_bias])

剩下的代碼就不介紹啦!好啦,本文只是提供一個引子,有關NFM的知識大家可以更多的進行學習呦。

4、小結

NFM模型將FM與神經(jīng)網(wǎng)絡結合以提升FM捕捉特征間多階交互信息的能力。根據(jù)論文中實驗結果,NFM的預測準確度相較FM有明顯提升,并且與現(xiàn)有的并行神經(jīng)網(wǎng)絡模型相比,復雜度更低。

NFM本質上還是基于FM,F(xiàn)M會讓一個特征固定一個特定的向量,當這個特征與其他特征做交叉時,都是用同樣的向量去做計算。這個是很不合理的,因為不同的特征之間的交叉,重要程度是不一樣的。因此,學者們提出了AFM模型(Attentional factorization machines),將attention機制加入到我們的模型中,關于AFM的知識,我們下一篇來一探究竟。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 神經(jīng)網(wǎng)絡

    關注

    42

    文章

    4722

    瀏覽量

    100308
  • dnn
    dnn
    +關注

    關注

    0

    文章

    59

    瀏覽量

    9024

原文標題:推薦系統(tǒng)遇上深度學習(七)--NFM模型理論和實踐

文章出處:【微信號:AI_shequ,微信公眾號:人工智能愛好者社區(qū)】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    【我是電子發(fā)燒友】如何加速DNN運算?

    深度神經(jīng)網(wǎng)絡DNN)目前是許多現(xiàn)代AI應用的基礎。自從DNN在語音識別和圖像識別任務中展現(xiàn)出突破性的成果,使用DNN的應用數(shù)量呈爆炸式增
    發(fā)表于 06-14 21:01

    神經(jīng)網(wǎng)絡DNN知識點總結

    DNN:關于神經(jīng)網(wǎng)絡DNN的知識點總結(持續(xù)更新)
    發(fā)表于 12-26 10:41

    什么是深度學習?使用FPGA進行深度學習的好處?

    FPGA實現(xiàn)。易于適應新的神經(jīng)網(wǎng)絡結構深度學習是一個非?;钴S的研究領域,每天都在設計新的 DNN。其中許多結合了現(xiàn)有的標準計算,但有些需要全新的計算
    發(fā)表于 02-17 16:56

    什么是DNN_如何使用硬件加速DNN運算

    深度神經(jīng)網(wǎng)絡DNN)目前是許多現(xiàn)代AI應用的基礎。自從DNN在語音識別和圖像識別任務中展現(xiàn)出突破性的成果,使用DNN的應用數(shù)量呈爆炸式增加
    的頭像 發(fā)表于 07-08 06:45 ?2.2w次閱讀
    什么是<b class='flag-5'>DNN</b>_如何使用硬件加速<b class='flag-5'>DNN</b>運算

    FM和FFM原理的探索和應用的經(jīng)驗

    FM和FFM模型是最近幾年提出的模型,憑借其在數(shù)據(jù)量比較大并且特征稀疏的情況下,仍然能夠得到優(yōu)秀的性能和效果的特性,屢次在各大公司舉辦的CTR預估比賽中獲得不錯的戰(zhàn)績。美團點評技術團隊在搭建DSP
    發(fā)表于 10-12 17:25 ?0次下載
    <b class='flag-5'>FM</b>和FFM原理的探索和應用的經(jīng)驗

    詳解DNN訓練中出現(xiàn)的問題與解決方法方法

    由于深度神經(jīng)網(wǎng)絡DNN)層數(shù)很多,每次訓練都是逐層由后至前傳遞。傳遞項1梯度非常大,以此修正網(wǎng)絡會不斷震蕩,無法形成一個收斂網(wǎng)絡。因而
    的頭像 發(fā)表于 12-25 14:34 ?7138次閱讀
    詳解<b class='flag-5'>DNN</b>訓練中出現(xiàn)的問題與解決<b class='flag-5'>方法方法</b>

    用于理解深度神經(jīng)網(wǎng)絡的CLass增強型注意響應(CLEAR)方法

    我們提出了CLass增強的注意響應(CLEAR):一種可視化和理解深度神經(jīng)網(wǎng)絡DNN)在給定特定輸入的情況下做出的決策的方法。
    的頭像 發(fā)表于 11-12 06:11 ?1939次閱讀

    回顧3年來的所有主流深度學習CTR模型

    微軟于2016年提出的Deep Crossing可以說是深度學習CTR模型的最典型和基礎性的模型。如圖2的模型結構圖所示,它涵蓋了深度CTR模型最典型的要素,即通過加入embeddin
    的頭像 發(fā)表于 07-18 14:33 ?6104次閱讀
    回顧3年來的所有<b class='flag-5'>主流</b><b class='flag-5'>深度</b>學習<b class='flag-5'>CTR</b>模型

    使用神經(jīng)網(wǎng)絡實現(xiàn)語音驅動發(fā)音器官運動合成方法詳細資料說明

    實現(xiàn)一種基于深度神經(jīng)網(wǎng)絡的語音驅動發(fā)音器官運動合成方法, 并應用于語音驅動虛擬說話人動畫合成。 通過
    發(fā)表于 12-05 15:53 ?15次下載
    使用神經(jīng)<b class='flag-5'>網(wǎng)絡</b>實現(xiàn)語音驅動發(fā)音器官運動<b class='flag-5'>合成方法</b>詳細資料說明

    基于注意力機制的深度興趣網(wǎng)絡點擊率模型

    廣告點擊率(CTR)是互聯(lián)網(wǎng)公司進行流量分配的重要依據(jù),針對目前點擊率預估精度較低的問題,結合通用的神經(jīng)網(wǎng)絡解決方案,構建一種基于注意力機制的深度
    發(fā)表于 03-12 10:55 ?5次下載
    基于注意力機制的<b class='flag-5'>深度</b>興趣<b class='flag-5'>網(wǎng)絡</b>點擊率模型

    綜述深度神經(jīng)網(wǎng)絡的解釋方法及發(fā)展趨勢

    深度神經(jīng)網(wǎng)絡具有非線性非凸、多層隱藏結構、特征矢量化、海量模型參數(shù)等特點,但弱解釋性是限制其理論發(fā)展和實際應用的巨大障礙,因此,深度神經(jīng)網(wǎng)絡解釋方法
    發(fā)表于 03-21 09:48 ?18次下載
    綜述<b class='flag-5'>深度</b>神經(jīng)<b class='flag-5'>網(wǎng)絡</b>的解釋<b class='flag-5'>方法</b>及發(fā)展趨勢

    淺析深度神經(jīng)網(wǎng)絡DNN)反向傳播算法(BP)

    深度神經(jīng)網(wǎng)絡DNN)模型與前向傳播算法 中,我們對DNN的模型和前向傳播算法做了總結,這里我們更進一步,對DNN的反向傳播算法(Bac
    的頭像 發(fā)表于 03-22 16:28 ?3569次閱讀
    淺析<b class='flag-5'>深度</b>神經(jīng)<b class='flag-5'>網(wǎng)絡</b>(<b class='flag-5'>DNN</b>)反向傳播算法(BP)

    基于深度神經(jīng)網(wǎng)絡的因果形式語音增強方法

    傳統(tǒng)的基于深度神經(jīng)網(wǎng)絡DNN)的語音增強方法由于采用非因果形式的輸入,在處理過程中具有固定延時,不適用于實時性要求較高的場合。針對這一問題,從網(wǎng)絡
    發(fā)表于 06-10 11:29 ?8次下載

    BP神經(jīng)網(wǎng)絡屬于DNN

    深度神經(jīng)網(wǎng)絡(Deep Neural Network,簡稱DNN)則是指具有多個隱藏層的神經(jīng)網(wǎng)絡,可以處理復雜的數(shù)據(jù)和任務。那么,BP神經(jīng)網(wǎng)絡
    的頭像 發(fā)表于 07-03 10:18 ?532次閱讀

    深度神經(jīng)網(wǎng)絡(DNN)架構解析與優(yōu)化策略

    深度神經(jīng)網(wǎng)絡(Deep Neural Network, DNN)作為機器學習領域中的一種重要技術,以其強大的特征學習能力和非線性建模能力,在多個領域取得了顯著成果。DNN的核心在于其多
    的頭像 發(fā)表于 07-09 11:00 ?1069次閱讀