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

Uploaded Source

Built Distribution

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

Uploaded Python 3

File details

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

File metadata

  • Download URL: tomni-2.2.1b0.tar.gz
  • Upload date:
  • Size: 86.6 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.1b0.tar.gz
Algorithm Hash digest
SHA256 53e060b39403b0357170d8efb039a311278a15f0c49b97b40f538c2f875bc850
MD5 e86391d4d61dd78250a49c21588c1e3d
BLAKE2b-256 afcaa97ca1d3283f79189221a259d43959cc4b5741d6eeb02402eb4661169fb9

See more details on using hashes here.

File details

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

File metadata

  • Download URL: tomni-2.2.1b0-py3-none-any.whl
  • Upload date:
  • Size: 128.7 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.1b0-py3-none-any.whl
Algorithm Hash digest
SHA256 ce2590159fde24e2bc8d850d9c9b96d19e4662a9ae622cacefa467bfff028399
MD5 21db1b262abcd18172a165d8e4fe4a28
BLAKE2b-256 c3b1a3beba81eeb16a81b717e12a29cd1e75f461882cbe202dee21c19ead48ac

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