利用Keras實(shí)現(xiàn)FGSM算法

改正了利用Keras實(shí)現(xiàn)FGSM算法里的一些錯(cuò)誤,并添加了一些注釋

import numpy as np
from keras import backend, losses

def FGSM(model, image, y_true, eps=0.1):
    # image 是 cv2 或者 plt 讀取的圖像
    y_pred = model.output
    # y_true: 目標(biāo)真實(shí)值的張量。
    # y_pred: 目標(biāo)預(yù)測值的張量。
    loss = losses.categorical_crossentropy(y_true, y_pred)
    gradient = backend.gradients(loss, model.input)
    gradient = gradient[0]

    adv = image + backend.sign(gradient) * eps
    # fgsm算法.整個(gè)程序最重要的其實(shí)就只有這一行

    sess = backend.get_session()

    adv = sess.run(adv, feed_dict={model.input: np.array([image])})
    # 注意這里傳遞參數(shù)的情況
    adv = np.clip(adv, 0, 1)
    # np.clip(adv, 0, 255) #看自己情況選擇 1 或者 255 
    # 有的像素點(diǎn)會(huì)超過255卖局,需要處理
    return adv

def FGSM_attack(model,img,img_number, eps=0.2):#epsilons=20):
    print("如果幫助到了你,點(diǎn)個(gè)贊可以嗎辈灼?")
    # fgsm攻擊 函數(shù)調(diào)用
    # 下面部分代碼(圖像處理)需要根據(jù)自己的攻擊圖像的實(shí)際情況進(jìn)行修改
    # # 加載準(zhǔn)備攻擊的模型甫匹,對要攻擊的圖形進(jìn)行轉(zhuǎn)換
    lpr_model = model
    
    img_convert=img

    ret_predict = lpr_model.predict_classes(np.array([img_convert]))  # 進(jìn)行預(yù)測
    # 獲取預(yù)測結(jié)果的one-hot編碼,在攻擊時(shí)需要用到
    # 是為了求得上一個(gè)函數(shù)中的 y_true
    # for example: if you use the keras to predict the MNIST,
    # then the shape of label will be (N,)
    # every label can be 0,...,9
    # The shape of one-hot will be (N,10)
    # one-hot[1]=[0., 1., 0., ..., 0., 0., 0.]
    label = np.zeros([1, 10])
    label[:,img_number]=1

    # print("開始使用FGSM進(jìn)行攻擊")
    # 計(jì)算eps的值蓝牲,這里是N等分
    # epsilons = np.linspace(0, 1, num=epsilons + 1)[1:]
    # 使用循環(huán)來逐漸增加攻擊的強(qiáng)度
    img_attack = FGSM(lpr_model, img_convert, label, eps=eps)
    attack_label = lpr_model.predict_classes(img_attack)
    if attack_label[0] != ret_predict[0]:
        print('攻擊成功趟脂,前為:',ret_predict,', 后為:', attack_label)
    else:
        print('攻擊失敗')
    return img_attack
    # 返回對抗樣本(圖像) 

使用時(shí)直接調(diào)用 FGSM_attack 函數(shù)就可以得到圖像了

GOOD LUCK

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市例衍,隨后出現(xiàn)的幾起案子昔期,更是在濱河造成了極大的恐慌已卸,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,427評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件镇眷,死亡現(xiàn)場離奇詭異咬最,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)欠动,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評論 3 395
  • 文/潘曉璐 我一進(jìn)店門永乌,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人具伍,你說我怎么就攤上這事翅雏。” “怎么了人芽?”我有些...
    開封第一講書人閱讀 165,747評論 0 356
  • 文/不壞的土叔 我叫張陵望几,是天一觀的道長。 經(jīng)常有香客問我萤厅,道長橄抹,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,939評論 1 295
  • 正文 為了忘掉前任惕味,我火速辦了婚禮楼誓,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘名挥。我一直安慰自己疟羹,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,955評論 6 392
  • 文/花漫 我一把揭開白布禀倔。 她就那樣靜靜地躺著榄融,像睡著了一般。 火紅的嫁衣襯著肌膚如雪救湖。 梳的紋絲不亂的頭發(fā)上愧杯,一...
    開封第一講書人閱讀 51,737評論 1 305
  • 那天,我揣著相機(jī)與錄音鞋既,去河邊找鬼民效。 笑死,一個(gè)胖子當(dāng)著我的面吹牛涛救,可吹牛的內(nèi)容都是我干的畏邢。 我是一名探鬼主播,決...
    沈念sama閱讀 40,448評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼检吆,長吁一口氣:“原來是場噩夢啊……” “哼舒萎!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起蹭沛,我...
    開封第一講書人閱讀 39,352評論 0 276
  • 序言:老撾萬榮一對情侶失蹤臂寝,失蹤者是張志新(化名)和其女友劉穎章鲤,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體咆贬,經(jīng)...
    沈念sama閱讀 45,834評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡败徊,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,992評論 3 338
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了掏缎。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片皱蹦。...
    茶點(diǎn)故事閱讀 40,133評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖眷蜈,靈堂內(nèi)的尸體忽然破棺而出沪哺,到底是詐尸還是另有隱情,我是刑警寧澤酌儒,帶...
    沈念sama閱讀 35,815評論 5 346
  • 正文 年R本政府宣布辜妓,位于F島的核電站,受9級特大地震影響忌怎,放射性物質(zhì)發(fā)生泄漏籍滴。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,477評論 3 331
  • 文/蒙蒙 一榴啸、第九天 我趴在偏房一處隱蔽的房頂上張望孽惰。 院中可真熱鬧,春花似錦插掂、人聲如沸灰瞻。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至燎竖,卻和暖如春璃弄,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背构回。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評論 1 272
  • 我被黑心中介騙來泰國打工夏块, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人纤掸。 一個(gè)月前我還...
    沈念sama閱讀 48,398評論 3 373
  • 正文 我出身青樓脐供,卻偏偏與公主長得像,于是被迫代替她去往敵國和親借跪。 傳聞我的和親對象是個(gè)殘疾皇子政己,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,077評論 2 355