Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/flechtenberg/pulpo

Python package for lifecycle optimization
https://github.com/flechtenberg/pulpo

brightway ecoinvent lca lifecycle optimization pyomo

Last synced: about 1 month ago
JSON representation

Python package for lifecycle optimization

Awesome Lists containing this project

README

        




โ—ฆ Python-based User-defined Lifecycle Production Optimization!


โ—ฆ Developed with the software and tools below.



Jupyter
Python
Markdown


GitHub license
git-last-commit
GitHub commit activity
GitHub top language

---

## ๐Ÿ“– Table of Contents
- [๐Ÿ“ Overview](#-overview)
- [โš™๏ธ Modules](#modules)
- [๐Ÿš€ Getting Started](#-getting-started)
- [๐Ÿ”ง Installation](#-installation)
- [๐Ÿค– Running pulpo](#-running-pulpo)
- [๐Ÿงช Tests](#-tests)
- [๐Ÿ›ฃ Roadmap](#-roadmap)
- [๐Ÿค Contributing](#-contributing)
- [๐Ÿ“„ License](#-license)
- [๐Ÿ‘ Acknowledgments](#-acknowledgments)

---

## ๐Ÿ“ Overview

Pulpo is a comprehensive Life Cycle Optimization (LCO) tool designed to streamline the optimization of environmental impacts across the entire lifecycle of products. It facilitates the import of data from the LCI databases accessed via brightway, converts inputs into optimization-ready formats, defines and solves optimization models using the Pyomo package, and saves and summarizes results. Pulpo empowers users to efficiently optimize and analyze environmental impacts, supporting sustainable decision-making through lifecycle-based strategies.

---

## โš™๏ธ Modules

Root

| File | Summary |
| --- | --- |
| [.gitconfig](https://github.com/flechtenberg/pulpo/blob/main/.gitconfig) | This code fragment configures a git filter to clean Jupyter Notebook files in the.gitconfig file. It uses the Jupyter nbconvert command to remove the output cells and smudge to display the file's contents. | |
| [pulpo.py](https://github.com/flechtenberg/pulpo/blob/main/pulpo\pulpo.py) | The code implements a PulpoOptimizer class that provides functionalities for data import, optimization, solving, retrieval, saving and summarizing results related to life cycle assessments. It uses modules like optimizer, bw_parser, converter, and saver for different operations. |
| [bw_parser.py](https://github.com/flechtenberg/pulpo/blob/main/pulpo\utils\bw_parser.py) | The code in `bw_parser.py` provides functions for importing, saving, and retrieving life cycle inventory (LCI) data from the Ecoinvent database using the Brightway2 library. It includes functions for importing data, checking if data needs to be reloaded, performing LCA calculations, saving LCI data to files, and reading LCI data from files. Additionally, it provides functions for retrieving activities and environmental flows from the database based on specified criteria. |
| [converter.py](https://github.com/flechtenberg/pulpo/blob/main/pulpo\utils\converter.py) | The code in pulpo\utils\converter.py combines various inputs into a dictionary for an optimization model. It converts sparse matrices to dictionaries, modifies the technosphere matrix, creates sets, specifies demand, limits, and supply, assigns weights, and assembles the final data dictionary for the model. This function serves as a crucial step in preparing the inputs for the optimization process. |
| [optimizer.py](https://github.com/flechtenberg/pulpo/blob/main/pulpo\utils\optimizer.py) | The code defines an optimization model using the pyomo package. It includes sets, parameters, variables, constraints, and an objective function. The model is created and solved using different solvers. |
| [saver.py](https://github.com/flechtenberg/pulpo/blob/main/pulpo\utils\saver.py) | The code provides two main functionalities:1. save_results: Saves the results of a Pyomo model to an Excel file, including raw results, metadata, and constraints.2. summarize_results: Prints a summary of the model results, including demand, impacts, choices, and constraints. |

---

## ๐Ÿš€ Getting Started

### ๐Ÿ”ง Installation
PULPO has been deployed to the pypi index and can now be installed via:
```sh
pip install pulpo-dev
```

### ๐Ÿค– Running pulpo
See [pypi](https://pypi.org/project/pulpo-dev/) for a description of how to use PULPO via pip.

Find example notebooks for a [hydrogen case](https://github.com/flechtenberg/pulpo/blob/master/notebooks/hydrogen_showcase.ipynb), an [electricity case](https://github.com/flechtenberg/pulpo/blob/master/notebooks/electricity_showcase.ipynb), and a [plastic case](https://github.com/flechtenberg/pulpo/blob/master/notebooks/plastic_showcase.ipynb) here.

There is also a "workshop" repository ([here](https://github.com/flechtenberg/pulpo_workshop)), which has been created for the Brightcon 2024 conference. It contains several notebooks that guide you through the PULPO package and its functionalities, as well as an exercise.

### ๐Ÿงช Tests

Calling from the package folder:

```sh
python -m unittest discover -s tests
```

### Updates
> - [ ] `โ„น๏ธ The package is currently under development.`

---

## ๐Ÿ›ฃ Roadmap

> - [ ] `โ„น๏ธ Task 1: Implement integer cuts to allow a fast calculation of a ranked list of best options`
> - [ ] `โ„น๏ธ Task 2: Implement functionality to treat uncertainty in the optimization problem (robust)`
> - [ ] `โ„น๏ธ ... Requests are welcome.`

---

## ๐Ÿค Contributing

Contributions are always welcome! Please follow these steps:
1. Fork the project repository. This creates a copy of the project on your account that you can modify without affecting the original project.
2. Clone the forked repository to your local machine using a Git client like Git or GitHub Desktop.
3. Create a new branch with a descriptive name (e.g., `new-feature-branch` or `bugfix-issue-123`).
```sh
git checkout -b new-feature-branch
```
4. Make changes to the project's codebase.
5. Commit your changes to your local branch with a clear commit message that explains the changes you've made.
```sh
git commit -m 'Implemented new feature.'
```
6. Push your changes to your forked repository on GitHub using the following command
```sh
git push origin new-feature-branch
```
7. Create a new pull request to the original project repository. In the pull request, describe the changes you've made and why they're necessary.
The project maintainers will review your changes and provide feedback or merge them into the main branch.

---

## ๐Ÿ“„ License

This project is licensed under the `โ„น๏ธ BSD 3-Clause` License. See the [LICENSE](LICENSE) file for additional info.
Copyright (c) 2024, Fabian Lechtenberg. All rights reserved.

---

## ๐Ÿ‘ Acknowledgments

We would like to acknowledge the authors and contributors of these main packages that pulpo is based on:
- [pyomo](https://github.com/Pyomo/pyomo)
- [brightway2](https://github.com/brightway-lca/brightway2)
---
## Authors
- [@flechtenberg](https://www.github.com/flechtenberg)
- [@robyistrate](https://www.github.com/robyistrate)
- [@vtulus](https://www.github.com/vtulus)
---
[โ†‘ Return](#Top)