Awesome
<p align="center"> <a href="https://github.com/pyronear/pyro-vision/actions/workflows/builds.yml"> <img alt="CI Status" src="https://img.shields.io/github/actions/workflow/status/pyronear/pyro-vision/builds.yml?branch=main&label=CI&logo=github&style=flat-square"> </a> <a href="https://pyronear.org/pyro-vision/"> <img src="https://img.shields.io/github/actions/workflow/status/pyronear/pyro-vision/docs.yaml?branch=main&label=docs&logo=read-the-docs&style=flat-square" alt="Documentation Status"> </a> <a href="https://codecov.io/gh/pyronear/pyro-vision"> <img src="https://img.shields.io/codecov/c/github/pyronear/pyro-vision.svg?logo=codecov&style=flat-square" alt="Test coverage percentage"> </a> <a href="https://github.com/ambv/black"> <img src="https://img.shields.io/badge/code%20style-black-000000.svg?style=flat-square" alt="black"> </a> <a href="https://www.codacy.com/gh/pyronear/pyro-vision/dashboard?utm_source=github.com&utm_medium=referral&utm_content=pyronear/pyro-vision&utm_campaign=Badge_Grade"><img src="https://app.codacy.com/project/badge/Grade/6835021037b04e8da919c646c1599f29"/></a> </p> <p align="center"> <a href="https://pypi.org/project/pyrovision/"> <img src="https://img.shields.io/pypi/v/pyrovision.svg?logo=python&logoColor=fff&style=flat-square" alt="PyPi Status"> </a> <a href="https://anaconda.org/pyronear/pyrovision"> <img alt="Anaconda" src="https://img.shields.io/conda/vn/pyronear/pyrovision?style=flat-square?style=flat-square&logo=Anaconda&logoColor=white&label=conda"> </a> <a href="https://hub.docker.com/r/pyronear/pyro-vision"> <img alt="Docker Image Version" src="https://img.shields.io/docker/v/pyronear/pyro-vision?style=flat-square&logo=Docker&logoColor=white&label=docker"> </a> <img src="https://img.shields.io/pypi/pyversions/pyrovision.svg?style=flat-square" alt="pyversions"> <img src="https://img.shields.io/pypi/l/pyrovision.svg?style=flat-square" alt="license"> </p>Pyrovision: wildfire early detection
The increasing adoption of mobile phones have significantly shortened the time required for firefighting agents to be alerted of a starting wildfire. In less dense areas, limiting and minimizing this duration remains critical to preserve forest areas.
Pyrovision aims at providing the means to create a wildfire early detection system with state-of-the-art performances at minimal deployment costs.
Quick Tour
Automatic wildfire detection in PyTorch
You can use the library like any other python package to detect wildfires as follows:
from pyrovision.models import rexnet1_0x
from torchvision import transforms
import torch
from PIL import Image
# Init
normalize = transforms.Normalize(mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225])
tf = transforms.Compose([transforms.Resize(size=(448)), transforms.CenterCrop(size=448),
transforms.ToTensor(), normalize])
model = rexnet1_0x(pretrained=True).eval()
# Predict
im = tf(Image.open("path/to/your/image.jpg").convert('RGB'))
with torch.no_grad():
pred = model(im.unsqueeze(0))
is_wildfire = torch.sigmoid(pred).item() >= 0.5
Setup
Python 3.6 (or higher) and pip/conda are required to install PyroVision.
Stable release
You can install the last stable release of the package using pypi as follows:
pip install pyrovision
or using conda:
conda install -c pyronear pyrovision
Developer installation
Alternatively, if you wish to use the latest features of the project that haven't made their way to a release yet, you can install the package from source:
git clone https://github.com/pyronear/pyro-vision.git
pip install -e pyro-vision/.
What else
Documentation
The full package documentation is available here for detailed specifications.
Demo app
The project includes a minimal demo app using Gradio
You can check the live demo, hosted on :hugs: HuggingFace Spaces :hugs: over here :point_down:
Docker container
If you wish to deploy containerized environments, a Dockerfile is provided for you build a docker image:
docker build . -t <YOUR_IMAGE_TAG>
Minimal API template
Looking for a boilerplate to deploy a model from PyroVision with a REST API? Thanks to the wonderful FastAPI framework, you can do this easily. Follow the instructions in ./api
to get your own API running!
Reference scripts
If you wish to train models on your own, we provide training scripts for multiple tasks!
Please refer to the ./references
folder if that's the case.
Citation
If you wish to cite this project, feel free to use this BibTeX reference:
@misc{pyrovision2019,
title={Pyrovision: wildfire early detection},
author={Pyronear contributors},
year={2019},
month={October},
publisher = {GitHub},
howpublished = {\url{https://github.com/pyronear/pyro-vision}}
}
Contributing
Please refer to CONTRIBUTING
to help grow this project!
License
Distributed under the Apache 2 License. See LICENSE
for more information.