All Projects → djgagne → hagelslag

djgagne / hagelslag

Licence: MIT license
Hagelslag is an object-based severe storm hazard forecasting system.

Programming Languages

Jupyter Notebook
11667 projects
python
139335 projects - #7 most used programming language
shell
77523 projects

Projects that are alternatives of or similar to hagelslag

verif
Software for verifying weather forecasts
Stars: ✭ 70 (+20.69%)
Mutual labels:  weather, verification
solar-weather
React Native Weather App w. Realm, Redux, ReasonReact & Forecast.io
Stars: ✭ 13 (-77.59%)
Mutual labels:  weather
leaflet-velocity
Visualise velocity data on a leaflet layer
Stars: ✭ 467 (+705.17%)
Mutual labels:  weather
civet
Continuous Integration, Verification, Enhancement, and Testing
Stars: ✭ 30 (-48.28%)
Mutual labels:  verification
meteofrance-api
Python client for Météo-France API. | Client python pour l'API Météo-France
Stars: ✭ 50 (-13.79%)
Mutual labels:  weather
klever
Read-only mirror of the Klever Git repository
Stars: ✭ 18 (-68.97%)
Mutual labels:  verification
openweather-laravel-api
Laravel OpenWeather API is a Laravel package to connect Open Weather Map API and get wether data in your own format laravel app.
Stars: ✭ 54 (-6.9%)
Mutual labels:  weather
WeatherApp MVI sample
🌸[Functional reactive programming (FRP)] 🍁Simple Android weather forecast application written in Kotlin, using RxKotlin, Retrofit2, Mosby, Room Persistence ❄️MVI Pattern with Mosby Library
Stars: ✭ 106 (+82.76%)
Mutual labels:  weather
link-verifier
A tool for verifying links in text-based files
Stars: ✭ 26 (-55.17%)
Mutual labels:  verification
yggdrasil
No description or website provided.
Stars: ✭ 26 (-55.17%)
Mutual labels:  verification
neural-network-lyapunov
Synthesizing neural-network Lyapunov functions (and controllers) as stability certificate.
Stars: ✭ 82 (+41.38%)
Mutual labels:  verification
info-bot
🤖 A Versatile Telegram Bot
Stars: ✭ 37 (-36.21%)
Mutual labels:  weather
LWClock
Multifunctional clock based on ESP8266 and MAX79xxx for Home Automation (IoT)
Stars: ✭ 40 (-31.03%)
Mutual labels:  weather
node-eorzea-weather
⛅ Weather forecast for Eorzea.
Stars: ✭ 14 (-75.86%)
Mutual labels:  weather
meteo-qt
System tray application for weather status information
Stars: ✭ 71 (+22.41%)
Mutual labels:  weather
passport-activedirectory
Active Directory strategy for passport.js
Stars: ✭ 28 (-51.72%)
Mutual labels:  verification
aprs-weather-submit
Manually submit weather station information to the APRS-IS network.
Stars: ✭ 17 (-70.69%)
Mutual labels:  weather
cuba-weather-python
Application programming interface of the Cuba Weather project implemented in Python
Stars: ✭ 17 (-70.69%)
Mutual labels:  weather
aw-clock
Astronomy/weather clock
Stars: ✭ 41 (-29.31%)
Mutual labels:  weather
raspberry-noaa
Fully automated ISS SSTV, NOAA and Meteor satellite image downloader using Raspberry PI
Stars: ✭ 155 (+167.24%)
Mutual labels:  weather

Hagelslag

Storm tracking, machine learning, and probabilistic evaluation

NSF-1261776

Hagelslag is an object-based severe storm forecasting system that utilizing image processing and machine learning tools to derive calibrated probabilities of severe hazards from convection-allowing numerical weather prediction model output. The package contains modules for storm identification and tracking, spatio-temporal data extraction, and machine learning model training to predict hazard intensity as well as space and time translations.

Citation

If you employ hagelslag in your research, please acknowledge its use with the following citations:

Gagne, D. J., A. McGovern, S. E. Haupt, R. A. Sobash, J. K. Williams, M. Xue, 2017: Storm-Based Probabilistic Hail
Forecasting with Machine Learning Applied to Convection-Allowing Ensembles, Wea. Forecasting, 32, 1819-1840. 
https://doi.org/10.1175/WAF-D-17-0010.1. 

Gagne II, D. J., A. McGovern, N. Snook, R. Sobash, J. Labriola, J. K. Williams, S. E. Haupt, and M. Xue, 2016: 
Hagelslag: Scalable object-based severe weather analysis and forecasting. Proceedings of the Sixth Symposium on 
Advances in Modeling and Analysis Using Python, New Orleans, LA, Amer. Meteor. Soc., 447.

If you discover any issues, please post them to the Github issue tracker page. Questions and comments should be sent to djgagne at ou dot edu.

Requirements

Hagelslag is compatible with Python 3.6 or newer. Hagelslag is easiest to install with the help of the Miniconda Python Distribution, but it should work with other Python setups as well. Hagelslag requires the following packages and recommends the following versions:

  • numpy >= 1.10
  • scipy >= 0.15
  • matplotlib >= 1.4
  • scikit-learn >= 0.16
  • pandas >= 0.15
  • arrow >= 0.8.0
  • pyproj
  • netCDF4-python
  • xarray
  • jupyter
  • ncepgrib2
  • pygrib
  • cython
  • pip
  • sphinx
  • mock

Install dependencies with the following commands:

git clone https://github.com/djgagne/hagelslag.git
cd ~/hagelslag
conda env create -f environment.yml
conda activate hagelslag

Installation

Install the latest version of hagelslag with the following command from the top-level hagelslag directory (where setup.py is): pip install .

Hagelslag will install the libraries in site-packages and will also install 3 applications into the bin directory of your Python installation.

Use

A Jupyter notebook is located in the demos directory that showcases the functionality of the package. For larger scale use, 3 scripts are provided in the bin directory.

  • hsdata performs object tracking and matching as well as data processing.
  • hsfore trains and applies machine learning models.
  • hseval performs forecast verification.

All scripts take input from a config file. The config file should be valid Python code and contain a dictionary called config. Custom machine learning models and parameters should be contained within the config files. Examples of them can be found in the config directory.

Documentation

API Documentation is available here.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].