GitXplorerGitXplorer
f

AugLy

public
4941 stars
298 forks
25 issues

Commits

List of commits on branch main.
Unverified
7a2741fc0dcbc17bb3c13ce6f1cd8cea88c59f48

Convert .pyre_configuration.local to fast by default architecture] [batch:90/3047] [shard:2/N]

committed 2 days ago
Unverified
95fd1392a2f1a0b2425bc2d7d8b6f7d7bed1de66

removing base_module] fbcode/aml/augly/tests/audio_tests/TARGETS

committed 10 days ago
Unverified
1b461042b8ab4f28b7f370f87928cf41d19661fe

removing base_module] fbcode/aml/augly/tests/video_tests/TARGETS

committed a month ago
Unverified
eb75f8666dbcfd5e9cb6863b2384f6a0829ae794

upgrade pyre version in `fbcode/aml` - batch 1

committed 6 months ago
Unverified
6eac73534cf441d309639aae2d76842dce6e66ce

Pyre Configurationless migration for] [batch:14/244]

cconnernilsen committed 6 months ago
Unverified
0117fbe64b9d7d070ce970e652e972203b5b08d9

apply Black 2024 style in fbcode (11/16)

aamyreese committed 7 months ago

README

The README file for this repository.

logo


AugLy is a data augmentations library that currently supports four modalities (audio, image, text & video) and over 100 augmentations. Each modality’s augmentations are contained within its own sub-library. These sub-libraries include both function-based and class-based transforms, composition operators, and have the option to provide metadata about the transform applied, including its intensity.

AugLy is a great library to utilize for augmenting your data in model training, or to evaluate the robustness gaps of your model! We designed AugLy to include many specific data augmentations that users perform in real life on internet platforms like Facebook's -- for example making an image into a meme, overlaying text/emojis on images/videos, reposting a screenshot from social media. While AugLy contains more generic data augmentations as well, it will be particularly useful to you if you're working on a problem like copy detection, hate speech detection, or copyright infringement where these "internet user" types of data augmentations are prevalent.

Visual

To see more examples of augmentations, open the Colab notebooks in the README for each modality! (e.g. image README & Colab)

The library is Python-based and requires at least Python 3.6, as we use dataclasses.

Authors

Joanna Bitton — Software Engineer at Meta AI

Zoe Papakipos — Software Engineer at Meta AI

Installation

AugLy is a Python 3.6+ library. It can be installed with:

pip install augly[all]

If you want to only install the dependencies needed for one sub-library e.g. audio, you can install like so:

pip install augly[audio]

Or clone AugLy if you want to be able to run our unit tests, contribute a pull request, etc:

git clone git@github.com:facebookresearch/AugLy.git && cd AugLy
[Optional, but recommended] conda create -n augly && conda activate augly && conda install pip
pip install -e .[all]

Backwards compatibility note: In versions augly<=0.2.1 we did not separate the dependencies by modality. For those versions to install most dependencies you could use pip install augly, and if you want to use the audio or video modalities you would install with pip install augly[av].

In some environments, pip doesn't install python-magic as expected. In that case, you will need to additionally run:

conda install -c conda-forge python-magic

Or if you aren't using conda:

sudo apt-get install python3-magic

Documentation

Check out our documentation on ReadtheDocs!

For more details about how to use each sub-library, how to run the tests, and links to colab notebooks with runnable examples, please see the READMEs in each respective directory (audio, image, text, & video).

Assets

We provide various media assets to use with some of our augmentations. These assets include:

  1. Emojis (Twemoji) - Copyright 2020 Twitter, Inc and other contributors. Code licensed under the MIT License. Graphics licensed under CC-BY 4.0.
  2. Fonts (Noto fonts) - Noto is a trademark of Google Inc. Noto fonts are open source. All Noto fonts are published under the SIL Open Font License, Version 1.1.
  3. Screenshot Templates - Images created by a designer at Facebook specifically to use with AugLy. You can use these with the overlay_onto_screenshot augmentation in both the image and video libraries to make it look like your source image/video was screenshotted in a social media feed similar to Facebook or Instagram.

Links

  1. Facebook AI blog post: https://ai.facebook.com/blog/augly-a-new-data-augmentation-library-to-help-build-more-robust-ai-models/
  2. PyPi package: https://pypi.org/project/augly/
  3. Arxiv paper: https://arxiv.org/abs/2201.06494
  4. Examples: https://github.com/facebookresearch/AugLy/tree/main/examples

Uses of AugLy in the wild

  1. Image Similarity Challenge - a NeurIPS 2021 competition run by Facebook AI with $200k in prizes, currently open for sign ups; also produced the DISC21 dataset, which will be made publicly available after the challenge concludes!
  2. DeepFake Detection Challenge - a Kaggle competition run by Facebook AI in 2020 with $1 million in prizes; also produced the DFDC dataset
  3. SimSearchNet - a near-duplicate detection model developed at Facebook AI to identify infringing content on our platforms

Citation

If you use AugLy in your work, please cite our Arxiv paper using the citation below:

@misc{papakipos2022augly,
  author        = {Zoe Papakipos and Joanna Bitton},
  title         = {AugLy: Data Augmentations for Robustness},
  year          = {2022},
  eprint        = {2201.06494},
  archivePrefix = {arXiv},
  primaryClass  = {cs.AI}}
}

License

AugLy is MIT licensed, as found in the LICENSE file. Please note that some of the dependencies AugLy uses may be licensed under different terms.