SDK Stream Python bindings API

class metavision_sdk_stream.Camera

Main class for the camera interface.

static from_file(file_path: os.PathLike, hints: metavision_sdk_stream.FileConfigHints = <metavision_sdk_stream.FileConfigHints object at 0x7f1d5d626030>) metavision_sdk_stream.Camera

Initializes a camera instance from a file.

CameraException

in case of initialization failure. :file_path: Path to the file

hints

Hints expressing how the file should be read, for more details see FileConfigHints

return

Camera instance initialized from the input file

static from_first_available(*args, **kwargs)

Overloaded function.

  1. from_first_available() -> metavision_sdk_stream.Camera

Initializes a camera instance from the first available camera plugged on the system.

Open the first available camera following at first EMBEDDED and then USB order.

Please note that remote cameras will not be opened with this function. To do that, please specify the OnlineSourceType and use the from_source function, or else specify the serial number and use the from_serial function.

Serial numbers and types of available sources can be found with list_online_sources function.

CameraException

in case of initialization failure.

  1. from_first_available(config: metavision_hal.DeviceConfig) -> metavision_sdk_stream.Camera

Initializes a camera instance from the first available camera plugged on the system.

Open the first available camera following at first EMBEDDED and then USB order.

Please note that remote cameras will not be opened with this function. To do that, please specify the OnlineSourceType and use the from_source function, or else specify the serial number and use the from_serial function.

Serial numbers and types of available sources can be found with list_online_sources function.

CameraException

in case of initialization failure. :config: Configuration used to open the camera This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

static from_serial(*args, **kwargs)

Overloaded function.

  1. from_serial(serial: str) -> metavision_sdk_stream.Camera

Initializes a camera instance from a ‘serial’ number.

Serial numbers of available sources can be found by with list_online_sources function.

If ‘serial’ is an empty string, the function works as the main constructor.

CameraException

if the camera with the input serial number has not been found. :serial: Serial number of the camera

return

Camera instance initialized from the serial number

  1. from_serial(serial: str, config: metavision_hal.DeviceConfig) -> metavision_sdk_stream.Camera

Initializes a camera instance from a ‘serial’ number.

CameraException

if the camera with the input serial number has not been found. :serial: Serial number of the camera

config

Configuration used to open the camera

return

Camera instance initialized from the serial number This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

get_device(self: metavision_sdk_stream.Camera) metavision_hal.Device

Gets corresponding Device in HAL library.

This Device retrieved can then be used to call the different facilities of the camera. for example: camera.get_device()->get_facility<Metavision::I_TriggerIn>()->enable(channel_id) or: camera.get_device()->get_facility<Metavision::I_Monitoring>()->get_temperature())

return

The Device used internally by the class Camera

height(self: metavision_sdk_stream.Camera) int

Returns the height of the camera

load(self: metavision_sdk_stream.Camera, path: os.PathLike) bool

Loads the camera settings from a given file.

path

The path of the file to load the camera settings from

return

true on success

move(self: metavision_sdk_stream.Camera) metavision_sdk_stream.RValueCamera
save(self: metavision_sdk_stream.Camera, path: os.PathLike) bool

Saves the camera settings to a given file.

path

The path of the file to save the camera settings to

return

true on success

width(self: metavision_sdk_stream.Camera) int

Returns the width of the camera

class metavision_sdk_stream.FileConfigHints(self: metavision_sdk_stream.FileConfigHints) None

Class represented by a map of string key/value pair, used to control how a file is read by the Camera class.

note

Some keys can be ignored when not applicable to the file format

Constructor.

By default, if applicable, the file will be read using a maximum memory footprint of 12Mo, with real time playback speed and time shifting enabled

get(self: metavision_sdk_stream.FileConfigHints, key: str, def: str = '') str

Gets the (typed) value for a named key in the config dictionary if it exists and can be extracted from the corresponding value safely or the provided default value.

T

type of the value to return as :key: Name of the config key

def

Default value if the config key is not found

return

Value of the config

max_memory(*args, **kwargs)

Overloaded function.

  1. max_memory(self: metavision_sdk_stream.FileConfigHints) -> int

Gets the maximum memory used (if applicable) setting.

return

Maximum memory used

  1. max_memory(self: metavision_sdk_stream.FileConfigHints, max_memory: int) -> metavision_sdk_stream.FileConfigHints

Named constructor for the max memory setting.

max_memory

Maximum memory that should be used when reading the file (if applicable)

return

FileConfigHints& Reference to the modified config

  1. max_memory(self: metavision_sdk_stream.FileConfigHints, max_read_per_op: int) -> metavision_sdk_stream.FileConfigHints

