Skip to main content

Image classification trainer using OpenCV and timm

Project description

AEK Image Trainer Logo

AEK Image Trainer

AI image preprocessing library

Installation

pip install aek-img-trainer

For more secure way after doing that you can upgrade via:

pip install --upgrade aek-img-trainer

Usage

Create object

Now you can just use Trainer class methods example usage is shown below.

from aek_img_trainer import Trainer, Preprocessor

model = Trainer(train_root="root/trainset",
                val_root="root/valset",
                num_classes=16,
                img_size=224,
                batch_size=4,
                val_reach=0.9999,
                num_epochs=150,
                learning_rate=1e-3,
                checkpoint_path="efficientnet_b0_best_model.pth",
                model_name="efficientnet_b0",
                device=None,
                augment=True,
                scheduler=None,
                scheduler_params=None,
                pretrained=True)

Those hyperparameters without train and val dataset path are default if you want to use default parameters you can just give your train and val datasets' path.

model = Trainer(train_root="root/trainset",val_root="root/valset")

Training

You can train your model with parameter that created earlier.

model.train()

Prediction

You can use your model in test with below code.

model.predict(checkpoint_path="example_model.pth",
               test_path="root/test.png")

Or if you give the test set path this method predict all images in the dataset folder. Your dataset should be labelled like training dataset.

Example usage:

model.predict(checkpoint_path="example_model.pth",
                test_set_path="root/testset")

Save XML

You can save the pth model file to xml and bin files

Example usage:

model.savexml(pth_path="efnet.pth", output_path="efnet.xml", class_number=16, model_name="efficientnet_b0")

Prediction on XML file

You can predict the model with xml and bin files. Like above predict function predict_xml takes either test_path or test_set_path and changes the result with the given path, either predict one image or images that inside the test set. Test set should be labelled like a training dataset.

Example usage:

model.predict_xml(xml_path="enfet.xml", bin_path="efnet.bin", test_path=None, test_set_path="root/testset")

Information

You can see your model's parameters and architecture.

model.print_model_info()

Help function for Trainer class

You can use help() function for get more information about functions that inside the Trainer class.

model.help()

Timm models

You can get models that inside the timm library you can use with their name in string format inside the Trainer() 'model_name' paramaters. ATTENTION: You can just use the models whose head layers are 'fc', 'head' and 'classifier'

model.list_all_timm_models()

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

aek_img_trainer-0.5.0.tar.gz (9.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

aek_img_trainer-0.5.0-py3-none-any.whl (9.3 kB view details)

Uploaded Python 3

File details

Details for the file aek_img_trainer-0.5.0.tar.gz.

File metadata

  • Download URL: aek_img_trainer-0.5.0.tar.gz
  • Upload date:
  • Size: 9.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for aek_img_trainer-0.5.0.tar.gz
Algorithm Hash digest
SHA256 0ba4ea7bc28c13a6d9e5c616469fc2d584d0bfea9f0d88a921005e88e91d3767
MD5 ca453c6454a5574be4604d8b7ca19a7c
BLAKE2b-256 28669cb6d9f508d83e69a1dbbf8fa342b9caa2dd902a794f79e58ef95cf61f17

See more details on using hashes here.

File details

Details for the file aek_img_trainer-0.5.0-py3-none-any.whl.

File metadata

File hashes

Hashes for aek_img_trainer-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 42e9675a39b4d720b33fcb5ee9a6147103d98b3be1434cc6cecd6f46920ac6cd
MD5 1c98b2a74b16fb96e45cd177e14f7408
BLAKE2b-256 eba73987a93082d0cc13ea0a8ea68afb301edeb5299bcace5765ef24b8000e14

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page