Skip to main content

A tiny DSL for calendar interval algebra - compose, filter, and query time ranges using set operations.

Project description

calgebra 🗓️

A tiny DSL for merging and searching over calendar-like intervals.

Installation

pip install calgebra

# Or with Google Calendar support
pip install calgebra[google-calendar]

Quick Start

from datetime import datetime, timezone
from calgebra import day_of_week, time_of_day, hours, HOUR

# Compose time windows from primitives
weekdays = day_of_week(["monday", "tuesday", "wednesday", "thursday", "friday"])
work_hours = time_of_day(start=9*HOUR, duration=8*HOUR, tz="US/Pacific")
business_hours = weekdays & work_hours

# Union: combine busy times (in practice: from Google Calendar, databases, etc.)
monday_meetings = day_of_week("monday") & time_of_day(start=10*HOUR, duration=2*HOUR)
friday_focus = day_of_week("friday") & time_of_day(start=14*HOUR, duration=3*HOUR)
busy = monday_meetings | friday_focus

# Difference: find free time during business hours
free = business_hours - busy

# Filter: only slots >= 2 hours
long_slots = free & (hours >= 2)

# Fetch results with slice notation (supports int, datetime, or date)
start = datetime(2025, 1, 1, tzinfo=timezone.utc)
end = datetime(2025, 1, 31, tzinfo=timezone.utc)
meeting_options = list(long_slots[start:end])

Intervals in calgebra are inclusive of both start and end—durations therefore reflect every second covered by an interval. Timeline slices accept integer seconds (Unix timestamps), timezone-aware datetime objects, or date objects. When you subclass Interval, define your subclass as a dataclass (ideally frozen=True) so the algebra can clone and clamp events internally.

Common helpers and aggregates are exposed alongside the core DSL:

Recurring Patterns (RFC 5545 via python-dateutil):

  • recurring(freq, ...) generates intervals based on recurrence rules (weekly, bi-weekly, monthly, etc.)
  • day_of_week(days, tz) convenience wrapper for filtering by day(s) of week
  • time_of_day(start, duration, tz) convenience wrapper for daily time windows
  • HOUR, MINUTE, DAY, SECOND constants for readable time specifications
  • Compose with & to create complex patterns like business hours, recurring meetings, etc.

Aggregation & Analysis:

  • flatten(timeline) converts overlapping/adjacent spans into a coalesced timeline (returns mask Intervals and must be sliced with explicit bounds)
  • union(*timelines) / intersection(*timelines) offer functional set operations
  • total_duration sums inclusive coverage inside a window
  • max_duration / min_duration find the longest or shortest clamped intervals
  • count_intervals tallies events over a slice
  • coverage_ratio reports utilization as a 0–1 fraction

Transformations:

  • buffer(timeline, before, after) adds buffer time around each interval (useful for travel time, setup/teardown)
  • merge_within(timeline, gap) coalesces intervals separated by at most gap seconds (useful for grouping related events)

Integrations:

  • calgebra.gcsa.Calendar provides Google Calendar integration with timezone normalization and automatic paging; it assumes locally stored OAuth credentials

Read the full tutorial for a complete guide to the DSL
API Reference for detailed function signatures and parameters

Status

calgebra is in beta (v0.1.0). The core API is stable and ready for use. Feedback and contributions are welcome!

License

MIT License - see LICENSE file for details.

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

calgebra-0.1.0.tar.gz (41.8 kB view details)

Uploaded Source

Built Distribution

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

calgebra-0.1.0-py3-none-any.whl (33.9 kB view details)

Uploaded Python 3

File details

Details for the file calgebra-0.1.0.tar.gz.

File metadata

  • Download URL: calgebra-0.1.0.tar.gz
  • Upload date:
  • Size: 41.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for calgebra-0.1.0.tar.gz
Algorithm Hash digest
SHA256 557d5d357d8302feec6ee6d98335fbdf4b4f8e7a391dcb5c3065d2012a5efd98
MD5 a47904e632cdc0bb82ed18a7ce3f9f8d
BLAKE2b-256 92db79e41a835318b0d019f9fefb91b6eba5c338a799bf3f677179b593d40204

See more details on using hashes here.

File details

Details for the file calgebra-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: calgebra-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 33.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.11

File hashes

Hashes for calgebra-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 86a3e4463471317eb55eff422bd6639671e23466cc8225d4dea237d0bf3c4517
MD5 65d397d6c7d8be7a6b8d7100239fbbba
BLAKE2b-256 bc08d98d7829ebfee3eda6bb8a74ec491de024fafd265cae3baf3a628e9673d6

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