Skip to main content

A Python framework for modeling scientific systems with persistence and composable object capabilities

Project description

Jangada

A Python framework for modeling scientific systems with persistence and composable object capabilities.

Overview

Jangada provides robust infrastructure components for data-intensive scientific applications, emphasizing:

  • Explicit serialization: Descriptor-driven schemas with HDF5 persistence
  • Composable capabilities: Orthogonal mixin classes for identity, metadata, and state
  • Rich terminal output: Template-based formatting with the Rich library
  • System modeling: Hierarchical system/subsystem paradigms with lazy loading

Key Features

Serialization & Persistence

  • SerializableProperty: Descriptors with validation, change tracking, and lazy initialization
  • Serializable: Registry-backed in-memory serialization protocol
  • Persistable: HDF5 persistence layer with lazy dataset loading via ProxyDataset
  • Support for NumPy arrays, Pandas DataFrames, and custom types

Composable Mixins

Six orthogonal capability classes:

  • Identifiable: Globally unique IDs with weak reference registry
  • Taggable: Validated symbolic tags for organization
  • Nameable: Human-readable names with validation
  • Describable: Long-form descriptions
  • Colorable: Canonical color representation (hex format)
  • Activatable: Boolean activation state

Display & Representation

  • Displayable: Abstract base for Rich library integration
  • Representable: Template method pattern for consistent formatting
  • Customizable terminal output with panels, tables, and color

System Modeling

  • System: Container for subsystems with hierarchical organization
  • Namespace management for system/subsystem paradigms
  • Integration with all framework capabilities

Installation

pip install jangada

Quick Start

from jangada import Persistable, SerializableProperty
from jangada.mixin import Identifiable, Nameable, Taggable

class ScientificModel(Persistable, Identifiable, Nameable, Taggable):
    """A simple scientific model with persistence and metadata."""
    
    data = SerializableProperty(default=None)
    parameters = SerializableProperty(default=dict)
    
    def __init__(self, name: str, tag: str):
        self.name = name
        self.tag = tag
        self.parameters = {"learning_rate": 0.01}

# Create and persist
model = ScientificModel(name="Experiment-1", tag="ml_model")
model.save("/path/to/storage.h5")

# Load later
loaded_model = ScientificModel.load("/path/to/storage.h5")
print(f"Loaded {loaded_model.name} with ID {loaded_model.id}")

Design Philosophy

Jangada follows these principles:

  • Modularity: Orthogonal components that work independently
  • Composability: Mix-and-match capabilities via multiple inheritance
  • Explicitness: Clear schemas and configuration over magic
  • Efficiency: Lazy loading for large datasets
  • Quality: Comprehensive documentation, testing, and type hints

Documentation

Full documentation is available at readthedocs.io.

Requirements

  • Python >= 3.10
  • numpy >= 1.20.0
  • pandas >= 1.3.0
  • h5py >= 3.0.0
  • matplotlib >= 3.4.0
  • rich >= 10.0.0

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

MIT License - see LICENSE file for details.

Author

Rafael - GitHub Profile

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

jangada-0.1.6.tar.gz (91.1 kB view details)

Uploaded Source

Built Distribution

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

jangada-0.1.6-py3-none-any.whl (54.5 kB view details)

Uploaded Python 3

File details

Details for the file jangada-0.1.6.tar.gz.

File metadata

  • Download URL: jangada-0.1.6.tar.gz
  • Upload date:
  • Size: 91.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for jangada-0.1.6.tar.gz
Algorithm Hash digest
SHA256 fd7c4727ec768db7e473b56f03e29e3a92bb1c3b7cfc22d3a3a814519ddc417b
MD5 422cbdf66e06a61ef08a1662cdcba2cd
BLAKE2b-256 356fba74b2df5ae20a92a37415bf518b172e1cd79ffb08ed21030aebd2b2789b

See more details on using hashes here.

File details

Details for the file jangada-0.1.6-py3-none-any.whl.

File metadata

  • Download URL: jangada-0.1.6-py3-none-any.whl
  • Upload date:
  • Size: 54.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for jangada-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 4d060db9c364cd0496372e8762f05e3b059c69c1f0009235f9f51ac59c843ec3
MD5 0d6731851bee548b0b525f8c4c127659
BLAKE2b-256 2739eb04f4c41c0e86242955ede2b2064877779f4a218657be16056f6af96407

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