Skip to content

ugcs/positiondata

Repository files navigation

PositionData Package

Overview

The PositionData package is a comprehensive tool designed for processing positional CSV data, particularly useful for surveyors and geophysicists. It facilitates the efficient handling of geospatial data collected from various drone-based sensors. These sensors range from methane detectors to wind sensors, magnetometers, echo sounders, and more, each providing valuable scalar georeferenced readings essential for a wide array of applications.

For a detailed class reference and examples, please refer to the Development Guide (DEVGUIDE.md).

To simply use the PositionData package, it can be installed from PyPI: PositionData on PyPI.

Package is being maintained by SPH Engineering.

To maintainers

Source Code

The source code for the PositionData package is located in the PositionData directory.

Dependencies

All dependencies for the package are specified in the requirements.txt file and the respective section of setup.py. It is crucial to keep these files updated to manage the package's dependencies effectively.

Unit Tests and Test Data

Unit tests and test data are located in the tests directory. These tests ensure the functionality and integrity of the package through various scenarios and data samples.

Running Unit Tests

For development purposes, unit tests can be run using the following scripts:

  • test_units.sh: A script for quick testing, which runs unit tests directly. To make script consitently running accross Windows and Linux environments use Linux styled line endings for the file. In VS Code "LF" for end of line sequence.
  • test_units_all_env.sh: This script runs tests across all supported Python versions in Docker containers, ensuring compatibility and robustness.

Releasing the Package

To release a new version of the package, use the release.sh script. This script automates the process of testing, building, tagging, and publishing the package to PyPI.

Building and Publishing the Package

  • To build the package locally, use the build.sh script.
  • To publish the package to PyPI, use the publish.sh script. Before publishing, ensure that the PYPI_TOKEN environment variable is set to the correct value.
  • The release.sh script utilizes these two scripts as part of the release workflow.

Testing the PyPI Package

To test the current PyPI package across different Python versions, use the test_pypi.sh script. This script creates Docker containers for each Python version, installs the package from PyPI, and instantiates all classes to ensure everything is functioning as expected.

Documentation

All API references and detailed documentation can be found in the Development Guide (DEVGUIDE.md). Please remember to update the development guide when adding new functionality or making changes to existing features to keep the documentation current and useful for all users.

About

Python package for positional CSV data processing

Resources

License

Stars

Watchers

Forks

Packages

No packages published