# Logo Detection AI Blueprint - deprecated from 11/2024
# Batch-Predict
Logo detection refers to detecting instances of a certain class logo in images and videos. The output from the logo-detector model describes the class of a logo and its coordinates, creating a box around the detected logo and labeling it according to its class.
# Purpose
Use this batch blueprint to run in batch mode a pretrained tailored model with your custom data which detects logo elements in images and videos stored in a directory. To run this blueprint, provide the S3 Connector path to a directory folder containing videos and images.
This blueprint supports by default detection of the following logo classes: CCD, Steeden, and 76. To detect custom logos, the path to the weights file is required. Run this counterpart’s training blueprint, and then upload the trained model weights to the S3 Connector.
This blueprint supports the following video and image formats:
Videos | Images |
---|---|
mov | bmp |
avi | jpg |
mp4 | jpeg |
mpg | png |
mpeg | tif |
m4v | tiff |
wmv | dng |
mkv | webp |
mpo |
# Deep Dive
The following flow diagram illustrates this batch blueprint’s pipeline:
# Flow
The following list provides a high-level flow of this blueprint’s run:
- In the S3 Connector, the user provides the directory path where the logo images/videos are stored.
- In the Batch task, the user provides the S3 location for
source
which contains the stored images/videos. - The blueprint outputs same-named images/videos of the detected logos with their bounding boxes and logo labels.
# Arguments/Artifacts
For more information on this blueprint’s tasks, its inputs, and outputs, click here.
# Inputs
--source
is the path to the directory containing the images and videos to be processed.--weights
is the path to weights file in this argument. Provide this argument to use custom weights trained using this counterpart’s training blueprint. Otherwise, leave this argument empty to use the default weights.
# Outputs
The output artifacts consist of the video and image outputs. For every input video and image processed, a same-named output video and image is produced with the labeled bounding boxes drawn around the detected logos.
# Instructions
NOTE
The minimum resource recommendations to run this blueprint are 3.5 CPU and 8 GB RAM.
Complete the following steps to run this logo-detector blueprint in batch mode:
- Click the Use Blueprint button. The cnvrg Blueprint Flow page displays.
- Click the S3 Connector task to display its dialog.
- Within the Parameters tab, provide the following Key-Value pair information:
- Key:
bucketname
− Value: provide the data bucket name - Key:
prefix
– Value: provide the main path where the data folder is located
- Key:
- Click the Advanced tab to change resources to run the blueprint, as required.
- Within the Parameters tab, provide the following Key-Value pair information:
- Click the Batch task to display its dialog.
Within the Parameters tab, provide the following Key-Value pair information:
- Key:
source
Value: provide the S3 location containing all the images and videos /input/s3_connector/logo_detection_batch
− ensure the path adheres to this format
NOTE
You can use the prebuilt example data paths provided.
- Key:
Click the Advanced tab to change resources to run the blueprint, as required.
- Click the Run button. The cnvrg software deploys a logo-detector model that detects logos and their locations in a batch of images.
- Track the blueprint’s real-time progress in its Experiments page, which displays artifacts such as logs, metrics, hyperparameters, and algorithms.
- Select Batch > Experiments > Artifacts and locate the output files.
- Select a File Name, click the Menu icon, and select Open File to view an output image or video file.
A tailored model that detects logos, draws their boundaries, and labels them in images and videos has now been deployed in batch mode. For information on this blueprint's software version and release details, click here.
# Connected Libraries
Refer to the following libraries connected to this blueprint:
# Related Blueprints
Refer to the following blueprints related to this batch blueprint:
# Inference
Logo detection refers to detecting instances of a certain class logo in images. The output from the logo-detector model describes the class of a logo and its coordinates, creating a box around the detected logo and labeling it according to its class.
# Purpose
Use this inference blueprint to immediately detect logo elements and their positions in images. To use this pretrained logo-detector model, create a ready-to-use API-endpoint that can be quickly integrated with your data and application.
This inference blueprint's model was trained using three logos: CCD, 76, Steeden. To use custom logo data according to your specific business, run this counterpart's training blueprint, which trains the model and establishes an endpoint based on the newly trained model. If no logo training data is available and the needs are to detect text, then the cnvrg team suggests the Text Detection Inference blueprint as an alternative.
# Instructions
NOTE
The minimum resource recommendations to run this blueprint are 3.5 CPU and 8 GB RAM.
Complete the following steps to deploy this logo-detector API endpoint:
- Click the Use Blueprint button. The cnvrg Blueprint Flow page displays.
- In the dialog, select the relevant compute to deploy API endpoint and click the Start button.
- The cnvrg software redirects to your endpoint. Complete one or both of the following options:
- Use the Try it Live section with any logo-containing image to check the model.
- Use the bottom integration panel to integrate your API with your code by copying in your code snippet.
An API endpoint that detects logos in images has now been deployed. For information on this blueprint's software version and release details, click here.
# Related Blueprints
Refer to the following blueprints related to this inference blueprint:
# Training
Logo detection refers to detecting instances of a certain class logo in images. The output from the logo-detector model describes the class of a logo and its coordinates, creating a box around the detected logo and labeling it according to its class.
# Overview
The following diagram provides an overview of this blueprint's inputs and outputs.
# Purpose
Use this training blueprint with your custom data to train a tailored model that detects logos in images. This blueprint also establishes an endpoint that can be used to detect logos in images based on the newly trained model. Training a logo-detection algorithm requires data provided in the form of logo-containing images, the logo locations, and their names (labels).
To train this model with your data, provide the following two folders to the S3 Connector:
- Images − A folder with all the logo-containing images to train the model
- Labels − A folder with labels that correlate to the logos in the images folder
# Deep Dive
The following flow diagram illustrates this blueprint's pipeline:
# Flow
The following list provides a high-level flow of this blueprint's run:
- In S3 Connector, the user provides the data bucket name and two-directory training dataset path, with one folder containing the logo images and another folder containing the correlating label files.
- In the Recreate task, the user provides the paths to the images and labels folders to split the dataset into train/validation/test.
- In the Retrain task, the user specifies the batch size, number of epochs, and the names of classes/categories of the logos for training. The class names represent the logo categories to detect, such as Pepsi, Coke, and Fanta. Provide the class names directly as an argument or specify the location of a CSV file containing the names under the classes column.
- The blueprint trains the tailored model using user-provided custom data to detect logos in images.
- The user uses the newly deployed endpoint to make predictions with new data using the newly trained model.
# Arguments/Artifacts
For more information on this blueprint's tasks, its inputs, and outputs, click here.
# Recreate
For more information and examples on this task's inputs and outputs, click here.
# Recreate Inputs
--images
is the path to the folder with the input logo-containing images for the detector to learn to detect.--labels
is the path to the folder with the label files containing each image's logo coordinates along with the class of each logo.
# Recreate Output
- An input dataset split into train/validation/test datasets. The images and labels folders each include three folders containing the images and labels with names train, test, and validation.
# Retrain
For more information and examples on this task's inputs and outputs, click here.
# Retrain Inputs
--batch
is the batch size the neural network ingests before calculating loss and readjusting weights. For example, for a two batch size and 100 images, the neural network inputs two training images at a time, calculates loss and readjusts weights, and then continues for all the training set's images.--epochs
is the number of times the neural network trains dataset to complete its learning. The more the better, but too many can lead to overfitting and too few can lead to underfitting.--class_name
sets the names of the classes for the model to learn. Class naming is important, or the trained model prints just numbers (like 0,1,2) for detected logos, so these numbers must be mapped to meaningful names. As input, provide double-quoted class names separated by commas (like "Pepsi,Coke,Fanta") or specify a one-column CSV file location such as\dataset_name\input_file
.NOTE
The order of the names must be same as the items in the labels files. For example, if the file's labels 0,1,2 are Pepsi, Coke, and Fanta respectively, then this parameter's input must be in the same "Pepsi,Coke,Fanta" order and the same order preserved in the CSV file.
# Retrain Outputs
best.pt
is the file containing the retrained neural network weights yielding the highest scores. Download and save these weights to make future inferences on images containing trained logos.last.pt
is the file containing the retrained neural network weights from the last epoch. Though these weights can also be used to make future logo detection inferences, the cnvrg team doesn't recommend using them because they perform worse than the best weights described above.Trainresults.csv
is the file containing all metrics evaluated on the training set.Valresults.csv
is the file containing all metrics evaluated on the validation dataset. Both previous metric CSV files have the following column/row format:- Images Overall column contains the total training images number, Labels column contains the total number of labels available per class, and mAp@.5 and mAp@.5:.95 columns refer to the respective mean-average precisions.
- The All row contains the average of evaluation metrics from all classes.
others files
are other output artifacts includingresults.csv
file containing evaluations performed every iteration; results.png containing plots namely, losses and evaluation metrics, a confusion matrix, precision-per-class, recall-per-class, F1 score-per-class, precision vs. recall, label distribution, and bounding box distribution; two YAML files with hyperparameters and training settings; and three images each containing examples of validation data, training data, and predictions.
# Instructions
NOTE
The minimum resource recommendations to run this blueprint are 3.5 CPU and 8 GB RAM.
Complete the following steps to train this logo-detector model:
Click the Use Blueprint button. The cnvrg Blueprint Flow page displays.
In the flow, click the S3 Connector task to display its dialog.
- Within the Parameters tab, provide the following Key-Value pair information:
- Key:
bucketname
- Value: enter the data bucket name - Key:
prefix
- Value: provide the main path to the data folder
- Key:
- Click the Advanced tab to change resources to run the blueprint, as required.
- Within the Parameters tab, provide the following Key-Value pair information:
Return to the flow and click the Recreate task to display its dialog.
Within the Parameters tab, provide the following Key-Value pair information:
- Key:
images
– Value: provide the path to the images including the S3 prefix, with the following format:/input/s3_connector/<prefix>/images
; see Recreate Inputs - Key:
labels
– Value: provide the path to the labels including the S3 prefix, with the following format:/input/s3_connector/<prefix>/labels
; see Recreate Inputs
NOTE
You can use prebuilt data examples paths already provided.
- Key:
Click the Advanced tab to change resources to run the blueprint, as required.
Click the Retrain task to display its dialog.
- Within the Parameters tab, provide the following Key-Value pair information:
- Key:
batch
– Value: set the batch size the neural network ingests before calculating loss and readjusting weights; see Retrain Inputs - Key:
epochs
– Value: set the number of times the neural network trains the dataset; see Retrain Inputs - Key:
class_names
– Value: provide the names of the classes for the model to learn; see Retrain Inputs
- Key:
- Click the Advanced tab to change resources to run the blueprint, as required.
- Within the Parameters tab, provide the following Key-Value pair information:
Click the Run button. The cnvrg software launches the training blueprint as set of experiments, generating a trained logo-detector model and deploying it as a new API endpoint.
NOTE
The time required for model training and endpoint deployment depends on the size of the training data, the compute resources, and the training parameters.
For more information on cnvrg endpoint deployment capability, see cnvrg Serving.
Track the blueprint's real-time progress in its Experiments page, which displays artifacts such as logs, metrics, hyperparameters, and algorithms.
Click the Serving tab in the project and locate your endpoint.
Complete one or both of the following options:
- Use the Try it Live section with any logo-containing image to check the model.
- Use the bottom integration panel to integrate your API with your code by copying in your code snippet.
A custom model and API endpoint which can detect logos in images have now been trained and deployed. For information on this blueprint's software version and release details, click here.
# Connected Libraries
Refer to the following libraries connected to this blueprint:
# Related Blueprints
Refer to the following blueprints related to this training blueprint: