tensorflow-1

outline

`安裝環(huán)境

`tensorflow原理簡(jiǎn)述

`定義網(wǎng)絡(luò)結(jié)構(gòu)、啟動(dòng)網(wǎng)絡(luò)計(jì)算

`使用Variable定義模型參數(shù),如何訓(xùn)練模型

`如何測(cè)試

只是自己的簡(jiǎn)要概括,最好對(duì)神經(jīng)網(wǎng)絡(luò)、機(jī)器學(xué)習(xí)略有了解。tensorflow的中文文檔新手入門真的做的還不錯(cuò),建議大家結(jié)合理論,碼一碼代碼,上手很快的。

`安裝環(huán)境

ubuntu 16.04,pycharm IDE、python 2.7

pycharm有教育賬戶的,學(xué)生可以免費(fèi)使用。IDE集成了terminal、python console,還能調(diào)試,真的好用。另外集成了virtual environment,可以切換使用python2.7、python3.x,有興趣的可以了解一下

#note

使用virtual environment的方法

file-new project-選擇解釋器的邊上有個(gè)設(shè)置可以創(chuàng)建虛擬環(huán)境,選擇相應(yīng)的解釋器就能創(chuàng)建,另外在這個(gè)project中的terminal會(huì)默認(rèn)使用這個(gè)虛擬環(huán)境,形如:

(tensorflow) ceo1207@ceo1207:

安裝tensorflow

pip install https://storage.googleapis.com/tensorflow/linux/cpu/tensorflow-0.5.0-cp27-none-linux_x86_64.whl

另外裝jupyter(就是常說(shuō)的python notebook)體驗(yàn)也很好,可以像python console中一樣交互式的編程,還能保存代碼

apt-get install python-dev

python -m pip install jupyter

使用時(shí),輸入 jupyter notebook 即可在瀏覽器中使用python

`tensorflow原理簡(jiǎn)述

(看不懂不要緊,看完下面的再來(lái)看一遍就會(huì)了)網(wǎng)絡(luò)結(jié)構(gòu)使用Graph表示,Graph由operation(節(jié)點(diǎn))組成,op接受輸入產(chǎn)生輸出,輸入輸出使用張量(tensor)表示,所以這個(gè)框架叫tensorflow,張量數(shù)據(jù)的流動(dòng)的意思。

定義graph不會(huì)產(chǎn)生計(jì)算,真正的計(jì)算使用Session(會(huì)話)驅(qū)動(dòng),可以使用會(huì)話傳入數(shù)據(jù),獲取輸入以及訓(xùn)練和測(cè)試網(wǎng)絡(luò)。

#note:計(jì)算優(yōu)化

為了用python實(shí)現(xiàn)高效的數(shù)值計(jì)算,我們通常會(huì)使用函數(shù)庫(kù),比如NumPy,會(huì)把類似矩陣乘法這樣的復(fù)雜運(yùn)算使用其他外部語(yǔ)言實(shí)現(xiàn)。不幸的是,從外部計(jì)算切換回Python的每一個(gè)操作,仍然是一個(gè)很大的開銷。如果你用GPU來(lái)進(jìn)行外部計(jì)算,這樣的開銷會(huì)更大。用分布式的計(jì)算方式,也會(huì)花費(fèi)更多的資源用來(lái)傳輸數(shù)據(jù)。

TensorFlow也把復(fù)雜的計(jì)算放在python之外完成,但是為了避免前面說(shuō)的那些開銷,它做了進(jìn)一步完善。Tensorflow不單獨(dú)地運(yùn)行單一的復(fù)雜計(jì)算,而是讓我們可以先用圖描述一系列可交互的計(jì)算操作,然后全部一起在Python之外運(yùn)行。

`定義網(wǎng)絡(luò)結(jié)構(gòu)、啟動(dòng)網(wǎng)絡(luò)計(jì)算

graph定義網(wǎng)絡(luò)結(jié)構(gòu),添加節(jié)點(diǎn)(計(jì)算單元)。但是graph只是定義結(jié)構(gòu)和數(shù)據(jù),真正的計(jì)算需要會(huì)話啟動(dòng)。

節(jié)點(diǎn)構(gòu)造器,接收輸入tensor,返回op的輸出。最簡(jiǎn)單的是常量節(jié)點(diǎn),可以作為整個(gè)網(wǎng)絡(luò)的輸入。也可以是一些計(jì)算操作,比如矩陣相加、相乘。直接上代碼,看看就明白了。

import numpy as np

import tensorflow as tf

# define input, create operation, result(tensor) return

input1 = tf.constant(3)

input2 = tf.constant(2)

input3 = tf.constant(5)

# define operations

add = tf.add(input3,input2)

mul = tf.mul(input1,add)

with tf.Session() as sess:

? ? # use the default graph

? ? result = sess.run([mul,add])

? ? print result

輸入也可以使用占位符,用于在會(huì)話時(shí),靈活的添加自定義的輸入。

import numpy as np

import tensorflow as tf

input1 = tf.placeholder(tf.types.float32)

input2 = tf.placeholder(tf.types.float32)

mul = tf.mul(input1, input2)

data1 = [1,2,3]

data2 = [2,4,6]

with tf.Session() as sess:

? ? print sess.run([mul], feed_dict={input1:data1,input2:data2})

關(guān)于數(shù)據(jù)的fetch和feed,上面兩段代碼都用到了其實(shí)。

Fetch,使用run獲取

with tf.Session():

? result = sess.run([mul, intermed])

? print result

需要獲取的多個(gè) tensor 值,在 op 的一次運(yùn)行中一起獲得(而不是逐個(gè)去獲取 tensor)

feed,在會(huì)話中插入數(shù)據(jù),使用placeholder

import numpy as np

import tensorflow as tf

