Skip to main content

Message

Enum Message 

Source
pub enum Message {
    Hello,
    WorkerInfo(WorkerInfo),
    SingleOp {
        layer_name: String,
        x: RawTensor,
        index_pos: usize,
        block_idx: usize,
    },
    Batch {
        x: RawTensor,
        batch: Vec<(String, usize, usize)>,
    },
    Tensor(RawTensor),
    Goodbye,
    LayerAssignment {
        layers: Vec<String>,
        model_hash: String,
    },
    LayerAssignmentAck {
        needs_data: bool,
    },
    ModelDataChunk {
        filename: String,
        offset: u64,
        total_size: u64,
        data: Vec<u8>,
    },
    ModelDataDone,
    WorkerReady,
    WorkerError {
        message: String,
    },
}
Expand description

A Cake protocol message.

Variants§

§

Hello

First message sent.

§

WorkerInfo(WorkerInfo)

Message that the worker sends when a master connects with runtime information.

§

SingleOp

Single inference operation for a given layer.

Fields

§layer_name: String
§index_pos: usize
§block_idx: usize
§

Batch

Batched inference operations over a Tensor.

Fields

§batch: Vec<(String, usize, usize)>
§

Tensor(RawTensor)

A message to transmit tensors.

§

Goodbye

Last message sent.

§

LayerAssignment

Master tells worker which layers to serve.

Fields

§layers: Vec<String>
§model_hash: String

Short hash of model config for cache keying.

§

LayerAssignmentAck

Worker tells master whether it needs model data.

Fields

§needs_data: bool
§

ModelDataChunk

Chunk of model file data from master to worker.

Fields

§filename: String
§offset: u64
§total_size: u64
§data: Vec<u8>
§

ModelDataDone

All model files have been sent.

§

WorkerReady

Worker has loaded all assigned layers and is ready for inference.

§

WorkerError

Worker encountered an error during inference.

Fields

§message: String

Implementations§

Source§

impl Message

Source

pub fn single_op( layer_name: &str, x: &Tensor, index_pos: usize, block_idx: usize, ) -> Self

Create a Message::SingleOp message.

Source

pub fn from_tensor(x: &Tensor) -> Self

Create a Message::Tensor message.

Source

pub fn from_batch(x: &Tensor, batch: Vec<(String, usize, usize)>) -> Self

Create a Message::Batch message.

Source

pub async fn from_reader<R>(reader: &mut R) -> Result<(usize, Self)>
where R: AsyncReadExt + Unpin,

Read a Message with the provided reader.

Source

pub async fn from_reader_buf<R>( reader: &mut R, buf: &mut Vec<u8>, ) -> Result<(usize, Self)>
where R: AsyncReadExt + Unpin,

Read a Message, reusing buf to avoid per-message heap allocation.

Source

pub async fn to_writer<W>(&self, writer: &mut W) -> Result<usize>
where W: AsyncWriteExt + Unpin,

Write a Message with the provided writer.

Source

pub async fn to_writer_buf<W>( &self, writer: &mut W, buf: &mut Vec<u8>, ) -> Result<usize>
where W: AsyncWriteExt + Unpin,

Write a Message, reusing buf to avoid per-message heap allocation.

Trait Implementations§

Source§

impl Debug for Message

Source§

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

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

impl<'a_, C_: Context> Readable<'a_, C_> for Message

Source§

fn read_from<R_: Reader<'a_, C_>>(_reader_: &mut R_) -> Result<Self, C_::Error>

Source§

fn minimum_bytes_needed() -> usize

Source§

