Struct RefCellComputeChannel

Source
pub struct RefCellComputeChannel<Server> { /* private fields */ }
Expand description

A channel using a ref cell to access the server with mutability.

§Important

Only use this channel if you don’t use any threading in your application, otherwise it will panic or cause undefined behaviors.

This is mosly useful for no-std environments where threads aren’t supported, otherwise prefer the mutex or the mpsc channels.

Implementations§

Source§

impl<Server> RefCellComputeChannel<Server>
where Server: ComputeServer,

Source

pub fn new(server: Server) -> RefCellComputeChannel<Server>

Create a new cell compute channel.

Trait Implementations§

Source§

impl<S> Clone for RefCellComputeChannel<S>

Source§

fn clone(&self) -> RefCellComputeChannel<S>

Returns a duplicate 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<Server> ComputeChannel<Server> for RefCellComputeChannel<Server>
where Server: ComputeServer + Send,

Source§

fn read( &self, bindings: Vec<Binding>, ) -> Pin<Box<dyn Future<Output = Vec<Vec<u8>>> + Send>>

Given bindings, returns owned resources as bytes
Source§

fn read_tensor( &self, bindings: Vec<BindingWithMeta>, ) -> Pin<Box<dyn Future<Output = Vec<Vec<u8>>> + Send>>

Given bindings, returns owned resources as bytes
Source§

fn sync(&self) -> Pin<Box<dyn Future<Output = ()> + Send>>

Wait for the completion of every task in the server.
Source§

fn get_resource( &self, binding: Binding, ) -> BindingResource<<<Server as ComputeServer>::Storage as ComputeStorage>::Resource>

Given a resource handle, return the storage resource.
Source§

fn create(&self, resource: &[u8]) -> Handle

Given a resource as bytes, stores it and returns the resource handle
Source§

fn create_tensors( &self, data: Vec<&[u8]>, shape: Vec<&[usize]>, elem_size: Vec<usize>, ) -> Vec<(Handle, Vec<usize>)>

Given a resource as bytes and a shape, stores it and returns the tensor handle
Source§

fn empty(&self, size: usize) -> Handle

Reserves size bytes in the storage, and returns a handle over them
Source§

fn empty_tensors( &self, shape: Vec<&[usize]>, elem_size: Vec<usize>, ) -> Vec<(Handle, Vec<usize>)>

Reserves a tensor with shape in the storage, and returns a handle to it
Source§

unsafe fn execute( &self, kernel_description: <Server as ComputeServer>::Kernel, count: CubeCount, bindings: Bindings, kind: ExecutionMode, logger: Arc<ServerLogger>, )

Executes the kernel over the given bindings. Read more
Source§

fn flush(&self)

Flush outstanding work of the server.
Source§

fn memory_usage(&self) -> MemoryUsage

Get the current memory usage of the server.
Source§

fn memory_cleanup(&self)

Ask the server to release memory that it can release.
Source§

fn start_profile(&self) -> ProfilingToken

Start a profile on the server. This allows you to profile kernels. Read more
Source§

fn end_profile( &self, token: ProfilingToken, ) -> Result<ProfileDuration, ProfileError>

End the profile and return a ProfileDuration. Read more
Source§

impl<Server> Debug for RefCellComputeChannel<Server>
where Server: Debug,

Source§

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

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

impl<Server> Send for RefCellComputeChannel<Server>
where Server: ComputeServer,

This is unsafe, since no concurrency is supported by the RefCell channel. However using this channel should only be done in single threaded environments such as no-std.

Source§

impl<Server> Sync for RefCellComputeChannel<Server>
where Server: ComputeServer,

Auto Trait Implementations§

§

impl<Server> Freeze for RefCellComputeChannel<Server>

§

impl<Server> !RefUnwindSafe for RefCellComputeChannel<Server>

§

impl<Server> Unpin for RefCellComputeChannel<Server>

§

impl<Server> !UnwindSafe for RefCellComputeChannel<Server>

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, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> 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, 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