A package to calculate gas emissions fluxes from natural and anthropogenic sources
Project description
GasFlux
pip install gasflux
gasflux --help
GasFlux is a tool for processing atmospheric gas concentration data and windspeeds into mass emissions fluxes, with principle applications to greenhouse gas measurement and vulcanology. Currently it works with in situ ("sniffing") data from UAVs and other aircraft, using mass balance as a paradigm and kriging as an interpolation strategy, but the intention is to expand this to other kinds of sampling and processing strategies, such as open-path and tracer methods.
It is released under the AGPLv3 license as a free and open-source project - comments, pull requests, issues and co-development are warmly welcomed. Currently development is co-ordinated by Jamie McQuilkin (@pipari) at the UAV Greenhouse Gas group at the University of Manchester.
User Installation
The package is available on PyPi and can be installed using pip install gasflux.
Usage
The package interface is in active development. Currently it ingests a data csv file (or folder containing only data csv files) and a config file that dictates the parameters of the analysis.
This is done through the syntax gasflux process <input_file> --config <config_file>.
The config file
The default gasflux_config.yaml is located in the package source. It can be generated in a supplied directory using gasflux generate-config <path>. If a directory is supplied to gasflux process and a config is not also explicitly supplied, the package will look for one config file in that directory or its subdirectories and attempt to process all csv files in that directory and subdirectories. If multiple or no config is found, it will raise an error. If supplying a single csv file for processing (rather than a directory), only the parent directory will be searched for config files (not its subdirectories).
Through it, variables can be passed to the scikit-gstat package used for kriging and the pybaselines package used for background correction.
The data file
Input data files must be csv-type (i.e. readable by pandas) and have the following columns (all lower case):
timestamp(datetime)latitude(float)longitude(float)height_ato(float) - height above takeoffwindspeed(float) - in m/s, as measured or inferred at each measurement pointwinddir(float) - in standard 0-360 degree format, relative to the earthtemperature(float) in degrees celsiuspressure(float) - in hPa/mBar
At least one gas concentration in ppm is also required. The column name should be the gas name, e.g. co2, ch4, n2o, etc.
The gas should be entered in the gasflux_config.yaml file along with a range of concentrations in ppmv, e.g.:
gases:
ch4: [1.5, 500]
co2: [300, 5000]
c2h6: [-0.5, 10]
Ensuring input data are sufficient and correctly formatted is non-trivial and important, but is left to the user. Data sources vary enormously so it is difficult to generalise this part of the analysis - in many cases these will be a mix of flight logs, GPS, one or more anemometers, one or more gas sensors, a thermometer, hygrometer, barometer.
Synchronisation and fusion of these data sources is important and should be given great attention - there are several ways to do this, including GPS logging on each sensor, recording everything on a single device, or NTP server synchronisation. Care should also be taken to avoid loss of data through resampling or interpolation.
One way to convert encoded DJI logs is to use djiparsetext, a C++ library available on github here and documented here.
Development
Installation
To install, clone the repository using e.g. git clone and use pip install -e . to install it as an editable python package.
It's highly recommended to use a virtual environment to manage dependencies. If you're not currently using one, virtualenvwrapper is a good option.
Then run pip install -r requirements.txt and pip install -r dev-requirements.txt to install the required dependencies.
User requirements.txt is generated using pigar generate rather than pip freeze.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gasflux-0.2.2.tar.gz.
File metadata
- Download URL: gasflux-0.2.2.tar.gz
- Upload date:
- Size: 290.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bbcb4260c95220a154c1c75def986af75cd1cbb19ab7d51fc554e08907687b64
|
|
| MD5 |
4499eb321e8ce542b4b9edc411449f10
|
|
| BLAKE2b-256 |
f5469db5c4cd7756a291191e6aefbeee1061a9f60557c40e77cc946fbf6ead3a
|
Provenance
The following attestation bundles were made for gasflux-0.2.2.tar.gz:
Publisher:
build-release.yml on gasflux/gasflux
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
gasflux-0.2.2.tar.gz -
Subject digest:
bbcb4260c95220a154c1c75def986af75cd1cbb19ab7d51fc554e08907687b64 - Sigstore transparency entry: 219183683
- Sigstore integration time:
-
Permalink:
gasflux/gasflux@58469ebd8290b75322d0b3428ef0d0d901306ce7 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/gasflux
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build-release.yml@58469ebd8290b75322d0b3428ef0d0d901306ce7 -
Trigger Event:
push
-
Statement type:
File details
Details for the file gasflux-0.2.2-py3-none-any.whl.
File metadata
- Download URL: gasflux-0.2.2-py3-none-any.whl
- Upload date:
- Size: 284.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
af3ee7b96a2a7706f78e7f97fe7828ecbae67538e8302f2bd60cf6bbe3919e75
|
|
| MD5 |
fd99b55c11811d9f35bc3e8d9897ec58
|
|
| BLAKE2b-256 |
0fb58c169ed0d6e07c6d749dddce4a6e4853f463b80360001f8e2e432bd5210d
|
Provenance
The following attestation bundles were made for gasflux-0.2.2-py3-none-any.whl:
Publisher:
build-release.yml on gasflux/gasflux
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
gasflux-0.2.2-py3-none-any.whl -
Subject digest:
af3ee7b96a2a7706f78e7f97fe7828ecbae67538e8302f2bd60cf6bbe3919e75 - Sigstore transparency entry: 219183684
- Sigstore integration time:
-
Permalink:
gasflux/gasflux@58469ebd8290b75322d0b3428ef0d0d901306ce7 -
Branch / Tag:
refs/heads/main - Owner: https://github.com/gasflux
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
build-release.yml@58469ebd8290b75322d0b3428ef0d0d901306ce7 -
Trigger Event:
push
-
Statement type: