Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/saravanabalagi/imaugtools
Tools used for aspect-ratio-preserving image augmentation, namely translate, rotate, crop WITHOUT stretching or skewing the image, or padding pixels to fill up empty space.
https://github.com/saravanabalagi/imaugtools
image-augmentation image-cropping image-processing image-processing-library image-rotation image-translation
Last synced: 4 months ago
JSON representation
Tools used for aspect-ratio-preserving image augmentation, namely translate, rotate, crop WITHOUT stretching or skewing the image, or padding pixels to fill up empty space.
- Host: GitHub
- URL: https://github.com/saravanabalagi/imaugtools
- Owner: saravanabalagi
- License: mit
- Created: 2019-10-16T10:51:13.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2020-06-02T12:24:42.000Z (over 4 years ago)
- Last Synced: 2024-10-04T21:24:12.599Z (5 months ago)
- Topics: image-augmentation, image-cropping, image-processing, image-processing-library, image-rotation, image-translation
- Language: Jupyter Notebook
- Homepage: https://pypi.org/project/imaugtools
- Size: 2.15 MB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# imaugtools
data:image/s3,"s3://crabby-images/bf94a/bf94abe9ac02af712cf078f80da1da04791aa2a4" alt=""
data:image/s3,"s3://crabby-images/1c4dd/1c4dd528d4e9dc346af4347b7dcc4378a8b76b52" alt=""
data:image/s3,"s3://crabby-images/98f91/98f91b8a57f078b63857ac452d1d4b40407af745" alt=""
data:image/s3,"s3://crabby-images/8ad52/8ad52f0f04ab9ecf3ae74fbfc5d6a6e7f48fa161" alt=""imaugtools contains tools used for image augmentation: translate, rotate, crop. This library is for you if you do NOT want to stretch or skew, or pad pixels that would make your images look strange when doing any of these operations.
## Installation
To install imaugtools, simply run in your terminal
```sh
pip install imaugtools
```## Usage
Example image
data:image/s3,"s3://crabby-images/a5b3d/a5b3d12ce2e3d6dffb8de8853e016c499316dcd4" alt="example-image"
### Translation
```py
from imaugtools import translate_image
my_image_translated = translate_image(my_image, 0.1, 0.2)
my_image_translated_uncropped = translate_image(my_image, 0.1, 0.2, crop=False)
imshow(my_image_translated, my_image_translated_uncropped, mode='BGR')
```
`imshow` function used here is to simply display the images, you can use it from [imshowtools](https://github.com/saravanabalagi/imshowtools) library.With and without crop:
data:image/s3,"s3://crabby-images/e86d8/e86d8ce5959c56304c516f67e95ae1b5e8a86db8" alt="translated-image"
### Rotation
```py
from imaugtools import rotate_image
my_image_rotated = rotate_image(my_image, 30) # angle in degrees
my_image_rotated_uncropped = rotate_image(my_image, 30, crop=False)
imshow(my_image_rotated, my_image_rotated_uncropped, mode='BGR')
```
With and without crop:data:image/s3,"s3://crabby-images/818c2/818c2f82a49bf1dd4d92091263a734563ed87bc6" alt="rotated-image"
### Cropping
```py
from imaugtools import center_crop, crop_around_center
my_image_center_cropped = center_crop(my_image, (150, 200))
my_image_cropped_around_center = crop_around_center(my_image, (150, 200))
imshow(my_image_center_cropped, my_image_cropped_around_center, mode='BGR')
```Aspect ratio preserving center crop and crop around center:
data:image/s3,"s3://crabby-images/cce44/cce44567e12a03be27522d1e3db87f97287c0578" alt="cropped-image"
```py
print(my_image_center_cropped.shape, my_image_cropped_around_center.shape)
# Output: (150, 200, 3) (150, 200, 3)
```## Advanced Usage
### Strided Translation
Strided translation is one of the powerful image augmentation techniques used in training neural networks.
`tx_max = 1` and `ty_max = 1` is equivalent to a stride of 1 in both directions. After you specify `tx_max`, you can specify `tx` (translation in x-axis) from -`tx_max` to +`tx_max`. The same applies to `ty` and `ty_max`.
```py
my_images_translated = []
for j in range(-1, 2):
for i in range(-1, 2):
my_images_translated.append(translate_image(my_image, i, j, tx_max=1, ty_max=1))
imshow(*my_images_translated, mode='BGR')
```
data:image/s3,"s3://crabby-images/6cf2a/6cf2a1b672e3ee1da92d96bab043a7a4580157ea" alt="stride-1-translation"`tx_max = 0.5` and `ty_max = 0.5` is equivalent to a stride of 0.5 in both directions
```py
my_images_translated = []
for j in range(-2, 3):
for i in range(-2, 3):
my_images_translated.append(translate_image(my_image, i/4, j/4, tx_max=0.5, ty_max=0.5))
imshow(*my_images_translated, mode='BGR')
```
data:image/s3,"s3://crabby-images/f2b8b/f2b8bf866f9f891f2bc4eaa173e4e2fcecbeef26" alt="stride-0.5-translation"## Contributing
Pull requests are very welcome.
1. Fork the repo
1. Create new branch with feature name as branch name
1. Check if things work with a jupyter notebook
1. Raise a pull request## Licence
Please see attached [Licence](https://github.com/saravanabalagi/imaugtools/blob/master/LICENSE)