Skip to main content

Collection of dynamic characterization functions for life cycle inventories with temporal information

Project description

dynamic_characterization

Read the Docs PyPI - Version Conda Version Conda - License

This is a collection of dynamic characterization functions for life cycle inventories with temporal information.

Here's an overview of what is currently included:

impact category metric covered emissions source
climate change radiative forcing CO2, CH4 bw_temporalis
climate change radiative forcing 247 GHGs from IPCC AR6 Ch.7 bw_timex

What do dynamic characterization functions do?

The functions are meant to work with a common input format of the dynamic inventory, collected in a pandas DataFrame that looks like this:

date amount flow activity
101 33 1 2
312 21 4 2

Each function takes one row of this dynamic inventory dataframe (i.e. one emission at one point in time) and transform it according to some metric. The output generated by applying a very simple function to both rows of the input dataframe could look like:

date amount flow activity
101 33 1 2
102 31 1 2
103 31 1 2
312 21 4 2
313 20 4 2
314 19 4 2

What do dynamic characterization functions look like?

Here's an example of what such a function could look like:

def characterize_something(series, period: int = 100, cumulative=False) -> pd.DataFrame:
    date_beginning: np.datetime64 = series.date.to_numpy()
    dates_characterized: np.ndarray = date_beginning + np.arange(
        start=0, stop=period, dtype="timedelta64[Y]"
    ).astype("timedelta64[s]")

    # let's assume some simple decay function
    decay_multipliers: list = np.array(
        [
            1.234 * (1 - np.exp(-year / 56.789))
            for year in range(period)
        ]
    )

    forcing = np.array(series.amount * decay_multipliers, dtype="float64")

    if not cumulative:
        forcing = np.diff(forcing, prepend=0)

    return pd.DataFrame(
        {
            "date": np.array(dates_characterized, dtype="datetime64[s]"),
            "amount": forcing,
            "flow": series.flow,
            "activity": series.activity,
        }
    )

Installation

You can install dynamic_characterization via [pip] from [PyPI]:

$ pip install dynamic_characterization

Alternatively, you can also use conda:

$ conda install -c diepers dynamic_characterization

Contributing

Contributions are very welcome. To learn more, see the Contributor Guide.

License

Distributed under the terms of the BSD 3 Clause license, dynamic_characterization is free and open source software.

Issues

If you encounter any problems, please file an issue along with a detailed description.

Support

If you have any questions or need help, do not hesitate to contact Timo Diepers (timo.diepers@ltt.rwth-aachen.de)

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

dynamic_characterization-0.0.3.tar.gz (13.3 kB view details)

Uploaded Source

Built Distribution

dynamic_characterization-0.0.3-py3-none-any.whl (14.5 kB view details)

Uploaded Python 3

File details

Details for the file dynamic_characterization-0.0.3.tar.gz.

File metadata

File hashes

Hashes for dynamic_characterization-0.0.3.tar.gz
Algorithm Hash digest
SHA256 a466490d5f39b09ce40bc4d324ed2be49a5ec6cdf458fabb3e6eeea12ef977ff
MD5 d63c1a1d7c41bc167efa3f71d578374a
BLAKE2b-256 b1866af164751959e94b8e691bae903a14f50cd400ef8dbe5b05c3ad1928a3bf

See more details on using hashes here.

File details

Details for the file dynamic_characterization-0.0.3-py3-none-any.whl.

File metadata

File hashes

Hashes for dynamic_characterization-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 bf6b6dd67ad99c979433bd6a8c427da8dba1a143e4abb4ff8f7d02951253b44a
MD5 96cd6600bb748f06830c8e05ee4450f2
BLAKE2b-256 685fd49c641c06cafc3a61a1f11500a77a620c04b1cdaeb50e8acb984eff27ec

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