Skip to main content

An API for streamlining unsupervised ML ops such as visualizations, clustering, CNN insights, etc.

Project description

opticaltoolkit_logo

A collection of deep learning -- computer vision utility functions

Installation

pip install optical_toolkit

Visualize

  • Visualize a dataset in a grid
from sklearn.datasets import load_digits
from optical_toolkit.visualize import plot_images

X, y = load_digits()

plot_images(X, targets=y)

dataset

  • Summarize a dataset by classes
from sklearn.datasets import load_digits
from optical_toolkit.visualize import plot_images

X, y = load_digits()

summarize_images(X, targets=y, num_images_per_class=10, num_classes=10)

dataset

  • Visualize the 2d and 3d embeddings of images
from sklearn.datasets import load_digits
from optical_toolkit.embeddings import get_embeddings

X, y = load_digits()

2d_embeddings, fig_2d = get_embeddings(X, y, dims=2, embedding_type="tsne", return_plot=True)
3d_embeddings, fig_3d = get_embeddings(X, y, dims=3, embedding_type="tsne", return_plot=True)

embedding2d embedding3d

embedding2d_comp embedding3d_comp

Insight

  • Visualize the filters of a (trained) CNN model
from optical_toolkit.cnn_filters import display_filters, display_model_filters

model_name = "xception"

layer_names = [
    "block2_sepconv1",
    "block5_sepconv1",
    "block9_sepconv1",
    "block14_sepconv1",
]

for layer_name in layer_names:
    display_filters(
    model=model_name,
    layer_name=layer_name,
)

filters filters filters filters

display_model_filters(model=model_name)

model_filters

  • Visualize the filters of your custom CNN with custom objects
import keras

model_name = "examples/custom_models/svdnet.keras"
dir_name = "examples/insights"

@keras.saving.register_keras_serializable()
class ResidualConvBlock(keras.layers.Layer):
    ...

display_model_filters(
    model_name,
    custom_layer_prefix="residual",
)

model_filters

Analyze

  • Analyze 'highly confident' errors in classification tasks
    • Confusion matrix normalized by row/column

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

optical_toolkit-1.2.0.tar.gz (15.0 kB view details)

Uploaded Source

Built Distribution

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

optical_toolkit-1.2.0-py3-none-any.whl (22.1 kB view details)

Uploaded Python 3

File details

Details for the file optical_toolkit-1.2.0.tar.gz.

File metadata

  • Download URL: optical_toolkit-1.2.0.tar.gz
  • Upload date:
  • Size: 15.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.2 CPython/3.10.16 Linux/6.8.0-1021-azure

File hashes

Hashes for optical_toolkit-1.2.0.tar.gz
Algorithm Hash digest
SHA256 adfb9e6cca7105fe1e28d03ec4d6516f891905047c27e30ebc2449465b994646
MD5 d52fb3da2cc3841d3c43706584fbc354
BLAKE2b-256 dea61ebe5b0ad8447b7c57653f3567b0c693a034ad174ee16529aafd724056ec

See more details on using hashes here.

File details

Details for the file optical_toolkit-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: optical_toolkit-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 22.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.1.2 CPython/3.10.16 Linux/6.8.0-1021-azure

File hashes

Hashes for optical_toolkit-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6b15f3037c7e641b405753fcc93aa5f0f3105cf3125dbdeb6659df6698e4ed51
MD5 33dfe6b68632047034c33cad16f7c7bc
BLAKE2b-256 c7bc59e1dce3cf37d1d1f4b24c44d4dcf2d8dd825d9116a76c9c6c46a2450d5a

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