Named constructor for the max read size per read operation.

max_read_per_op

Maximum size of data read per read operation

return

FileConfigHints& Reference to the modified config

max_read_per_op(self: metavision_sdk_stream.FileConfigHints) int

Gets the maximum read size (if applicable) setting.

return

Maximum read size in bytes

real_time_playback(*args, **kwargs)

Overloaded function.

  1. real_time_playback(self: metavision_sdk_stream.FileConfigHints) -> bool

Gets the real-time playback status.

return

true if enabled, false otherwise

  1. real_time_playback(self: metavision_sdk_stream.FileConfigHints, enabled: bool) -> metavision_sdk_stream.FileConfigHints

Named constructor for the real time playback status.

enabled

true if the setting should be enabled, false otherwise

return

FileConfigHints& Reference to the modified config

set(self: metavision_sdk_stream.FileConfigHints, key: str, value: str) None

Sets a value for a named key in the config dictionary This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

time_shift(*args, **kwargs)

Overloaded function.

  1. time_shift(self: metavision_sdk_stream.FileConfigHints) -> bool

Gets the timeshift status.

return

true if enabled, false otherwise

  1. time_shift(self: metavision_sdk_stream.FileConfigHints, enabled: bool) -> metavision_sdk_stream.FileConfigHints

Named constructor for the time shift status.

enabled

true if the setting should be enabled, false otherwise

return

FileConfigHints& Reference to the modified config

class metavision_sdk_stream.HDF5EventFileWriter(self: metavision_sdk_stream.HDF5EventFileWriter, path: os.PathLike = '', metadata_map: dict[str, str] = {}) None
add_cd_events(self: metavision_sdk_stream.HDF5EventFileWriter, events: numpy.ndarray[metavision_sdk_base._EventCD_decode]) None

Adds an array of EventCD to write to the file

Parameters

events – numpy array of EventCD

add_ext_trigger_events(self: metavision_sdk_stream.HDF5EventFileWriter, events: numpy.ndarray[metavision_sdk_base._EventExtTrigger_decode]) None

Adds an array of EventExtTrigger to write to the file

Parameters

events – numpy array of EventExtTrigger

add_metadata(self: metavision_sdk_stream.HDF5EventFileWriter, key: str, value: str) None

Adds metadata to the file.

key

Metatadata key to be added

value

Metadata value to be added

warning

Calling this function after some data has been added may throw an exception in some implementation

add_metadata_map_from_camera(self: metavision_sdk_stream.HDF5EventFileWriter, camera: metavision_sdk_stream.Camera) None

Adds metadata to the file from a Camera instance.

camera

Camera instance to build metadata from

warning

Calling this function after some data has been added may throw an exception in some implementation

close(self: metavision_sdk_stream.HDF5EventFileWriter) None

Close the writer.

flush(self: metavision_sdk_stream.HDF5EventFileWriter) None

Try to flush any data not yet written to disk.

The underlying implementation will do its best to flush any data not yet written but it’s not guaranteed that all data will be written after this call (a library or the OS might prevent completely flushing that data at this point). If no more data will be added, closing the writer is the only way to make sure the data is fully written to disk.

is_open(self: metavision_sdk_stream.HDF5EventFileWriter) bool

Check that the writer is currently opened and ready to write data.

return

true if the writer is opened and ready, false otherwise

open(self: metavision_sdk_stream.HDF5EventFileWriter, path: os.PathLike) None

Open the writer with specified path.

path

Path to the file to write

class metavision_sdk_stream.RAWEvt2EventFileWriter(self: metavision_sdk_stream.RAWEvt2EventFileWriter, stream_width: int, stream_height: int, path: os.PathLike = PosixPath('.'), enable_trigger_support: bool = False, metadata_map: dict[str, str] = {}, max_events_add_latency: int = 9223372036854775807) None

EventFileWriter specialized class to write events to a RAW EVT2 file.

Note

This class only supports writing CD and Trigger events

add_cd_events(self: metavision_sdk_stream.RAWEvt2EventFileWriter, events: numpy.ndarray[metavision_sdk_base._EventCD_decode]) None

Adds an array of EventCD to write to the file

Parameters

events – numpy array of EventCD

add_ext_trigger_events(self: metavision_sdk_stream.RAWEvt2EventFileWriter, events: numpy.ndarray[metavision_sdk_base._EventExtTrigger_decode]) None

Adds an array of EventExtTrigger to write to the file

Parameters

events – numpy array of EventExtTrigger

add_metadata(self: metavision_sdk_stream.RAWEvt2EventFileWriter, key: str, value: str) None