fn read_from_buffer(buffer: &'a [u8]) -> Result<Self, <C as Context>::Error>
where Self: DefaultContext<Context = C>, C: Default,

Deserializes from a given buffer. Read more
Source§

fn read_with_length_from_buffer( buffer: &'a [u8], ) -> (Result<Self, <C as Context>::Error>, usize)
where Self: DefaultContext<Context = C>, C: Default,

Deserializes from a given buffer while also returning the amount of bytes consumed. Read more
Source§

fn read_from_buffer_copying_data( buffer: &[u8], ) -> Result<Self, <C as Context>::Error>
where Self: DefaultContext<Context = C>, C: Default,

Deserializes from a given buffer. Read more
Source§

fn read_with_length_from_buffer_copying_data( buffer: &[u8], ) -> (Result<Self, <C as Context>::Error>, usize)
where Self: DefaultContext<Context = C>, C: Default,

Deserializes from a given buffer while also returning the amount of bytes consumed. Read more
Source§

fn read_from_stream_unbuffered( stream: impl Read, ) -> Result<Self, <C as Context>::Error>
where Self: DefaultContext<Context = C>, C: Default,

Reads from a given stream without any buffering. Read more
Source§

fn read_from_stream_buffered( stream: impl Read, ) -> Result<Self, <C as Context>::Error>
where Self: DefaultContext<Context = C>, C: Default,

Reads from a given stream with internal buffering. Read more
Source§

fn read_from_file(path: impl AsRef<Path>) -> Result<Self, <C as Context>::Error>
where Self: DefaultContext<Context = C>, C: Default,

Source§

fn read_from_buffer_with_ctx( context: C, buffer: &'a [u8], ) -> Result<Self, <C as Context>::Error>

Source§

fn read_with_length_from_buffer_with_ctx( context: C, buffer: &'a [u8], ) -> (Result<Self, <C as Context>::Error>, usize)

Source§

fn read_from_buffer_copying_data_with_ctx( context: C, buffer: &[u8], ) -> Result<Self, <C as Context>::Error>

Source§

fn read_with_length_from_buffer_copying_data_with_ctx( context: C, buffer: &[u8], ) -> (Result<Self, <C as Context>::Error>, usize)

Source§

fn read_with_length_from_buffer_copying_data_with_ctx_mut( context: &mut C, buffer: &[u8], ) -> (Result<Self, <C as Context>::Error>, usize)

Source§

fn read_from_stream_unbuffered_with_ctx<S>( context: C, stream: S, ) -> Result<Self, <C as Context>::Error>
where S: Read,

Source§

fn read_from_stream_buffered_with_ctx<S>( context: C, stream: S, ) -> Result<Self, <C as Context>::Error>
where S: Read,

Source§

fn read_from_file_with_ctx( context: C, path: impl AsRef<Path>, ) -> Result<Self, <C as Context>::Error>

Source§

impl<C_: Context> Writable<C_> for Message

Source§

fn write_to<T_: ?Sized + Writer<C_>>( &self, _writer_: &mut T_, ) -> Result<(), C_::Error>

Source§

fn write_to_buffer( &self, buffer: &mut [u8], ) -> Result<(), <C as Context>::Error>
where Self: DefaultContext<Context = C>, C: Default,

Source§

fn write_to_vec(&self) -> Result<Vec<u8>, <C as Context>::Error>
where Self: DefaultContext<Context = C>, C: Default,

Source§

fn write_to_stream<S>(&self, stream: S) -> Result<(), <C as Context>::Error>
where S: Write, Self: DefaultContext<Context = C>, C: Default,

Source§

fn write_to_file( &self, path: impl AsRef<Path>, ) -> Result<(), <C as Context>::Error>
where Self: DefaultContext<Context = C>, C: Default,

Source§

fn write_to_buffer_with_ctx( &self, context: C, buffer: &mut [u8], ) -> Result<(), <C as Context>::Error>

Source§

fn write_to_buffer_with_ctx_mut( &self, context: &mut C, buffer: &mut [u8], ) -> Result<(), <C as Context>::Error>

Source§

fn write_to_vec_with_ctx( &self, context: C, ) -> Result<Vec<u8>, <C as Context>::Error>

Source§

fn write_to_vec_with_ctx_mut( &self, context: &mut C, ) -> Result<Vec<u8>, <C as Context>::Error>

Source§

fn write_to_stream_with_ctx<S>( &self, context: C, stream: S, ) -> Result<(), <C as Context>::Error>
where S: Write,

Source§

fn write_to_file_with_ctx( &self, context: C, path: impl AsRef<Path>, ) -> Result<(), <C as Context>::Error>

Source§

fn bytes_needed(&self) -> Result<usize, <C as Context>::Error>

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> 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> 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> 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> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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

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> ErasedDestructor for T
where T: 'static,