iOS 圖片風格轉換(CoreML)

1. 前言

??圖片風格轉換最早進入人們的視野,估計就是Prisma這款來自俄羅斯的網紅App。他利用神經網絡(多層卷積神經網絡)將圖片轉換成為特定風格藝術照片。利用圖片風格轉換算法,我們可以將一個圖片放入以及訓練好的神經網絡模型進行預測結果得到風格迥異,獨具特色的圖片。隨著iOS11蘋果推出了CoreML,我們可以很輕松將訓練好的這些風格轉換模型轉換成為蘋果的CoreML Model,并使用這個模型來進行圖片風格轉換。

圖片風格轉換 @Prisma

2. 圖片風格轉換算法介紹

??2015年,德國科學家 Gatys等人發表一篇名為《A Neural Algorithm of Artistic Style》的論文,打開了神經網絡在圖像藝術創作的大門。作者利用VGG16模型對一張原圖(Content Image)和一張風格圖(Style Image)分別進行圖像特征提取。通過利用對兩種特征構造損失函數,對一張初始化圖片進行損失值計算并反饋重繪圖像得到生成圖(Generated Image)。但是這個算法每一次生成一張圖片都需要進行一次網絡訓練,需要耗費的時間比較長。斯坦福大學的Johnson[6]等人提出了快速風格轉移算法,訓練一個網絡,對于任意一張圖片都可以轉換成為網絡對應的風格。快速轉移算法包含兩個網絡。一個為圖片轉換網絡(Image Transform Network),一個為損失網絡(Loss Network)。在訓練階段利用大量圖片用兩個網絡進行訓練得到模型,在輸出階段套用模型將結果進行輸出得到生成圖。他們得出的網絡相對Gatys的模型得到生成圖的速度快上三個數量級。我們在iPhone上進行圖片風格轉換的時候可以使用Johnson的方法快速的生成風格圖片,當然使用Gatys的方式也是可以的,但是在生成圖片的時候會消耗更多的時候。

快速風格遷移算法

??上圖即是快速風格遷移算法的整體結構圖,該算法包括圖片轉換網絡和損失計算網絡。其中圖片轉換網絡是一個多層卷積神經網絡,它將一張輸入的原始圖片轉換成為一張生成圖片。損失計算網絡是一個VGG-16網絡,用于計算圖片轉換網絡生成圖片對于我們輸入的風格圖和原圖之間的損失大小。通過計算生成圖與原圖的內容損失以及生成圖與風格圖的風格損失大小來判斷生成圖的質量。通過不斷計算來減少損失,反向傳播到圖片轉換網絡并對其進行優化,最終得到合格的圖片風格轉換模型。而這個模型就可以被我們不斷用來進行圖片到具體某一風格的轉換。

3. CoreML介紹

??CoreML 是 Apple 今年 WWDC 新推出面向開發者的機器學習框架。如果我們有一個MLModel我們可以容易的利用Model進行結果的預測,所有的MLModel都會有以下結構。


MLModel結構

??一般一個MLModel文件會包括MLInput,MLModel,MLOutput三部分,我們將數據封裝成為Input并交付給MLModel,模型會進行結果預測并輸出預測結果Output,我們再將預測的結果轉換成為我們需要的數據類型。

4. 代碼實現

??CoreML對圖片的處理都需要將圖片轉換成為CVPixelBufferRef數據,這里提供一段UIImageCVPixelBufferRef的代碼。

CVPixelBufferRef轉換代碼

??將圖片轉換成為CVPixelBufferRef之后放入模型進行處理生成Output并得到結果,結果也是一個CVPixelBufferRef的數據。

Output

??所以這里我們還需要將CVPixelBufferRef轉回去UIImage,具體的實現代碼如下:

image.png

更多具體的代碼見項目。

5. 細節優化

5.1 合成圖生成效果轉換

有時候我們會覺得合成圖片的效果并不如意,如下面的示例圖1跟2,我們可以看到2已經跟1差異非常的大了,一定程度上我會覺得風格過度了。這個時候我們可以通過調整合成圖的效果來換取整體構圖的完整性,比如說圖3的風格只有50%。我們可以看到圖3成像會更加具體而又有獨特風味。此外還可以通過調整對比度,顏色飽和度來調整構圖,這里就需要根據圖片消耗更多的時間了。


示例圖 @Fzliu
5.2 合成圖顏色轉換

圖片風格轉換在我看來有一點是獨特但是也是致命的,那就是顏色的遷移。我么可以看到在示例圖2中,合成圖是使用梵高的星空轉換出來的圖片,整體圖片紋理以及顏色進行了變化。這個時候如果我們希望保留原圖的顏色而未知合成圖的紋理,就可以使用YUV顏色空間進行轉換。


示例圖2

YUV是圖片的一種數據格式,YUV中的“Y”表示圖片的明亮程度;“U”代表色度,也稱為飽和度;“V”代表濃度。從YUV的示例圖我們可以很清楚的看到他們的具體含義。


YUV示例

在這里我們可以看到其中U以及V可以很好代表圖片的顏色,而Y代表了圖片的大部分內容。因此我們可以移植原圖的U以及V到合成圖上,就可以得到示例圖2中的顏色轉換合成圖了。

6. 運行環境

  • Mac OS 10.12.6
  • Xcode 9 beta 6
  • Python 3.1
  • Tensorflow 1.0
  • Keras 2
  • Coremltools 0.4.0

7. Demo

這里我將現有的風格轉換模型集合在一起寫了一個風格轉換Demo,具體可以見截圖:

shoot1.jpeg
shoot2.jpeg
shoot3.jpeg
shoot4.jpeg
shoot5.jpeg
shoot6.jpeg

Demo地址:https://github.com/kingandyoga/StyleTransfer-iOS

8. 參考文獻

  • [1]. Ethan Chan and Rishabh Bhargava. Show, Divide and Neural: Weighted Style Transfer[D]. Stanford University,2016
  • [2]. Leon A. Gatys, Alexander S. Ecker,Matthias Bethge. A Neural Algorithm of Artistic Style[D]. Germany,2015
  • [3]. Justin Johnson, Alexandre Alahi, Li Fei-Fei. Perceptual Losses for Real-Time Style Transfer and Super-Resolution[D]. Stanford University,2016
  • [4]. Leon A.Gatys, Matthias Bethge, Aaron Hertzmann, Eli Shechtman.Preserving Color in Neural Artistic Style Transfer[D].Germany,2016
  • [5]. Apple Core ML documentation (https://developer.apple.com/documentation/coreml)
  • [6]. Style Transfer Sample(https://github.com/fzliu/style-transfer)
  • [7]. MLModelZoo
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,443評論 6 532
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,530評論 3 416
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,407評論 0 375
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,981評論 1 312
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,759評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,204評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,263評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,415評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,955評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,782評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,983評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,528評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,222評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,650評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,892評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,675評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,967評論 2 374

推薦閱讀更多精彩內容