Toolbox for 3D geonumerical calculations and atmospheric composition
Project description
geonum provides functionality for geographical calculations in three dimensions and includes interfaces for accessing and processing of topographic data. Most of the features (e.g. distance retrievals) are based on the two fundamental objects GeoPoint and GeoVector3D which are inherited from the respective 2D base classes of the LatLon23 module and were expanded to support also the vertical dimension. Geonum features online access to topographic data from the SRTM dataset, using the SRTM module. Furthermore, topographic data from the ETOPO1 Dataset is supported.
Copyright
Copyright (C) 2017 Jonas Gliß (jonasgliss@gmail.com)
This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License a published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see here.
Requirements
It is recommended to use the conda Python package manager (get it e.g. via miniconda)
Please see requirements.txt for a list of requirements. Note that these are only the minimum required dependencies. Further, optional requirements are listed below. Note, that dependent on your OS and python version, some of these may be tricky to install:
Optional dependencies (to use extra features)
basemap (plotting of maps)
OpenCV
netCDF4
Installation
geonum is tested and can be installed both for Python >= 3.6 and on all common OS (Windows, linux and OSX).
Installation via conda
The easiest way to install geonum is to install the latest release via the conda-forge channel:
conda install -c conda-forge geonum
This will install all requirements as well.
Installation via pip or from source
Please make sure to install all requirements beforehand (see above). You may do this by downloading the requirements file and calling from the command line:
pip install -r requirements.txt
or - if you use Python 3 - by creating a new conda environment using the provided conda environment file:
conda env create -n geonum_env -f geonum_env.yml
After installing the requirements, geonum can be installed from PyPi using:
pip install geonum
or from source by downloading and extracting the latest release or cloning the repository. After navigating to the source folder (where the setup.py file is located) call:
python setup.py install
Instructions and code documentation
The code documentation of geonum is hosted on Read The Docs
Getting started
After installation try running the example scripts in order to test the installation. The scripts are also meant to provide an easy start into the main features of geonum.
Supported ETOPO1 files
In order to use topography data from the ETOPO1 dataset, please download and unzip one of the following files to the package folder geonum/local_topo_data/. Tested and supported are the following two files (grid registered):
The local installation folder can be accessed via:
import geonum print(geonum.LOCAL_TOPO_PATH)
If a valid data file is stored in this folder, it will be detected automatically. It is also possible to store the topodata at another location (e.g. <data_path>). In this case, the local path to the folder containing the topograph files needs to be provided, e.g.:
import geonum access = geonum.topodata.TopoDataAccess(mode="etopo1", local_path=<data_path>)
If the path is valid, it will be added to the installation file LOCAL_TOPO_PATHS.txt
Planned changes (for v2.0.0)
See below for my (@jgliss) personal wish-list of new features, help is more than welcome as I have to work on geonum mostly in my spare time.
Refactoring of basemap dependency to cartopy
Base TopoData on xarray.DataArray
Support for more topographic datasets, interpolation of gaps in topodata, merging and interpolation of different topographic datasets
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for geonum-1.4.5rc1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 13a26c4cfc9c3c140f7b69920cba1ab8fbc75aadc81d2923b5688e12d9e50fbe |
|
MD5 | 084c13bdc0e4d0868f6896e3c0063116 |
|
BLAKE2b-256 | 44705e16e1ea6fa26732a1bd035a69275fb40db0b91fd4a636754c57db8c13a1 |