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.12.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-0.12.0-py3-none-any.whl (95.1 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for geocompy-0.12.0.tar.gz
Algorithm Hash digest
SHA256 5ca9197922e6af382d2a9328f44fff77b3e6f1ec38fdb198fc1245dc6ff8d81d
MD5 41303f87acf958302b4c5191c66d3450
BLAKE2b-256 4ef88ccb41dc2bcd962bc1c21c14a12c6cf679c19cfb14329dae51767a32e6fb

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: geocompy-0.12.0-py3-none-any.whl
  • Upload date:
  • Size: 95.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.12.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9094252206acaa988b619aaa189d392a8d6a03effccaf890430fe72c70e1d1f9
MD5 6875882abdc2ddce5c0a76d6ef28ed75
BLAKE2b-256 1b23b2a5ecf333ece01a3a6d8b8d77b3df79cd50f88c386dce640f19ef9e7921

See more details on using hashes here.

Provenance

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