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.1.tar.gz (86.9 kB view details)

Uploaded Source

Built Distribution

tomni-2.2.1-py3-none-any.whl (131.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: tomni-2.2.1.tar.gz
  • Upload date:
  • Size: 86.9 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.1.tar.gz
Algorithm Hash digest
SHA256 3dadca21c1ff658e4bb8ea686dfad2e26df06d71747afd12661d8f95e3a9081d
MD5 969814538af9150cce2256fafc80d357
BLAKE2b-256 228fe2f18f2b8b0073333f7ca8c2a19814582d60d1762213f2c2154108929a6d

See more details on using hashes here.

File details

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

File metadata

  • Download URL: tomni-2.2.1-py3-none-any.whl
  • Upload date:
  • Size: 131.0 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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 6324777ec565287b596cdff04882fa033d0c7b96a5dcdf2c70f10717e3fbd6be
MD5 b845a9fa476fc9b4e60ad9b317967ba4
BLAKE2b-256 27edc86e06c10e7fa9e14873c1ee238e26070dfc69589c69c5a58e66eddb286d

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