input1 = tf.placeholder(tf.types.float32)

input2 = tf.placeholder(tf.types.float32)

mul = tf.mul(input1, input2)

data1 = [1,2,3]

data2 = [2,4,6]

with tf.Session() as sess:

? ? print sess.run([mul], feed_dict={input1:data1,input2:data2})

`使用Variable定義模型參數(shù)、如何訓(xùn)練模型

到這一步,請(qǐng)你確保具備以下能力,給你具體的公式和輸入,可以使用tensorflow,控制數(shù)據(jù)的輸入,利用會(huì)話驅(qū)動(dòng)運(yùn)算獲得最后的輸出,甚至是任意中間步驟的結(jié)果。

但是常用的神經(jīng)網(wǎng)絡(luò)、機(jī)器學(xué)習(xí)的模型都是有模型參數(shù)的,模型參數(shù)是需要訓(xùn)練的。參數(shù)如何輸入?當(dāng)然我們可以把它們當(dāng)做是另外的輸入(使用占位符),但TensorFlow有一個(gè)更好的方法來(lái)表示它們:Variable。

Variable你可以理解為一個(gè)可變的tensor,事后,框架會(huì)根據(jù)你設(shè)置的訓(xùn)練方法自動(dòng)更新他的值。

#note:

模型的多種輸入:常量、占位符、Variable

有了可變的tensor(Variable),如何訓(xùn)練他們?

看懂下面的部分,先了解一下什么是softmax regression

如下,regression解決的是分類問(wèn)題,對(duì)于多分類問(wèn)題,使用softmax層得到歸一化的多分類的概率分布。

概率分布:(這個(gè)詞,其實(shí)不容易解釋)多分類問(wèn)題下,一個(gè)隨機(jī)事件,在各個(gè)分類上的概率分布,就是所謂的概率分布。概率分布的特點(diǎn),各個(gè)分類的概率之和為1.

好吧,不了解你就硬著頭皮往下看吧,沒什么關(guān)系。

首先定義優(yōu)化的目標(biāo),即確定loss function。

多分類問(wèn)題采用交叉熵作為loss,形如:

cross_entropy = -tf.reduce_sum(y_*tf.log(y))

再確定優(yōu)化的方法,可以使用常用的梯度下降方法

train_step = tf.train.GradientDescentOptimizer(0.01).minimize(cross_entropy)

設(shè)置步長(zhǎng)為0.01,優(yōu)化目標(biāo)是cross_entropy

好了,可以看mnist的實(shí)戰(zhàn)代碼了,可以在tensorflow github上看,這里貼一下

"""A very simple MNIST classifier.

See extensive documentation at

https://www.tensorflow.org/get_started/mnist/beginners

"""

from __future__ import absolute_import

from __future__ import division

from __future__ import print_function

import argparse

import sys

from tensorflow.examples.tutorials.mnist import input_data

import tensorflow as tf

FLAGS = None

def main(_):

? # Import data

? mnist = input_data.read_data_sets(FLAGS.data_dir)

? # Create the model

? x = tf.placeholder(tf.float32, [None, 784])

? W = tf.Variable(tf.zeros([784, 10]))

? b = tf.Variable(tf.zeros([10]))

? y = tf.matmul(x, W) + b

? # Define loss and optimizer

? y_ = tf.placeholder(tf.int64, [None])

? # The raw formulation of cross-entropy,

? #

? #? tf.reduce_mean(-tf.reduce_sum(y_ * tf.log(tf.nn.softmax(y)),

? #? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? reduction_indices=[1]))

? #

? # can be numerically unstable.

? #

? # So here we use tf.losses.sparse_softmax_cross_entropy on the raw

? # outputs of 'y', and then average across the batch.

? cross_entropy = tf.losses.sparse_softmax_cross_entropy(labels=y_, logits=y)

? train_step = tf.train.GradientDescentOptimizer(0.5).minimize(cross_entropy)

? sess = tf.InteractiveSession()

? tf.global_variables_initializer().run()

? # Train

? for _ in range(1000):

? ? batch_xs, batch_ys = mnist.train.next_batch(100)

? ? sess.run(train_step, feed_dict={x: batch_xs, y_: batch_ys})

? # Test trained model

? correct_prediction = tf.equal(tf.argmax(y, 1), y_)

? accuracy = tf.reduce_mean(tf.cast(correct_prediction, tf.float32))

? print(sess.run(

? ? ? accuracy, feed_dict={

? ? ? ? ? x: mnist.test.images,

? ? ? ? ? y_: mnist.test.labels

? ? ? }))

if __name__ == '__main__':

? parser = argparse.ArgumentParser()

? parser.add_argument(

? ? ? '--data_dir',

? ? ? type=str,

? ? ? default='/tmp/tensorflow/mnist/input_data',

? ? ? help='Directory for storing input data')

? FLAGS, unparsed = parser.parse_known_args()

? tf.app.run(main=main, argv=[sys.argv[0]] + unparsed)

`如何測(cè)試

最后說(shuō)一下如何測(cè)試,其實(shí)上面的代碼以及中文文檔里已經(jīng)說(shuō)的蠻好了。

好吧,下一篇,深入mnist(讀作m-nist),明兒見

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,818評(píng)論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,185評(píng)論 3 414
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,656評(píng)論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,647評(píng)論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,446評(píng)論 6 405
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 54,951評(píng)論 1 321
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,041評(píng)論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,189評(píng)論 0 287
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,718評(píng)論 1 333
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,602評(píng)論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,800評(píng)論 1 369
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,316評(píng)論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,045評(píng)論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,419評(píng)論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,671評(píng)論 1 281
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,420評(píng)論 3 390
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,755評(píng)論 2 371

推薦閱讀更多精彩內(nèi)容