Skip to content
Snippets Groups Projects
augment.py 4.56 KiB
Newer Older
tomrink's avatar
tomrink committed
from functools import partial

import tensorflow as tf


tomrink's avatar
tomrink committed
def augment_image():
tomrink's avatar
tomrink committed
    """ Helper function used for augmentation of images in the dataset.
      Returns:
        tf.data.Dataset mappable function for image augmentation
    """

tomrink's avatar
tomrink committed
    def augment_fn(data, label, *args, **kwargs):
tomrink's avatar
tomrink committed
        # Augmenting data (~ 80%)
tomrink's avatar
tomrink committed

tomrink's avatar
tomrink committed
        def augment_steps_fn(data, label):
tomrink's avatar
tomrink committed
            # Randomly rotating image (~50%)
tomrink's avatar
tomrink committed
            def rotate_fn(data, label):
tomrink's avatar
tomrink committed
                times = tf.random.uniform(minval=1, maxval=4, dtype=tf.int32, shape=[])
tomrink's avatar
tomrink committed
                return (tf.image.rot90(data, times),
                        tf.image.rot90(label, times))
tomrink's avatar
tomrink committed

tomrink's avatar
tomrink committed
            data, label = tf.cond(
tomrink's avatar
tomrink committed
                tf.less_equal(tf.random.uniform([]), 0.5),
tomrink's avatar
tomrink committed
                lambda: rotate_fn(data, label),
                lambda: (data, label))
tomrink's avatar
tomrink committed

            # Randomly flipping image (~50%)
tomrink's avatar
tomrink committed
            def flip_fn(data, label):
                return (tf.image.flip_left_right(data),
                        tf.image.flip_left_right(label))
tomrink's avatar
tomrink committed

tomrink's avatar
tomrink committed
            data, label = tf.cond(
tomrink's avatar
tomrink committed
                tf.less_equal(tf.random.uniform([]), 0.5),
tomrink's avatar
tomrink committed
                lambda: flip_fn(data, label),
                lambda: (data, label))
tomrink's avatar
tomrink committed

tomrink's avatar
tomrink committed
            return data, label
tomrink's avatar
tomrink committed

        # Randomly returning unchanged data (~20%)
        return tf.cond(
            tf.less_equal(tf.random.uniform([]), 0.2),
tomrink's avatar
tomrink committed
            lambda: (data, label),
            partial(augment_steps_fn, data, label))
tomrink's avatar
tomrink committed

    return augment_fn
tomrink's avatar
tomrink committed


tomrink's avatar
tomrink committed
def augment_icing():
tomrink's avatar
tomrink committed
    """ Helper function used for augmentation of images in the dataset.
      Returns:
        tf.data.Dataset mappable function for image augmentation
    """

    def augment_fn(data, data_b, label, *args, **kwargs):
        # Augmenting data (~ 80%)

        def augment_steps_fn(data, data_b, label):
            # Randomly rotating image (~50%)
            def rotate_fn(data, data_b, label):
                times = tf.random.uniform(minval=1, maxval=4, dtype=tf.int32, shape=[])
                return (tf.image.rot90(data, times),
tomrink's avatar
tomrink committed
                        data_b,
                        label)
tomrink's avatar
tomrink committed

            data, data_b, label = tf.cond(
                tf.less_equal(tf.random.uniform([]), 0.5),
                lambda: rotate_fn(data, data_b, label),
                lambda: (data, data_b, label))

            # Randomly flipping image (~50%)
            def flip_fn(data, data_b, label):
                return (tf.image.flip_left_right(data),
tomrink's avatar
tomrink committed
                        data_b,
                        label)
tomrink's avatar
tomrink committed

            data, data_b, label = tf.cond(
                tf.less_equal(tf.random.uniform([]), 0.5),
                lambda: flip_fn(data, data_b, label),
                lambda: (data, data_b, label))

            return data, data_b, label

        # Randomly returning unchanged data (~20%)
        return tf.cond(
            tf.less_equal(tf.random.uniform([]), 0.2),
            lambda: (data, data_b, label),
            partial(augment_steps_fn, data, data_b, label))

    return augment_fn
tomrink's avatar
tomrink committed


def augment_image_3arg():
    """ Helper function used for augmentation of images in the dataset.
      Returns:
        tf.data.Dataset mappable function for image augmentation
    """

    def augment_fn(data, data_b, label, *args, **kwargs):
        # Augmenting data (~ 80%)

        def augment_steps_fn(data, data_b, label):
            # Randomly rotating image (~50%)
            def rotate_fn(data, data_b, label):
                times = tf.random.uniform(minval=1, maxval=4, dtype=tf.int32, shape=[])
                return (tf.image.rot90(data, times),
                        tf.image.rot90(data_b, times),
                        tf.image.rot90(label, times))

            data, data_b, label = tf.cond(
                tf.less_equal(tf.random.uniform([]), 0.5),
                lambda: rotate_fn(data, data_b, label),
                lambda: (data, data_b, label))

            # Randomly flipping image (~50%)
            def flip_fn(data, data_b, label):
                return (tf.image.flip_left_right(data),
                        tf.image.flip_left_right(data_b),
                        tf.image.flip_left_right(label))

            data, data_b, label = tf.cond(
                tf.less_equal(tf.random.uniform([]), 0.5),
                lambda: flip_fn(data, data_b, label),
                lambda: (data, data_b, label))

            return data, data_b, label

        # Randomly returning unchanged data (~20%)
        return tf.cond(
            tf.less_equal(tf.random.uniform([]), 0.2),
            lambda: (data, data_b, label),
            partial(augment_steps_fn, data, data_b, label))

    return augment_fn