Skip to main content

Python framework to manage time series structured as one-level dictionaries.

Project description

Gregory

Python Framework to Manage Time Series structured as one-level dictionaries.

Overview

This framework is an extension of the OUTATIME package to facilitate operations on time series built as dictionaries.

The main requirement is that the data attribute of the dataclass TimeSeriesData is a one-level dictionary.

E.g.

TimeSeriesData(
    day=date('2022-04-28'),
    date={
        'gold': 1887.77,
        'silver': 23.03
    }
)

Some features are added such as:

  • interpolation of missing data
  • trend and seasonality calculation
  • methods of aggregation between dictionaries
  • other

Installation

pip install gregory

Framework Structure

gregory
├── dataclass
│   └── time_series_data.py --> Class used to manage daily data.
│
├── granularity
│   ├── granularity.py --> Set of classes used for managing time intervals of different length.
│   ├── granularity_factory.py --> Factory class for creating granularity objects.
│   └── utils.py --> Utils related to granularities.
│
├── timeseries
│   ├── batches.py --> Set of methods to operate on time series dividing them into batches.
│   ├── expr.py --> Set of operations between time series.
│   ├── processing.py --> Set of methods to elaborate time series.
│   └── time_series.py --> Core class that represents a series of daily records.
│
└── util
    ├── agenda.py --> Utils related to calendar info and evalutations.
    ├── bisect.py --> Utils related to binary search.
    ├── decorators.py --> Useful decorators.
    ├── dictionaries.py --> Utils related to operations on dictionaries.
    └── relativedelta.py --> Class that extends relativedelta with useful properties.

License

MIT license, see LICENSE file.

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

gregory-2.1.1.tar.gz (12.1 kB view details)

Uploaded Source

Built Distribution

gregory-2.1.1-py3-none-any.whl (15.7 kB view details)

Uploaded Python 3

File details

Details for the file gregory-2.1.1.tar.gz.

File metadata

  • Download URL: gregory-2.1.1.tar.gz
  • Upload date:
  • Size: 12.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.8.13

File hashes

Hashes for gregory-2.1.1.tar.gz
Algorithm Hash digest
SHA256 75be07612e8fd737095dd393b129dd3ed579b4431411a4dda515ea0bf5b6b2b2
MD5 2e5f0768164f2a48864e1d483281060a
BLAKE2b-256 26d828f9c03c14b0ee67ef7a4d7b3dcb00351c740f2e93c33f34c71b8ad9043e

See more details on using hashes here.

File details

Details for the file gregory-2.1.1-py3-none-any.whl.

File metadata

  • Download URL: gregory-2.1.1-py3-none-any.whl
  • Upload date:
  • Size: 15.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.8.13

File hashes

Hashes for gregory-2.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c63d2b3a67769c241897e0f28ffdd15dc64d71547379fb40373dcb3b8d27d557
MD5 e002da69f3dae8981d5b7d0454bcc08f
BLAKE2b-256 89247870924e11503c26c45e1feab10fbe372354b7a808a50f2a8c870cebf1ce

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