Skip to main content

Measured data visualization and pipelines creation

Project description

CorrAI

PyPI Static Badge codecov Ruff License Documentation Status

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 python-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=True)
fig.show(None)

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_name": "Prophet",
                    "resample_at_td": "1h",
                    "gaps_gte": "3h",
                    "gaps_lte": "3d"
                }
            ]
        ]
    }
}

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=None,
    plot_gaps=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=None,
    plot_gaps=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.5.tar.gz (57.8 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.5-py3-none-any.whl (60.9 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for python_tide-0.1.5.tar.gz
Algorithm Hash digest
SHA256 4389196fe8b0c0b4c0c7e259be7f45c000de58cde39741d342d1d5251f15a89a
MD5 256d78c83b6259f454b2f0c198d0bd0a
BLAKE2b-256 59d6fc0e229231519f0c8fa8b6c2ff05de0289a3f1145b280eb7332856a9bc70

See more details on using hashes here.

Provenance

The following attestation bundles were made for python_tide-0.1.5.tar.gz:

Publisher: build.yaml on BuildingEnergySimulationTools/tide

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

File details

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

File metadata

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

File hashes

Hashes for python_tide-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 2edbd241b5e3fbbd9d6ff8520ac8eab591cd96088747f12312fc20c075412adb
MD5 347cf9bc5ee7b9324c2609d0e478fe06
BLAKE2b-256 22d9775391d775251e9a73bd3931a3d2792256b826afb99ef1017b0858f2d928

See more details on using hashes here.

Provenance

The following attestation bundles were made for python_tide-0.1.5-py3-none-any.whl:

Publisher: build.yaml on BuildingEnergySimulationTools/tide

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