Skip to main content

pycraf

Project description

******
pycraf
******

- *Version:* 0.24
- *Author:* Benjamin Winkel
- *User manual:* Hosted on `GitHub Pages <https://bwinkel.github.io/pycraf/>`_

.. image:: https://img.shields.io/pypi/v/pycraf.svg
:target: https://pypi.python.org/pypi/pycraf
:alt: PyPI tag

.. image:: https://img.shields.io/badge/license-GPL-blue.svg
:target: https://www.github.com/bwinkel/pycraf/blob/master/COPYING
:alt: License

The pycraf Python package provides functions and procedures for
various tasks in spectrum-management compatibility studies. A typical example
would be to calculate the interference levels at a radio telescope produced
from a ratio broadcasting tower.

Releases are `registered on PyPI <http://pypi.python.org/pypi/pycraf>`_,
and development is occurring at the
`project's github page <http://github.com/bwinkel/pycraf/>`_.

Project Status
==============

.. image:: https://travis-ci.org/bwinkel/pycraf.svg?branch=master
:target: https://travis-ci.org/bwinkel/pycraf
:alt: Pycrafs's Travis CI Status

.. image:: https://ci.appveyor.com/api/projects/status/tj7swn14t6bek3jr?svg=true
:target: https://ci.appveyor.com/project/bwinkel/pycraf
:alt: Pycrafs's AppVeyor CI Status

.. image:: https://coveralls.io/repos/github/bwinkel/pycraf/badge.svg?branch=master
:target: https://coveralls.io/github/bwinkel/pycraf?branch=master
:alt: Pycrafs's Coveralls Status

`pycraf` is still in the early-development stage. While much of the
functionality is already working as intended, the API is not yet stable.
Nevertheless, we kindly invite you to use and test the library and we are
grateful for feedback. Note, that work on the documentation is still ongoing.

Features
========

- Full implementation of `ITU-R Rec. P.452-16 <https://www.itu.int/rec/R-REC-P.452-16-201507-I/en>`_ that allows to calculate path
attenuation for the distance between interferer and victim service. Supports
to load NASA's `Shuttle Radar Topography Mission (SRTM) <https://www2.jpl.nasa.gov/srtm/>`_ data for height-profile generation.
- Full implementation of `ITU-R Rec. P.676-10 <https://www.itu.int/rec/R-REC-P.676-10-201309-S/en>`_, which provides two atmospheric
models to calculate the attenuation for paths through Earth's atmosphere.
- Provides various antenna patterns necessary for compatibility studies (e.g.,
RAS, IMT, fixed-service links).
- Functions to convert power flux densities, field strengths, transmitted and
received powers at certain distances and frequencies into each other.

Usage
=====

Examples and Documentation
--------------------------

We provide `an online documentation and API reference <https://bwinkel.github.io/pycraf/>`_. Furthermore, you can find tutorials and HowTos in
the `notebooks <http://nbviewer.jupyter.org/github/bwinkel/pycraf/blob/master/notebooks/>`_
directory on the pycraf repository.

Testing
-------

After installation (see below) you can test, if everything works as intended::

import pycraf
pycraf.tests()


License
=======

Several licenses apply; see the `license directory <https://github.com/bwinkel/pycraf/blob/master/licenses/>`_ in the repository. The pycraf Python package
itself is published under `GPL v3 <https://github.com/bwinkel/pycraf/blob/master/licenses/COPYING>`_, an open-source license.

For some of the functionality provided in pycraf, data files provided by the
ITU are necessary. For example, the atmospheric model in the *pycraf.atm*
subpackage implements the algorithm described in `ITU-R Recommendation P.676 <https://www.itu.int/rec/R-REC-P.676-10-201309-S/en>`_.
Annex 1 of this Recommendation makes use of spectroscopic information of the
oxygen and water vapour lines given in Tables 1 and 2 of P.676. Another
example are the radiometeorological data files that are distributed alongside
`ITU-R Rec. P.452-16 <https://www.itu.int/rec/R-REC-P.452-16-201507-I/en>`_