Adds metadata to the file.

key

Metatadata key to be added

value

Metadata value to be added

warning

Calling this function after some data has been added may throw an exception in some implementation

close(self: metavision_sdk_stream.RAWEvt2EventFileWriter) None

Close the writer.

flush(self: metavision_sdk_stream.RAWEvt2EventFileWriter) None

Try to flush any data not yet written to disk.

The underlying implementation will do its best to flush any data not yet written but it’s not guaranteed that all data will be written after this call (a library or the OS might prevent completely flushing that data at this point). If no more data will be added, closing the writer is the only way to make sure the data is fully written to disk.

is_open(self: metavision_sdk_stream.RAWEvt2EventFileWriter) bool

Check that the writer is currently opened and ready to write data.

return

true if the writer is opened and ready, false otherwise

open(self: metavision_sdk_stream.RAWEvt2EventFileWriter, path: os.PathLike) None

Open the writer with specified path.

path

Path to the file to write

class metavision_sdk_stream.Slice(self: metavision_sdk_stream.Slice) None

Structure representing a slice of events and triggers.

Default constructor.

property events

Events in the slice.

property n_events

Number of CD events in the slice.

property status

Status indicating how the slice was completed.

property t

Timestamp of the slice.

property triggers

Triggers in the slice.

class metavision_sdk_stream.ReslicingConditionType(self: metavision_sdk_stream.ReslicingConditionType, value: int) None

Members:

IDENTITY

N_EVENTS

N_US

MIXED

class metavision_sdk_stream.ReslicingConditionStatus(self: metavision_sdk_stream.ReslicingConditionStatus, value: int) None

Members:

NOT_MET

MET_AUTOMATIC

MET_N_EVENTS

MET_N_US

class metavision_sdk_stream.SliceCondition(self: metavision_sdk_stream.SliceCondition) None
is_tracking_duration(self: metavision_sdk_stream.SliceCondition) bool
is_tracking_events_count(self: metavision_sdk_stream.SliceCondition) bool
static make_identity() metavision_sdk_stream.SliceCondition
static make_mixed(delta_ts: int, delta_n_events: int) metavision_sdk_stream.SliceCondition
static make_n_events(delta_n_events: int) metavision_sdk_stream.SliceCondition
static make_n_us(delta_ts: int) metavision_sdk_stream.SliceCondition
class metavision_sdk_stream.CameraStreamSlicer(self: metavision_sdk_stream.CameraStreamSlicer, rvalue_camera: metavision_sdk_stream.RValueCamera, slice_condition: metavision_sdk_stream.SliceCondition = <metavision_sdk_stream.SliceCondition object at 0x7f1d5d63eaf0>, max_queue_size: int = 5) None

Class that slices a stream of events and triggers according to a given condition.

Internally, a concurrent queue is used to store the slices produced by the background threads of the Camera class (i.e. in the callbacks). The size of this concurrent queue can be limited to prevent the background threads from producing too many slices (i.e. especially in offline mode) and consuming too much memory.

begin(self: metavision_sdk_stream.CameraStreamSlicer) Metavision::SliceIteratorT<Metavision::Slice>

Starts the camera stream and returns an iterator to the first slice.

camera(self: metavision_sdk_stream.CameraStreamSlicer) metavision_sdk_stream.Camera

Returns the underlying camera instance.

class metavision_sdk_stream.SyncedSlice(self: metavision_sdk_stream.SyncedSlice) None

A slice of synchronized events from a master and slave cameras.

Default constructor.

property master_events

Events in the master slice.

property master_triggers

Triggers in the master slice.

property n_events

Number of events in the master slice.

property slave_events

Events in the slave slices.

property status

Status indicating how the slice was completed.

property t

Timestamp of the slice.

class metavision_sdk_stream.SyncedCameraStreamsSlicer(self: metavision_sdk_stream.SyncedCameraStreamsSlicer, camera: metavision_sdk_stream.RValueCamera, Cameras: list, slice_condition: metavision_sdk_stream.SliceCondition = <metavision_sdk_stream.SliceCondition object at 0x7f1d5d5103b0>, max_queue_size: int = 5) None

Class for slicing event streams from master and slave cameras based on a condition.

The slicing condition is applied to the master stream and the end of the slave streams are determined accordingly. Internally, a concurrent queue is used to store the slices produced by the background threads of the master Camera class (i.e. in the callbacks). The size of this concurrent queue can be limited to prevent the background threads from producing too many slices (i.e. especially in offline mode) and consuming too much memory.

begin(self: metavision_sdk_stream.SyncedCameraStreamsSlicer) Metavision::SliceIteratorT<Metavision::SyncedSlice>

