Skip to main content

A Python library for machine learning model training and inference

Project description

MemoLib

PyPI version Python Version License: MIT Downloads

A comprehensive Python library for machine learning model training and inference, supporting both classification and object detection tasks with state-of-the-art models.

Features

  • Multiple Model Architectures

    • EfficientNet (B0-B7, EfficientNetV2)
    • YOLO series for object detection
  • Flexible Task Support

    • Image Classification
    • Object Detection
  • Export Capabilities

    • ONNX format for cross-platform deployment
    • OpenVINO format for Intel hardware optimization
  • Training Pipeline

    • Built-in training loops with customizable callbacks
    • Support for custom loss functions (FocalLoss, etc.)
    • Easy model configuration via YAML/JSON
  • Utilities

    • Dataset format conversion tools
    • Data serialization and configuration management
    • Image preprocessing and augmentation

Installation

Install MemoLib using pip:

pip install MemoLib

For development with optional dependencies:

# With OpenVINO support
pip install MemoLib[openvino]

# All optional dependencies
pip install MemoLib[all]

# Development tools
pip install MemoLib[dev]

Quick Start

Classification Example

from MemoLib import MemoModel, eModelTask, eClassifyModel

# Create a classification model (EfficientNet-B0)
model = MemoModel(eModelTask.Classification, eClassifyModel.EfficientNetB0)

# Load pretrained weights and class labels
model.LoadWeight("path/to/weights.pth")
model.LoadLabelName("path/to/labels.txt")

# Make predictions on an image
result = model.Predict("path/to/image.jpg")
print(f"Prediction: {result.label}")
print(f"Confidence: {result.confidence:.2f}")

Object Detection Example

from MemoLib import MemoModel, eModelTask, eDetectModel

# Create a YOLO detection model
model = MemoModel(eModelTask.ObjectDetection, eDetectModel.YOLOv8)

# Load weights
model.LoadWeight("yolov8n.pt")

# Detect objects in image
results = model.Predict("path/to/image.jpg")
for detection in results:
    print(f"Class: {detection.label}, Confidence: {detection.confidence:.2f}")
    print(f"BBox: {detection.bbox}")

Model Export

# Export to ONNX
model.ExportToONNX("model.onnx")

# Export to OpenVINO (requires openvino package)
model.ExportToOpenVINO("model.xml")

Package Structure

MemoLib/
├── Model/              # Core model implementations
│   ├── Data/          # Data loading and preprocessing
│   ├── EfficientNet/  # EfficientNet model variants
│   └── YOLO/          # YOLO detection models
├── DataSerializer/     # Configuration management
├── DatasetFormatConvert/  # Dataset conversion utilities
└── Loss/              # Custom loss functions (FocalLoss, etc.)

Supported Models

Classification

  • EfficientNet-B0 to B7
  • EfficientNetV2-S, M, L

Object Detection

  • YOLOv5
  • YOLOv8
  • YOLOv9
  • YOLO11

Requirements

  • Python >= 3.8
  • PyTorch >= 1.12.0
  • TorchVision >= 0.13.0
  • OpenCV >= 4.5.0
  • Ultralytics >= 8.0.0
  • EfficientNet-PyTorch >= 0.7.0

See pyproject.toml for full dependency list.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

Issues

If you encounter any problems or have suggestions, please open an issue.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Author

NghiaKTHP

Changelog

Version 0.1.5

  • Added GitHub repository links
  • Improved documentation
  • Updated package metadata

Version 0.1.4

  • Initial PyPI release
  • Support for EfficientNet and YOLO models
  • ONNX and OpenVINO export capabilities

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

memolib-0.1.7.8.tar.gz (20.8 kB view details)

Uploaded Source

Built Distribution

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

memolib-0.1.7.8-py3-none-any.whl (22.7 kB view details)

Uploaded Python 3

File details

Details for the file memolib-0.1.7.8.tar.gz.

File metadata

  • Download URL: memolib-0.1.7.8.tar.gz
  • Upload date:
  • Size: 20.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for memolib-0.1.7.8.tar.gz
Algorithm Hash digest
SHA256 774446d9d85fefadeb7d89157e327de68551596d817c6b3d5b9efe947eda5bc0
MD5 333960696d415fe1edbbd9b595e1b77f
BLAKE2b-256 efc678255ff6e455cc732e493a77a256d90a9b6ea243a847778097fc81019020

See more details on using hashes here.

Provenance

The following attestation bundles were made for memolib-0.1.7.8.tar.gz:

Publisher: publish-pypi.yml on NghiaKTHP/MemoLib

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file memolib-0.1.7.8-py3-none-any.whl.

File metadata

  • Download URL: memolib-0.1.7.8-py3-none-any.whl
  • Upload date:
  • Size: 22.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for memolib-0.1.7.8-py3-none-any.whl
Algorithm Hash digest
SHA256 165e3abc8217f76d8c63e26e82061bdb0ab1ab2bd34d116da2a175b5b2a5a429
MD5 d549a334430a92be6b933bc24b022a3e
BLAKE2b-256 33b17bec6f7f35f0828535f82247c3cf6052729e7e425be28ac3abd967db7978

See more details on using hashes here.

Provenance

The following attestation bundles were made for memolib-0.1.7.8-py3-none-any.whl:

Publisher: publish-pypi.yml on NghiaKTHP/MemoLib

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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