ITU kindly gave us permission to include data files into pycraf that are
distributed with the Recommendations on the ITU servers. This makes it possible
to just use pycraf without the need to manually download necessary data files.
However, these data files are not free for commercial use. For details, please
see the `LICENSE.ITU <https://www.github.com/bwinkel/pycraf/blob/master/LICENSE.ITU>`_ file.

Since pycraf uses the `Astropy Package Template <https://github.com/astropy/package-template>`_ for packaging, we also refer to the associated `license <https://github.com/bwinkel/pycraf/blob/master/licenses/LICENSE_ASTROPY_PACKAGE_TEMPLATE.rst>`_.


Installation
============

The easiest way to install pycraf is via pip::

pip install pycraf

The installation is also possible from source. Download the tar.gz-file,
extract (or clone from GitHub) and simply execute::

python setup.py install

Dependencies
------------

We kept the dependencies as minimal as possible. The following packages are
required:

* numpy 1.8 or later
* astropy 1.1 or later
* matplotlib 1.2 or later
* cython 0.23 or later
* pyproj 1.9 or later

Windows machines
----------------

Note, for Windows machines we provide a binary wheel (Python 3.5+ only).
However, the pyproj package is a dependency and unfortunately, the official
pyproj repository on PyPI contains only the sources. You can download a
suitable wheel from `Christoph Gohlke's package site <http://www.lfd.uci.edu/~gohlke/pythonlibs/#pyproj>`_. Then use::

pip install [path-to-wheel]\pyproj‑*.whl

If you're using `Anaconda <https://www.continuum.io/downloads>`_ (recommended), it is much simpler::

conda install -c conda-forge pyproj

MacOS machines
--------------

For installation on MacOS you'll have to install gcc-6. The clang compiler
seems not to support OpenMP in a way that is needed by pycraf::

brew install gcc6
brew link --overwrite gcc@6

SRTM data
---------

To make full use of the path attenuation calculations provided by pycraf
(implements `ITU-R Rec. P.452 <https://www.itu.int/rec/R-REC-P.452-16-201507-I/en>`_), we recommend to use NASA's
`Shuttle Radar Topography Mission (SRTM) <https://www2.jpl.nasa.gov/srtm/>`_
data for height- profile generation. pycraf can work with so-called *.hgt*
files, a very simple binary format. Each *.hgt* file, a so-called tile, just
contains 1201x1201 16-bit integers. From the file naming scheme, one can infer
the associated coordinates. Most tiles contain one square-degree.

Unfortunately, we cannot provide SRTM data as part of the package, due to the
large file sizes and legal reasons. But once you downloaded the necessary tiles
(all or only a subset appropriate for your region), simply define the
environment variable *SRTMDATA*, let it point to the folder containing the
tiles, and pycraf will find the files when it is imported from Python.

On windows::

set SRTMDATA=C:\[path-to-srtm]\

On linux/MacOS (sh-like)::

export SRTMDATA=[path-to-srtm]/


Acknowledgments
===============
We are very grateful for the kind support from ITU study groups and ITU's
legal department.

This code is makes use of the excellent work provided by the
`Astropy <http://www.astropy.org/>`_ community. pycraf uses the Astropy package and also the
`Astropy Package Template <https://github.com/astropy/package-template>`_
for the packaging.

Who do I talk to?
=================

If you encounter any problems or have questions, do not hesitate to raise an
issue or make a pull request. Moreover, you can contact the devs directly:

- *bwinkel@mpifr.de*


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

pycraf-0.24.3.tar.gz (4.3 MB view hashes)

Uploaded Source

Built Distributions

pycraf-0.24.3-cp36-cp36m-win_amd64.whl (4.5 MB view hashes)

Uploaded CPython 3.6m Windows x86-64

pycraf-0.24.3-cp35-cp35m-win_amd64.whl (4.5 MB view hashes)

Uploaded CPython 3.5m Windows x86-64

Supported by

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