Starts the camera streams and returns an iterator to the first slice.

master(self: metavision_sdk_stream.SyncedCameraStreamsSlicer) metavision_sdk_stream.Camera

Returns the underlying master camera instance.

slave(self: metavision_sdk_stream.SyncedCameraStreamsSlicer, i: int) metavision_sdk_stream.Camera

Returns the underlying slave camera instance.

slaves_count(self: metavision_sdk_stream.SyncedCameraStreamsSlicer) int

Returns the number of slave cameras.

class metavision_sdk_stream.SyncedCameraSystemBuilder(self: metavision_sdk_stream.SyncedCameraSystemBuilder) None

Builder class to create a synced camera system.

Depending on the provided parameters, the builder will create a synced camera system with live cameras or with files.

add_live_camera_parameters(self: metavision_sdk_stream.SyncedCameraSystemBuilder, serial_number: str, device_config: metavision_hal.DeviceConfig = <metavision_hal.DeviceConfig object at 0x7f1d4c37dff0>, settings_file_path: Optional[os.PathLike] = None) None

Adds live camera parameters to the builder.

The first provided parameters will be used as the master camera parameters :parameters: Live camera parameters

return

Reference to the builder

add_record_path(self: metavision_sdk_stream.SyncedCameraSystemBuilder, record_path: os.PathLike) metavision_sdk_stream.SyncedCameraSystemBuilder

Adds a path to a record file.

The first provided path will be used as the master camera file path :record_path: Path to a record file

return

Reference to the builder

build(self: metavision_sdk_stream.SyncedCameraSystemBuilder) tuple[metavision_sdk_stream.Camera, list[metavision_sdk_stream.Camera]]

Builds the synced camera system.

return

Tuple containing the master camera and the slave cameras :std::runtime_error: in case: - No camera parameters provided - Mixing live and offline parameters - Less than two live cameras provided - Less than two records provided

set_file_config_hints(self: metavision_sdk_stream.SyncedCameraSystemBuilder, file_config_hints: metavision_sdk_stream.FileConfigHints) metavision_sdk_stream.SyncedCameraSystemBuilder

Sets the file config hints.

The hints will be used for all the records :file_config_hints: File config hints

return

Reference to the builder

set_record(self: metavision_sdk_stream.SyncedCameraSystemBuilder, record: bool) metavision_sdk_stream.SyncedCameraSystemBuilder

Sets whether the system should record the live events or not.

record

True to record the events, false otherwise

return

Reference to the builder

set_record_dir(self: metavision_sdk_stream.SyncedCameraSystemBuilder, record_dir: os.PathLike) metavision_sdk_stream.SyncedCameraSystemBuilder

Sets the directory where the events will be recorded.

Setting this option will automatically enable recording :record_dir: Directory where the events will be recorded

return

Reference to the builder

class metavision_sdk_stream.SyncedCameraSystemFactory(self: metavision_sdk_stream.SyncedCameraSystemFactory) None
class LiveCameraParameters(self: metavision_sdk_stream.SyncedCameraSystemFactory.LiveCameraParameters) None

Parameters to create a live camera.

property device_config

Device configuration.

property serial_number

Serial number of the camera.

property settings_file_path

Optional path to a camera settings file.

class LiveParameters(self: metavision_sdk_stream.SyncedCameraSystemFactory.LiveParameters) None

Parameters to create a synced live camera system.

property master_parameters

Parameters for the master camera.

property record

True to record the events, false otherwise.

property record_dir

Optional directory where the events will be recorded.

property slave_parameters

Parameters for the slave cameras.

class OfflineParameters(self: metavision_sdk_stream.SyncedCameraSystemFactory.OfflineParameters) None

Parameters to create a synced offline camera system.

property file_config_hints

Hints to configure the file reading.

property master_file_path

Path to the master record.

property slave_file_paths

Paths to the slave records.

static build(*args, **kwargs)

Overloaded function.

  1. build(parameters: Metavision::SyncedCameraSystemFactory::LiveParameters) -> tuple[metavision_sdk_stream.Camera, list[metavision_sdk_stream.Camera]]

Builds a synced camera system with live cameras.

parameters

Parameters to create the synced camera system

return

A tuple with the master camera and the slave cameras

  1. build(parameters: Metavision::SyncedCameraSystemFactory::OfflineParameters) -> tuple[metavision_sdk_stream.Camera, list[metavision_sdk_stream.Camera]]

Builds a synced camera system with offline cameras.

parameters

Parameters to create the synced camera system

return

A tuple with the master camera and the slave cameras