圖像數(shù)據(jù)增強

一蝇庭、做隨機亮度、對比度、飽和度修改秉继,使用tensorflow API
核心部分是 aug_op 函數(shù)祈噪,這可是菜鳥的心血啊尚辑!

#coding:utf-8
import tensorflow as tf
import cv2
import random
import sys
import os
import shutil

#os.environ["CUDA_VISIBLE_DEVICES"] = ""

def random_normal(img, mean=0.0, stddev=2.0, limit=6):
    img = tf.cast(img, dtype=tf.int32)# This type cast is very important.
    noise = tf.random_normal(tf.shape(img), mean, stddev)
    noise = tf.cast(noise, dtype=tf.int32)# This type cast is very important. For negative value.
    up_limit = tf.where(tf.less_equal(noise, limit), tf.ones_like(noise, dtype=tf.uint8), tf.zeros_like(noise, dtype=tf.uint8))
    down_limit = tf.where(tf.greater_equal(noise, 0-limit), tf.ones_like(noise, dtype=tf.uint8), tf.zeros_like(noise, dtype=tf.uint8))
    up_limit = tf.cast(up_limit, dtype=tf.int32)
    down_limit = tf.cast(down_limit, dtype=tf.int32)

    noise = (up_limit*down_limit)*noise
    new_img = tf.add(img, noise)
    new_img = tf.cast(img, dtype=tf.uint8)
    return new_img

def aug_op(img):
    new_img = img
    cnt = 0

    a = tf.constant([0,1],dtype=tf.int32)
    b = tf.random_shuffle(a)
    cnt = tf.constant([0], dtype=tf.int32)

    new_img, cnt = tf.cond(b[0]>0, lambda: (tf.image.random_brightness(new_img, 0.3), cnt+1), lambda: (new_img,cnt))
    new_img, cnt = tf.cond(b[0]>0, lambda: (tf.image.random_contrast(new_img, 0.5, 2), cnt+1), lambda: (new_img,cnt))
    new_img, cnt = tf.cond(b[0]>0, lambda: (tf.image.random_saturation(new_img, 0.3, 2), cnt+1) , lambda: (new_img,cnt))
    new_img, cnt = tf.cond(b[0]>0, lambda: (random_normal(new_img), cnt+1), lambda: (new_img,cnt+1))

    return new_img, cnt

if __name__ == "__main__":
    
    src_dir = sys.argv[1]
    src_landmark_dir = sys.argv[2]
    dst_dir = sys.argv[3]
    dst_landmark_dir = sys.argv[4]
    loop_times = 5

    if not os.path.exists(src_dir):
        print("{} not exists,exit.".format(src_dir))
    if not os.path.exists(src_landmark_dir):
        print("{} not exists,exit.".format(src_landmark_dir))
    if not os.path.exists(dst_dir):
        os.makedirs(dst_dir)
    if not os.path.exists(dst_landmark_dir):
        os.makedirs(dst_landmark_dir)
    
    sess = tf.Session()

    input_image = tf.placeholder(tf.uint8, shape=[None, None, 3], name="input_image")
    op, cnt_op = aug_op(input_image)

    src_names = os.listdir(src_dir)
    cnt = 0
    total_cnt = len(src_names)
    new_cnt = 0
    for name in src_names:
        
        img = cv2.imread(os.path.join(src_dir, name))
        if img is None:
            print("Image:{} read none, skip".format(os.path.join(src_dir, name)))
            continue

        pre, ext = os.path.splitext(name)
        pts_name = pre+".pts"
        
        for i in range(loop_times):

            new_name = pre+"_"+str(i)+ext
            new_pts_name = pre+"_"+str(i)+".pts"

            new_img,  isaug= sess.run([op,cnt_op], feed_dict={input_image:img})
            print(isaug)
            if isaug == 0:
                continue

            cv2.imwrite(os.path.join(dst_dir, new_name), new_img)
            shutil.copy(os.path.join(src_landmark_dir, pts_name), os.path.join(dst_landmark_dir, new_pts_name))
            new_cnt = new_cnt + 1
        cnt = cnt + 1
        print("progress: {}/{}, new image:{}".format(cnt, total_cnt, new_cnt))
    

    #python img_aug.py /home/hongjie.li/FaceAlign/dataset-landmark/20181018-1000-camera /home/hongjie.li/FaceAlign/dataset-landmark/landmark_all /home/hongjie.li/FaceAlign/dataset-landmark/20181018-1000-camera-aug /home/hongjie.li/FaceAlign/dataset-landmark/20181018-1000-camera-aug-landmark
 
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末辑鲤,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子杠茬,更是在濱河造成了極大的恐慌月褥,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件瓢喉,死亡現(xiàn)場離奇詭異宁赤,居然都是意外死亡,警方通過查閱死者的電腦和手機栓票,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進店門决左,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人走贪,你說我怎么就攤上這事佛猛。” “怎么了坠狡?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵继找,是天一觀的道長。 經(jīng)常有香客問我擦秽,道長码荔,這世上最難降的妖魔是什么漩勤? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任感挥,我火速辦了婚禮,結(jié)果婚禮上越败,老公的妹妹穿的比我還像新娘触幼。我一直安慰自己,他們只是感情好究飞,可當我...
    茶點故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布置谦。 她就那樣靜靜地躺著,像睡著了一般亿傅。 火紅的嫁衣襯著肌膚如雪媒峡。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天葵擎,我揣著相機與錄音谅阿,去河邊找鬼。 笑死,一個胖子當著我的面吹牛签餐,可吹牛的內(nèi)容都是我干的寓涨。 我是一名探鬼主播,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼氯檐,長吁一口氣:“原來是場噩夢啊……” “哼戒良!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起冠摄,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤糯崎,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后河泳,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體拇颅,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年乔询,在試婚紗的時候發(fā)現(xiàn)自己被綠了樟插。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡竿刁,死狀恐怖黄锤,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情食拜,我是刑警寧澤鸵熟,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站负甸,受9級特大地震影響流强,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜呻待,卻給世界環(huán)境...
    茶點故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一打月、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蚕捉,春花似錦奏篙、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至敛熬,卻和暖如春肺稀,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背应民。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工话原, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留炸茧,地道東北人。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓稿静,卻偏偏與公主長得像梭冠,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子改备,可洞房花燭夜當晚...
    茶點故事閱讀 44,619評論 2 354

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

  • 與 TensorFlow 的初次相遇 https://jorditorres.org/wp-content/upl...
    布客飛龍閱讀 3,948評論 2 89
  • 最近一直在思考這個問題控漠,而且自己也有往這方面走的傾向,所以就整理出身邊的小故事來給自己提到警示的作用吧 第一個故事...
    漁翁123閱讀 532評論 0 1
  • 銘記一份來自別人的幫助悬钳,不關(guān)乎大事還是小事盐捷,當然小事才最最不能忘記去感謝!你以為的只是嘴嘴說說的嗎默勾,比如改天請你吃...
    蘑菇樂閱讀 183評論 0 0
  • 每天2張碉渡,今天感覺不錯
    熱愛侶行閱讀 107評論 0 0
  • 這兩天因為天氣原因一直在休息,與其說休息不如說煎熬母剥,煎自己虛度光陰熬自己無所事事滞诺。沒有什么規(guī)劃的每一天,今天一定能...
    待解救的傻子閱讀 222評論 0 0