Skip to main content

PyPolSAR is a python module for Polarimetric Synthetic Aperture Radar (PolSAR) data processing.

Project description

PyPolSAR

Build status Python Version Dependencies Status

Code style: black Security: bandit Pre-commit Semantic Versions License

PyPolSAR is a python module for Polarimetric Synthetic Aperture Radar (PolSAR) data processing.

Documentation & Software Citation

To see the latest full documentation click on here.

If you use the software in a publication then please cite it using the Zenodo DOI. Be aware that this badge links to the latest package version.

Please select your specific version at [to do in future] to get the DOI of that version. You should normally always use the DOI for the specific version of your record in citations. This is to ensure that other researchers can access the exact research artefact you used for reproducibility.

You can find additional information regarding DOI versioning at http://help.zenodo.org/#versioning

Installation This package should be installable through pip which downloads the package from the python package repository Pypi. However, pypolsar also needs some packages that depend on C or Fortran libraries (like netCDF4). They should be installed first with conda. See http://conda.pydata.org/docs/ on how to use it. We recommend using either Anaconda or Miniconda.

conda install -c conda-forge numpy scipy pandas netCDF4 cython libgdal gdal

Afterwards pypolsar can be installed via pip.

 pip install pypolsar

You can also install all needed (conda and pip) dependencies at once using the following commands after cloning this repository. This is recommended for developers of the package. Note that the git --recursive flag will clone test-data, which is needed by some tests.

git clone https://github.com/IslamAlam/pypolsar.git --recursive
cd pypolsar
conda create -n pypolsar python=3.6 # or any supported python version
source activate pypolsar
conda update -f environment.yml -n pypolsar
python setup.py develop

Initial setting up

  • Set up Dependabot to ensure you have the latest dependencies.
  • Set up Stale bot for automatic issue closing.

Poetry

All manipulations with dependencies are executed through Poetry. If you're new to it, look through the documentation.

Notes about Poetry

Poetry's commands are very intuitive and easy to learn, like:

  • poetry add numpy
  • poetry run pytest
  • poetry build
  • etc

Building your package

Building a new version of the application contains steps:

  • Bump the version of your package poetry version <version>. You can pass the new version explicitly, or a rule such as major, minor, or patch. For more details, refer to the Semantic Versions standard.
  • Make a commit to GitHub.
  • Create a GitHub release.
  • And... publish 🙂 poetry publish --build

What's next

Well, that's up to you. I can only recommend the packages and articles that helped me.

Packages:

  • Typer is great for creating CLI applications.
  • Rich makes it easy to add beautiful formatting in the terminal.
  • FastAPI is a type-driven asynchronous web framework.
  • IceCream is a little library for sweet and creamy debugging

Articles:

🚀 Features

For your development we've prepared:

For building and deployment:

  • GitHub integration.
  • Makefile for building routines. Everything is already set up for security checks, codestyle checks, code formatting, testing, linting, docker builds, etc. More details at Makefile summary).
  • Dockerfile for your package.
  • Github Actions with predefined build workflow as the default CI/CD.
  • Always up-to-date dependencies with @dependabot (You will only enable it).
  • Automatic drafts of new releases with Release Drafter. It creates a list of changes based on labels in merged Pull Requests. You can see labels (aka categories) in release-drafter.yml. Works perfectly with Semantic Versions specification.

For creating your open source community:

Installation

pip install pypolsar

or install with Poetry

poetry add pypolsar

Then you can run

pypolsar --help
pypolsar --name Roman

or if installed with Poetry:

poetry run pypolsar --help
poetry run pypolsar --name Roman

Makefile usage

Makefile contains many functions for fast assembling and convenient work.

1. Download Poetry

make download-poetry

2. Install all dependencies and pre-commit hooks

make install

If you do not want to install pre-commit hooks, run the command with the NO_PRE_COMMIT flag:

make install NO_PRE_COMMIT=1

3. Check the security of your code

make check-safety

This command launches a Poetry and Pip integrity check as well as identifies security issues with Safety and Bandit. By default, the build will not crash if any of the items fail. But you can set STRICT=1 for the entire build, or you can configure strictness for each item separately.

make check-safety STRICT=1

or only for safety:

