Skip to main content

No project description provided

Project description

Tomni

Build Status Downloads

Tomni is a python package that contains a collection of helper functions based on OpenCV and NumPy. It can be used for any python based computer vision or image analysis problem. The package simplifies the code and takes care of edge cages, everything from simplifying code like img_dim to compute optimization like labels2contours or illumination correction image processing. Tomni uses the image coordinates (same as OpenCV).

Tomni is created by CytoSMART.

The package was developed in-house to centralize the helper function for computer vision problems. In 2021, CytoSMART engineers turned it to open source, enabling researchers and educators to use it for free.

Getting Tomni

pip install tomni

License

Tomni is free for academic and educational use.

For commercial use please contact CytoSMART.

The name

The name Tomni is a combination of creator (Tom) and other CytoSMART product he was working on, the Omni. Tomni name was proposed by Denissa Daroţi, a former CytoSMART intern, who won a bet with her mentor by getting a (well deserved) 9/10 for her internship.

Features

  • Bounding box fitting (bbox fitting)
    • Center bounding box fit
    • Custom location box fit
  • Image helpers
    • Get image dimensions
    • Convert color of an image
  • Illumination correction
    • Brightfield
    • Fluorescence
  • Contour operations
    • Get center
    • Approximate circle by area
    • Get roundness
    • Get circularity
  • CytoSMART data format
    • Tba
  • Json operation
    • Add circularity property
    • Scale object
    • Translate object
  • Make a mask
    • Ellipse
    • Polygon
  • Polygon downsampling
    • iterative downsampling
  • Shape fitting
    • Rect around ellipse
  • Transformers of data format
    • Contours to json
    • Ellipse to json
    • Json 2 contours
    • Json 2 label
    • Json 2 bbox
    • Labels 2 contours
    • Labels 2 lists of points
    • Binary 2 contours

Examples

Diameter vs radius

Most geometric operation use functions from OpenCV

Some of these function return diameter and some radius of the circle. This is not consistent.

For example, the function cv2.minEnclosingCircle returns the center and radius of the circle. The function cv2.fitEllipse returns the center and the major and minor axes of the ellipse.

Min enclosing circle example

import cv2
import math
import numpy as np

points = np.array([[0, 0], [100, 0], [100, 100], [0, 100], [0, 0]], dtype=np.float32)

center, radius = cv2.minEnclosingCircle(points)
diameter = math.sqrt(50**2 + 50**2) 

print("Center:", center)
print("Major and Minor Axes:", radius)
print("Diameter calculated with Pythagoras formula", diameter)

this results in the following output:

Center: (50.0, 50.0)
Major and Minor Axes: 70.71077728271484
Diameter calculated with Pythagoras formula 70.71067811865476

Fit ellipse example

import cv2
import math
import numpy as np

# Generate some example points
points = np.array([[0, 0], [100, 0], [100, 100], [0, 100], [0, 0]], dtype=np.float32)

# Fit an ellipse to the points
ellipse = cv2.fitEllipse(points)

# Extract ellipse parameters
center, axes, angle = ellipse

diameter = math.sqrt(50**2 + 50**2) * 2

print("Center:", center)
print("Major and Minor Axes:", axes)
print("Diameter calculated with Pythagoras formula", diameter)

this results in the following output:

Center: (50.0, 49.95212173461914)
Major and Minor Axes: (141.43260192871094, 141.5462188720703)
Diameter: 141.4213562373095

Example is related to the following functions in the package

Credits

Sorted alphabetically

  • Bram van der Velden
  • Coenraad Stijne
  • Denisa Daroţi
  • Hristo Atanasov
  • Jan-Niklas Schneider
  • Jelle van Kerkvoorde
  • Kirsten Koopman
  • Lisa Koolen
  • Manon van Erp
  • Marina Tzenkova
  • Tom de Vries
  • Tom Nijhof

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

tomni-2.2.2.tar.gz (87.0 kB view details)

Uploaded Source

Built Distribution

tomni-2.2.2-py3-none-any.whl (131.1 kB view details)

Uploaded Python 3

File details

Details for the file tomni-2.2.2.tar.gz.

File metadata

  • Download URL: tomni-2.2.2.tar.gz
  • Upload date:
  • Size: 87.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.19

File hashes

Hashes for tomni-2.2.2.tar.gz
Algorithm Hash digest
SHA256 bcdcb5dea3231eb816f293e115795a414d7405498a6853978e82197354b1ab72
MD5 b831bc3067d38125fe4d48a2321c5483
BLAKE2b-256 04c2074cebf6fe624f375c810a899685ed61cede11c94da57d88201c66eaa1b7

See more details on using hashes here.

File details

Details for the file tomni-2.2.2-py3-none-any.whl.

File metadata

  • Download URL: tomni-2.2.2-py3-none-any.whl
  • Upload date:
  • Size: 131.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.19

File hashes

Hashes for tomni-2.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 47c8ebad3edd1255f674bbabadf3f5eed5f1131c8cffa17c1bc489a4e1207635
MD5 437a33af3f8b5a27eddf22dae4e8461f
BLAKE2b-256 91f59c247c381f555378470316e8c17bfad462340cbbcb8aab3f09d3cb2a9c40

See more details on using hashes here.

Supported by

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