scanner

class blickfeld_scanner.scanner.scanner(hostname_or_ip='localhost', port=None, name=None, key_and_cert_file=None, key_and_cert=None)

Scanner is a class to connect to a device, get a point cloud stream, get a status stream and set a scan pattern.

Parameters
  • hostname_or_ip (str) – Device to which the connection should be established.

  • port (int) – Port on which the device is reachable the default is 8000.

  • name (str) – Name of the device used for string representation.

  • key_and_cert_file (str) – Filename containing a private key and certificate for SSL connection.

  • key_and_cert (str) – String containing a private key and certificate for SSL connection.

protocol_version = 1
get_status()

Request status of device

Returns

Status object, see Protobuf definitions Status

get_status_stream()

Request status stream of device

This returns a status stream, which only delivers updates when the device has changed. Do not use this in a synchronous blocking call. Use the get_status method instead.

Returns

blickfeld_scanner.scanner.stream.status object

get_point_cloud_stream(filter=None, reference_frame=None, point_filter=None)

Request point cloud stream of device

Parameters
  • filter

    DEPRECATED

    > Introduced in BSL v2.10 and firmware v1.9

    Filter points and returns by point attributes during the post-processing on the device. Is replaced by ‘point_filter’.

  • reference_frame

    > Introduced in BSL v2.10 and firmware v1.9

    Frame representing the desired data. To request a field, set it to any value (also in submessages). For a repeated field, add at least one element.

  • point_filter

    > Introduced in BSL v2.13 and firmware v1.9

    Filter points and returns by point attributes during the post-processing on the device. This replaces the ‘filter’ parameter

Returns

blickfeld_scanner.scanner.stream.point_cloud object

get_raw_point_cloud_stream(point_filter=None, reference_frame=None)

Request raw point cloud stream of device

> Introduced in BSL v2.13 and firmware v1.13

Parameters
  • point_filter

    > Introduced in BSL v2.10 and firmware v1.9

    Filter points and returns by point attributes during the post-processing on the device.

  • reference_frame

    > Introduced in BSL v2.10 and firmware v1.9

    Frame representing the desired data. To request a field, set it to any value (also in submessages). For a repeated field, add at least one element.

Returns

blickfeld_scanner.scanner.stream.raw object

record_point_cloud_stream(file_name, point_filter=None, reference_frame=None)

Record point cloud stream to file

> Introduced in BSL v2.13 and firmware v1.13

Parameters
  • file_name – Path to the file where it should be dumped

  • point_filter

    > Introduced in BSL v2.10 and firmware v1.9

    Filter points and returns by point attributes during the post-processing on the device.

  • reference_frame

    > Introduced in BSL v2.10 and firmware v1.9

    Frame representing the desired data. To request a field, set it to any value (also in submessages). For a repeated field, add at least one element.

Returns

blickfeld_scanner.scanner.stream.raw object

static file_point_cloud_stream(dump_filename)

Request a point_cloud_stream, which streams off a .bfpc file. No device (and connection to a device) is needed for this operation.

Parameters

dump_filename – path to .bfpc file

Returns

blickfeld_scanner.scanner.stream.point_cloud object

set_scan_pattern(config=None, name=None, persist=False)

Function to set a new scan pattern, see: Protobuf definitions. First call blickfeld_scanner.scanner.scanner.fill_scan_pattern() with the scan pattern you want to set and then use that returned scan pattern as a config in this function.

> Changed in BSL v2.15 and firmware v1.16

It is now possible to set a named scan pattern. Either a scan pattern config or a name of a named scan pattern can be provided.

Parameters
  • config – scan pattern to be set

  • name – name of named scan pattern to be set

  • persist – Persist scan pattern on device and reload it after a power-cycle, see: Protobuf definitions scan pattern

Returns

response scan pattern, see Protobuf definitions Connection, see Protobuf definitions Connection

fill_scan_pattern(config)

Function to fill a scan pattern, see: Protobuf definitions. The device fill the missing fields with default values and return it. After it is filled the scan pattern can be set with the blickfeld_scanner.scanner.scanner.set_scan_pattern() function.

Parameters

config – scan pattern to be filled by the BSS, see: Protobuf definitions scan pattern

Returns

Filled scan pattern, which can be set, see Protobuf definitions scan pattern

get_scan_pattern()

Returns the currently set scan pattern, see: Protobuf definitions.

Returns

Currently set scan pattern, see Protobuf definitions scan pattern

get_scan_pattern_constraints()

This request returns a list of constraints which are applied on scan patterns.

> Introduced in BSL v2.14 and firmware v1.14

The constraints define the constant and dynamic relationships between field values. The constraints are equal for a device type and firmware, but might vary for firmware releases and device variants. It is mainly used to visualize the constraints in the scan pattern configuration of the web gui.

