pub struct MainbrainConfig {
    pub cal_fname: Option<PathBuf>,
    pub output_base_dirname: PathBuf,
    pub tracking_params: TrackingParams,
    pub lowlatency_camdata_udp_addr: Option<String>,
    pub http_api_server_addr: String,
    pub model_server_addr: SocketAddr,
    pub save_empty_data2d: bool,
    pub secret_base64: Option<String>,
    pub packet_capture_dump_fname: Option<PathBuf>,
    pub acquisition_duration_allowed_imprecision_msec: Option<f64>,
}
Expand description

The sub-configuration of BraidConfig for mainbrain - the central component of Braid that integrates information from multiple cameras and performs tracking.

Fields§

§cal_fname: Option<PathBuf>

Filename of the camera calibration, optional.

Can contain shell variables such as ~, $A, or ${B}.

If the filename ends with .pymvg or .json, it will be treated as a pymvg calibration file. Else it will be treated considered in the flydra XML calibration format.

§output_base_dirname: PathBuf

Directory where data should be saved. Can contain shell variables. Defaults to DEFAULT_OUTPUT_BASE_DIRNAME.

§tracking_params: TrackingParams

Parameters for Kalman filter and data association

§lowlatency_camdata_udp_addr: Option<String>

Address of UDP port to send low-latency detection data

§http_api_server_addr: String

Address of HTTP port for control API. This is specified in the format IP:PORT where:

IP can be:

  • a numerical IPv4 address:
    • e.g. 1.1.1.1 uses the specific IP
    • 127.0.0.1 for the loopback interface
    • 0.0.0.0 to open the server on all available IPv4 interfaces
  • a numerical IPv6 address:
    • e.g. [2001:db8:3333:4444:5555:6666:7777:8888] uses the specific IP
    • [::1] for the loopback interface
    • [::] to open the server on all available IPv6 interfaces
  • a hostname which resolves to an IP address (depending on your DNS configuration, resolves to either IPv4 or IPv6):
    • localhost resolves to the IP address of the loopback interface
    • e.g. hostname for a specific IP address

PORT can be:

  • 0 allows the operating system to choose an unassigned port dynamically
  • e.g. 1234 uses the specific port

Set to 0.0.0.0:0 to be automatically assigned a public IP address with a dynamically assigned port.

The default value is set to DEFAULT_HTTP_API_SERVER_ADDR.

§model_server_addr: SocketAddr

Address of HTTP port for model server emitting realtime tracking results

§save_empty_data2d: bool

Save rows to data2d_distorted where nothing detected (saves timestamps)

§secret_base64: Option<String>

Secret to use for signing HTTP cookies (base64 encoded)

§packet_capture_dump_fname: Option<PathBuf>

For debugging: filename to store captured packet data.

§acquisition_duration_allowed_imprecision_msec: Option<f64>

Threshold duration before logging error (msec).

If the image acquisition timestamp precedes the computed trigger timestamp, clearly an error has happened. This error must lie in the computation of the trigger timestamp. This specifies the threshold error at which an error is logged. (The underlying source of such errors remains unknown.)

Trait Implementations§

source§

impl Clone for MainbrainConfig

source§

fn clone(&self) -> MainbrainConfig

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for MainbrainConfig

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for MainbrainConfig

source§

fn default() -> Self

Returns the “default value” for a type. Read more
source§

impl<'de> Deserialize<'de> for MainbrainConfig

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl Serialize for MainbrainConfig

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> FromRef<T> for T
where T: Clone,

source§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

impl<SS, SP> SupersetOf<SS> for SP
where SS: SubsetOf<SP>,

source§

fn to_subset(&self) -> Option<SS>

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more
source§

fn is_in_subset(&self) -> bool

Checks if self is actually part of its subset T (and can be converted to it).
source§

fn to_subset_unchecked(&self) -> SS

Use with care! Same as self.to_subset but without any property checks. Always succeeds.
source§

fn from_subset(element: &SS) -> SP

The inclusion map: converts self to the equivalent element of its superset.
source§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,