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.11.0.tar.gz (577.8 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.11.0-py3-none-any.whl (85.4 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for geocompy-0.11.0.tar.gz
Algorithm Hash digest
SHA256 f7a59dcac5a4b88d44602b4df24181f01b93c936c0fd0dc1348c11741b9482cd
MD5 2b66b08ab6fd8e0bd48aec730ffe853e
BLAKE2b-256 55d70c0c3ab32e4cf0a9558bd7c3d9917425dfdb8df1eb9d9a80471a90bbf26b

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: geocompy-0.11.0-py3-none-any.whl
  • Upload date:
  • Size: 85.4 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.11.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1429c30e5a965b0dd9c12e3660148d8e1e5ba544090a2d158a454ddbd5f15a8d
MD5 ec6980fad4c6d324114c41fc396d13fd
BLAKE2b-256 57a073575fe493a6832186b0c0a267ca9dd3849cc26fb15f5464946b4e3f5589

See more details on using hashes here.

Provenance

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