改進版的fashion-mnist DCGAN

在loss函數(shù)寫法上做改進,代碼更簡單贬墩;

import tensorflow as tf
from tensorflow.keras.datasets.fashion_mnist import load_data
from tensorflow.keras.models import Sequential
from tensorflow.keras.layers import Dense,Reshape,Conv2DTranspose,Conv2D,MaxPool2D,Flatten,BatchNormalization
import numpy as np
import matplotlib.pyplot as plt

(train_x,train_y),(test_x,test_y) = load_data()
train_x = train_x[:150]/255
x_real,y_real = zip(*zip(train_x,np.ones(train_x.shape[0])))

g = Sequential([Dense(4*4*128,input_shape=(10,)),
                Reshape((4,4,128)),
                Conv2DTranspose(64,(4,4),padding="valid",activation="relu"),
                BatchNormalization(),
                Conv2DTranspose(32,(2,2),strides=(2, 2),padding="same",activation="relu"),
                BatchNormalization(),
                Conv2DTranspose(1, (2,2),strides=(2, 2),padding="same",activation="tanh"),
                Reshape((28,28))])

d = Sequential([Reshape((28,28,1),input_shape=(28,28)),
                Conv2D(32,(2,2),padding="same",activation="relu"),
                MaxPool2D((2,2)),
                Conv2D(64,(2,2),padding="same",activation="relu"),
                MaxPool2D((2,2)),
                Conv2D(64,(2,2),padding="valid",activation="relu"),
                MaxPool2D((2,2)),
                Flatten(),
                Dense(1,activation="sigmoid")])
gan = Sequential([g,d])
d.compile(optimizer="adam",loss="binary_crossentropy",metrics=['accuracy'])

for i in range(50):
    print(f"===============判別器第{i+1}輪訓(xùn)練================")
    d.trainable = True
    x_fake,y_fake = zip(*zip(g(tf.random.uniform((train_x.shape[0],10),1,0)),np.zeros(train_x.shape[0])))
    x = x_real + x_fake
    y = y_real + y_fake
    dataset = tf.data.Dataset.from_tensor_slices((np.array(x),np.array(y))).shuffle(150).batch(20)
    d.fit(dataset,epochs=2)
    
    print(f"===============生成器第{i+1}輪訓(xùn)練================")
    d.trainable = False
    gan.compile(optimizer="adam",loss="binary_crossentropy")
    x = tf.random.uniform((100,10),1,0)
    y = 1-d(g(x))
    gan.fit(x,y,epochs=50)

img = g(tf.random.uniform((1,10),1,0))[0]
plt.imshow(img)
plt.show()

訓(xùn)練20個來回,能看到可識別的效果妄呕。
可以調(diào)節(jié)加載數(shù)據(jù)量陶舞,當(dāng)然越多越慢!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末绪励,一起剝皮案震驚了整個濱河市肿孵,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌疏魏,老刑警劉巖停做,帶你破解...
    沈念sama閱讀 212,029評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異大莫,居然都是意外死亡雅宾,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,395評論 3 385
  • 文/潘曉璐 我一進店門葵硕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來眉抬,“玉大人,你說我怎么就攤上這事懈凹∈癖洌” “怎么了?”我有些...
    開封第一講書人閱讀 157,570評論 0 348
  • 文/不壞的土叔 我叫張陵介评,是天一觀的道長库北。 經(jīng)常有香客問我,道長们陆,這世上最難降的妖魔是什么寒瓦? 我笑而不...
    開封第一講書人閱讀 56,535評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮坪仇,結(jié)果婚禮上杂腰,老公的妹妹穿的比我還像新娘。我一直安慰自己椅文,他們只是感情好喂很,可當(dāng)我...
    茶點故事閱讀 65,650評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著皆刺,像睡著了一般少辣。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上羡蛾,一...
    開封第一講書人閱讀 49,850評論 1 290
  • 那天漓帅,我揣著相機與錄音,去河邊找鬼。 笑死忙干,一個胖子當(dāng)著我的面吹牛屯伞,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播豪直,決...
    沈念sama閱讀 39,006評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼劣摇,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了弓乙?” 一聲冷哼從身側(cè)響起末融,我...
    開封第一講書人閱讀 37,747評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎暇韧,沒想到半個月后勾习,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,207評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡懈玻,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,536評論 2 327
  • 正文 我和宋清朗相戀三年巧婶,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片涂乌。...
    茶點故事閱讀 38,683評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡艺栈,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出湾盒,到底是詐尸還是另有隱情湿右,我是刑警寧澤,帶...
    沈念sama閱讀 34,342評論 4 330
  • 正文 年R本政府宣布罚勾,位于F島的核電站毅人,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏尖殃。R本人自食惡果不足惜丈莺,卻給世界環(huán)境...
    茶點故事閱讀 39,964評論 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望送丰。 院中可真熱鬧缔俄,春花似錦、人聲如沸蚪战。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,772評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽邀桑。三九已至,卻和暖如春科乎,著一層夾襖步出監(jiān)牢的瞬間壁畸,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,004評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留捏萍,地道東北人太抓。 一個月前我還...
    沈念sama閱讀 46,401評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像令杈,于是被迫代替她去往敵國和親走敌。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,566評論 2 349

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

  • 漸變的面目拼圖要我怎么拼捶障? 我是疲乏了還是投降了? 不是不允許自己墜落纲刀, 我沒有滴水不進的保護膜项炼。 就是害怕變得面...
    悶熱當(dāng)乘涼閱讀 4,238評論 0 13
  • 夜鶯2517閱讀 127,717評論 1 9
  • 版本:ios 1.2.1 亮點: 1.app角標(biāo)可以實時更新天氣溫度或選擇空氣質(zhì)量,建議處女座就不要選了示绊,不然老想...
    我就是沉沉閱讀 6,884評論 1 6
  • 我是一名過去式的高三狗锭部,很可悲,在這三年里我沒有戀愛面褐,看著同齡的小伙伴們一對兒一對兒的空免,我的心不好受。怎么說呢盆耽,高...
    小娘紙閱讀 3,384評論 4 7
  • 那一年蹋砚,我選擇了獨立遠行,火車帶著我在前進的軌道上爬行了超過23個小時摄杂; 那一年杏慰,我走過泥濘的柏油路,在那個遠離故...
    木芽閱讀 1,630評論 4 5