Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tillbeemelmanns/tfops-aug
TFOps-Aug: Implementation of policy-based image augmentation techniques based on TF2 Operations. All augmentations as efficient Tensorflow 2.11.0 operations. Easy integration into a tf.data API pipeline.
https://github.com/tillbeemelmanns/tfops-aug
augmentation-libraries augmentation-methods augmentation-operation augmentation-policy google-autoaugment keras tf2
Last synced: 3 months ago
JSON representation
TFOps-Aug: Implementation of policy-based image augmentation techniques based on TF2 Operations. All augmentations as efficient Tensorflow 2.11.0 operations. Easy integration into a tf.data API pipeline.
- Host: GitHub
- URL: https://github.com/tillbeemelmanns/tfops-aug
- Owner: TillBeemelmanns
- License: mit
- Created: 2020-04-20T20:26:33.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2022-12-12T18:58:04.000Z (about 2 years ago)
- Last Synced: 2024-11-15T03:44:44.244Z (3 months ago)
- Topics: augmentation-libraries, augmentation-methods, augmentation-operation, augmentation-policy, google-autoaugment, keras, tf2
- Language: Python
- Homepage:
- Size: 55.2 MB
- Stars: 14
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# TFOps-Aug: Implementation of policy-based image augmentation techniques based on TF2 Operations
The principle for the augmentation mechanism of __TFOps-Aug__ relies on Google's AutoAugment paper "Learning
Augmentation Policies from Data" [1]. This repository implements the augmentation policy logic and many of the
augmentation functions. Like in the original implementation, the augmentation procedure is defined as a policy,
which consists of several subpolicies and operations.
The augmentation operations rely on Tensorflow 2 operations which allow scalability and high computational throughput
even with large images. Furthermore, the augmentation pipeline can be easily integrated into the `tf.data` API, because
all operations rely on Tensorflow operations and can be execute on image representations of type `tf.Tensor`. Currently,
only image representations of type `tf.uint8` are supported.### Installation
The package is available on [pypi.org](https://pypi.org/project/tfops-aug/) and can be installed with `pip`:```bash
pip install tfops-aug
```### Example for an augmentation policy
```python
policy = {'sub_policy0': {'op0': ['adjust_saturation', 0.2, 2],
'op1': ['equalize', 0.1, 6],
'op2': ['add_noise', 0.9, 6]},
'sub_policy1': {'op0': ['adjust_contrast', 0.1, 7],
'op1': ['add_noise', 0.0, 10]},
'sub_policy2': {'op0': ['posterize', 0.9, 6],
'op1': ['unbiased_gamma_sampling', 0.5, 1]},
'sub_policy3': {'op0': ['adjust_brightness', 0.3, 1],
'op1': ['adjust_hue', 0.4, 5]},
'sub_policy4': {'op0': ['adjust_saturation', 0.2, 9],
'op1': ['add_noise', 0.1, 0]},
'sub_policy5': {'op0': ['adjust_contrast', 1.0, 1],
'op1': ['unbiased_gamma_sampling', 0.4, 9]},
'sub_policy6': {'op0': ['unbiased_gamma_sampling', 0.3, 0],
'op1': ['adjust_hue', 0.1, 6]},
'sub_policy7': {'op0': ['solarize', 0.6, 0],
'op1': ['adjust_gamma', 0.3, 6]},
'sub_policy8': {'op0': ['adjust_jpeg_quality', 0.7, 10],
'op1': ['adjust_hue', 0.1, 2]},
'sub_policy9': {'op0': ['equalize', 0.6, 0],
'op1': ['solarize', 0.0, 6]}}
```Similar to Google's AutoAugment, a single augmentation policy consists of several subpolicies, which in turn consists of
one or more augmentation operation. Each operation is defined as a tuple of **augmentation method**,
**probability** and **intensity**. Several operations within one subpolicy are applied in sequence.
The augmentation policy from above would augment the [original image](assets/test_image.jpg) to the following output:
data:image/s3,"s3://crabby-images/dcb4b/dcb4b8ae9cffa7ace5155f495c052b74e261c1fb" alt=""### Usage
A full example script for image classification can be found in [classification_example.py](utils/classification_example.py).
This excerpt demonstrates the simplicity for the usage of the augmentation methods:
```python
import tensorflow as tffrom tfops_aug.augmentation_utils import apply_augmentation_policy
def augmentor_func(img, label):
img = apply_augmentation_policy(img, policy)
return img, labeltrain_dataset = tf.keras.preprocessing.image_dataset_from_directory(
"PetImages",
subset="training",
image_size=(180, 180),
batch_size=1
).unbatch()train_dataset = train_dataset.map(augmentor_func).batch(32).prefetch(32)
```### Augmentation Methods
A list of all implemented augmentation techniques is given here. Additional, methods will be implemented in the near
future. Performance is measured with the `test_image.jpg` which has size `2048 x 1024`. All augmentation methods are
executed with `level=5`. Averaged over 500 samples on the Intel Core i7 Prozessor 8665U.| Augmentation | Image | Performance (per Image) |
|----------|:-------------|:-----------------------:|
| Additive Gaussian Noise | data:image/s3,"s3://crabby-images/45816/45816c33d48e3887915bc3cf9e3a66900154d5d3" alt="" | 0.02 s |
| Adjust Brightness | data:image/s3,"s3://crabby-images/4d29a/4d29ac000d9e53e0534ed36e1b9364762f9f9214" alt="" | 0.01 s |
| Adjust Contrast | data:image/s3,"s3://crabby-images/58eda/58edabd381ac5538812a438a251bf7b2ec8b8480" alt="" | 0.02 s |
| Adjust Gamma | data:image/s3,"s3://crabby-images/b9740/b97408b73e4a1a31947c767503932575ee0b476c" alt="" | 0.02 s |
| Adjust Hue | data:image/s3,"s3://crabby-images/88bf6/88bf6f42db5d1d9df849ad2cb5d6235bb991c670" alt="" | 0.01 s |
| Adjust JPEG Quality | data:image/s3,"s3://crabby-images/59284/5928407b4745c0dda636deac1650edfcae3fceb9" alt="" | 0.035 s |
| Adjust Saturation | data:image/s3,"s3://crabby-images/3b85d/3b85de7d91fd84568ae1cfa610e113df1b9fc85f" alt="" | 0.02 s |
| Histogramm Equalization | data:image/s3,"s3://crabby-images/37253/37253f8bd424e7b8c151b7bcee9d35c0a34620f0" alt="" | 0.04 s |
| Invert | data:image/s3,"s3://crabby-images/7d8da/7d8dad48b041c0b3abc661d8290b59eb2d3b16bd" alt="" | 0.01 s |
| Posterize | data:image/s3,"s3://crabby-images/2aa28/2aa289ca9e0996b0a019268f447246af896100fe" alt="" | 0.02 s |
| Solarize | data:image/s3,"s3://crabby-images/a9e49/a9e495e495d523156fe28826a7f82f03a82520c8" alt="" | 0.01 s |
| Unbiased Gamma Sampling | data:image/s3,"s3://crabby-images/625c4/625c47d11c49c548509ce4ee9d7b0d7f62648a44" alt="" | 0.02 s |
| Gaussian Blur | data:image/s3,"s3://crabby-images/2876b/2876b8564f1ac9e94c4c130e3576ce93df14692c" alt="" | 0.14 s |
| Sharpen | data:image/s3,"s3://crabby-images/7b3b8/7b3b85f3f1c5bbd838a2c327b50cd3d50db0ab36" alt="" | 0.05 s |
| Shear X | data:image/s3,"s3://crabby-images/6ab6c/6ab6c4db7e887fb01ea290dea532a8b48480eb8d" alt="" | 0.04 s |
| Shear Y | data:image/s3,"s3://crabby-images/56c11/56c11434549377e3cfd346ef95f46e904950452d" alt="" | 0.04 s |
| Translate X | data:image/s3,"s3://crabby-images/766f9/766f96cedbfa62cef1e1a551b8d5abb55fa62f42" alt="" | 0.05 s |
| Translate Y | data:image/s3,"s3://crabby-images/0ea3e/0ea3e34f433f67a10c3b37a20a127e0a33212f3a" alt="" | 0.05 s |### Reference
```
[1] AutoAugment: Learning Augmentation Policies from Data - 2019
Ekin Dogus Cubuk and Barret Zoph and Dandelion Mane and Vijay Vasudevan and Quoc V. Le
https://arxiv.org/pdf/1805.09501.pdf
```### TODO
- [ ] More Augmentation Methods
- [X] Shear X
- [X] Shear Y
- [X] Translate X
- [X] Translate Y
- [ ] Random Translation
- [ ] Random Rotation
- [ ] Make augmentation min and max values configurable
- [X] Implement Learning Pipeline
- [ ] Implement augmentation policies identical to these in [1]
- [ ] Implement augmentation policy search with Ray Tune
- [ ] Clean up Code (Unified Docstrings)
- [X] Create Python package
- [ ] Support image representation types, other than `uint8`