tof_dataclasses::calibrations

Struct RBCalibrations

Source
pub struct RBCalibrations {
    pub rb_id: u8,
    pub d_v: f32,
    pub timestamp: u32,
    pub serialize_event_data: bool,
    pub v_offsets: [[f32; 1024]; 9],
    pub v_dips: [[f32; 1024]; 9],
    pub v_inc: [[f32; 1024]; 9],
    pub tbin: [[f32; 1024]; 9],
    pub vcal_data: Vec<RBEvent>,
    pub tcal_data: Vec<RBEvent>,
    pub noi_data: Vec<RBEvent>,
}

Fields§

§rb_id: u8§d_v: f32§timestamp: u32§serialize_event_data: bool§v_offsets: [[f32; 1024]; 9]§v_dips: [[f32; 1024]; 9]§v_inc: [[f32; 1024]; 9]§tbin: [[f32; 1024]; 9]§vcal_data: Vec<RBEvent>§tcal_data: Vec<RBEvent>§noi_data: Vec<RBEvent>

Implementations§

Source§

impl RBCalibrations

Source

pub const NSKIP: usize = 2usize

Source

pub const SINMAX: usize = 60usize

Source

pub const DVCUT: f32 = 15f32

Source

pub const NOMINALFREQ: f32 = 2f32

Source

pub const CALFREQ: f32 = 0.0250000004f32

Source

pub fn assemble_from_flightcal( fcal_t: RBCalibrationsFlightT, fcal_v: RBCalibrationsFlightV, ) -> Result<Self, CalibrationError>

Re-assemble a RBCalibration from chopped up parts

Source

pub fn emit_flighttcal(&self) -> RBCalibrationsFlightT

Return the timing part of the calibration in a package digestable by the flight computer.

Additonal compression by using f16

Source

pub fn emit_flightvcal(&self) -> RBCalibrationsFlightV

Return the voltage part of the calibration in a package digestable by the flight computer.

Additional compression by using f16

Source

pub fn clean_input_data(&mut self)

Remove events with invalid traces or event fragment bits set

Source

pub fn apply_vcal_constants( &self, adc: &Vec<f32>, channel: usize, stop_cell: usize, ) -> Vec<f32>

Source

pub fn timing_calibration( &self, edge: &Edge, apply_vcal: bool, ) -> Result<Vec<Vec<f32>>, CalibrationError>

Voltage calibration has to be applied

§Returns

vec[ch[9], tbin[1024]]

Source

pub fn calibrate(&mut self) -> Result<(), CalibrationError>

Call to the calibration routine, using the set input data

Source

pub fn spike_cleaning( voltages: &mut Vec<Vec<f32>>, stop_cell: u16, ) -> Result<(), WaveformError>

Apply the spike cleaning to all channels

Source

pub fn voltages( &self, channel: usize, stop_cell: usize, adc: &Vec<u16>, waveform: &mut Vec<f32>, )

Apply the voltage calibration to a single channel FIXME - mixing of naming conventions for the channels

FIXME - make it return Result<(), CalibrationError>

§Arguments
  • channel : Channel id 1-9
  • stop_cell : This channels stop cell
  • adc : Uncalibrated channel data
  • waveform : Pre-allocated array to hold calibrated waveform data.
Source

pub fn nanoseconds( &self, channel: usize, stop_cell: usize, times: &mut Vec<f32>, )

Apply the timing calibration to a single channel

This will allocate the array for the waveform time bins (unit is ns)

§Arguments
  • channel : Channel id 1-9
  • stop_cell : This channels stop cell
Source

pub fn new(rb_id: u8) -> Self

Source

pub fn discard_data(&mut self)

Discard the data to reduce the memory footprint

Source

pub fn from_file( filename: String, discard_data: bool, ) -> Result<Self, SerializationError>

Gets the calibration from a file which has the RBCalibration stored in a TofPacket

E.g. if it was written with TofPacketWriter

Source

pub fn from_txtfile(filename: &Path) -> Self

Load a calibration from an asci file This is deperacted and only kept for compatibility reasons with older data

§Arguments:
  • filename : human readable textfile with all calibraiton constants
Source

pub fn get_id_from_filename(&mut self, filename: &Path) -> u8

Infer the readoutboard id from the filename

Assuming a certain naming scheme for the filename “rbXX_cal.txt” we extract the readoutboard id

Trait Implementations§

Source§

impl Clone for RBCalibrations

Source§

fn clone(&self) -> RBCalibrations

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 RBCalibrations

Source§

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

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

impl Default for RBCalibrations

Source§

fn default() -> Self

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

impl Display for RBCalibrations

Source§

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

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

impl From<&Path> for RBCalibrations

Source§

fn from(path: &Path) -> Self

Read an asci text file with calibration constants.

Source§

impl From<&RBCalibrations> for TofPacket

Source§

fn from(calib: &RBCalibrations) -> Self

Converts to this type from the input type.
Source§

impl From<&mut RBCalibrations> for TofPacket

Source§

fn from(calib: &mut RBCalibrations) -> Self

Converts to this type from the input type.
Source§

impl FromRandom for RBCalibrations

Source§

fn from_random() -> Self

Source§

impl Packable for RBCalibrations

Source§

const PACKET_TYPE: PacketType = PacketType::RBCalibration

Source§

fn pack(&self) -> TofPacket
where Self: Serialization,

Wrap myself in a TofPacket
Source§

impl PartialEq for RBCalibrations

Source§

fn eq(&self, other: &RBCalibrations) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialization for RBCalibrations

Source§

const SIZE: usize = 294_918usize

The SIZE is the size of the serialized bytestream INCLUDING 4 bytes for head and tail bytes. In case the struct does NOT HAVE a fixed size, SIZE will be 0 (so default value of the trait
Source§

const HEAD: u16 = 43_690u16

Source§

const TAIL: u16 = 21_845u16

Source§

fn from_bytestream( bytestream: &Vec<u8>, pos: &mut usize, ) -> Result<Self, SerializationError>

Decode a serializable from a bytestream
Source§

fn to_bytestream(&self) -> Vec<u8>

Encode a serializable to a bytestream
Source§

fn verify_fixed( stream: &Vec<u8>, pos: &mut usize, ) -> Result<(), SerializationError>

Verify that the serialized representation of the struct has the correct size, including header + footer. Read more
Source§

fn from_tofpacket(packet: &TofPacket) -> Result<Self, SerializationError>
where Self: Sized,

Decode a serializable directly from a TofPacket
Source§

fn from_slice( _slice: &[u8], _start_pos: usize, ) -> Result<Self, SerializationError>
where Self: Sized,

Source§

fn to_slice(&self) -> &[u8]
where Self: Sized,

Construct byte slice out of self. Read more
Source§

impl StructuralPartialEq for RBCalibrations

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> IntoSql for T

Source§

fn into_sql<T>(self) -> Self::Expression

Convert self to an expression for Diesel’s query builder. Read more
Source§

fn as_sql<'a, T>(&'a self) -> <&'a Self as AsExpression<T>>::Expression
where &'a Self: AsExpression<T>, T: SqlType + TypedExpressionType,

Convert &self to an expression for Diesel’s query builder. Read more
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize = _

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

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

Source§

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> ToString for T
where T: Display + ?Sized,

Source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

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

Source§

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>,

Source§

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