Skip to main content

DISCOver PATterns (DISCOPAT)

Project description

https://raw.githubusercontent.com/mansour-b/discopat/main/assets/discopat_hollywood.png

DISCOver PATterns (DISCOPAT)

Build Status Code Coverage

Welcome to discopat, the pattern discovery library!

This library provides tools to discover, detect, and track meaningful patterns in physical signals. These signals can be of various forms:

  1. Time series,

  2. Images,

  3. Movies,

  4. Any other type of n-dimensional data.

Installation

You can install discopat by doing the following:

pip install discopat

You can then try running this notebook on your computer to verify that the installation was succesful.

Quickstart

Here is an example to briefly present the API:

import numpy as np

from discopat.core import Box, Frame, Model, Movie, Tracker
from discopat.display import plot_frame

# Define the dimensions of the problem
frame_width = 5
frame_height = 5
movie_length = 3
gif_frames_per_second = 2

# Define a concrete model class, just for the example
class DumbModel(Model):
    def predict(self, frame: Frame) -> Frame:
        frame_id = int(frame.name)
        frame.annotations.append(
            Box(label="noise_in_a_square", x=frame_id, y=frame_id, width=1, height=1)
        )
        return frame

model = DumbModel()

# Our data for this short tutorial
frames = [
    Frame(
        name=str(10 * i),
        width=frame_width,
        height=frame_height,
        annotations=[],
        image_array=np.random.random(frame_height, frame_width),
    )
    for i in range(movie_length)
]

movie = Movie(name="some_noise", frames=frames, tracks=[])

# Run the detection model on individual frames
analysed_frames = [model(frame) for frame in movie.frames]
analysed_movie = Movie(
    name="some_noise_with_boxes", frames=analysed_frames, tracks=[]
)

# TBD: run tracker on detections
analysed_movie = tracker.make_tracks(analysed_movie)
analysed_movie.name = "some_noise_with_boxes_and_tracks"

# Plot individual frames with detections
for frame in analysed_movie:
    plot_frame(frame)

# TBD: make a GIF to show the tracks
export_to_gif(analysed_movie, fps=gif_frames_per_seconds)

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

discopat-0.3.0.tar.gz (5.1 kB view details)

Uploaded Source

Built Distribution

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

discopat-0.3.0-py3-none-any.whl (5.5 kB view details)

Uploaded Python 3

File details

Details for the file discopat-0.3.0.tar.gz.

File metadata

  • Download URL: discopat-0.3.0.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for discopat-0.3.0.tar.gz
Algorithm Hash digest
SHA256 d586f1923e5a67908b759a4bf322e23d678b7fb2584df8bbf7e52cfd6e542e50
MD5 428c900c0ab30fff1fe478d669f86fe7
BLAKE2b-256 7ac36db2ed48d4435f42c3809ba41e424160bdd55cc3a44341d8f5f20af4c9fd

See more details on using hashes here.

Provenance

The following attestation bundles were made for discopat-0.3.0.tar.gz:

Publisher: pypi_upload.yaml on mansour-b/discopat

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

File details

Details for the file discopat-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: discopat-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 5.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for discopat-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b81504584816a3f27b083ceb3f13d19bf03df642ebdba7d40815a50218ae72f9
MD5 af44461de334e7099aeef49acf23f5a2
BLAKE2b-256 3b9a92d81fd8e4333f8eac2370e95811931e1a4856b5a6e5a610f472e08b7d86

See more details on using hashes here.

Provenance

The following attestation bundles were made for discopat-0.3.0-py3-none-any.whl:

Publisher: pypi_upload.yaml on mansour-b/discopat

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