Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/transition-zero/feo-client
A client repository for accessing FEO data programmatically.
https://github.com/transition-zero/feo-client
Last synced: about 1 month ago
JSON representation
A client repository for accessing FEO data programmatically.
- Host: GitHub
- URL: https://github.com/transition-zero/feo-client
- Owner: transition-zero
- License: apache-2.0
- Created: 2023-02-03T08:50:06.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-06-25T12:01:03.000Z (6 months ago)
- Last Synced: 2024-10-29T16:17:22.487Z (2 months ago)
- Language: Python
- Homepage: https://docs.feo.transitionzero.org
- Size: 2.04 MB
- Stars: 22
- Watchers: 4
- Forks: 4
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE-OF-CONDUCT.md
Awesome Lists containing this project
- open-sustainable-technology - feo-client - Crafted for energy systems modellers seeking access to data for nodes, assets, technologies, as well as the data supporting models and scenarios published by TransitionZero. (Energy Systems / Energy Data Accessibility and Integration)
README
# TransitionZero Python Client
[![License][license badge]][license]
[![Contributor Covenant][contributor covenant badge]][code of conduct]
![Tests][tests badge]
![Coverage][coverage badge]
![Python][python badge]
![Status][status badge][license badge]: https://img.shields.io/badge/License-Apache_2.0-blue.svg
[license]: https://opensource.org/licenses/Apache-2.0[contributor covenant badge]: https://img.shields.io/badge/Contributor%20Covenant-2.1-4baaaa.svg
[code of conduct]: https://github.com/transition-zero/tz-client/blob/main/CODE-OF-CONDUCT.md[tests badge]: https://img.shields.io/endpoint?url=https://gist.githubusercontent.com/Lkruitwagen/feffb38d46c750cad5402dca5dd54bf9/raw/tests_passing.json
[coverage badge]: https://img.shields.io/endpoint?url=https://gist.githubusercontent.com/Lkruitwagen/d2b6ec23e3c6e8309236216689d91782/raw/coverage_badge.json
[python badge]: https://img.shields.io/endpoint?url=https://gist.githubusercontent.com/Lkruitwagen/bd1e357c1bce5fc2c0808bcdb569157c/raw/python_version_badge.json
[status badge]: https://img.shields.io/badge/under%20construction-ffae00
**Documentation**: https://docs.feo.transitionzero.org
**API Reference**: https://api.feo.transitionzero.org/latest/docs
**Model Builder**: https://feo.transitionzero.org
---
TransitionZero is building an open-access energy transition research platform.
This Python Client gives programmatic access to all the functionality of the TransitionZero platform:* **Open Data**: Asset-level and historical data free to access, forever.
* **No-barriers Systems Modelling**: Begin asking your energy transition research questions with a simple UI or a few lines of code.
* **Transparent Data Provenance**: Trace all data back to its origin.
* **Reproduceable**: Built with open-source systems modelling frameworks, with transparent or user-defined assumptions.
* **Social and Shareable**: Share systems models reports publicly and star your favourites.
* **Analysis-Ready Outputs**: Download analysis-ready spreadsheets.
* **Flagship Analysis**: Access premier research outputs prepared by TransitionZero researchers.---
## Installation
The latest release of the TZ Python Client can be installed via `pip`.
pip install tz-client
The client can also be installed from this repo, for any features not yet available via the Python Package Index:
pip install git+https://github.com/transition-zero/tz-client.git@main
## Authentication
To access resources via the Python Client you must have a (free) account. An account can be created [here](https://feo.transitionzero.org).
To log in for programmatic access, use the tz command-line tool:
tz auth login
You'll be invited to login via a browser, verify a device code and then will be redirected to your terminal.
An access token will be stored in your machine's home directory at `.tz/token.json`.The tz login can also be called directly (for example via a Jupyter notebook):
from tz.client.auth import login
login()## Quickstart
The TZ client provides object-level interfaces to the main TZ building blocks. Users may also use the underlying API wrapper.
### Accessing node-level data
In the TZ platform, all data is indexed to a `Node`. Nodes are used to represent useful physical and administrative boundaries - ranging from individual physical assets through to entire countries and continents. This flexibility allows TZ users to access data at all levels of aggregation via the TZ platform .
In the physics of systems modelling, Nodes are discrete units around which the continuity of energy and materials is constrained. In other words, at every node in a systems model, the input plus supply to the node must equal the output plus demand.
To begin, import the `Node` client.
```
from tz.client import Node
```The `Node.search` method can be used to search for Nodes.
```
Node.search("Indonesia")
```Each search result is an instance of the `Node` object.
```
IDN = Node.search("Indonesia")[0]
IDN
```Nodes have an `uuid` which is unique. Nodes can have many names (or `aliases`), one of which is attached to the node as a primary English name.
```
IDN.uuid, IDN.primary_alias
```### Accessing asset-level data
In the TZ platform, `Assets` are a subset of Nodes. Assets are Nodes which correspond to physical plant and equipment like power stations and steelworks.
To begin, import the Asset client.
```
from tz.client import Asset
```Like nodes, assets can be searched for:
```
search_results = Asset.search("Banten Suralaya power", sector="power")
for asset in search_results:
print(asset.id, asset.name_primary_en)
```... or directly instantiated:
```
asset = Asset.from_id("PWRCOAIDNA0U0")
asset.id, asset.name_primary_en
```### Accessing historical data
### Accessing systems models and reports
System Models are representations of energy and material flows, usually optimised by economic logic like least-costs-minimisation.
System models in the TransitionZero platform are composed of three objects - Models, Scenarios, and Runs.
- **Models** describe the geographic, temporal, and sectoral scope of the systems model.
- **Scenarios** are narrative counter-factuals of the future, which may be accompanied by numeric projections
- **Runs** are solutions to parameterised systems models, used to explore uncertaintyModels, Scenarios, and Runs can be imported from the client:
```
from tz.client import Model, Scenario, Run
```The `Model` client can be used to search and retrieve model objects.
```
Model.search(model_slug='feo-indonesia')
```Models can also be retrieved directly by id
```
idn_model = Model.from_slug(owner="feo-core-admin", slug='feo-indonesia')
```Scenarios associated can also be retrieved from the model object.
```
idn_model.model_scenarios
```... as can the runs associated with scenarios
```
run = idn_model.model_scenarios[0].runs
```## Documentation
The full documentation for the TZ platform can be found here: https://docs.feo.transitionzero.org
## Contributing
See the [Contributing Guide](CONTRIBUTING.md) and our [Code of Conduct](CODE-OF-CONDUCT.md).
## License
[Apache license 2.0](LICENSE)