Skip to content

A small program that uses the Fruits-360 dataset to generate images and annotations for object detection.

License

Notifications You must be signed in to change notification settings

aledp/Fruit-Image-Generation

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Fruit-Experimental: An extension to the networks from Fruits-360 repository

The code here relies on the images from the Fruits-360 repository so you will need to download that as well.

Running Object Detection

1 Prerequisites

1.1 Get dataset

The Fruits-360 Repository

I recommend creating soft links to the Training and Test folders from the Fruits-360 repo in the folder where you download Fruit-Experimental. Open a command line or terminal in the Fruit-Experimental folder and do:

mklink /D Training "path-to-Fruits-360/Training"

mklink /D Test "path-to-Fruits-360/Test"

Where "path-to-Fruits-360" is the absolute or relative path to the Fruits-360 folder, which you should have after downloading the Fruits-360 repo.

1.2 Install Python, TensorFlow 2 and other dependencies

Install Python 3.8 TensorFlow does not support a higher version

Install TensorFlow 2

Install opencv by running in a command line:

pip install opencv-python

Install scikit-learn by running in a command line:

pip install scikit-learn

Install shapely by running in a command line:

pip install shapely

2 Config (in folder src/object_detection)

Make a copy of each of the detection_config.py.tmplt and labels.txt.tmplt files and name them detection_config.py and labels.txt, respectively.

The labels.txt file is used to select the source classes from the Fruits-360 dataset to build the detection dataset. Each label should be on a separate line.

The detection_config.py file contains all the settings related to the data generation and network configuration.

3 Build dataset (in folder src/object_detection)

The default settings in detection_config.py use 5 threads to generate 300 images, and the default labels.txt use the Apple Red 1, Banana and Orange labels.

Provided in this repo, there is only one background image: Dataset/Backgrounds/default_bkg.png, Others images can be added (recommended resolution 1024 x 768) and they will be used as background for generating data.

Run the following command

python build_detection_dataset.py

If the script was executed successfully, under the src/Dataset folder there should be a train folder containing images, masks and annotations.

images - contains images generated by the algorithm

masks - contains binary masks for each image, which can ve used for training a segmentation algoritm

annotations - contains a text file for each generated image with the coordinates of each bounding box as comma separated values

How to cite

Horea-Bogdan Mureşan, An Automated Algorithm for Fruit Image Dataset Building, 2022 17th Conference on Computer Science and Intelligence Systems (FedCSIS), pp. 103-107.

License

MIT License

Copyright (c) 2024 Horea Muresan

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

About

A small program that uses the Fruits-360 dataset to generate images and annotations for object detection.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 88.9%
  • C++ 11.1%