This repository allows you to get started with a gui based training a Deep Learning model with no detailed configuration needed! Set your dataset and start the training right away and monitor it with TensorBoard or DLTGUI tool.
- You won't have any problems for training image classification algorithms.
- It is easy to train a image classification model, save the model, and make predictions from the saved model.
- A few parameters!
- You will be able to train on pre-trained models.
- It doesn't exist for 1.0 but, it will be much easier to train and use object detection algortihms.
- You can train your model on GPU or CPU.
- Parallel operation is possible.
- You won't be needing a second terminal and a script code to run TensorBoard.
In the words of Stephen Hawking:
Science is beautiful when it makes simple explanations of phenomena or connections between different observations. Examples include the double helix in biology and the fundamental equations of physics.
- Anaconda 64-bit
- Python 3.7.3
- Tensorflow 2.0.0
- Numpy 1.16.4
- Matplotlib
- PIL
- subprocess
- pathlib
The following is an example of how a dataset should be structured. Before you train a deep learning model, put all your dataset into datasets directory.
├──datasets/
├──example_dataset/
├── cat
│ ├── img_1.jpg/png
│ └── img_2.jpg/png
├──flower_photos/
├── daisy
│── dandelion
│── roses
│── sunflowers
│── tulips
For image classification.
- Clone this repo.
cd Deep-Learning-Training-GUI- On your terminal:
pip install requirements.txt - Set your dataset directory as I show above.
- When you set your dataset, go to the terminal and run
python app.py. You can access the program onlocalhost:5000 - Now you will see the home page.
- You must enter the path where your dataset is located. For example, I want to select the
flower_photosfolder in the datasets and I will write to the form element like this:datasets/flower_photos - Split the dataset, we need to specify what percentage of the training data we will use as a test.
- Pre-trained Models - Currently only MobileNetV2 is available, but in future versions you can easily select other pre-trained models for fine-tuning.
- CPU / GPU - You need to specify whether you want to train on the GPU or CPU (the first version will automatically run on the GPU).
- Number Of Classes - I'll go again from the flower_photos example. There are 5 separate folders under the
flower_photosfolder. This is our class count. When you train your own data set, you have to create as many folders here as you have classes. - Batch Size - Specifies whether the training samples are uploaded to the training network in escapes. If you have a 1080 Ti or better GPU, you can set it to 64 or 128. The higher Batch Size, less noise that the model learns.
- Epoch - The number of training data shown to the model network. So if you make 10 Epoch, the training data will be shown to the model network 10 times.
When you start to training, you will be able to access TensorBoard without writing any script on terminal!
Check localhost:6006
Contributions with example scripts for other frameworks (PyTorch or Caffe 2) are welcome!
Coming soon.


.png)


