Skip to main content

Surveying instrument automation through GeoCOM and other protocols.

Project description

GeoComPy logo


PyPI - Version Python Version MIT Tests status Docs status Typed

GeoComPy is a Python library providing wrapper functions for serial communication protocols of Leica surveying instruments.

The package is mainly built around the GeoCOM ASCII protocol, supported by a number of total stations and other instruments running TPS1000, 1100, 1200 and other firmware. For some older instruments that do not support GeoCOM, the GSI Online command set is used for communication.

[!TIP] Command line applications using GeoComPy are available as a separate complimentary package called Instrumentman.

Main features

  • Pure Python implementation
  • Support for type checkers
  • Primitives for relevant data
  • Command building and parsing through function calls
  • Multiple supported protocols (e.g. GeoCOM, GSI Online)

Requirements

To use the package, Python 3.11 or higher is required.

For the platform independent serial communication, GeoComPy relies on the pySerial package to provide the necessary abstractions.

Installation

The preferred method to install GeoComPy is through PyPI, where both wheel and source distributions are made available.

python -m pip install geocompy

If not yet published changes/fixes are needed, that are only available in source, GeoComPy can also be installed locally from source, without any external tools. Once the repository is cloned to a directory, it can be installed with pip.

git clone https://github.com/MrClock8163/GeoComPy.git
cd GeoComPy
python -m pip install .

Short example

The below example demonstrates how to connect to a GeoCOM capable instrument through a serial connection. Once the connection is up and running, the total station is instructed to turn to horizontal 0, and position the telescope parallel to the ground.

from geocompy import (
    Angle,
    open_serial,
    GeoCom
)


with open_serial("COM1") as com:
    tps = GeoCom(com)
    tps.aut.turn_to(Angle(0), Angle(90, 'deg'))

License

GeoComPy is free and open source software, and it is distributed under the terms of the MIT License.

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

geocompy-1.0.0.tar.gz (1.8 MB view details)

Uploaded Source

Built Distribution

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

geocompy-1.0.0-py3-none-any.whl (99.0 kB view details)

Uploaded Python 3

File details

Details for the file geocompy-1.0.0.tar.gz.

File metadata

  • Download URL: geocompy-1.0.0.tar.gz
  • Upload date:
  • Size: 1.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for geocompy-1.0.0.tar.gz
Algorithm Hash digest
SHA256 5b16e24c3137309a1a43e0d247beb4c1764aeaeb680ef66db29ce28c7f793c1d
MD5 ccea9a0bb0f4585303f865dc3f9e4b67
BLAKE2b-256 647e35ba36e026aff886f92ed6da32185db0aea1506966c3b1899c8fa2e395db

See more details on using hashes here.

Provenance

The following attestation bundles were made for geocompy-1.0.0.tar.gz:

Publisher: python-publish.yml on MrClock8163/GeoComPy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file geocompy-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: geocompy-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 99.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for geocompy-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b12e572328da21684aa66eba94ab6f752145189dd2664cc4ab64698c6dcdea77
MD5 bad399a23991fae88caf48f6f445d69b
BLAKE2b-256 1939c70f323c131b3988b1675800748bf471b97672aa196c5a5152fdd75d9351

See more details on using hashes here.

Provenance

The following attestation bundles were made for geocompy-1.0.0-py3-none-any.whl:

Publisher: python-publish.yml on MrClock8163/GeoComPy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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