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 comm:
    tps = GeoCom(comm)
    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-0.10.0.tar.gz (577.4 kB view details)

Uploaded Source

Built Distribution

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

geocompy-0.10.0-py3-none-any.whl (85.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: geocompy-0.10.0.tar.gz
  • Upload date:
  • Size: 577.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for geocompy-0.10.0.tar.gz
Algorithm Hash digest
SHA256 f9795d2d17ad727344869949fea12b5693908450945e7773c82e78a6a7d81657
MD5 427bd4815d067e2134de3686f128d96c
BLAKE2b-256 f79b81b8ae098541544676ff0852e25d0e8428a72d366208018ffccaa2050017

See more details on using hashes here.

Provenance

The following attestation bundles were made for geocompy-0.10.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-0.10.0-py3-none-any.whl.

File metadata

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

File hashes

Hashes for geocompy-0.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e207a74c6934c4dbd87465e0f001366e2cf6fda02f0431d8967b3c5c917561f2
MD5 52cc43d28ebab583a5248c5419c4b023
BLAKE2b-256 00daa3854351cab2125588be9a30a298dee6a79bb30ba521a3bc27ae3c788f1c

See more details on using hashes here.

Provenance

The following attestation bundles were made for geocompy-0.10.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