Returns

List of active constraints, see Protobuf definitions common

set_advanced_config(config, persist=False)

Function to set advanced config, see: Protobuf definitions. Expert parameters: It is not recommended to adapt this calibrated configuration without understanding the influences on the resulting point cloud quality.

> Introduced in BSL v2.11 and firmware v1.11

Parameters
  • config – advanced config to be set

  • persist – Persist advanced config on device and reload it after a power-cycle

Returns

response advanced config, see Protobuf definitions advanced config

get_advanced_config()

Returns the currently set advanced config, see: Protobuf definitions.

> Introduced in BSL v2.11 and firmware v1.11

Returns

Currently set advanced config, see Protobuf definitions advanced config

get_device_timestamp()

Returns the current device timestamp in seconds.

Returns

Current device timestamp in seconds

get_ntp_server()

Attention: To use this function you need the requests library https://requests.readthedocs.io/en/master/

Function to get a ntp server

Returns

Returns the ntp server IP address

set_ntp_server(server)

Attention: To use this function you need the requests library https://requests.readthedocs.io/en/master/

Function to set a ntp server

Parameters

server (str) – Server IP to set the ntp server to

run_self_test()

> Introduced in BSL v2.10 and firmware v1.9

Run self test on the device. See Protobuf definitions Request.RunSelfTest.

Returns

Self test run response, see Protobuf definitions Response.RunSelfTest

create_connection()

Function to create a new connection

Returns

Newly created blickfeld_scanner.scanner.connection

attempt_error_recovery()

> Introduced in BSL v2.13 and firmware v1.13

This request can be used to attempt a re-initialization of the device if it is errored. A self test is automatically triggered after a successful re-initialization.

get_named_scan_patterns()

> Introduced in BSL v2.15 and firmware v1.16

Get protobuf list of named scan patterns. There are two types of named scan patterns: 1. Default scan patterns, which are not changeable. 2. User defined named scan patterns, which are changeable.

Returns

List of named scan patterns, see Protobuf definitions Response.GetNamedScanPatterns

store_named_scan_pattern(name, config)

> Introduced in BSL v2.15 and firmware v1.16

Store a named scan patterns. The default scan patterns can’t be overwritten.

Parameters
  • name – Name of the scan pattern

  • config – Config of the scan pattern, see Protobuf definitions ScanPattern

delete_named_scan_pattern(name)

> Introduced in BSL v2.15 and firmware v1.16

Delete a named scan patterns. The default scan patterns can’t be deleted.

Parameters

name – Name of the scan pattern

static sync(devices, scan_pattern=None, target_frame_rate=None, max_time_difference=0.1)

Sync two or more devices to record frames at the same time.

Parameters
  • server (list of blickfeld_scanner.scanner.scanner) – list of scanners to sync

  • scan_pattern (scan pattern, see: Protobuf definitions,) – scan pattern that the devices should use, if None is given, it will select the current scan pattern

  • target_frame_rate (float) – Frame rate that the devices should run. Maximum frame rate is dependent on the scan pattern, if None is given the maximum possible frame rate will be used.

  • max_time_difference (float) – Maximum time difference allowed.

exception blickfeld_scanner.scanner.protocol_exception(value)

Protocol exception class for errors, see errors in Protobuf definitions

Parameters

value (Protocol Exception, see: Protobuf definitions) – Exception that occured

errno()

Returns error number

Returns

Error number

name()

Returns error name as in Protobuf definitions

Returns

Error name

description()

Returns error description as in Protobuf definitions

Returns

Error description

class blickfeld_scanner.scanner.connection(hostname_or_ip, port, key_and_cert=None, ssl_protocol=<_SSLMethod.PROTOCOL_TLS: 2>)

Class to create a connection to the Blickfeld LiDAR device

Parameters
  • hostname_or_ip (str) – hostname or IP to which the connection should be established

  • port (int) – port on which the connection should be established

  • key_and_cert (str) – String containing a private key and certificate for SSL connection

  • ssl_protocol (see ssl lib: ssl.PROTOCOL_…) – The protocol used for an SSL connection

clone(other_hostname_or_ip=None, other_port=None, other_key_and_cert=None)

Copies connection object.

Parameters
  • other_hostname_or_ip (str) – a different hostname or IP to use for the clone

  • port (other) – a different port to use for the clone

  • other_key_and_cert (str) – a different string containing a private key and certificate for the clone

send_request(req)

Send request to the device

Parameters

req (Request, see: Protobuf definitions) – Request to the device

Returns

Response of the device, see: Protobuf definitions

send(req)

Send request to the device

Parameters

req (Request, see: Protobuf definitions) – Request to the device

recv()

Receive response of the device

Returns

Response of the device, see: Protobuf definitions

close()

Close connection to the device