Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/AugustinMortier/a-profiles
Python library for reading and processing Lidar and ceilometer data
https://github.com/AugustinMortier/a-profiles
aerosol ceilometer lidar python
Last synced: about 1 month ago
JSON representation
Python library for reading and processing Lidar and ceilometer data
- Host: GitHub
- URL: https://github.com/AugustinMortier/a-profiles
- Owner: AugustinMortier
- License: gpl-3.0
- Created: 2021-09-20T14:16:08.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2024-10-29T13:08:54.000Z (2 months ago)
- Last Synced: 2024-10-29T15:56:41.121Z (2 months ago)
- Topics: aerosol, ceilometer, lidar, python
- Language: Python
- Homepage: https://augustinmortier.github.io/a-profiles/
- Size: 59.8 MB
- Stars: 11
- Watchers: 1
- Forks: 1
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Citation: CITATION.cff
Awesome Lists containing this project
- open-sustainable-technology - A-Profiles - A python library dedicated to the analysis of atmospheric profilers measurements. (Atmosphere / Atmospheric Composition and Dynamics)
README
[![CI](https://github.com/AugustinMortier/A-Profiles/actions/workflows/ci.yml/badge.svg)](https://github.com/AugustinMortier/A-Profiles/actions/workflows/ci.yml)
[![Documentation Status](https://img.shields.io/badge/docs-online-brightgreen)](https://augustinmortier.github.io/a-profiles/)
[![codecov](https://codecov.io/gh/AugustinMortier/A-Profiles/branch/master/graph/badge.svg?token=CQH8TD7VES)](https://codecov.io/gh/AugustinMortier/A-Profiles)
Python library for reading and processing ALC (Automated Lidars and Ceilometers) measurements. A-Profiles supports [E-PROFILE](https://e-profile.eu/#/cm_profile) ceilometer data. This library is used by [V-Profiles](https://vprofiles.met.no).
## 📗 Documentation
The official documentation is available [here](https://augustinmortier.github.io/a-profiles/).## ✨ Installation
### via *pip*
*aprofiles* is directly available on *pip*. This will install the latest released version of *aprofiles* and its depencencies.- with *pip*
```
pip install aprofiles
```- with *pipx*
```
pipx install aprofiles
```### from source
1. clone this repository```
git clone https://github.com/AugustinMortier/A-Profiles.git
```2. installation
- with *pip* (>21.3)```
pip install .
```
- with *pipx*```
pipx install .
```- with *poetry*
```
poetry install
```In order to install directly the package from source with pip, you can also use the combined command
```
pip install "git+ssh://[email protected]/AugustinMortier/A-Profiles.git"
```## 🚀 Get started
### Reading Data
```python
# import library
import aprofiles as apro# read local NetCDF L2 data
path = "examples/data/E-PROFILE/L2_0-20000-006735_A20210908.nc"
profiles = apro.reader.ReadProfiles(path).read()
```### Basic corrections and Image plotting
```python
# extrapolate lowest layers for removing outliers
profiles.extrapolate_below(z=150, inplace=True)# image plotting of backscatter signal in log scale
profiles.plot(zref='agl', vmin=1e-2, vmax=1e1, log=True)
```### Profiles Analysis
```python
# fog/condensation detection
profiles.foc(zmin_cloud=200)# clouds detection
profiles.clouds(zmin=300, thr_noise=5, thr_clouds=4)# planetary boundary layer
profiles.pbl(zmin=200, zmax=3000, under_clouds=True)
```### Visualization
#### Image
```python
# image plotting with additional retrievals
profiles.plot(show_fog=True, show_clouds=True, show_pbl=True, vmin=1e-2, vmax=1e1, log=True)
```##### Single Profile
```python
# plot single profile at 21:20
datetime = np.datetime64('2021-09-09T21:20:00')
profiles.plot(datetime=datetime, vmin=-1, vmax=10, zmax=12000, show_clouds=True, show_pbl=True)
```## ⚖️ License
[GPL-3.0](LICENSE).## 🎓 Support
*A-Profiles* is developed by [MET Norway](https://github.com/metno) and supported by [EUMETNET](https://www.eumetnet.eu/).