make check-safety SAFETY_STRICT=1

multiple

make check-safety PIP_STRICT=1 SAFETY_STRICT=1

List of flags for check-safety (can be set to 1 or 0): STRICT, POETRY_STRICT, PIP_STRICT, SAFETY_STRICT, BANDIT_STRICT.

4. Check the codestyle

The command is similar to check-safety but to check the code style, obviously. It uses Black, Darglint, Isort, and Mypy inside.

make check-style

It may also contain the STRICT flag.

make check-style STRICT=1

List of flags for check-style (can be set to 1 or 0): STRICT, BLACK_STRICT, DARGLINT_STRICT, ISORT_STRICT, MYPY_STRICT.

5. Run all the codestyle formaters

Codestyle uses pre-commit hooks, so ensure you've run make install before.

make codestyle

6. Run tests

make test

7. Run all the linters

make lint

the same as:

make test && make check-safety && make check-style

List of flags for lint (can be set to 1 or 0): STRICT, POETRY_STRICT, PIP_STRICT, SAFETY_STRICT, BANDIT_STRICT, BLACK_STRICT, DARGLINT_STRICT, ISORT_STRICT, MYPY_STRICT.

8. Build docker

make docker

which is equivalent to:

make docker VERSION=latest

More information here.

9. Cleanup docker

make clean_docker

or to remove all build

make clean

More information here.

📈 Releases

You can see the list of available releases on the GitHub Releases page.

We follow Semantic Versions specification.

We use Release Drafter. As pull requests are merged, a draft release is kept up-to-date listing the changes, ready to publish when you’re ready. With the categories option, you can categorize pull requests in release notes using labels.

For Pull Request this labels are configured, by default:

Label Title in Releases
enhancement, feature 🚀 Features
bug, refactoring, bugfix, fix 🔧 Fixes & Refactoring
build, ci, testing 📦 Build System & CI/CD
breaking 💥 Breaking Changes
documentation 📝 Documentation
dependencies ⬆️ Dependencies updates

You can update it in release-drafter.yml.

GitHub creates the bug, enhancement, and documentation labels for you. Dependabot creates the dependencies label. Create the remaining labels on the Issues tab of your GitHub repository, when you need them.

🛡 License

License

This project is licensed under the terms of the GPL-3.0-or-later license. See LICENSE for more details.

📃 Citation

@misc{pypolsar,
  author = {Earth-Observation},
  title = {PyPolSAR is a python module for Polarimetric Synthetic Aperture Radar (PolSAR) data processing.},
  year = {2020},
  publisher = {GitHub},
  journal = {GitHub repository},
  howpublished = {\url{https://github.com/IslamAlam/pypolsar}}
}

Credits

This project was generated with python-package-template.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pypolsar-2.1.0.tar.gz (58.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pypolsar-2.1.0-py3-none-any.whl (60.8 kB view details)

Uploaded Python 3

File details

Details for the file pypolsar-2.1.0.tar.gz.

File metadata

  • Download URL: pypolsar-2.1.0.tar.gz
  • Upload date:
  • Size: 58.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.10 CPython/3.8.5 Linux/4.15.0-132-generic

File hashes

Hashes for pypolsar-2.1.0.tar.gz
Algorithm Hash digest
SHA256 011aaaa2400953800b2ce01b4128f7d1730df0362f863287058f9ca5e561155d
MD5 86936ee292a21f6f62143e011ca6cf6e
BLAKE2b-256 d4bdd995038ecdba4164d5e7b123de4327977c98424733c7d82f08e90a29de0e

See more details on using hashes here.

File details

Details for the file pypolsar-2.1.0-py3-none-any.whl.

File metadata

  • Download URL: pypolsar-2.1.0-py3-none-any.whl
  • Upload date:
  • Size: 60.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.0.10 CPython/3.8.5 Linux/4.15.0-132-generic

File hashes

Hashes for pypolsar-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c2a5a617782ef2befba90aed3f2b63226cba3b0c340ab3fde66e057b8af40cc6
MD5 0823f45cf034e76823ec2e843dca2288
BLAKE2b-256 cf5044ed0c987cda846d1baf89602fdf741fba079046c2e29d6ec527b5dce3c3

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page