pub struct Wgpu<G = AutoGraphicsApi, F = f32, I = i32>where
G: GraphicsApi,
F: FloatElement,
I: IntElement,{ /* private fields */ }Expand description
Tensor backend that uses the wgpu crate for executing GPU compute shaders.
This backend can target multiple graphics APIs, including:
- Vulkan on Linux, Windows, and Android.
- OpenGL on Linux, Windows, and Android.
- DirectX 11 on Windows.
- DirectX 12 on Windows.
- Metal on Apple hardware.
- WebGPU on supported browsers and
wasmruntimes.
Trait Implementations§
source§impl<G, F, I> ActivationOps<Wgpu<G, F, I>> for Wgpu<G, F, I>where
G: GraphicsApi + 'static,
F: FloatElement,
I: IntElement,
impl<G, F, I> ActivationOps<Wgpu<G, F, I>> for Wgpu<G, F, I>where G: GraphicsApi + 'static, F: FloatElement, I: IntElement,
source§fn relu<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
fn relu<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
Applies the ReLU activation function. Read more
source§fn relu_backward<const D: usize>(
output: <B as Backend>::TensorPrimitive<D>,
grad: <B as Backend>::TensorPrimitive<D>
) -> <B as Backend>::TensorPrimitive<D>
fn relu_backward<const D: usize>( output: <B as Backend>::TensorPrimitive<D>, grad: <B as Backend>::TensorPrimitive<D> ) -> <B as Backend>::TensorPrimitive<D>
Applies the ReLU activation function backward. Read more
source§fn gelu<const D: usize>(
tensor: <B as Backend>::TensorPrimitive<D>
) -> <B as Backend>::TensorPrimitive<D>
fn gelu<const D: usize>( tensor: <B as Backend>::TensorPrimitive<D> ) -> <B as Backend>::TensorPrimitive<D>
Applies the Gelu activation function. Read more
source§fn gelu_backward<const D: usize>(
x: <B as Backend>::TensorPrimitive<D>,
grad: <B as Backend>::TensorPrimitive<D>
) -> <B as Backend>::TensorPrimitive<D>
fn gelu_backward<const D: usize>( x: <B as Backend>::TensorPrimitive<D>, grad: <B as Backend>::TensorPrimitive<D> ) -> <B as Backend>::TensorPrimitive<D>
Applies the Gelu activation function backward. Read more
source§impl<G: GraphicsApi + 'static, F: FloatElement, I: IntElement> Backend for Wgpu<G, F, I>
impl<G: GraphicsApi + 'static, F: FloatElement, I: IntElement> Backend for Wgpu<G, F, I>
§type Device = WgpuDevice
type Device = WgpuDevice
Device type.
§type FullPrecisionBackend = Wgpu<G>
type FullPrecisionBackend = Wgpu<G>
Pointer to another backend that have a full precision float element type
§type FullPrecisionElem = f32
type FullPrecisionElem = f32
Full precision float element type.
§type TensorPrimitive<const D: usize> = WgpuTensor<F, D>
type TensorPrimitive<const D: usize> = WgpuTensor<F, D>
Tensor primitive to be used for all float operations.
§type IntTensorPrimitive<const D: usize> = WgpuTensor<I, D>
type IntTensorPrimitive<const D: usize> = WgpuTensor<I, D>
Tensor primitive to be used for all int operations.
§type BoolTensorPrimitive<const D: usize> = WgpuTensor<u32, D>
type BoolTensorPrimitive<const D: usize> = WgpuTensor<u32, D>
Tensor primitive to be used for all bool operations.
source§fn ad_enabled() -> bool
fn ad_enabled() -> bool
If autodiff is enabled.
source§impl<G, F, I> BoolTensorOps<Wgpu<G, F, I>> for Wgpu<G, F, I>where
G: GraphicsApi + 'static,
F: FloatElement,
I: IntElement,
impl<G, F, I> BoolTensorOps<Wgpu<G, F, I>> for Wgpu<G, F, I>where G: GraphicsApi + 'static, F: FloatElement, I: IntElement,
source§fn bool_empty<const D: usize>(
shape: Shape<D>,
device: &Device<Self>
) -> BoolTensor<Self, D>
fn bool_empty<const D: usize>( shape: Shape<D>, device: &Device<Self> ) -> BoolTensor<Self, D>
Creates a new bool tensor. Read more
source§fn bool_shape<const D: usize>(tensor: &BoolTensor<Self, D>) -> Shape<D>
fn bool_shape<const D: usize>(tensor: &BoolTensor<Self, D>) -> Shape<D>
Returns the shape of the tensor. Read more
source§fn bool_into_data<const D: usize>(
tensor: BoolTensor<Self, D>
) -> Reader<Data<bool, D>>
fn bool_into_data<const D: usize>( tensor: BoolTensor<Self, D> ) -> Reader<Data<bool, D>>
Converts the tensor to a data structure. Read more
source§fn bool_from_data<const D: usize>(
data: Data<bool, D>,
device: &Device<Self>
) -> BoolTensor<Self, D>
fn bool_from_data<const D: usize>( data: Data<bool, D>, device: &Device<Self> ) -> BoolTensor<Self, D>
Creates a tensor from the data structure. Read more
source§fn bool_into_int<const D: usize>(
tensor: BoolTensor<Self, D>
) -> IntTensor<Self, D>
fn bool_into_int<const D: usize>( tensor: BoolTensor<Self, D> ) -> IntTensor<Self, D>
Converts bool tensor to int tensor. Read more
source§fn bool_device<const D: usize>(tensor: &BoolTensor<Self, D>) -> Device<Self>
fn bool_device<const D: usize>(tensor: &BoolTensor<Self, D>) -> Device<Self>
Gets the device of the tensor. Read more
source§fn bool_to_device<const D: usize>(
tensor: BoolTensor<Self, D>,
device: &Device<Self>
) -> BoolTensor<Self, D>
fn bool_to_device<const D: usize>( tensor: BoolTensor<Self, D>, device: &Device<Self> ) -> BoolTensor<Self, D>
Moves the tensor to the device.
source§fn bool_reshape<const D1: usize, const D2: usize>(
tensor: BoolTensor<Self, D1>,
shape: Shape<D2>
) -> BoolTensor<Self, D2>
fn bool_reshape<const D1: usize, const D2: usize>( tensor: BoolTensor<Self, D1>, shape: Shape<D2> ) -> BoolTensor<Self, D2>
Reshapes the tensor. Read more
source§fn bool_slice<const D1: usize, const D2: usize>(
tensor: BoolTensor<Self, D1>,
ranges: [Range<usize>; D2]
) -> BoolTensor<Self, D1>
fn bool_slice<const D1: usize, const D2: usize>( tensor: BoolTensor<Self, D1>, ranges: [Range<usize>; D2] ) -> BoolTensor<Self, D1>
Gets the values from the tensor for the given ranges. Read more
source§fn bool_slice_assign<const D1: usize, const D2: usize>(
tensor: BoolTensor<Self, D1>,
ranges: [Range<usize>; D2],
value: BoolTensor<Self, D1>
) -> BoolTensor<Self, D1>
fn bool_slice_assign<const D1: usize, const D2: usize>( tensor: BoolTensor<Self, D1>, ranges: [Range<usize>; D2], value: BoolTensor<Self, D1> ) -> BoolTensor<Self, D1>
Sets the values in the tensor for the given ranges. Read more
source§fn bool_cat<const D: usize>(
tensors: Vec<BoolTensor<Self, D>>,
dim: usize
) -> BoolTensor<Self, D>
fn bool_cat<const D: usize>( tensors: Vec<BoolTensor<Self, D>>, dim: usize ) -> BoolTensor<Self, D>
Concatenates the tensors along the given dimension. Read more
source§fn bool_equal<const D: usize>(
lhs: BoolTensor<Self, D>,
rhs: BoolTensor<Self, D>
) -> BoolTensor<Self, D>
fn bool_equal<const D: usize>( lhs: BoolTensor<Self, D>, rhs: BoolTensor<Self, D> ) -> BoolTensor<Self, D>
Equates the two tensors. Read more
source§fn bool_not<const D: usize>(tensor: BoolTensor<Self, D>) -> BoolTensor<Self, D>
fn bool_not<const D: usize>(tensor: BoolTensor<Self, D>) -> BoolTensor<Self, D>
Inverses boolean values. Read more
source§fn bool_into_float<const D: usize>(
tensor: BoolTensor<Self, D>
) -> FloatTensor<Self, D>
fn bool_into_float<const D: usize>( tensor: BoolTensor<Self, D> ) -> FloatTensor<Self, D>
Converts bool tensor to float tensor. Read more
source§fn bool_swap_dims<const D: usize>(
tensor: BoolTensor<Self, D>,
dim1: usize,
dim2: usize
) -> <Wgpu<G, F, I> as Backend>::BoolTensorPrimitive<D>
fn bool_swap_dims<const D: usize>( tensor: BoolTensor<Self, D>, dim1: usize, dim2: usize ) -> <Wgpu<G, F, I> as Backend>::BoolTensorPrimitive<D>
Swaps two dimensions of a bool tensor. Read more
source§fn bool_to_data<const D: usize>(
tensor: &<B as Backend>::BoolTensorPrimitive<D>
) -> Reader<Data<bool, D>>
fn bool_to_data<const D: usize>( tensor: &<B as Backend>::BoolTensorPrimitive<D> ) -> Reader<Data<bool, D>>
Gets the data from the tensor. Read more
source§fn bool_repeat<const D: usize>(
tensor: <B as Backend>::BoolTensorPrimitive<D>,
dim: usize,
times: usize
) -> <B as Backend>::BoolTensorPrimitive<D>
fn bool_repeat<const D: usize>( tensor: <B as Backend>::BoolTensorPrimitive<D>, dim: usize, times: usize ) -> <B as Backend>::BoolTensorPrimitive<D>
Repeats one dimension of the tensor a given number of times along that dimension. Read more
source§fn bool_transpose<const D: usize>(
tensor: <B as Backend>::BoolTensorPrimitive<D>
) -> <B as Backend>::BoolTensorPrimitive<D>
fn bool_transpose<const D: usize>( tensor: <B as Backend>::BoolTensorPrimitive<D> ) -> <B as Backend>::BoolTensorPrimitive<D>
Transposes a bool tensor. Read more
source§impl<G, F, I> Clone for Wgpu<G, F, I>where
G: GraphicsApi + Clone,
F: FloatElement + Clone,
I: IntElement + Clone,
impl<G, F, I> Clone for Wgpu<G, F, I>where G: GraphicsApi + Clone, F: FloatElement + Clone, I: IntElement + Clone,
source§impl<G, F, I> Debug for Wgpu<G, F, I>where
G: GraphicsApi + Debug,
F: FloatElement + Debug,
I: IntElement + Debug,
impl<G, F, I> Debug for Wgpu<G, F, I>where G: GraphicsApi + Debug, F: FloatElement + Debug, I: IntElement + Debug,
source§impl<G, F, I> Default for Wgpu<G, F, I>where
G: GraphicsApi + Default,
F: FloatElement + Default,
I: IntElement + Default,
impl<G, F, I> Default for Wgpu<G, F, I>where G: GraphicsApi + Default, F: FloatElement + Default, I: IntElement + Default,
source§impl<G, F, I> IntTensorOps<Wgpu<G, F, I>> for Wgpu<G, F, I>where
G: GraphicsApi + 'static,
F: FloatElement,
I: IntElement,
impl<G, F, I> IntTensorOps<Wgpu<G, F, I>> for Wgpu<G, F, I>where G: GraphicsApi + 'static, F: FloatElement, I: IntElement,
source§fn int_empty<const D: usize>(
shape: Shape<D>,
device: &Device<Self>
) -> IntTensor<Self, D>
fn int_empty<const D: usize>( shape: Shape<D>, device: &Device<Self> ) -> IntTensor<Self, D>
Creates a new int tensor. Read more
source§fn int_shape<const D: usize>(tensor: &IntTensor<Self, D>) -> Shape<D>
fn int_shape<const D: usize>(tensor: &IntTensor<Self, D>) -> Shape<D>
Returns the shape of the tensor. Read more
source§fn int_into_data<const D: usize>(
tensor: IntTensor<Self, D>
) -> Reader<Data<I, D>>
fn int_into_data<const D: usize>( tensor: IntTensor<Self, D> ) -> Reader<Data<I, D>>
Converts the tensor to a data structure. Read more
source§fn int_from_data<const D: usize>(
data: Data<I, D>,
device: &Device<Self>
) -> IntTensor<Self, D>
fn int_from_data<const D: usize>( data: Data<I, D>, device: &Device<Self> ) -> IntTensor<Self, D>
Creates a tensor from the data structure. Read more
source§fn int_device<const D: usize>(tensor: &IntTensor<Self, D>) -> Device<Self>
fn int_device<const D: usize>(tensor: &IntTensor<Self, D>) -> Device<Self>
Gets the device of the tensor. Read more
source§fn int_to_device<const D: usize>(
tensor: IntTensor<Self, D>,
device: &Device<Self>
) -> IntTensor<Self, D>
fn int_to_device<const D: usize>( tensor: IntTensor<Self, D>, device: &Device<Self> ) -> IntTensor<Self, D>
Moves the tensor to the given device.
source§fn int_reshape<const D1: usize, const D2: usize>(
tensor: IntTensor<Self, D1>,
shape: Shape<D2>
) -> IntTensor<Self, D2>
fn int_reshape<const D1: usize, const D2: usize>( tensor: IntTensor<Self, D1>, shape: Shape<D2> ) -> IntTensor<Self, D2>
Reshapes the tensor. Read more
source§fn int_slice<const D1: usize, const D2: usize>(
tensor: IntTensor<Self, D1>,
ranges: [Range<usize>; D2]
) -> IntTensor<Self, D1>
fn int_slice<const D1: usize, const D2: usize>( tensor: IntTensor<Self, D1>, ranges: [Range<usize>; D2] ) -> IntTensor<Self, D1>
Gets the element at the given indices. Read more
source§fn int_slice_assign<const D1: usize, const D2: usize>(
tensor: IntTensor<Self, D1>,
ranges: [Range<usize>; D2],
value: IntTensor<Self, D1>
) -> IntTensor<Self, D1>
fn int_slice_assign<const D1: usize, const D2: usize>( tensor: IntTensor<Self, D1>, ranges: [Range<usize>; D2], value: IntTensor<Self, D1> ) -> IntTensor<Self, D1>
Sets the element at the given indices. Read more
source§fn int_mask_where<const D: usize>(
tensor: IntTensor<Self, D>,
mask: BoolTensor<Self, D>,
value: IntTensor<Self, D>
) -> IntTensor<Self, D>
fn int_mask_where<const D: usize>( tensor: IntTensor<Self, D>, mask: BoolTensor<Self, D>, value: IntTensor<Self, D> ) -> IntTensor<Self, D>
Fills the tensor with values from the source tensor if the mask is true at the given
indices. Read more
source§fn int_mask_fill<const D: usize>(
tensor: IntTensor<Self, D>,
mask: BoolTensor<Self, D>,
value: IntElem<Self>
) -> IntTensor<Self, D>
fn int_mask_fill<const D: usize>( tensor: IntTensor<Self, D>, mask: BoolTensor<Self, D>, value: IntElem<Self> ) -> IntTensor<Self, D>
Fills the tensor with the given value if the mask is true at the given indices. Read more
source§fn int_gather<const D: usize>(
dim: usize,
tensor: IntTensor<Self, D>,
indices: IntTensor<Self, D>
) -> IntTensor<Self, D>
fn int_gather<const D: usize>( dim: usize, tensor: IntTensor<Self, D>, indices: IntTensor<Self, D> ) -> IntTensor<Self, D>
Gather elements from the tensor at the given indices. Read more
source§fn int_scatter<const D: usize>(
dim: usize,
tensor: IntTensor<Self, D>,
indices: IntTensor<Self, D>,
value: IntTensor<Self, D>
) -> IntTensor<Self, D>
fn int_scatter<const D: usize>( dim: usize, tensor: IntTensor<Self, D>, indices: IntTensor<Self, D>, value: IntTensor<Self, D> ) -> IntTensor<Self, D>
Scatter a given value to the tensor at the given indices. Read more
source§fn int_select<const D: usize>(
tensor: IntTensor<Self, D>,
dim: usize,
indices: IntTensor<Self, 1>
) -> IntTensor<Self, D>
fn int_select<const D: usize>( tensor: IntTensor<Self, D>, dim: usize, indices: IntTensor<Self, 1> ) -> IntTensor<Self, D>
Select tensor elements along the given dimension corresponding to the given indices. Read more
source§fn int_select_assign<const D: usize>(
tensor: IntTensor<Self, D>,
dim: usize,
indices: IntTensor<Self, 1>,
value: IntTensor<Self, D>
) -> IntTensor<Self, D>
fn int_select_assign<const D: usize>( tensor: IntTensor<Self, D>, dim: usize, indices: IntTensor<Self, 1>, value: IntTensor<Self, D> ) -> IntTensor<Self, D>
Assign the selected elements along the given dimension corresponding to the given indices
to the given value. Read more
source§fn int_cat<const D: usize>(
tensors: Vec<IntTensor<Self, D>>,
dim: usize
) -> IntTensor<Self, D>
fn int_cat<const D: usize>( tensors: Vec<IntTensor<Self, D>>, dim: usize ) -> IntTensor<Self, D>
Concatenates the given tensors along the given dimension. Read more
source§fn int_equal<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntTensor<Self, D>
) -> BoolTensor<Self, D>
fn int_equal<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntTensor<Self, D> ) -> BoolTensor<Self, D>
Elementwise equality comparison. Read more
source§fn int_equal_elem<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntElem<Self>
) -> BoolTensor<Self, D>
fn int_equal_elem<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntElem<Self> ) -> BoolTensor<Self, D>
Elementwise equality comparison with a scalar. Read more
source§fn int_greater<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntTensor<Self, D>
) -> BoolTensor<Self, D>
fn int_greater<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntTensor<Self, D> ) -> BoolTensor<Self, D>
Elementwise greater than comparison. Read more
source§fn int_greater_elem<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntElem<Self>
) -> BoolTensor<Self, D>
fn int_greater_elem<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntElem<Self> ) -> BoolTensor<Self, D>
Elementwise greater than comparison with a scalar. Read more
source§fn int_greater_equal<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntTensor<Self, D>
) -> BoolTensor<Self, D>
fn int_greater_equal<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntTensor<Self, D> ) -> BoolTensor<Self, D>
Elementwise greater than or equal comparison. Read more
source§fn int_greater_equal_elem<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntElem<Self>
) -> BoolTensor<Self, D>
fn int_greater_equal_elem<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntElem<Self> ) -> BoolTensor<Self, D>
Elementwise greater than or equal comparison with a scalar. Read more
source§fn int_lower<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntTensor<Self, D>
) -> BoolTensor<Self, D>
fn int_lower<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntTensor<Self, D> ) -> BoolTensor<Self, D>
Elementwise less than comparison. Read more
source§fn int_lower_elem<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntElem<Self>
) -> BoolTensor<Self, D>
fn int_lower_elem<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntElem<Self> ) -> BoolTensor<Self, D>
Elementwise less than comparison with a scalar. Read more
source§fn int_lower_equal<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntTensor<Self, D>
) -> BoolTensor<Self, D>
fn int_lower_equal<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntTensor<Self, D> ) -> BoolTensor<Self, D>
Elementwise less than or equal comparison. Read more
source§fn int_lower_equal_elem<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntElem<Self>
) -> BoolTensor<Self, D>
fn int_lower_equal_elem<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntElem<Self> ) -> BoolTensor<Self, D>
Elementwise less than or equal comparison with a scalar. Read more
source§fn int_add<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntTensor<Self, D>
) -> IntTensor<Self, D>
fn int_add<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntTensor<Self, D> ) -> IntTensor<Self, D>
Elementwise addition. Read more
source§fn int_add_scalar<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntElem<Self>
) -> IntTensor<Self, D>
fn int_add_scalar<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntElem<Self> ) -> IntTensor<Self, D>
Elementwise addition with a scalar. Read more
source§fn int_sub<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntTensor<Self, D>
) -> IntTensor<Self, D>
fn int_sub<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntTensor<Self, D> ) -> IntTensor<Self, D>
Elementwise subtraction. Read more
source§fn int_sub_scalar<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntElem<Self>
) -> IntTensor<Self, D>
fn int_sub_scalar<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntElem<Self> ) -> IntTensor<Self, D>
Elementwise subtraction with a scalar. Read more
source§fn int_mul<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntTensor<Self, D>
) -> IntTensor<Self, D>
fn int_mul<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntTensor<Self, D> ) -> IntTensor<Self, D>
Elementwise multiplication. Read more
source§fn int_mul_scalar<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntElem<Self>
) -> IntTensor<Self, D>
fn int_mul_scalar<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntElem<Self> ) -> IntTensor<Self, D>
Elementwise multiplication with a scalar. Read more
source§fn int_div<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntTensor<Self, D>
) -> IntTensor<Self, D>
fn int_div<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntTensor<Self, D> ) -> IntTensor<Self, D>
Elementwise division. Read more
source§fn int_div_scalar<const D: usize>(
lhs: IntTensor<Self, D>,
rhs: IntElem<Self>
) -> IntTensor<Self, D>
fn int_div_scalar<const D: usize>( lhs: IntTensor<Self, D>, rhs: IntElem<Self> ) -> IntTensor<Self, D>
Elementwise division with a scalar. Read more
source§fn int_zeros<const D: usize>(
shape: Shape<D>,
device: &Device<Self>
) -> IntTensor<Self, D>
fn int_zeros<const D: usize>( shape: Shape<D>, device: &Device<Self> ) -> IntTensor<Self, D>
Creates a tensor of zeros. Read more
source§fn int_ones<const D: usize>(
shape: Shape<D>,
device: &Device<Self>
) -> IntTensor<Self, D>
fn int_ones<const D: usize>( shape: Shape<D>, device: &Device<Self> ) -> IntTensor<Self, D>
Creates a tensor of ones. Read more
source§fn int_sum<const D: usize>(tensor: IntTensor<Self, D>) -> IntTensor<Self, 1>
fn int_sum<const D: usize>(tensor: IntTensor<Self, D>) -> IntTensor<Self, 1>
Sums all elements in the tensor. Read more
source§fn int_sum_dim<const D: usize>(
tensor: IntTensor<Self, D>,
dim: usize
) -> IntTensor<Self, D>
fn int_sum_dim<const D: usize>( tensor: IntTensor<Self, D>, dim: usize ) -> IntTensor<Self, D>
Sums all elements in the tensor along a dimension. Read more
source§fn int_mean_dim<const D: usize>(
tensor: IntTensor<Self, D>,
dim: usize
) -> IntTensor<Self, D>
fn int_mean_dim<const D: usize>( tensor: IntTensor<Self, D>, dim: usize ) -> IntTensor<Self, D>
Computes the mean of all elements in the tensor along a dimension. Read more
source§fn int_argmax<const D: usize>(
tensor: IntTensor<Self, D>,
dim: usize
) -> IntTensor<Self, D>
fn int_argmax<const D: usize>( tensor: IntTensor<Self, D>, dim: usize ) -> IntTensor<Self, D>
Gets the indices of the maximum elements along a dimension. Read more
source§fn int_argmin<const D: usize>(
tensor: IntTensor<Self, D>,
dim: usize
) -> IntTensor<Self, D>
fn int_argmin<const D: usize>( tensor: IntTensor<Self, D>, dim: usize ) -> IntTensor<Self, D>
Gets the indices of the minimum elements along a dimension. Read more
source§fn int_clamp_min<const D: usize>(
tensor: IntTensor<Self, D>,
min: IntElem<Self>
) -> IntTensor<Self, D>
fn int_clamp_min<const D: usize>( tensor: IntTensor<Self, D>, min: IntElem<Self> ) -> IntTensor<Self, D>
Clamps a tensor under a minimum value. Read more
source§fn int_clamp_max<const D: usize>(
tensor: IntTensor<Self, D>,
max: IntElem<Self>
) -> IntTensor<Self, D>
fn int_clamp_max<const D: usize>( tensor: IntTensor<Self, D>, max: IntElem<Self> ) -> IntTensor<Self, D>
Clamps a tensor over a maximum value. Read more
source§fn int_clamp<const D: usize>(
tensor: IntTensor<Self, D>,
min: IntElem<Self>,
max: IntElem<Self>
) -> IntTensor<Self, D>
fn int_clamp<const D: usize>( tensor: IntTensor<Self, D>, min: IntElem<Self>, max: IntElem<Self> ) -> IntTensor<Self, D>
Clamps a tensor between a minimum and maximum value. Read more
source§fn int_abs<const D: usize>(tensor: IntTensor<Self, D>) -> IntTensor<Self, D>
fn int_abs<const D: usize>(tensor: IntTensor<Self, D>) -> IntTensor<Self, D>
Returns a new tensor with absolute values. Read more
source§fn int_into_float<const D: usize>(
tensor: IntTensor<Self, D>
) -> FloatTensor<Self, D>
fn int_into_float<const D: usize>( tensor: IntTensor<Self, D> ) -> FloatTensor<Self, D>
Converts int tensor to float tensor. Read more
source§fn int_swap_dims<const D: usize>(
tensor: IntTensor<Self, D>,
dim1: usize,
dim2: usize
) -> IntTensor<Self, D>
fn int_swap_dims<const D: usize>( tensor: IntTensor<Self, D>, dim1: usize, dim2: usize ) -> IntTensor<Self, D>
Swaps two dimensions of an int tensor. Read more
source§fn int_to_data<const D: usize>(
tensor: &<B as Backend>::IntTensorPrimitive<D>
) -> Reader<Data<<B as Backend>::IntElem, D>>
fn int_to_data<const D: usize>( tensor: &<B as Backend>::IntTensorPrimitive<D> ) -> Reader<Data<<B as Backend>::IntElem, D>>
Gets the data from the tensor. Read more
source§fn int_repeat<const D: usize>(
tensor: <B as Backend>::IntTensorPrimitive<D>,
dim: usize,
times: usize
) -> <B as Backend>::IntTensorPrimitive<D>
fn int_repeat<const D: usize>( tensor: <B as Backend>::IntTensorPrimitive<D>, dim: usize, times: usize ) -> <B as Backend>::IntTensorPrimitive<D>
Repeats the tensor along the given dimension the given number of times. Read more
source§fn int_neg<const D: usize>(
tensor: <B as Backend>::IntTensorPrimitive<D>
) -> <B as Backend>::IntTensorPrimitive<D>
fn int_neg<const D: usize>( tensor: <B as Backend>::IntTensorPrimitive<D> ) -> <B as Backend>::IntTensorPrimitive<D>
Elementwise negation. Read more
source§fn int_full<const D: usize>(
shape: Shape<D>,
fill_value: <B as Backend>::IntElem,
device: &<B as Backend>::Device
) -> <B as Backend>::IntTensorPrimitive<D>
fn int_full<const D: usize>( shape: Shape<D>, fill_value: <B as Backend>::IntElem, device: &<B as Backend>::Device ) -> <B as Backend>::IntTensorPrimitive<D>
Creates a tensor filled with given value. Read more
source§fn int_mean<const D: usize>(
tensor: <B as Backend>::IntTensorPrimitive<D>
) -> <B as Backend>::IntTensorPrimitive<1>
fn int_mean<const D: usize>( tensor: <B as Backend>::IntTensorPrimitive<D> ) -> <B as Backend>::IntTensorPrimitive<1>
Computes the mean of all elements in the tensor. Read more
source§fn int_max<const D: usize>(
tensor: <B as Backend>::IntTensorPrimitive<D>
) -> <B as Backend>::IntTensorPrimitive<1>
fn int_max<const D: usize>( tensor: <B as Backend>::IntTensorPrimitive<D> ) -> <B as Backend>::IntTensorPrimitive<1>
Gets the maximum element in the tensor. Read more
source§fn int_max_dim<const D: usize>(
tensor: <B as Backend>::IntTensorPrimitive<D>,
dim: usize
) -> <B as Backend>::IntTensorPrimitive<D>
fn int_max_dim<const D: usize>( tensor: <B as Backend>::IntTensorPrimitive<D>, dim: usize ) -> <B as Backend>::IntTensorPrimitive<D>
Gets the maximum element in the tensor along a dimension. Read more
source§fn int_max_dim_with_indices<const D: usize>(
tensor: <B as Backend>::IntTensorPrimitive<D>,
dim: usize
) -> (<B as Backend>::IntTensorPrimitive<D>, <B as Backend>::IntTensorPrimitive<D>)
fn int_max_dim_with_indices<const D: usize>( tensor: <B as Backend>::IntTensorPrimitive<D>, dim: usize ) -> (<B as Backend>::IntTensorPrimitive<D>, <B as Backend>::IntTensorPrimitive<D>)
Gets the maximum elements and corresponding indices along a dimension. Read more
source§fn int_min<const D: usize>(
tensor: <B as Backend>::IntTensorPrimitive<D>
) -> <B as Backend>::IntTensorPrimitive<1>
fn int_min<const D: usize>( tensor: <B as Backend>::IntTensorPrimitive<D> ) -> <B as Backend>::IntTensorPrimitive<1>
Gets the minimum element in the tensor. Read more
source§fn int_min_dim<const D: usize>(
tensor: <B as Backend>::IntTensorPrimitive<D>,
dim: usize
) -> <B as Backend>::IntTensorPrimitive<D>
fn int_min_dim<const D: usize>( tensor: <B as Backend>::IntTensorPrimitive<D>, dim: usize ) -> <B as Backend>::IntTensorPrimitive<D>
Gets the minimum elements in the tensor along a dimension. Read more
source§fn int_min_dim_with_indices<const D: usize>(
tensor: <B as Backend>::IntTensorPrimitive<D>,
dim: usize
) -> (<B as Backend>::IntTensorPrimitive<D>, <B as Backend>::IntTensorPrimitive<D>)
fn int_min_dim_with_indices<const D: usize>( tensor: <B as Backend>::IntTensorPrimitive<D>, dim: usize ) -> (<B as Backend>::IntTensorPrimitive<D>, <B as Backend>::IntTensorPrimitive<D>)
Gets the minimum elements and corresponding indices along a dimension. Read more
source§fn int_transpose<const D: usize>(
tensor: <B as Backend>::IntTensorPrimitive<D>
) -> <B as Backend>::IntTensorPrimitive<D>
fn int_transpose<const D: usize>( tensor: <B as Backend>::IntTensorPrimitive<D> ) -> <B as Backend>::IntTensorPrimitive<D>
Transposes an int tensor. Read more
source§impl<G, F, I> ModuleOps<Wgpu<G, F, I>> for Wgpu<G, F, I>where
G: GraphicsApi + 'static,
F: FloatElement,
I: IntElement,
impl<G, F, I> ModuleOps<Wgpu<G, F, I>> for Wgpu<G, F, I>where G: GraphicsApi + 'static, F: FloatElement, I: IntElement,
source§fn conv2d(
x: FloatTensor<Self, 4>,
weight: FloatTensor<Self, 4>,
bias: Option<FloatTensor<Self, 1>>,
options: ConvOptions<2>
) -> FloatTensor<Self, 4>
fn conv2d( x: FloatTensor<Self, 4>, weight: FloatTensor<Self, 4>, bias: Option<FloatTensor<Self, 1>>, options: ConvOptions<2> ) -> FloatTensor<Self, 4>
Two dimensional convolution. Read more
source§fn conv_transpose2d(
x: FloatTensor<Self, 4>,
weight: FloatTensor<Self, 4>,
bias: Option<FloatTensor<Self, 1>>,
options: ConvTransposeOptions<2>
) -> FloatTensor<Self, 4>
fn conv_transpose2d( x: FloatTensor<Self, 4>, weight: FloatTensor<Self, 4>, bias: Option<FloatTensor<Self, 1>>, options: ConvTransposeOptions<2> ) -> FloatTensor<Self, 4>
Two dimensional transposed convolution. Read more
source§fn avg_pool2d(
x: FloatTensor<Self, 4>,
kernel_size: [usize; 2],
stride: [usize; 2],
padding: [usize; 2],
count_include_pad: bool
) -> FloatTensor<Self, 4>
fn avg_pool2d( x: FloatTensor<Self, 4>, kernel_size: [usize; 2], stride: [usize; 2], padding: [usize; 2], count_include_pad: bool ) -> FloatTensor<Self, 4>
Two dimensional avg pooling. Read more
source§fn avg_pool2d_backward(
x: FloatTensor<Self, 4>,
grad: FloatTensor<Self, 4>,
kernel_size: [usize; 2],
stride: [usize; 2],
padding: [usize; 2],
count_include_pad: bool
) -> FloatTensor<Self, 4>
fn avg_pool2d_backward( x: FloatTensor<Self, 4>, grad: FloatTensor<Self, 4>, kernel_size: [usize; 2], stride: [usize; 2], padding: [usize; 2], count_include_pad: bool ) -> FloatTensor<Self, 4>
Backward pass for the avg pooling 2d operation.
source§fn max_pool2d(
x: FloatTensor<Self, 4>,
kernel_size: [usize; 2],
stride: [usize; 2],
padding: [usize; 2],
dilation: [usize; 2]
) -> FloatTensor<Self, 4>
fn max_pool2d( x: FloatTensor<Self, 4>, kernel_size: [usize; 2], stride: [usize; 2], padding: [usize; 2], dilation: [usize; 2] ) -> FloatTensor<Self, 4>
Two dimensional max pooling. Read more
source§fn max_pool2d_with_indices(
x: FloatTensor<Self, 4>,
kernel_size: [usize; 2],
stride: [usize; 2],
padding: [usize; 2],
dilation: [usize; 2]
) -> MaxPool2dWithIndices<Wgpu<G, F, I>>
fn max_pool2d_with_indices( x: FloatTensor<Self, 4>, kernel_size: [usize; 2], stride: [usize; 2], padding: [usize; 2], dilation: [usize; 2] ) -> MaxPool2dWithIndices<Wgpu<G, F, I>>
Two dimensional max pooling with indices. Read more
source§fn max_pool2d_with_indices_backward(
x: FloatTensor<Self, 4>,
kernel_size: [usize; 2],
stride: [usize; 2],
padding: [usize; 2],
dilation: [usize; 2],
output_grad: FloatTensor<Self, 4>,
indices: IntTensor<Self, 4>
) -> MaxPool2dBackward<Wgpu<G, F, I>>
fn max_pool2d_with_indices_backward( x: FloatTensor<Self, 4>, kernel_size: [usize; 2], stride: [usize; 2], padding: [usize; 2], dilation: [usize; 2], output_grad: FloatTensor<Self, 4>, indices: IntTensor<Self, 4> ) -> MaxPool2dBackward<Wgpu<G, F, I>>
Backward pass for the max pooling 2d operation.
source§fn adaptive_avg_pool2d(
x: FloatTensor<Self, 4>,
output_size: [usize; 2]
) -> FloatTensor<Self, 4>
fn adaptive_avg_pool2d( x: FloatTensor<Self, 4>, output_size: [usize; 2] ) -> FloatTensor<Self, 4>
Two dimensional adaptive avg pooling. Read more
source§fn adaptive_avg_pool2d_backward(
x: FloatTensor<Self, 4>,
grad: FloatTensor<Self, 4>
) -> FloatTensor<Self, 4>
fn adaptive_avg_pool2d_backward( x: FloatTensor<Self, 4>, grad: FloatTensor<Self, 4> ) -> FloatTensor<Self, 4>
Backward pass for the adaptive avg pooling 2d operation.
source§fn embedding(
weights: <B as Backend>::TensorPrimitive<2>,
indices: <B as Backend>::IntTensorPrimitive<2>
) -> <B as Backend>::TensorPrimitive<3>
fn embedding( weights: <B as Backend>::TensorPrimitive<2>, indices: <B as Backend>::IntTensorPrimitive<2> ) -> <B as Backend>::TensorPrimitive<3>
Embedding operation. Read more
source§fn embedding_backward(
weights: <B as Backend>::TensorPrimitive<2>,
output_grad: <B as Backend>::TensorPrimitive<3>,
indices: <B as Backend>::IntTensorPrimitive<2>
) -> <B as Backend>::TensorPrimitive<2>
fn embedding_backward( weights: <B as Backend>::TensorPrimitive<2>, output_grad: <B as Backend>::TensorPrimitive<3>, indices: <B as Backend>::IntTensorPrimitive<2> ) -> <B as Backend>::TensorPrimitive<2>
Embedding backward operation. Read more
source§fn conv1d(
x: <B as Backend>::TensorPrimitive<3>,
weight: <B as Backend>::TensorPrimitive<3>,
bias: Option<<B as Backend>::TensorPrimitive<1>>,
options: ConvOptions<1>
) -> <B as Backend>::TensorPrimitive<3>
fn conv1d( x: <B as Backend>::TensorPrimitive<3>, weight: <B as Backend>::TensorPrimitive<3>, bias: Option<<B as Backend>::TensorPrimitive<1>>, options: ConvOptions<1> ) -> <B as Backend>::TensorPrimitive<3>
One dimensional convolution. Read more
source§fn conv1d_backward(
x: <B as Backend>::TensorPrimitive<3>,
weight: <B as Backend>::TensorPrimitive<3>,
bias: Option<<B as Backend>::TensorPrimitive<1>>,
output_grad: <B as Backend>::TensorPrimitive<3>,
options: ConvOptions<1>
) -> Conv1dBackward<B>
fn conv1d_backward( x: <B as Backend>::TensorPrimitive<3>, weight: <B as Backend>::TensorPrimitive<3>, bias: Option<<B as Backend>::TensorPrimitive<1>>, output_grad: <B as Backend>::TensorPrimitive<3>, options: ConvOptions<1> ) -> Conv1dBackward<B>
Backward pass for the conv1d operation.
source§fn conv2d_backward(
x: <B as Backend>::TensorPrimitive<4>,
weight: <B as Backend>::TensorPrimitive<4>,
bias: Option<<B as Backend>::TensorPrimitive<1>>,
output_grad: <B as Backend>::TensorPrimitive<4>,
options: ConvOptions<2>
) -> Conv2dBackward<B>
fn conv2d_backward( x: <B as Backend>::TensorPrimitive<4>, weight: <B as Backend>::TensorPrimitive<4>, bias: Option<<B as Backend>::TensorPrimitive<1>>, output_grad: <B as Backend>::TensorPrimitive<4>, options: ConvOptions<2> ) -> Conv2dBackward<B>
Backward pass for the conv2d operation.
source§fn conv_transpose1d(
x: <B as Backend>::TensorPrimitive<3>,
weight: <B as Backend>::TensorPrimitive<3>,
bias: Option<<B as Backend>::TensorPrimitive<1>>,
options: ConvTransposeOptions<1>
) -> <B as Backend>::TensorPrimitive<3>
fn conv_transpose1d( x: <B as Backend>::TensorPrimitive<3>, weight: <B as Backend>::TensorPrimitive<3>, bias: Option<<B as Backend>::TensorPrimitive<1>>, options: ConvTransposeOptions<1> ) -> <B as Backend>::TensorPrimitive<3>
One dimensional transposed convolution. Read more
source§fn conv_transpose1d_backward(
x: <B as Backend>::TensorPrimitive<3>,
weight: <B as Backend>::TensorPrimitive<3>,
bias: Option<<B as Backend>::TensorPrimitive<1>>,
output_grad: <B as Backend>::TensorPrimitive<3>,
options: ConvTransposeOptions<1>
) -> Conv1dBackward<B>
fn conv_transpose1d_backward( x: <B as Backend>::TensorPrimitive<3>, weight: <B as Backend>::TensorPrimitive<3>, bias: Option<<B as Backend>::TensorPrimitive<1>>, output_grad: <B as Backend>::TensorPrimitive<3>, options: ConvTransposeOptions<1> ) -> Conv1dBackward<B>
Backward pass for the conv transpose 1d operation.
source§fn conv_transpose2d_backward(
x: <B as Backend>::TensorPrimitive<4>,
weight: <B as Backend>::TensorPrimitive<4>,
bias: Option<<B as Backend>::TensorPrimitive<1>>,
output_grad: <B as Backend>::TensorPrimitive<4>,
options: ConvTransposeOptions<2>
) -> Conv2dBackward<B>
fn conv_transpose2d_backward( x: <B as Backend>::TensorPrimitive<4>, weight: <B as Backend>::TensorPrimitive<4>, bias: Option<<B as Backend>::TensorPrimitive<1>>, output_grad: <B as Backend>::TensorPrimitive<4>, options: ConvTransposeOptions<2> ) -> Conv2dBackward<B>
Backward pass for the conv transpose 2d operation.
source§fn unfold4d(
x: <B as Backend>::TensorPrimitive<4>,
kernel_size: [usize; 2],
options: UnfoldOptions
) -> <B as Backend>::TensorPrimitive<3>
fn unfold4d( x: <B as Backend>::TensorPrimitive<4>, kernel_size: [usize; 2], options: UnfoldOptions ) -> <B as Backend>::TensorPrimitive<3>
Four-dimensional unfolding. Read more
source§fn avg_pool1d(
x: <B as Backend>::TensorPrimitive<3>,
kernel_size: usize,
stride: usize,
padding: usize,
count_include_pad: bool
) -> <B as Backend>::TensorPrimitive<3>
fn avg_pool1d( x: <B as Backend>::TensorPrimitive<3>, kernel_size: usize, stride: usize, padding: usize, count_include_pad: bool ) -> <B as Backend>::TensorPrimitive<3>
One dimensional avg pooling. Read more
source§fn avg_pool1d_backward(
x: <B as Backend>::TensorPrimitive<3>,
grad: <B as Backend>::TensorPrimitive<3>,
kernel_size: usize,
stride: usize,
padding: usize,
count_include_pad: bool
) -> <B as Backend>::TensorPrimitive<3>
fn avg_pool1d_backward( x: <B as Backend>::TensorPrimitive<3>, grad: <B as Backend>::TensorPrimitive<3>, kernel_size: usize, stride: usize, padding: usize, count_include_pad: bool ) -> <B as Backend>::TensorPrimitive<3>
Backward pass for the avg pooling 1d operation.
source§fn adaptive_avg_pool1d(
x: <B as Backend>::TensorPrimitive<3>,
output_size: usize
) -> <B as Backend>::TensorPrimitive<3>
fn adaptive_avg_pool1d( x: <B as Backend>::TensorPrimitive<3>, output_size: usize ) -> <B as Backend>::TensorPrimitive<3>
One dimensional adaptive avg pooling. Read more
source§fn adaptive_avg_pool1d_backward(
x: <B as Backend>::TensorPrimitive<3>,
grad: <B as Backend>::TensorPrimitive<3>
) -> <B as Backend>::TensorPrimitive<3>
fn adaptive_avg_pool1d_backward( x: <B as Backend>::TensorPrimitive<3>, grad: <B as Backend>::TensorPrimitive<3> ) -> <B as Backend>::TensorPrimitive<3>
Backward pass for the adaptive avg pooling 1d operation.
source§fn max_pool1d(
x: <B as Backend>::TensorPrimitive<3>,
kernel_size: usize,
stride: usize,
padding: usize,
dilation: usize
) -> <B as Backend>::TensorPrimitive<3>
fn max_pool1d( x: <B as Backend>::TensorPrimitive<3>, kernel_size: usize, stride: usize, padding: usize, dilation: usize ) -> <B as Backend>::TensorPrimitive<3>
One dimensional max pooling. Read more
source§fn max_pool1d_with_indices(
x: <B as Backend>::TensorPrimitive<3>,
kernel_size: usize,
stride: usize,
padding: usize,
dilation: usize
) -> MaxPool1dWithIndices<B>
fn max_pool1d_with_indices( x: <B as Backend>::TensorPrimitive<3>, kernel_size: usize, stride: usize, padding: usize, dilation: usize ) -> MaxPool1dWithIndices<B>
One dimensional max pooling with indices. Read more
source§fn max_pool1d_with_indices_backward(
x: <B as Backend>::TensorPrimitive<3>,
kernel_size: usize,
stride: usize,
padding: usize,
dilation: usize,
output_grad: <B as Backend>::TensorPrimitive<3>,
indices: <B as Backend>::IntTensorPrimitive<3>
) -> MaxPool1dBackward<B>
fn max_pool1d_with_indices_backward( x: <B as Backend>::TensorPrimitive<3>, kernel_size: usize, stride: usize, padding: usize, dilation: usize, output_grad: <B as Backend>::TensorPrimitive<3>, indices: <B as Backend>::IntTensorPrimitive<3> ) -> MaxPool1dBackward<B>
Backward pass for the max pooling 1d operation.
source§impl<G, F, I> TensorOps<Wgpu<G, F, I>> for Wgpu<G, F, I>where
G: GraphicsApi + 'static,
F: FloatElement,
I: IntElement,
impl<G, F, I> TensorOps<Wgpu<G, F, I>> for Wgpu<G, F, I>where G: GraphicsApi + 'static, F: FloatElement, I: IntElement,
source§fn from_data<const D: usize>(
data: Data<FloatElem<Self>, D>,
device: &Device<Self>
) -> FloatTensor<Self, D>
fn from_data<const D: usize>( data: Data<FloatElem<Self>, D>, device: &Device<Self> ) -> FloatTensor<Self, D>
Creates a new tensor from the data structure. Read more
source§fn random<const D: usize>(
shape: Shape<D>,
distribution: Distribution,
device: &Device<Self>
) -> FloatTensor<Self, D>
fn random<const D: usize>( shape: Shape<D>, distribution: Distribution, device: &Device<Self> ) -> FloatTensor<Self, D>
Creates a new tensor with random values. Read more
source§fn shape<const D: usize>(tensor: &FloatTensor<Self, D>) -> Shape<D>
fn shape<const D: usize>(tensor: &FloatTensor<Self, D>) -> Shape<D>
Gets the shape of the tensor. Read more
source§fn into_data<const D: usize>(
tensor: FloatTensor<Self, D>
) -> Reader<Data<FloatElem<Self>, D>>
fn into_data<const D: usize>( tensor: FloatTensor<Self, D> ) -> Reader<Data<FloatElem<Self>, D>>
Converts the tensor to a data structure. Read more
source§fn device<const D: usize>(tensor: &FloatTensor<Self, D>) -> Device<Self>
fn device<const D: usize>(tensor: &FloatTensor<Self, D>) -> Device<Self>
Gets the device of the tensor. Read more
source§fn to_device<const D: usize>(
tensor: FloatTensor<Self, D>,
device: &Device<Self>
) -> FloatTensor<Self, D>
fn to_device<const D: usize>( tensor: FloatTensor<Self, D>, device: &Device<Self> ) -> FloatTensor<Self, D>
Moves the tensor to the given device. Read more
source§fn empty<const D: usize>(
shape: Shape<D>,
device: &Device<Self>
) -> FloatTensor<Self, D>
fn empty<const D: usize>( shape: Shape<D>, device: &Device<Self> ) -> FloatTensor<Self, D>
Creates an empty tensor with the given shape. Read more
source§fn add<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatTensor<Self, D>
) -> FloatTensor<Self, D>
fn add<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatTensor<Self, D> ) -> FloatTensor<Self, D>
Adds two tensors together. Read more
source§fn add_scalar<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatElem<Self>
) -> FloatTensor<Self, D>
fn add_scalar<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatElem<Self> ) -> FloatTensor<Self, D>
Adds a scalar to a tensor. Read more
source§fn zeros<const D: usize>(
shape: Shape<D>,
device: &Device<Self>
) -> FloatTensor<Self, D>
fn zeros<const D: usize>( shape: Shape<D>, device: &Device<Self> ) -> FloatTensor<Self, D>
Creates a new tensor with zeros. Read more
source§fn full<const D: usize>(
shape: Shape<D>,
fill_value: FloatElem<Self>,
device: &WgpuDevice
) -> FloatTensor<Self, D>
fn full<const D: usize>( shape: Shape<D>, fill_value: FloatElem<Self>, device: &WgpuDevice ) -> FloatTensor<Self, D>
Creates a tensor filled with given value. Read more
source§fn ones<const D: usize>(
shape: Shape<D>,
device: &Device<Self>
) -> FloatTensor<Self, D>
fn ones<const D: usize>( shape: Shape<D>, device: &Device<Self> ) -> FloatTensor<Self, D>
Creates a new tensor with ones. Read more
source§fn sub<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatTensor<Self, D>
) -> FloatTensor<Self, D>
fn sub<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatTensor<Self, D> ) -> FloatTensor<Self, D>
Subtracts two tensors. Read more
source§fn sub_scalar<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatElem<Self>
) -> FloatTensor<Self, D>
fn sub_scalar<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatElem<Self> ) -> FloatTensor<Self, D>
Subtracts a scalar from a tensor. Read more
source§fn mul<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatTensor<Self, D>
) -> FloatTensor<Self, D>
fn mul<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatTensor<Self, D> ) -> FloatTensor<Self, D>
Multiplies two tensors together element-wise.
source§fn mul_scalar<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatElem<Self>
) -> FloatTensor<Self, D>
fn mul_scalar<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatElem<Self> ) -> FloatTensor<Self, D>
Multiplies a tensor by a scalar. Read more
source§fn div<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatTensor<Self, D>
) -> FloatTensor<Self, D>
fn div<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatTensor<Self, D> ) -> FloatTensor<Self, D>
Divides two tensors element-wise. Read more
source§fn div_scalar<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatElem<Self>
) -> FloatTensor<Self, D>
fn div_scalar<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatElem<Self> ) -> FloatTensor<Self, D>
Divides a tensor by a scalar. Read more
source§fn matmul<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatTensor<Self, D>
) -> FloatTensor<Self, D>
fn matmul<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatTensor<Self, D> ) -> FloatTensor<Self, D>
Multiplies two tensors together using matrix multiplication. Read more
source§fn swap_dims<const D: usize>(
tensor: FloatTensor<Self, D>,
dim1: usize,
dim2: usize
) -> FloatTensor<Self, D>
fn swap_dims<const D: usize>( tensor: FloatTensor<Self, D>, dim1: usize, dim2: usize ) -> FloatTensor<Self, D>
Swaps two dimensions of a tensor. Read more
source§fn reshape<const D1: usize, const D2: usize>(
tensor: FloatTensor<Self, D1>,
shape: Shape<D2>
) -> FloatTensor<Self, D2>
fn reshape<const D1: usize, const D2: usize>( tensor: FloatTensor<Self, D1>, shape: Shape<D2> ) -> FloatTensor<Self, D2>
Reshapes a tensor. Read more
source§fn gather<const D: usize>(
dim: usize,
tensor: FloatTensor<Self, D>,
indices: IntTensor<Self, D>
) -> FloatTensor<Self, D>
fn gather<const D: usize>( dim: usize, tensor: FloatTensor<Self, D>, indices: IntTensor<Self, D> ) -> FloatTensor<Self, D>
Gather elements from a tensor. Read more
source§fn scatter<const D: usize>(
dim: usize,
tensor: FloatTensor<Self, D>,
indices: IntTensor<Self, D>,
value: FloatTensor<Self, D>
) -> FloatTensor<Self, D>
fn scatter<const D: usize>( dim: usize, tensor: FloatTensor<Self, D>, indices: IntTensor<Self, D>, value: FloatTensor<Self, D> ) -> FloatTensor<Self, D>
Scatter elements into a tensor. Read more
source§fn select<const D: usize>(
tensor: FloatTensor<Self, D>,
dim: usize,
indices: IntTensor<Self, 1>
) -> FloatTensor<Self, D>
fn select<const D: usize>( tensor: FloatTensor<Self, D>, dim: usize, indices: IntTensor<Self, 1> ) -> FloatTensor<Self, D>
Select tensor elements along the given dimension corresponding for the given indices. Read more
source§fn select_assign<const D: usize>(
tensor: FloatTensor<Self, D>,
dim: usize,
indices: IntTensor<Self, 1>,
value: FloatTensor<Self, D>
) -> FloatTensor<Self, D>
fn select_assign<const D: usize>( tensor: FloatTensor<Self, D>, dim: usize, indices: IntTensor<Self, 1>, value: FloatTensor<Self, D> ) -> FloatTensor<Self, D>
Assign the selected elements along the given dimension corresponding for the given indices
to the given value. Read more
source§fn slice<const D1: usize, const D2: usize>(
tensor: FloatTensor<Self, D1>,
ranges: [Range<usize>; D2]
) -> FloatTensor<Self, D1>
fn slice<const D1: usize, const D2: usize>( tensor: FloatTensor<Self, D1>, ranges: [Range<usize>; D2] ) -> FloatTensor<Self, D1>
Select tensor elements corresponding for the given ranges. Read more
source§fn slice_assign<const D1: usize, const D2: usize>(
tensor: FloatTensor<Self, D1>,
ranges: [Range<usize>; D2],
value: FloatTensor<Self, D1>
) -> FloatTensor<Self, D1>
fn slice_assign<const D1: usize, const D2: usize>( tensor: FloatTensor<Self, D1>, ranges: [Range<usize>; D2], value: FloatTensor<Self, D1> ) -> FloatTensor<Self, D1>
Assign the selected elements corresponding for the given ranges to the given value. Read more
source§fn mask_where<const D: usize>(
tensor: FloatTensor<Self, D>,
mask: BoolTensor<Self, D>,
value: FloatTensor<Self, D>
) -> FloatTensor<Self, D>
fn mask_where<const D: usize>( tensor: FloatTensor<Self, D>, mask: BoolTensor<Self, D>, value: FloatTensor<Self, D> ) -> FloatTensor<Self, D>
Update the given tensor with the value tensor where the mask is true. Read more
source§fn mask_fill<const D: usize>(
tensor: FloatTensor<Self, D>,
mask: BoolTensor<Self, D>,
value: FloatElem<Self>
) -> FloatTensor<Self, D>
fn mask_fill<const D: usize>( tensor: FloatTensor<Self, D>, mask: BoolTensor<Self, D>, value: FloatElem<Self> ) -> FloatTensor<Self, D>
Update the given tensor with the value where the mask is true. Read more
source§fn equal<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatTensor<Self, D>
) -> BoolTensor<Self, D>
fn equal<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatTensor<Self, D> ) -> BoolTensor<Self, D>
Equal comparison of two tensors. Read more
source§fn equal_elem<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatElem<Self>
) -> BoolTensor<Self, D>
fn equal_elem<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatElem<Self> ) -> BoolTensor<Self, D>
Equal comparison of a tensor and a scalar. Read more
source§fn greater<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatTensor<Self, D>
) -> BoolTensor<Self, D>
fn greater<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatTensor<Self, D> ) -> BoolTensor<Self, D>
Greater than comparison of two tensors. Read more
source§fn greater_elem<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatElem<Self>
) -> BoolTensor<Self, D>
fn greater_elem<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatElem<Self> ) -> BoolTensor<Self, D>
Greater than comparison of a tensor and a scalar. Read more
source§fn greater_equal<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatTensor<Self, D>
) -> BoolTensor<Self, D>
fn greater_equal<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatTensor<Self, D> ) -> BoolTensor<Self, D>
Greater than or equal comparison of two tensors. Read more
source§fn greater_equal_elem<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatElem<Self>
) -> BoolTensor<Self, D>
fn greater_equal_elem<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatElem<Self> ) -> BoolTensor<Self, D>
Greater than or equal comparison of a tensor and a scalar. Read more
source§fn lower<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatTensor<Self, D>
) -> BoolTensor<Self, D>
fn lower<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatTensor<Self, D> ) -> BoolTensor<Self, D>
Less than comparison of two tensors. Read more
source§fn lower_elem<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatElem<Self>
) -> BoolTensor<Self, D>
fn lower_elem<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatElem<Self> ) -> BoolTensor<Self, D>
Less than comparison of a tensor and a scalar. Read more
source§fn lower_equal<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatTensor<Self, D>
) -> BoolTensor<Self, D>
fn lower_equal<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatTensor<Self, D> ) -> BoolTensor<Self, D>
Less than or equal comparison of two tensors. Read more
source§fn lower_equal_elem<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: FloatElem<Self>
) -> BoolTensor<Self, D>
fn lower_equal_elem<const D: usize>( lhs: FloatTensor<Self, D>, rhs: FloatElem<Self> ) -> BoolTensor<Self, D>
Less than or equal comparison of a tensor and a scalar. Read more
source§fn sum<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, 1>
fn sum<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, 1>
Sum of all elements in a tensor. Read more
source§fn sum_dim<const D: usize>(
tensor: FloatTensor<Self, D>,
dim: usize
) -> FloatTensor<Self, D>
fn sum_dim<const D: usize>( tensor: FloatTensor<Self, D>, dim: usize ) -> FloatTensor<Self, D>
Sum of all elements in a tensor along a dimension. Read more
source§fn mean_dim<const D: usize>(
tensor: FloatTensor<Self, D>,
dim: usize
) -> FloatTensor<Self, D>
fn mean_dim<const D: usize>( tensor: FloatTensor<Self, D>, dim: usize ) -> FloatTensor<Self, D>
Mean of all elements in a tensor along a dimension. Read more
source§fn to_full_precision<const D: usize>(
tensor: &FloatTensor<Self, D>
) -> FloatTensor<FullPrecisionBackend<Self>, D>
fn to_full_precision<const D: usize>( tensor: &FloatTensor<Self, D> ) -> FloatTensor<FullPrecisionBackend<Self>, D>
Converts a tensor to full precision. Read more
source§fn from_full_precision<const D: usize>(
tensor: FloatTensor<FullPrecisionBackend<Self>, D>
) -> FloatTensor<Self, D>
fn from_full_precision<const D: usize>( tensor: FloatTensor<FullPrecisionBackend<Self>, D> ) -> FloatTensor<Self, D>
Converts a tensor from full precision. Read more
source§fn exp<const D: usize>(lhs: FloatTensor<Self, D>) -> FloatTensor<Self, D>
fn exp<const D: usize>(lhs: FloatTensor<Self, D>) -> FloatTensor<Self, D>
Returns a new tensor with exponential values. Read more
source§fn log<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
fn log<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
Returns a new tensor with natural logarithm values. Read more
source§fn log1p<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
fn log1p<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
Returns a new tensor with logarithm values of (1 + Xi). Read more
source§fn powf<const D: usize>(
lhs: FloatTensor<Self, D>,
rhs: f32
) -> FloatTensor<Self, D>
fn powf<const D: usize>( lhs: FloatTensor<Self, D>, rhs: f32 ) -> FloatTensor<Self, D>
Returns a new tensor with values raised to the power of
value. Read moresource§fn sqrt<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
fn sqrt<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
Returns a new tensor with square root values. Read more
source§fn abs<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
fn abs<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
Returns a new tensor with absolute values. Read more
source§fn cos<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
fn cos<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
Returns a new tensor with cosine values. Read more
source§fn sin<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
fn sin<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
Returns a new tensor with sine values. Read more
source§fn tanh<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
fn tanh<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
Returns a new tensor with tangent values. Read more
source§fn erf<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
fn erf<const D: usize>(tensor: FloatTensor<Self, D>) -> FloatTensor<Self, D>
Returns a new tensor with the error function values. Read more
source§fn cat<const D: usize>(
tensors: Vec<FloatTensor<Self, D>>,
dim: usize
) -> FloatTensor<Self, D>
fn cat<const D: usize>( tensors: Vec<FloatTensor<Self, D>>, dim: usize ) -> FloatTensor<Self, D>
Catcatenates tensors along a dimension. Read more
source§fn argmax<const D: usize>(
tensor: FloatTensor<Self, D>,
dim: usize
) -> IntTensor<Self, D>
fn argmax<const D: usize>( tensor: FloatTensor<Self, D>, dim: usize ) -> IntTensor<Self, D>
Gets the indices of the maximum elements of a tensor along an axis. Read more
source§fn argmin<const D: usize>(
tensor: FloatTensor<Self, D>,
dim: usize
) -> IntTensor<Self, D>
fn argmin<const D: usize>( tensor: FloatTensor<Self, D>, dim: usize ) -> IntTensor<Self, D>
Gets the indices of the minimum elements of a tensor along an axis. Read more
source§fn into_int<const D: usize>(tensor: FloatTensor<Self, D>) -> IntTensor<Self, D>
fn into_int<const D: usize>(tensor: FloatTensor<Self, D>) -> IntTensor<Self, D>
Converts float tensor to int tensor. Read more
source§fn clamp_min<const D: usize>(
tensor: FloatTensor<Self, D>,
min: FloatElem<Self>
) -> FloatTensor<Self, D>
fn clamp_min<const D: usize>( tensor: FloatTensor<Self, D>, min: FloatElem<Self> ) -> FloatTensor<Self, D>
Clamps a tensor under a minimum value. Read more
source§fn clamp_max<const D: usize>(
tensor: FloatTensor<Self, D>,
max: FloatElem<Self>
) -> FloatTensor<Self, D>
fn clamp_max<const D: usize>( tensor: FloatTensor<Self, D>, max: FloatElem<Self> ) -> FloatTensor<Self, D>
Clamps a tensor over a maximum value. Read more
source§fn clamp<const D: usize>(
tensor: FloatTensor<Self, D>,
min: FloatElem<Self>,
max: FloatElem<Self>
) -> FloatTensor<Self, D>
fn clamp<const D: usize>( tensor: FloatTensor<Self, D>, min: FloatElem<Self>, max: FloatElem<Self> ) -> FloatTensor<Self, D>
Clamps a tensor between a minimum and maximum value. Read more
source§fn recip<const D: usize>(
tensor: FloatTensor<Wgpu<G, F, I>, D>
) -> FloatTensor<Wgpu<G, F, I>, D>
fn recip<const D: usize>( tensor: FloatTensor<Wgpu<G, F, I>, D> ) -> FloatTensor<Wgpu<G, F, I>, D>
Calculates the reciprocals elementwise
source§fn to_data<const D: usize>(
tensor: &<B as Backend>::TensorPrimitive<D>
) -> Reader<Data<<B as Backend>::FloatElem, D>>
fn to_data<const D: usize>( tensor: &<B as Backend>::TensorPrimitive<D> ) -> Reader<Data<<B as Backend>::FloatElem, D>>
Converts the tensor to a data structure. Read more
source§fn arange(
range: Range<usize>,
device: &<B as Backend>::Device
) -> <B as Backend>::IntTensorPrimitive<1>
fn arange( range: Range<usize>, device: &<B as Backend>::Device ) -> <B as Backend>::IntTensorPrimitive<1>
Creates a new tensor with values from the given range. Read more
source§fn arange_step(
range: Range<usize>,
step: usize,
device: &<B as Backend>::Device
) -> <B as Backend>::IntTensorPrimitive<1>
fn arange_step( range: Range<usize>, step: usize, device: &<B as Backend>::Device ) -> <B as Backend>::IntTensorPrimitive<1>
Creates a new tensor with values from the given range with the given step size. Read more
source§fn repeat<const D: usize>(
tensor: <B as Backend>::TensorPrimitive<D>,
dim: usize,
times: usize
) -> <B as Backend>::TensorPrimitive<D>
fn repeat<const D: usize>( tensor: <B as Backend>::TensorPrimitive<D>, dim: usize, times: usize ) -> <B as Backend>::TensorPrimitive<D>
Repeat the tensor along the given dimension. Read more
source§fn neg<const D: usize>(
tensor: <B as Backend>::TensorPrimitive<D>
) -> <B as Backend>::TensorPrimitive<D>
fn neg<const D: usize>( tensor: <B as Backend>::TensorPrimitive<D> ) -> <B as Backend>::TensorPrimitive<D>
Negates a tensor element-wise.
source§fn transpose<const D: usize>(
tensor: <B as Backend>::TensorPrimitive<D>
) -> <B as Backend>::TensorPrimitive<D>
fn transpose<const D: usize>( tensor: <B as Backend>::TensorPrimitive<D> ) -> <B as Backend>::TensorPrimitive<D>
Transposes a tensor. Read more
source§fn detach<const D: usize>(
tensor: <B as Backend>::TensorPrimitive<D>
) -> <B as Backend>::TensorPrimitive<D>
fn detach<const D: usize>( tensor: <B as Backend>::TensorPrimitive<D> ) -> <B as Backend>::TensorPrimitive<D>
Detaches a tensor from the computation graph.
source§fn set_require_grad<const D: usize>(
tensor: <B as Backend>::TensorPrimitive<D>,
_require_grad: bool
) -> <B as Backend>::TensorPrimitive<D>
fn set_require_grad<const D: usize>( tensor: <B as Backend>::TensorPrimitive<D>, _require_grad: bool ) -> <B as Backend>::TensorPrimitive<D>
Sets the
require_grad flag of a tensor.source§fn is_require_grad<const D: usize>(
_tensor: &<B as Backend>::TensorPrimitive<D>
) -> bool
fn is_require_grad<const D: usize>( _tensor: &<B as Backend>::TensorPrimitive<D> ) -> bool
Returns the
require_grad flag of a tensor.source§fn mean<const D: usize>(
tensor: <B as Backend>::TensorPrimitive<D>
) -> <B as Backend>::TensorPrimitive<1>
fn mean<const D: usize>( tensor: <B as Backend>::TensorPrimitive<D> ) -> <B as Backend>::TensorPrimitive<1>
Mean of all elements in a tensor. Read more
source§fn max<const D: usize>(
tensor: <B as Backend>::TensorPrimitive<D>
) -> <B as Backend>::TensorPrimitive<1>
fn max<const D: usize>( tensor: <B as Backend>::TensorPrimitive<D> ) -> <B as Backend>::TensorPrimitive<1>
Gets the maximum element of a tensor. Read more
source§fn max_dim<const D: usize>(
tensor: <B as Backend>::TensorPrimitive<D>,
dim: usize
) -> <B as Backend>::TensorPrimitive<D>
fn max_dim<const D: usize>( tensor: <B as Backend>::TensorPrimitive<D>, dim: usize ) -> <B as Backend>::TensorPrimitive<D>
Gets the maximum elements of a tensor along an axis. Read more
source§fn max_dim_with_indices<const D: usize>(
tensor: <B as Backend>::TensorPrimitive<D>,
dim: usize
) -> (<B as Backend>::TensorPrimitive<D>, <B as Backend>::IntTensorPrimitive<D>)
fn max_dim_with_indices<const D: usize>( tensor: <B as Backend>::TensorPrimitive<D>, dim: usize ) -> (<B as Backend>::TensorPrimitive<D>, <B as Backend>::IntTensorPrimitive<D>)
Gets the maximum elements of a tensor along an axis and their indices. Read more
source§fn min<const D: usize>(
tensor: <B as Backend>::TensorPrimitive<D>
) -> <B as Backend>::TensorPrimitive<1>
fn min<const D: usize>( tensor: <B as Backend>::TensorPrimitive<D> ) -> <B as Backend>::TensorPrimitive<1>
Gets the minimum element of a tensor. Read more
source§fn min_dim<const D: usize>(
tensor: <B as Backend>::TensorPrimitive<D>,
dim: usize
) -> <B as Backend>::TensorPrimitive<D>
fn min_dim<const D: usize>( tensor: <B as Backend>::TensorPrimitive<D>, dim: usize ) -> <B as Backend>::TensorPrimitive<D>
Gets the minimum elements of a tensor along an axis. Read more
source§fn min_dim_with_indices<const D: usize>(
tensor: <B as Backend>::TensorPrimitive<D>,
dim: usize
) -> (<B as Backend>::TensorPrimitive<D>, <B as Backend>::IntTensorPrimitive<D>)
fn min_dim_with_indices<const D: usize>( tensor: <B as Backend>::TensorPrimitive<D>, dim: usize ) -> (<B as Backend>::TensorPrimitive<D>, <B as Backend>::IntTensorPrimitive<D>)
Gets the minimum elements of a tensor along an axis and their indices. Read more
Auto Trait Implementations§
impl<G, F, I> RefUnwindSafe for Wgpu<G, F, I>where F: RefUnwindSafe, G: RefUnwindSafe, I: RefUnwindSafe,
impl<G, F, I> Send for Wgpu<G, F, I>
impl<G, F, I> Sync for Wgpu<G, F, I>
impl<G, F, I> Unpin for Wgpu<G, F, I>where F: Unpin, G: Unpin, I: Unpin,
impl<G, F, I> UnwindSafe for Wgpu<G, F, I>where F: UnwindSafe, G: UnwindSafe, I: UnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more