Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/deliton/idt
Image Dataset Tool (idt) is a cli tool designed to make the otherwise repetitive and slow task of creating image datasets into a fast and intuitive process.
https://github.com/deliton/idt
bing bing-api deep-learning download download-dataset download-images duckgo flickr-api idt image-datasets image-download mount scraping scraping-web search-engine
Last synced: 17 days ago
JSON representation
Image Dataset Tool (idt) is a cli tool designed to make the otherwise repetitive and slow task of creating image datasets into a fast and intuitive process.
- Host: GitHub
- URL: https://github.com/deliton/idt
- Owner: deliton
- License: mit
- Created: 2020-08-19T22:59:21.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2021-01-09T22:50:25.000Z (almost 4 years ago)
- Last Synced: 2024-09-18T17:11:55.189Z (about 2 months ago)
- Topics: bing, bing-api, deep-learning, download, download-dataset, download-images, duckgo, flickr-api, idt, image-datasets, image-download, mount, scraping, scraping-web, search-engine
- Language: Python
- Homepage:
- Size: 105 KB
- Stars: 227
- Watchers: 10
- Forks: 28
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# IDT - Image Dataset Tool
## Version 0.0.6 beta
![idt-logo](https://user-images.githubusercontent.com/47995046/96403078-d675f080-11ad-11eb-8435-c8ce69a6c871.png)
## Description
The image dataset tool (IDT) is a CLI app developed to make it easier and faster to create image datasets to be used for deep learning. The tool achieves this by scraping images from several search engines such as duckgo, bing and deviantart. IDT also optimizes the image dataset, although this feature is optional, the user can downscale and compress the images for optimal file size and dimensions. A sample dataset created using **idt** that contains a total amount of 23.688 image files weights only 559,2 megabytes.
## NEW UPDATE!
I am proud to announce our newest version! 🎉🎉**What changed**
* Added auto duplicate images remover
* Added longer side resize method. With this option, the image is resized to its longer side.
* Added shorter side resize method. With this option, the image is resized to its shorter side.
* Added Smart Crop. This method tries to crop and resize exactly the main subject of the image. The algorithm is based on SmartCrop.js and SmartCrop.py.
* Removed verbose mode. This was used in earlier stages of development but now don't add value to the experience.
* The official documentation is almost ready. A link will be available soon## Installing
You can install it via pip or cloning this repository.
```console
user@admin:~$ pip3 install idt```
**OR**
```console
user@admin:~$ git clone https://github.com/deliton/idt.git && cd idt
user@admin:~/idt$ sudo python3 setup.py install```
## Getting Started
![idt-gif](https://user-images.githubusercontent.com/47995046/96406740-6d46ab00-11b6-11eb-980b-a40968ed38b4.gif)
The quickest way to get started with IDT is running the simple "run" command. Just write in your favorite console something like:
```console
user@admin:~$ idt run -i apples
```This will quickly download 50 images of apples. By default it uses the duckgo search engine to do so.
The run command accepts the following options:| Option | Description |
| ----------- | ----------- |
| **-i** or **--input** | the keyword to find the desired images. |
| **-s** or **--size** | the amount of images to be downloaded. |
| **-e** or **--engine** | the desired search engine (options: duckgo, bing, bing_api and flickr_api) |
| **--resize-method** | choose a resize method of images. (options: longer_side, shorter_side and smartcrop) |
| **-is** or **--image-size** | option to set the desired image size ratio. default=512 |
| **-ak** or **--api-key** | If you are using a search engine that requires an API key, this option is required |## Usage
IDT requires a config file that tells it how your dataset should be organized. You can create it using the following command:
```console
user@admin:~$ idt init
```This command will trigger the config file creator and will ask for the desired dataset parameters. In this example let's create a dataset containing images of your favorite cars. The first parameters this command will ask is what name should your dataset have? In this example, let's name our dataset "My favorite cars"
```console
Insert a name for your dataset: : My favorite cars
```Then the tool will ask how many samples per search are required to mount your dataset. In order to build a good dataset for deep learning, many images are required and since we're using a search engine to scrape images, many searches with different keywords are required to mount a good sized dataset. This value will correspond to how many images should be downloaded at every search. In this example we need a dataset with 250 images in each class, and we'll use 5 keywords to mount each class. So if we type the number 50 here, IDT will download 50 images of every keyword provided. If we provide 5 keywords we should get the required 250 images.
```console
How many samples per search will be necessary? : 50
```The tool will now ask for and image size ratio. Since using large images to train neural networks is not a viable thing, we can optionally choose one of the following image size ratios and scale down our images to that size. In this example, we'll go for 512x512, although 256x256 would be an even better option for this task.
```console
Choose images resolution:[1] 512 pixels / 512 pixels (recommended)
[2] 1024 pixels / 1024 pixels
[3] 256 pixels / 256 pixels
[4] 128 pixels / 128 pixels
[5] Keep original image sizeps: note that the aspect ratio of the image will not be changed,
so possibly the images received will have slightly different sizeWhat is the desired image size ratio: 1
```And then choose "longer_side" for resize method.
```console
[1] Resize image based on longer side
[2] Resize image based on shorter side
[3] Smartcropps: note that the aspect ratio of the image will not be changed,
so possibly the images received will have slightly different sizeDesired Image resize method: : longer_side
```
Now you must choose how many classes/folders your dataset should have. In this example, this part can be very personal, but my favorite cars are: Chevrolet Impala, Range Rover Evoque, Tesla Model X and (why not) AvtoVAZ Lada. So in this case we have 4 classes, one for each favorite.
```console
How many image classes are required? : 4
```Afterwards, you'll be asked to choose between one of the search engines available. In this example, we'll use DuckGO to search images for us.
```console
Choose a search engine:[1] Duck GO (recommended)
[2] Bing
[3] Bing API
[4] Flickr APISelect option:: 1
```Now we have to do some repetitive form filling. We must name each class and all the keywords that will be used to find the images. Note that this part can be later changed by your own code, to generate more classes and keywords.
```console
Class 1 name: : Chevrolet Impala
```After typing the first class name, we'll be asked to provide all the keywords to find the dataset. Remember that we told the program to download 50 images of each keyword so we must provide 5 keywords in this case to get all 250 images. Each keyword MUST be separated by commas(,)
```console
In order to achieve better results, choose several keywords that will
be provided to the search engine to find your class in different settings.Example:
Class Name: Pineapple
keywords: pineapple, pineapple fruit, ananas, abacaxi, pineapple drawingType in all keywords used to find your desired class, separated by commas: Chevrolet Impala 1967 car photos,
chevrolet impala on the road, chevrolet impala vintage car, chevrolet impala convertible 1961, chevrolet impala 1964 lowrider```
Then repeat the process of filling class name and its keywords until you fill all the 4 classes required.
```console
Dataset YAML file has been created successfully. Now run idt build to mount your dataset!
```Your dataset configuration file has been created. Now just rust the following command and see the magic happen:
```console
user@admin:~$ idt build
```And wait while the dataset is being mounted:
```console
Creating Chevrolet Impala class
Downloading Chevrolet Impala 1967 car photos [#########################-----------] 72% 00:00:12```
At the end, all your images will be available in a folder with the dataset name. Also, a csv file with the dataset stats are also included in the dataset's root folder.
![idt-results](https://user-images.githubusercontent.com/47995046/93012667-808fa680-f578-11ea-82fc-7ebcb8ce3c41.png)
## Split image dataset for Deep Learning
Since deep learning often requires you to split your dataset into a subset of training/validation folders, this project can also do this for you! Just run:
```console
user@admin:~$ idt split
```Now you must choose a train/valid proportion. In this example I've chosen that 70% of the images will be reserved for training, while the rest will be reserved for validation:
```console
Choose the desired proportion of images of each class to be distributed in train/valid folders.
What percentage of images should be distributed towards training?
(0-100): 7070 percent of the images will be moved to a train folder, while 30 percent of the remaining images
will be stored in a validation folder.
Is that ok? [Y/n]: y
```And that's it! The dataset-split should now be found with the corresponding train/valid subdirectories.
## Issues
This project is being developed in my spare time and it still needs a lot of effort to be free of bugs. Pull requests and contributors are really appreciated, feel free to contribute in any way you can!