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

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

NAC的工作原理,以及它如何處理加法和減法等操作

Tensorflowers ? 來源:未知 ? 作者:李倩 ? 2018-10-10 11:34 ? 次閱讀

DeepMind 最近發(fā)布了一篇新的論文---《神經(jīng)算術(shù)邏輯單元(NALU)》(https://arxiv.org/abs/1808.00508),這是一篇很有趣的論文,它解決了深度學(xué)習(xí)中的一個重要問題,即教導(dǎo)神經(jīng)網(wǎng)絡(luò)計(jì)算。 令人驚訝的是,盡管神經(jīng)網(wǎng)絡(luò)已經(jīng)能夠在許多任務(wù),如肺癌分類中獲得卓絕表現(xiàn),卻往往在一些簡單任務(wù),像計(jì)算數(shù)字上苦苦掙扎。

在一個展示網(wǎng)絡(luò)如何努力從新數(shù)據(jù)中插入特征的實(shí)驗(yàn)中,我們的研究發(fā)現(xiàn),他們能夠用 -5 到 5 之間的數(shù)字將訓(xùn)練數(shù)據(jù)分類,準(zhǔn)確度近乎完美,但對于訓(xùn)練數(shù)據(jù)之外的數(shù)字,網(wǎng)絡(luò)幾乎無法歸納概括。

論文提供了一個解決方案,分成兩個部分。以下我將簡單介紹一下 NAC 的工作原理,以及它如何處理加法和減法等操作。之后,我會介紹 NALU,它可以處理更復(fù)雜的操作,如乘法和除法。 我提供了可以嘗試演示這些代碼的代碼,您可以閱讀上述的論文了解更多詳情。

第一神經(jīng)網(wǎng)絡(luò)(NAC)

神經(jīng)累加器(簡稱 NAC)是其輸入的一種線性變換。什么意思呢? 它是一個轉(zhuǎn)換矩陣,是 tanh(W_hat)和 sigmoid(M_hat)的元素乘積。 最后,轉(zhuǎn)換矩陣 W 乘以輸入(x)。

Python 中的 NAC

1import tensorflow as tf

2

3# NAC

4W_hat = tf.Variable(tf.truncated_normal(shape, stddev=0.02))

5M_hat = tf.Variable(tf.truncated_normal(shape, stddev=0.02))

6

7W = tf.tanh(W_hat) * tf.sigmoid(M_hat)

8# Forward propogation

9a = tf.matmul(in_dim, W)

NAC

第二神經(jīng)網(wǎng)絡(luò)(NALU)

神經(jīng)算術(shù)邏輯單元,或者我們簡稱之為 NALU,是由兩個 NAC 單元組成。 第一個 NAC g 等于 sigmoid(Gx)。 第二個 NAC 在一個等于 exp 的日志空間 m 中運(yùn)行 (W(log(|x| + epsilon)))

Python 中的 NALU

1import tensorflow as tf

2

3# NALU

4G = tf.Variable(tf.truncated_normal(shape, stddev=0.02))

5

6m = tf.exp(tf.matmul(tf.log(tf.abs(in_dim) + epsilon), W))

7

8g = tf.sigmoid(tf.matmul(in_dim, G))

9

10y = g * a + (1 - g) * m

NALU

通過學(xué)習(xí)添加來測試 NAC

現(xiàn)在讓我們進(jìn)行測試,首先將 NAC 轉(zhuǎn)換為函數(shù)。

1# Neural Accumulator

2def NAC(in_dim, out_dim):

3

4in_features = in_dim.shape[1]

5

6# define W_hat and M_hat

7W_hat = tf.get_variable(name = 'W_hat', initializer=tf.initializers.random_uniform(minval=-2, maxval=2),shape=[in_features, out_dim], trainable=True)

8M_hat = tf.get_variable(name = 'M_hat', initializer=tf.initializers.random_uniform(minval=-2, maxval=2), shape=[in_features, out_dim], trainable=True)

9

10W = tf.nn.tanh(W_hat) * tf.nn.sigmoid(M_hat)

11

12a = tf.matmul(in_dim, W)

13

14return a, W

NAC function in Python

Python 中的 NAC 功能

接下來,讓我們創(chuàng)建一些玩具數(shù)據(jù),用于訓(xùn)練和測試數(shù)據(jù)。 NumPy 有一個名為 numpy.arrange 的優(yōu)秀 API,我們將利用它來創(chuàng)建數(shù)據(jù)集。

1# Generate a series of input number X1 and X2 for training

2x1 = np.arange(0,10000,5, dtype=np.float32)

3x2 = np.arange(5,10005,5, dtype=np.float32)

4

5

6y_train = x1 + x2

7

8x_train = np.column_stack((x1,x2))

9

10print(x_train.shape)

11print(y_train.shape)

12

13# Generate a series of input number X1 and X2 for testing

14x1 = np.arange(1000,2000,8, dtype=np.float32)

15x2 = np.arange(1000,1500,4, dtype= np.float32)

16

17x_test = np.column_stack((x1,x2))

18y_test = x1 + x2

19

20print()

21print(x_test.shape)

22print(y_test.shape)

添加玩具數(shù)據(jù)

現(xiàn)在,我們可以定義樣板代碼來訓(xùn)練模型。 我們首先定義占位符 X 和 Y,用以在運(yùn)行時提供數(shù)據(jù)。 接下來我們定義的是 NAC 網(wǎng)絡(luò)(y_pred,W = NAC(in_dim = X,out_dim = 1))。 對于損失,我們使用 tf.reduce_sum()。 我們將有兩個超參數(shù),alpha,即學(xué)習(xí)率和我們想要訓(xùn)練網(wǎng)絡(luò)的時期數(shù)。在運(yùn)行訓(xùn)練循環(huán)之前,我們需要定義一個優(yōu)化器,這樣我們就可以使用 tf.train.AdamOptimizer() 來減少損失。

1# Define the placeholder to feed the value at run time

2X = tf.placeholder(dtype=tf.float32, shape =[None , 2]) # Number of samples x Number of features (number of inputs to be added)

3Y = tf.placeholder(dtype=tf.float32, shape=[None,])

4

5# define the network

6# Here the network contains only one NAC cell (for testing)

7y_pred, W = NAC(in_dim=X, out_dim=1)

8y_pred = tf.squeeze(y_pred)# Remove extra dimensions if any

9

10# Mean Square Error (MSE)

11loss = tf.reduce_mean( (y_pred - Y) **2)

12

13

14# training parameters

15alpha = 0.05 # learning rate

16epochs = 22000

17

18optimize = tf.train.AdamOptimizer(learning_rate=alpha).minimize(loss)

19

20with tf.Session() as sess:

21

22#init = tf.global_variables_initializer()

23cost_history = []

24

25sess.run(tf.global_variables_initializer())

26

27# pre training evaluate

28print("Pre training MSE: ", sess.run (loss, feed_dict={X: x_test, Y:y_test}))

29print()

30for i in range(epochs):

31_, cost = sess.run([optimize, loss ], feed_dict={X:x_train, Y: y_train})

32print("epoch: {}, MSE: {}".format( i,cost) )

33cost_history.append(cost)

34

35# plot the MSE over each iteration

36plt.plot(np.arange(epochs),np.log(cost_history)) # Plot MSE on log scale

37plt.xlabel("Epoch")

38plt.ylabel("MSE")

39plt.show()

40

41print()

42print(W.eval())

43print()

44# post training loss

45print("Post training MSE: ", sess.run(loss, feed_dict={X: x_test, Y: y_test}))

46

47print("Actual sum: ", y_test[0:10])

48print()

49print("Predicted sum: ", sess.run(y_pred[0:10], feed_dict={X: x_test, Y: y_test}))

訓(xùn)練之后,成本圖的樣子:

NAC 訓(xùn)練之后的成本

Actual sum: [2000. 2012. 2024. 2036. 2048. 2060. 2072. 2084. 2096. 2108.]Predicted sum: [1999.9021 2011.9015 2023.9009 2035.9004 2047.8997 2059.8992 2071.8984 2083.898 2095.8975 2107.8967]

雖然 NAC 可以處理諸如加法和減法之類的操作,但是它無法處理乘法和除法。 于是,就有了 NALU 的用武之地。它能夠處理更復(fù)雜的操作,例如乘法和除法。

通過學(xué)習(xí)乘法來測試 NALU

為此,我們將添加片段以使 NAC 成為 NALU。

神經(jīng)累加器(NAC)是其輸入的線性變換。神經(jīng)算術(shù)邏輯單元(NALU)使用兩個帶有綁定的權(quán)重的 NACs 來啟用加法或者減法(較小的紫色單元)和乘法/除法(較大的紫色單元),由一個門(橙色單元)來控制。

1# The Neural Arithmetic Logic Unit

2def NALU(in_dim, out_dim):

3

4shape = (int(in_dim.shape[-1]), out_dim)

5epsilon = 1e-7

6

7# NAC

8W_hat = tf.Variable(tf.truncated_normal(shape, stddev=0.02))

9M_hat = tf.Variable(tf.truncated_normal(shape, stddev=0.02))

10G = tf.Variable(tf.truncated_normal(shape, stddev=0.02))

11

12W = tf.tanh(W_hat) * tf.sigmoid(M_hat)

13# Forward propogation

14a = tf.matmul(in_dim, W)

15

16# NALU

17m = tf.exp(tf.matmul(tf.log(tf.abs(in_dim) + epsilon), W))

18g = tf.sigmoid(tf.matmul(in_dim, G))

19y = g * a + (1 - g) * m

20

21return y

Python 中的 NALU 函數(shù)

現(xiàn)在,再次創(chuàng)建一些玩具數(shù)據(jù),這次我們將進(jìn)行兩行更改。

1# Test the Network by learning the multiplication

2

3# Generate a series of input number X1 and X2 for training

4x1 = np.arange(0,10000,5, dtype=np.float32)

5x2 = np.arange(5,10005,5, dtype=np.float32)

6

7

8y_train = x1 * x2

9

10x_train = np.column_stack((x1,x2))

11

12print(x_train.shape)

13print(y_train.shape)

14

15# Generate a series of input number X1 and X2 for testing

16x1 = np.arange(1000,2000,8, dtype=np.float32)

17x2 = np.arange(1000,1500,4, dtype= np.float32)

18

19x_test = np.column_stack((x1,x2))

20y_test = x1 * x2

21

22print()

23print(x_test.shape)

24print(y_test.shape)

用于乘法的玩具數(shù)據(jù)

第 8 行和第 20 行是進(jìn)行更改的地方,將加法運(yùn)算符切換為乘法。

現(xiàn)在我們可以訓(xùn)練的是 NALU 網(wǎng)絡(luò)。 我們唯一需要更改的地方是定義 NAC 網(wǎng)絡(luò)改成 NALU(y_pred = NALU(in_dim = X,out_dim = 1))。

1# Define the placeholder to feed the value at run time

2X = tf.placeholder(dtype=tf.float32, shape =[None , 2]) # Number of samples x Number of features (number of inputs to be added)

3Y = tf.placeholder(dtype=tf.float32, shape=[None,])

4

5# Define the network

6# Here the network contains only one NAC cell (for testing)

7y_pred = NALU(in_dim=X, out_dim=1)

8y_pred = tf.squeeze(y_pred) # Remove extra dimensions if any

9

10# Mean Square Error (MSE)

11loss = tf.reduce_mean( (y_pred - Y) **2)

12

13

14# training parameters

15alpha = 0.05 # learning rate

16epochs = 22000

17

18optimize = tf.train.AdamOptimizer(learning_rate=alpha).minimize(loss)

19

20with tf.Session() as sess:

21

22#init = tf.global_variables_initializer()

23cost_history = []

24

25sess.run(tf.global_variables_initializer())

26

27# pre training evaluate

28print("Pre training MSE: ", sess.run (loss, feed_dict={X: x_test, Y: y_test}))

29print()

30for i in range(epochs):

31_, cost = sess.run([optimize, loss ], feed_dict={X: x_train, Y: y_train})

32print("epoch: {}, MSE: {}".format( i,cost) )

33cost_history.append(cost)

34

35# Plot the loss over each iteration

36plt.plot(np.arange(epochs),np.log(cost_history)) # Plot MSE on log scale

37plt.xlabel("Epoch")

38plt.ylabel("MSE")

39plt.show()

40

41

42# post training loss

43print("Post training MSE: ", sess.run(loss, feed_dict={X: x_test, Y: y_test}))

44

45print("Actual product: ", y_test[0:10])

46print()

47print("Predicted product: ", sess.run(y_pred[0:10], feed_dict={X: x_test, Y: y_test}))

NALU 訓(xùn)練后的成本

Actual product: [1000000. 1012032. 1024128. 1036288. 1048512. 1060800. 1073152. 1085568. 1098048. 1110592.]Predicted product: [1000000.2 1012032. 1024127.56 1036288.6 1048512.06 1060800.8 1073151.6 1085567.6 1098047.6 1110592.8 ]

在 TensorFlow 中全面實(shí)現(xiàn)

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

原文標(biāo)題:想理解神經(jīng)算術(shù)邏輯單元嗎?

文章出處:【微信號:tensorflowers,微信公眾號:Tensorflowers】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    數(shù)字電路中加法器和減法器邏輯圖分析

    多位二進(jìn)制減法器,是由加法電路構(gòu)成的;在加法電路的基礎(chǔ)上,減法加法采用同一套電路,實(shí)現(xiàn)加減法
    發(fā)表于 09-01 16:02 ?2.3w次閱讀
    數(shù)字電路中<b class='flag-5'>加法</b>器和<b class='flag-5'>減法</b>器邏輯圖分析

    減法器電路與原理 減法器電路圖分享

    減法器是一種電路,它可以實(shí)現(xiàn)二進(jìn)制數(shù)字的減法運(yùn)算。減法器的工作原理基于位運(yùn)算和進(jìn)位/借位機(jī)制。
    的頭像 發(fā)表于 02-19 09:36 ?8275次閱讀
    <b class='flag-5'>減法</b>器電路與原理 <b class='flag-5'>減法</b>器電路圖分享

    4位帶進(jìn)位的加法+減法計(jì)算器

    前段時間動手做了個小項(xiàng)目,跟大家分享一下!可實(shí)現(xiàn)4位帶進(jìn)位加法/減法計(jì)算。目前負(fù)值無法顯示,只顯示負(fù)數(shù)絕對值。對實(shí)例1中的顯示部分有優(yōu)化。目前已實(shí)現(xiàn)計(jì)算器功能,但程序有待優(yōu)化。遙控板測試說明(紅外):—:表示減法+: 表示
    發(fā)表于 01-20 17:15

    LUT用作加法器或減法

    嗨,我正在盡可能使用壓縮邏輯來執(zhí)行加法減法。我有兩個8位數(shù)據(jù),我想有時添加或有時減去這兩個數(shù)字。看起來像是Elelment有一個叫做“CYINIT”的輸入,根據(jù)的值,它可以執(zhí)行
    發(fā)表于 03-28 06:07

    減法運(yùn)算

    減法運(yùn)算   同加法運(yùn)算一樣,減法運(yùn)算可采用減法器來實(shí)現(xiàn)。半減器和全減器的設(shè)計(jì)方法和步驟與設(shè)計(jì)加法器相同。實(shí)用上,為了簡化系統(tǒng)結(jié)構(gòu),通常不
    發(fā)表于 04-07 10:38 ?1.3w次閱讀
    <b class='flag-5'>減法</b>運(yùn)算

    十進(jìn)制加法器,十進(jìn)制加法工作原理是什么?

    十進(jìn)制加法器,十進(jìn)制加法工作原理是什么?   十進(jìn)制加法器可由BCD碼(二-十進(jìn)制碼)來設(shè)計(jì),它可以在二進(jìn)制加法器的基礎(chǔ)上加上適當(dāng)?shù)摹?/div>
    發(fā)表于 04-13 10:58 ?1.4w次閱讀

    本的二進(jìn)制加法/減法器,本的二進(jìn)制加法/減法器原理

    本的二進(jìn)制加法/減法器,本的二進(jìn)制加法/減法器原理   兩個二進(jìn)制數(shù)字Ai,Bi和一個進(jìn)位輸入Ci相加,產(chǎn)生一個和輸出Si,以及一個進(jìn)位
    發(fā)表于 04-13 11:11 ?5272次閱讀

    補(bǔ)碼減法,補(bǔ)碼減法原理是什么?

    補(bǔ)碼減法,補(bǔ)碼減法原理是什么?    負(fù)數(shù)的減法運(yùn)算也要設(shè)法化為加法來做,其所以使用這種方法而不使用直接減法,是因?yàn)樗梢院统R?guī)的
    發(fā)表于 04-13 11:45 ?6837次閱讀

    8位加法器和減法器設(shè)計(jì)實(shí)習(xí)報告

    8位加法器和減法器設(shè)計(jì)實(shí)習(xí)報告
    發(fā)表于 09-04 14:53 ?134次下載

    加法器與減法器_反相加法器與同相加法

    加法器是產(chǎn)生數(shù)的和的裝置。加數(shù)和被加數(shù)為輸入,和數(shù)與進(jìn)位為輸出的裝置為半加器。減法電路是基本集成運(yùn)放電路的一種,減法電路可以由反相加法電路構(gòu)成,也可以由差分電路構(gòu)成。基本集成運(yùn)放電路有
    發(fā)表于 08-16 11:09 ?16.7w次閱讀
    <b class='flag-5'>加法</b>器與<b class='flag-5'>減法</b>器_反相<b class='flag-5'>加法</b>器與同相<b class='flag-5'>加法</b>器

    加法減法運(yùn)算電路性能特點(diǎn)及值計(jì)算方法

    4.1.3加法減法運(yùn)算電路
    的頭像 發(fā)表于 04-18 06:03 ?1.6w次閱讀
    <b class='flag-5'>加法</b>和<b class='flag-5'>減法</b>運(yùn)算電路性能特點(diǎn)及值計(jì)算方法

    指針的加法操作

    指針的加法操作我們見過很多,但是減法操作遇到的好像很少。
    的頭像 發(fā)表于 03-29 10:12 ?627次閱讀

    fpga實(shí)現(xiàn)加法減法運(yùn)算的方法是什么

    FPGA實(shí)現(xiàn)加法減法運(yùn)算非常簡單,實(shí)現(xiàn)乘法和除法可以用IP,那實(shí)現(xiàn)對數(shù)和指數(shù)運(yùn)算該用什么呢?
    發(fā)表于 08-05 09:37 ?1472次閱讀
    fpga實(shí)現(xiàn)<b class='flag-5'>加法</b>和<b class='flag-5'>減法</b>運(yùn)算的方法是什么

    什么是串?dāng)_?該如何處理

    什么是串?dāng)_?該如何處理?
    的頭像 發(fā)表于 12-05 16:39 ?865次閱讀
    什么是串?dāng)_?該如<b class='flag-5'>何處理</b><b class='flag-5'>它</b>?

    PLC的工作原理、組成以及應(yīng)用

    和監(jiān)控。本文將詳細(xì)介紹PLC的工作原理、組成以及應(yīng)用。 一、PLC的工作原理 輸入處理 PLC的輸入處理是指將外部信號(如傳感器信號、開關(guān)信
    的頭像 發(fā)表于 07-01 09:38 ?4285次閱讀