conda create -n myenv python=3.6
conda install tensorflow-gpu==1.15.0
conda install -c anaconda protobuf
After cloning this repo, upload from within the requirements.txt file.
pip install -r requirements.txt
Download the Tensorflow model file from the link below. We will do the work in this directory. Upload this repo as .zip and unzipped into the directory where you will be working.
https://github.com/tensorflow/models
NOTE 📝 Change the name of the file you unzipped to models.
Move the model in the repo, the file faster_rcnn_inception_v2_coco_2018_01_28 to the models/research/object_detection directory.
NOTE 📝 To find the missing files in the object_detection directory, move the missing files models/research/object_detection like in the object_detection.rar
📣Way 1: Specify pythonpathi in system environment variables. And create new system variable.
variable name: PYTHONPATH
variable: C:\tensorflow\models;C:\tensorflow\models\research;C:\tensorflow\models\research\slim
📣Way 2: Set environment in Command Prompt with command below.
PYTHONPATH=C:\tensorflowapi\models;C:\tensorflowapi\models\research;C:\tensorflowapi\models\research\slim
Run the following commands in the model/research directory.
protoc --python_out=. .\object_detection\protos\anchor_generator.proto .\object_detection\protos\argmax_matcher.proto .\object_detection\protos\bipartite_matcher.proto .\object_detection\protos\box_coder.proto .\object_detection\protos\box_predictor.proto .\object_detection\protos\eval.proto .\object_detection\protos\faster_rcnn.proto .\object_detection\protos\faster_rcnn_box_coder.proto .\object_detection\protos\flexible_grid_anchor_generator.proto .\object_detection\protos\grid_anchor_generator.proto .\object_detection\protos\calibration.proto .\object_detection\protos\hyperparams.proto .\object_detection\protos\image_resizer.proto .\object_detection\protos\input_reader.proto .\object_detection\protos\losses.proto .\object_detection\protos\matcher.proto .\object_detection\protos\mean_stddev_box_coder.proto .\object_detection\protos\model.proto .\object_detection\protos\optimizer.proto .\object_detection\protos\pipeline.proto .\object_detection\protos\post_processing.proto .\object_detection\protos\preprocessor.proto .\object_detection\protos\region_similarity_calculator.proto .\object_detection\protos\square_box_coder.proto .\object_detection\protos\ssd.proto .\object_detection\protos\ssd_anchor_generator.proto .\object_detection\protos\string_int_label_map.proto .\object_detection\protos\train.proto .\object_detection\protos\keypoint_box_coder.proto .\object_detection\protos\multiscale_anchor_generator.proto .\object_detection\protos\graph_rewriter.proto .\object_detection\protos\center_net.proto .\object_detection\protos\fpn.proto .\object_detection\protos\target_assigner.proto
NOTE 📝 Please check the \object_detection\protos directory after running the above code,it should have both .proto and _pb2.py at the end of the each files. If there is missing python file, rerun the proto file name that does not have a python file with the protoc command as above.
Move the setup.py file under the model/research folder. Then run the following commands in models/research directory to run the setup.py file we moved.
python setup.py build
python setup.py install
Your dataset must be in voc format and each image must have its own tag file (with an .xml extension).
Move the data you will use as test and train folders to models/research/object_detection/images directory.
Run the code below in models/research/object_detection directory. In the images folder, test_labels.csv and train_labels.csv csv files will be created. You can check.
python xml_to_csv.py
Type your classes in the generate_tfrecord.py file as below.
# TO-DO replace this with label map
def class_text_to_int(row_label):
if row_label == 'yourclassname':
return 1
else:
None
Run the code below in models/research/object_detection directory.
python generate_tfrecord.py --csv_input=images\train_labels.csv --image_dir=images\train --output_path=train.record
python generate_tfrecord.py --csv_input=images\test_labels.csv --image_dir=images\test --output_path=test.record
- The first thing to do in this step is to move files faster_rcnn_inception_v2_pets.config, graph.pbtxt into models / research / object_detection / training directory.
- Then a file named labelmap.pbtxt should be created in models / research / object_detection / training directory.
- Type your classes and ids in the labelmap.pbtxt file as below:
item
{
id: 1
name: 'yourclassname'
}
NOTE 📝 id = return values, name = name of your class in generate_tfrecord.py NOTE 📝 Before the training models/research/object_detection/training folder must contain faster_rcnn_inception_v2_pets.config, graph.pbtxt, labelmap.pbtxt
- Line 9: # write your class count
faster_rcnn {
num_classes: 32
- Line 106: Write your fine_tune_checkpoint
fine_tune_checkpoint : "C:/tensorflowapi/models/research/object_detection/faster_rcnn_inception_v2_coco_2018_01_28/model.ckpt"
- Line 123: Write your input path of train.record path.
input_path: "C:/tensorflowapi/models/research/object_detection/train.record"
- Line 125: Write your label map path.
label_map_path: "C:/tensorflowapi/models/research/object_detection/training/labelmap.pbtxt"
- Line 130: Write the count of your test images in models/research/images/test folder.
num_examples: 1
- Line 135: Write your input path of test.record path.
input_path: "C:/tensorflowapi/models/research/object_detection/test.record"
- Line 137: Write your label map path.
label_map_path: "C:/tensorflowapi/models/research/object_detection/training/labelmap.pbtxt"
For starting to train, run the command below in models/research/object_detection directory.
python train.py --logtostderr --train_dir=training/ --pipeline_config_path=training/faster_rcnn_inception_v2_pets.config
It will show like the following image.
python export_inference_graph.py --input_type image_tensor --pipeline_config_path training/faster_rcnn_inception_v2_pets.config --trained_checkpoint_prefix training/model.ckpt-XXXX --output_directory inference_graph
Example: The number of my model, which was formed after the training I did, was "0" as follows.
Write the IDLE to your command and you will see screen like in the follow.
Choose File/Open... from the left corner of the idle. Selec the Object_detection_image.py file in directory models/research/object_detection from the screen that opens.
There are two options here. You can set the path of the test folder in the object_detection_image.py file, or you can move the image you want to test to the models/research / object_detection directory.
Hint 🗝️ Here, the operations are carried out by moving the desired image to the test models / research / object_detection directory.
IMAGE_NAME = 'yourtestimagename.JPG'
Write the number of classes the object detector can identify.
NUM_CLASSES = 1
Press F5 to Run Module.
- Dilara Özdemir (@GitHub dilaraozdemir)
- Buse Yaren Tekin (@GitHub buseyarentekin)
- Elif Meşeci (@GitHub elifmeseci)
- Süheda Çilek (@GitHub suhedacilek)