Skip to main content

Measured data visualization and pipelines

Project description

CorrAI

PyPI Static Badge codecov Ruff License

Pipeline Development and Data Visualization for Time Series in Physical Measurements

Tide is a tool for developing data processing pipelines and visualizing time series data, particularly suited for physical measurements. Key features include:

  • Efficient Data Management

    • Organize and select data using a tagging system
  • Pipeline Construction

    • Store and retrieve pipelines easily with JSON-based dictionary structures
    • Build dynamic pipelines that adjust based on the selected data
  • Interactive Visualization

    • Create interactive plots to explore data (plotly)
    • Visualize pipeline or slices of pipelines effects on data
  • Custom Data Enrichment

    • Integrate external weather data sources
    • Implement autoregressive models for gaps filling
    • Develop and incorporate custom data processors

Uses pandas DataFrames and Series for robust data handling. bigtree for tags and data selection. Scikit-learn's API for pipeline construction.

Getting started

1- Install ⬇️

pip install tide

2- Load and format data 🌲

To begin, load your time series data into a pandas DataFrame, ensuring the index is a DateTimeIndex:

df = pd.read_csv(
    "https://raw.githubusercontent.com/BuildingEnergySimulationTools/tide/main/tutorials/getting_started_ts.csv",
    parse_dates=True,
    index_col=0
)

Rename columns using Tide's tagging system. The format is: name__unit__bloc__sub_bloc with tags separated by double underscores. The order of the tags matters. The order of tags is important, and you can use "OTHER" as a placeholder You can use one or several tags.

df.columns = ["Tin__°C__Building", "Text__°C__Outdoor", "Heat__W__Building"]

Plumber objects are used to help us with pipelines building and data visualization

from tide.plumbing import Plumber

plumber = Plumber(df)

Display the data organization as a tree:

plumber.show()

Select data using tags:

plumber.get_corrected_data("°C")
plumber.get_corrected_data("Building")
plumber.get_corrected_data("Tin")

3- Visualizing data 📈

Show data availability:

plumber.plot_gaps_heatmap(time_step='d')

Plot time series with missing data highlighted:

fig = plumber.plot(plot_gaps_1=True)
fig.show()

4- Building and testing Pipelines 🛠️

Create a pipeline dictionary:

pipe_dict = {
    "step_1": [["Common_proc_1"], ["Common_proc_2", ["arg1", "arg2"]]],
    "step_2": {
        "selection_1": [["Proc_selection_1", {"arg": "arg_value"}]]
    }
}

Pipeline Rules:

  • Use dictionaries for pipeline description
  • Keys represent pipeline steps ex. "step_1"
  • Step values can be lists (apply to all columns) or dicts (filter columns)
  • Processing objects are listed as [class_name, arguments]

Example Pipeline:

  • Resample data to 15-minute intervals
  • Interpolate temperature gaps ≤ 3 hours
  • Fill large Tin gaps using Autoregressive STLForecast
pipe_dict = {
    "resample_15min": [["Resample", ["15min"]]],
    "interpolate_temps": {
        "°C": [["Interpolate", {"gaps_lte": "3h"}]]
    },
    "ar_tin": {
        "Tin": [
            [
                "FillGapsAR",
                {
                    "model_kwargs": {
                        "ar_kwargs": {"order": (4, 1, 2), "trend": "t"},
                        "seasonal": "2d",
                        "trend": "2d",
                    }
                },
            ],
        ],
    }
}

plumber.pipe_dict = pipe_dict

Get pipeline using get_pipeline method.

plumber.get_pipeline(verbose=True)

Get pipelines for specific columns

plumber.get_pipeline(select="Building", verbose=True)

Visualize pipeline effects:

plumber.plot(
    steps_1=None,
    plot_gaps_1=True,
    steps_2=slice(None, "interpolate_temps"),
    plot_gaps_2=True,
    verbose=True
)

Step Arguments:

  • None: No operation (Identity)
  • str: Process until named step
  • list[str]: Perform specified steps
  • slice: Process a slice of the pipeline

Compare full pipeline to raw data:

plumber.plot(
    steps_1=None,
    plot_gaps_1=True,
    steps_2=slice(None),
    plot_gaps_2=True,
    verbose=True
)

Sponsors

eu_flag The development of this library has been supported by ENSNARE Project, which has received funding from the European Union’s Horizon 2020 Research and Innovation Programme under Grant Agreement No. 953193. The sole responsibility for the content of this library lies entirely with the author’s view. The European Commission is not responsible for any use that may be made of the information it contains.

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

python_tide-0.1.0.tar.gz (41.5 kB view details)

Uploaded Source

Built Distribution

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

python_tide-0.1.0-py3-none-any.whl (36.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: python_tide-0.1.0.tar.gz
  • Upload date:
  • Size: 41.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.0

File hashes

Hashes for python_tide-0.1.0.tar.gz
Algorithm Hash digest
SHA256 48ff2872dd868df33e4798c2b736c68e2d1cb8cb1b6a3fd39f7c0752369067ef
MD5 15b947f85142564acb9afaf8325e68cc
BLAKE2b-256 57241027aa5b09d380e838beec04e81d63bdee2a8ae4daaecfd7ffd853e24a38

See more details on using hashes here.

File details

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

File metadata

  • Download URL: python_tide-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 36.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.0

File hashes

Hashes for python_tide-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e054b0eb87fa5970ba2b22f6d32a9c62f1144caf57974e53412bbf79325b72bf
MD5 e9ad75f1d83cc6c2b583ad2e97adccb3
BLAKE2b-256 d970a9b36d8e08adb0142c5c0770360bcbbc8759694f1e15dc2f5df701fbf56c

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