GeoCOM API
The DMPACK library provides Leica GeoCOM abstraction layers for Fortran and Lua, to write distinct programs for TPS control or to load evaluable configuration files into dmserial.
DMPACK does not follow the Leica GeoCOM API for C/C++ and Visual Basic.
Instead, the API is entirely object-oriented, and methods are given more
memorable names without any sub-system prefix. Structured types have been
removed altogether. Named parameters start with prefix GEOCOM_
and return
codes with prefix GRC_
. See the
source code documentation
for an overview of the API.
The following example in Fortran 2018 opens the TTY /dev/ttyUSB0
, calls the
null procedure of the instrument (COM_NullProc
), and then prints return code,
associated error message, and last request to standard output:
! geocom.f90
program main
use :: dmpack
implicit none (type, external)
integer :: rc ! DMPACK return code.
type(geocom_class) :: geocom ! GeoCOM object.
type(request_type) :: request ! Last request.
! Initialise DMPACK.
call dm_init()
! Open connection to instrument, quit on error.
call geocom%open('/dev/ttyUSB0', GEOCOM_COM_BAUD_115200, verbose=.true., error=rc)
call dm_error_out(rc, fatal=.true.)
! Call remote procedure COM_NullProc and output result.
call geocom%null()
print '(i0, ": ", a)', geocom%code(), geocom%message()
! Output last request.
call geocom%last_request(request)
call dm_request_out(request)
! Close connection.
call geocom%close()
end program main
Make sure that the instrument is configured to 115,200 baud. Invalid parameters passed to the GeoCOM methods will be replaced with their default values, and an error message is printed in verbose mode.
If the DMPACK library and module files are installed to /opt
, build, link, and
run the example program with:
$ gfortran -I/opt/include/dmpack -o geocom geocom.f90 /opt/lib/libdmpack.a -lpcre2-8 $ ./geocom
Enumerators
All GeoCOM named types and enumerators supported by DMPACK start with prefix
GEOCOM_
.
Name | Description |
---|---|
|
Standard intensity of beep expressed as percentage. |
|
Direction close-wise. |
|
Direction counter clock-wise. |
Name | Description |
---|---|
|
Positioning to Hz and V angle. |
|
Positioning to a target in the env. of the Hz and V angle. |
Name | Description |
---|---|
|
Fast positioning mode. |
|
Exact positioning mode. |
|
For TM30/TS30. |
Name | Description |
---|---|
|
Reflector not defined. |
|
Reflector prism. |
|
Reflector tape. |
Name | Description |
---|---|
|
With reflector. |
|
Without reflector. |
Name | Description |
---|---|
|
ASCII protocol. |
|
Binary protocol. |
Name | Description |
---|---|
|
Power source is external. |
|
Power source is the internal battery. |
Name | Description |
---|---|
|
Not supported by TPS1200. |
|
RPC is enabled (online mode). |
Name | Description |
---|---|
|
Power down instrument. |
|
Not supported by TPS1200. |
Name | Description |
---|---|
|
Internal memory module. |
|
External memory card. |
Name | Description |
---|---|
|
Undocumented (0). |
|
Extension wildcard: |
Name | Description |
---|---|
|
Internal memory module. |
|
External memory card. |
Name | Description |
---|---|
|
Locked out. |
|
Locked in. |
|
Prediction mode. |
Name | Description |
---|---|
|
Slow down with current acceleration. |
|
Slow down by switch off power supply. |
Name | Description |
---|---|
|
Instrument remains on. |
|
Turns off mechanism. |
Name | Description |
---|---|
|
Position 1 of telescope. |
|
Position 2 of telescope. |
Name | Description |
---|---|
|
Face in normal position. |
|
Face turned. |
Return Codes
All GeoCOM return codes start with prefix GRC_
.
Code | Name | Description |
---|---|---|
0 |
|
Function successfully completed. |
1 |
|
Unknown error, result unspecified. |
2 |
|
Invalid parameter detected. Result unspecified. |
3 |
|
Invalid result. |
4 |
|
Fatal error. |
5 |
|
Not implemented. |
6 |
|
Function execution timed out. Result unspecified. |
7 |
|
Parameter setup for subsystem is incomplete. |
8 |
|
Function execution has been aborted. |
9 |
|
Fatal error (not enough memory). |
10 |
|
Fatal error (subsystem not initialised). |
12 |
|
Subsystem is down. |
13 |
|
System busy/already in use of another process. |
14 |
|
Fatal error (hardware failure). |
15 |
|
Execution of application has been aborted. |
16 |
|
Operation aborted (insufficient power supply level). |
17 |
|
Invalid version of file. |
18 |
|
Battery empty, about 1 minute remaining. |
20 |
|
No event pending. |
21 |
|
Out of temperature range. |
22 |
|
Instrument tilting out of range. |
23 |
|
Communication error. |
24 |
|
GRC_TYPE input (do no action) |
25 |
|
Instrument went into sleep mode. |
26 |
|
Function not successfully completed. |
27 |
|
Not available (licence key not available). |
28 |
|
Overflow error. |
29 |
|
System or subsystem has been stopped. |
256 |
|
ANG error. |
257 |
|
Angles and inclinations not valid. |
258 |
|
Inclinations not valid. |
259 |
|
Value accuracies not reached. |
260 |
|
Angle accuracies not reached. |
261 |
|
Inclination accuracies not reached. |
266 |
|
No write access allowed. |
267 |
|
Value out of range. |
268 |
|
Function aborted due to interrupt. |
269 |
|
Hz moved during incline measurement. |
270 |
|
Troubles with operation system. |
271 |
|
Overflow at parameter values. |
272 |
|
Not enough peaks. |
273 |
|
Reading timeout. |
274 |
|
Too many exposures wanted. |
275 |
|
Picture height out of range. |
276 |
|
Positive exposure dynamic overflow. |
277 |
|
Negative exposure dynamic overflow. |
278 |
|
Exposure time overflow. |
279 |
|
Picture under-exposured. |
280 |
|
Picture over-exposured. |
300 |
|
Too many peaks detected. |
301 |
|
Not enough peaks detected. |
302 |
|
Peak too slim. |
303 |
|
Peak to wide. |
304 |
|
Bad peak difference. |
305 |
|
Too low peak amplitude. |
306 |
|
Inhomogeneous peak amplitudes. |
307 |
|
No peak decoding possible. |
308 |
|
Peak decoding not stable. |
309 |
|
Not enough valid fine-peaks. |
316 |
|
Inclination plane out of time range. |
317 |
|
Inclination no plane available. |
326 |
|
Errors in 5 kHz and or 2.5 kHz angle. |
327 |
|
Errors in 5 kHz angle. |
328 |
|
Errors in 2.5 kHz angle. |
329 |
|
LVDS transfer error detected. |
330 |
|
LVDS transfer error detected in 5 kHz mode. |
331 |
|
LVDS transfer error detected in 2.5 kHz mode. |
512 |
|
ATR system is not ready. |
513 |
|
Result is not available yet. |
514 |
|
Several targets detected. |
515 |
|
Spot is too big for analyse. |
516 |
|
Background is too bright. |
517 |
|
No targets detected. |
518 |
|
Accuracy worse than asked for. |
519 |
|
Spot is on the edge of the sensing area. |
522 |
|
Blooming or spot on edge detected. |
523 |
|
ATR is not in a continuous mode. |
524 |
|
Not the spot of the own target illuminator. |
525 |
|
Communication error to sensor (ATR). |
526 |
|
Received Arguments cannot be decoded. |
527 |
|
No spot detected in Hz direction. |
528 |
|
No spot detected in V direction. |
529 |
|
Strange light in Hz direction. |
530 |
|
Strange light in V direction. |
531 |
|
On multiple ATA_SLDR_OpenTransfer. |
532 |
|
No ATA_SLDR_OpenTransfer happened. |
533 |
|
Unexpected data format received. |
534 |
|
Checksum error in transmitted data. |
535 |
|
Address out of valid range. |
536 |
|
Firmware file has invalid format. |
537 |
|
Current (loaded) firmware does not support upload. |
538 |
|
PowerSearch system is not ready. |
539 |
|
ATR system error. |
768 |
|
EDM error. |
769 |
|
Fatal EDM sensor error. |
770 |
|
Invalid command or unknown command. |
771 |
|
Boomerang error. |
772 |
|
Received signal too low, prism to far away, or natural barrier, bad environment, etc. |
773 |
|
Obsolete. |
774 |
|
Received signal to strong, prism to near, strange light effect. |
775 |
|
Timeout, measuring time exceeded (signal too weak, beam interrupted). |
776 |
|
Too much turbulences or distractions. |
777 |
|
Filter motor defective. |
778 |
|
Device like EGL, DL is not installed. |
779 |
|
Search result invalid. |
780 |
|
Communication ok, but an error reported from the EDM sensor. |
781 |
|
No service password is set. |
782 |
|
Communication ok, but an unexpected answer received. |
783 |
|
Data send error, sending buffer is full. |
784 |
|
Data receive error, like parity buffer overflow. |
785 |
|
Internal EDM subsystem error. |
786 |
|
Sensor is working already, abort current measuring first. |
787 |
|
No measurement activity started. |
788 |
|
Calculated checksum, resp. received data wrong. |
789 |
|
During start up or shut down phase an error occured. |
790 |
|
Red laser not available on this sensor hardware. |
791 |
|
Measurement will be aborted (will be used for the laser security). |
798 |
|
Multiple OpenTransfer calls. |
799 |
|
No open transfer happened. |
800 |
|
Unexpected data format received. |
801 |
|
Checksum error in transmitted data. |
802 |
|
Address out of valid range. |
803 |
|
Firmware file has invalid format. |
804 |
|
Current (loaded) firmware doesn’t support upload. |
808 |
|
Undocumented error from the EDM sensor, should not occur. |
818 |
|
Out of distance range (too small or large). |
819 |
|
Signal to noise ratio too small. |
820 |
|
Noise too high. |
821 |
|
Password is not set. |
822 |
|
Elapsed time between prepare and start fast measurement for ATR too long. |
823 |
|
Possibly more than one target (also a sensor error). |
824 |
|
EEPROM constants are missing. |
825 |
|
No precise measurement possible. |
826 |
|
Measured distance is too big (not allowed). |
1024 |
|
GMF error. |
1025 |
|
Wrong area definition. |
1026 |
|
Identical points. |
1027 |
|
Points on one line |
1028 |
|
Out of range. |
1029 |
|
Plausibility error. |
1030 |
|
Too few observations to calculate the average. |
1031 |
|
No solution. |
1032 |
|
Only one solution. |
1033 |
|
Second solution. |
1034 |
|
Intersection angle < 15 gon. |
1035 |
|
Invalid triangle. |
1036 |
|
Invalid angle unit. |
1037 |
|
Invalid distance unit. |
1038 |
|
Invalid vertical angle. |
1039 |
|
Invalid temperature system. |
1040 |
|
Invalid pressure unit. |
1041 |
|
Invalid radius. |
1042 |
|
Insufficient data (GM2). |
1043 |
|
Bad data (GM2). |
1044 |
|
Bad data distr (GM2). |
1045 |
|
Same tie points (GM2). |
1046 |
|
Station and tie point same (GM2). |
1280 |
|
TMC error. |
1283 |
|
Measurement without full correction. |
1284 |
|
Accuracy can not be guaranteed. |
1285 |
|
Only angle measurement valid. |
1288 |
|
Only angle measurement valid but without full correction. |
1289 |
|
Only angle measurement valid but accuracy can not be guaranteed. |
1290 |
|
No angle measurement. |
1291 |
|
Wrong setting of PPM or MM on EDM. |
1292 |
|
Distance measurement not done (no aim). |
1293 |
|
System is busy (no measurement done). |
1294 |
|
No signal on EDM (only in signal mode). |
1792 |
|
Motorisation is not ready. |
1793 |
|
Motorisation is handling another task. |
1794 |
|
Motorisation is not in velocity mode. |
1795 |
|
Motorisation is in the wrong mode or busy. |
1796 |
|
Motorisation is not in posit mode. |
1797 |
|
Motorisation is not in service mode. |
1798 |
|
Motorisation is handling no task. |
1799 |
|
Motorisation is not in tracking mode. |
1800 |
|
Motorisation is not in spiral mode. |
1801 |
|
Vertical encoder/motor error. |
1802 |
|
Horizontal encoder/motor error. |
1803 |
|
Horizontal and vertical encoder/motor error. |
2304 |
|
BMM error. |
2305 |
|
Loading process already opened. |
2306 |
|
Transfer not opened. |
2307 |
|
Unknown character set. |
2308 |
|
Display module not present. |
2309 |
|
Character set already exists. |
2310 |
|
Character set cannot be deleted. |
2311 |
|
Memory cannot be allocated. |
2312 |
|
Character set still used. |
2313 |
|
Charset cannot be deleted or is protected. |
2314 |
|
Attempt to copy a character block outside the allocated memory. |
2315 |
|
Error during release of allocated memory. |
2316 |
|
Number of bytes specified in header does not match the bytes read. |
2317 |
|
Allocated memory could not be released. |
2318 |
|
Max. number of character sets already loaded. |
2319 |
|
Layer cannot be deleted. |
2320 |
|
Required layer does not exist. |
2321 |
|
Layer length exceeds maximum. |
3072 |
|
Initiate Extended Runtime Operation (ERO). |
3073 |
|
Cannot encode arguments in client. |
3074 |
|
Cannot decode results in client. |
3075 |
|
Hardware error while sending. |
3076 |
|
Hardware error while receiving. |
3077 |
|
Request timed out. |
3078 |
|
Packet format error. |
3079 |
|
Version mismatch between client and server. |
3080 |
|
Cannot decode arguments in server. |
3081 |
|
Unknown RPC, procedure ID invalid. |
3082 |
|
Cannot encode results in server. |
3083 |
|
Unspecified generic system error. |
3085 |
|
Unspecified error. |
3086 |
|
Binary protocol not available. |
3087 |
|
Call interrupted. |
3090 |
|
Protocol needs 8 bit encoded characters. |
3093 |
|
TRANSACTIONS ID mismatch error. |
3094 |
|
Protocol not recognisable. |
3095 |
|
Invalid port address. |
3099 |
|
ERO is terminating. |
3100 |
|
Internal error (data buffer overflow). |
3101 |
|
Invalid checksum on server side received. |
3102 |
|
Invalid checksum on client side received. |
3103 |
|
Port not available. |
3104 |
|
Port not opened. |
3105 |
|
Unable to find TPS. |
3106 |
|
Extended Runtime Operation could not be started. |
3107 |
|
Att to send cons reqs. |
3108 |
|
TPS has gone to sleep (wait and try again). |
3109 |
|
TPS has shut down (wait and try again). |
3110 |
|
No checksum in ASCII protocol available. |
8704 |
|
Position not reached. |
8705 |
|
Positioning not possible due to mounted EDM. |
8706 |
|
Angle measurement error. |
8707 |
|
Motorisation error. |
8708 |
|
Position not exactly reached. |
8709 |
|
Deviation measurement error. |
8710 |
|
No target detected. |
8711 |
|
Multiple targets detected. |
8712 |
|
Bad environment conditions. |
8713 |
|
Error in target acquisition. |
8714 |
|
Target acquisition not enabled. |
8715 |
|
ATR calibration failed. |
8716 |
|
Target position not exactly reached. |
8717 |
|
Distance measurement has been started. |
8718 |
|
External supply voltage is too high. |
8719 |
|
Internal or external supply voltage is too low. |
8720 |
|
Working area not set. |
8721 |
|
Power search data array is filled. |
8722 |
|
No data available. |
12544 |
|
KDM device is not available. |
13056 |
|
File access error. |
13057 |
|
Block number was not the expected one. |
13058 |
|
Not enough space on device to proceed uploading. |
13059 |
|
Rename of file failed. |
13060 |
|
Invalid parameter as input. |