Struct Tensor

Source
pub struct Tensor { /* private fields */ }

Implementations§

Source§

impl Tensor

Source

pub fn new() -> Tensor

Source

pub fn data_copy(&self, o: &Tensor)

Source

pub fn swap(&self, o: &Tensor)

Source

pub fn ref_copy(&self) -> Tensor

Source

pub fn index2dimpos(&self, index: usize) -> Vec<usize>

Right most is the continous indexing, This method convert continuous index to index along each dimension.

Source

pub fn dimpos2index(&self, dimpos: &[usize]) -> usize

Right most is the continous indexing, This method convert index along each dimension to continuous index.

Source

pub fn is_empty() -> bool

Source

pub fn size(&self) -> Vec<usize>

Source

pub fn numel(&self) -> usize

Source

pub fn get_scale_f32(&self) -> f32

Source

pub fn get_scale_f64(&self) -> f64

Source

pub fn get_n(&self) -> Tensor

Source

pub fn get_c(&self) -> Tensor

Source

pub fn get_d(&self) -> Tensor

Source

pub fn get_h(&self) -> Tensor

Source

pub fn get_w(&self) -> Tensor

Source

pub fn numel_tensor(&self) -> Tensor

Source

pub fn get_patch( &self, range: &[(usize, usize)], step: Option<&[usize]>, ) -> Tensor

Source

pub fn set_patch( &self, other: &Tensor, range: &[(usize, usize)], step: Option<&[usize]>, ) -> Tensor

Source

pub fn same_shape(&self, o: &Tensor) -> bool

Source

pub fn from_vec_usize(input: &[usize], dim: &[usize]) -> Tensor

Source

pub fn from_vec_f32(input: &[f32], dim: &[usize]) -> Tensor

Create a tensor from a Vec,

let t1 = Tensor::from_vec_f32(&vec![0., 1., 2., 4.,], &vec![2,2]);
Source

pub fn get_raw_f32(&self) -> Vec<f32>

return the internal buffer May fail if the underlying data is f64

Source

pub fn from_vec_f64(input: &[f64], dim: &[usize]) -> Tensor

Source

pub fn get_raw_f64(&self) -> Vec<f64>

return the internal buffer May fail if the underlying data is f32

Source

pub fn get_u8(&self) -> Option<Vec<u8>>

try convert to Vec, value should be between 0, 255

Source

pub fn from_record_f32( &self, row: usize, record: &[f32], ) -> Result<(), &'static str>

Source

pub fn from_record_f64( &self, row: usize, record: &[f64], ) -> Result<(), &'static str>

Source

pub fn get_f32(&self, o: &[usize]) -> f32

Source

pub fn set_f32(&mut self, o: &[usize], v: f32)

Source

pub fn get_f64(&self, o: &[usize]) -> f64

Source

pub fn set_f64(&mut self, o: &[usize], v: f64)

Source

pub fn fill(size: &[usize], fill_value: &Tensor) -> Tensor

Returns a tensor of size size filled with fill_value.

Source

pub fn fill_f32(size: &[usize], fill_value: f32) -> Tensor

Source

pub fn fill_f64(size: &[usize], fill_value: f64) -> Tensor

Source

pub fn zeros(dim: &[usize]) -> Tensor

Source

pub fn zeros_like(&self) -> Tensor

Source

pub fn ones(dim: &[usize]) -> Tensor

Source

pub fn twos(dim: &[usize]) -> Tensor

Source

pub fn int_n(dim: &[usize], n: isize) -> Tensor

Source

pub fn ones_like(&self) -> Tensor

Source

pub fn range(start: f32, end: f32, step: Option<f32>) -> Tensor

Source

pub fn linspace(start: f32, end: f32, steps: usize) -> Tensor

Source

pub fn logspace(start: f32, end: f32, steps: usize, base: f32) -> Tensor

Source

pub fn eye(n: usize, m: usize) -> Tensor

Source

pub fn empty(shape: &[usize]) -> Tensor

Source

pub fn log10_like(&self) -> Tensor

Source

pub fn log2_like(&self) -> Tensor

Source

pub fn cat(&self, tensors: &[Tensor], dim: usize) -> Tensor

Source

pub fn chunk(&self, chunks: usize, dim: usize) -> Vec<Tensor>

Source

pub fn gather(&self, dim: usize, index: &Tensor) -> Tensor

Source

pub fn spread(&self, dim: usize, index: &Tensor, value: &Tensor) -> Tensor

Source

pub fn index_select(&self, dim: usize, index: &Tensor) -> Tensor

Source

pub fn index_exclude(&self, dim: usize, index: &Tensor) -> Tensor

Source

pub fn masked_select()

Source

pub fn narrow()

Source

pub fn nonzero()

Source

pub fn reshape(&self, new_shape: &[usize]) -> Tensor

Source

pub fn split(&self, sections: &[usize], dim: usize) -> Vec<Tensor>

Source

pub fn squeeze(&self, dim: Option<usize>) -> Tensor

Source

pub fn stack(&self, tensors: &[Tensor], dim: usize) -> Tensor

Source

pub fn t(&self) -> Tensor

Source

pub fn take(&self, index: &[usize]) -> Tensor

Source

pub fn transpose()

Source

pub fn unbind()

Source

pub fn permute(&self, dim: &[usize]) -> Tensor

Source

pub fn unsqueeze(&self, dim: usize) -> Tensor

Returns a new tensor with a dimension of size one inserted at the specified position.

The returned tensor shares the same underlying data with this tensor.

Source

pub fn conditional_select(&self, x: &Tensor, y: &Tensor) -> Tensor

Source

pub fn repeat(&self, dim: &[usize]) -> Tensor

Source

pub fn to_f64(&mut self)

Source

pub fn to_f32(&mut self)

Source

pub fn abs(&self) -> Tensor

Source

pub fn acos(&self) -> Tensor

Source

pub fn asin(&self) -> Tensor

Source

pub fn atan(&self) -> Tensor

Source

pub fn ceil(&self) -> Tensor

Source

pub fn cos(&self) -> Tensor

Source

pub fn cosh(&self) -> Tensor

Source

pub fn exp(&self) -> Tensor

Source

pub fn expm1(&self) -> Tensor

Source

pub fn floor(&self) -> Tensor

Source

pub fn frac(&self) -> Tensor

Source

pub fn lerp(&self, end: &Tensor, weight: &Tensor) -> Tensor

Source

pub fn log(&self) -> Tensor

Source

pub fn log10(&self) -> Tensor

Source

pub fn log1p(&self) -> Tensor

Source

pub fn log1pexp(&self) -> Tensor

Source

pub fn log2(&self) -> Tensor

Source

pub fn neg(&self) -> Tensor

Source

pub fn pow_f32(&self, n: f32) -> Tensor

Source

pub fn reciprocal(&self) -> Tensor

Source

pub fn round(&self) -> Tensor

Source

pub fn rsqrt(&self) -> Tensor

Source

pub fn sigmoid(&self) -> Tensor

Source

pub fn sign(&self) -> Tensor

Source

pub fn sin(&self) -> Tensor

Source

pub fn sinh(&self) -> Tensor

Source

pub fn sqrt(&self) -> Tensor

Source

pub fn square(&self) -> Tensor

Source

pub fn tan(&self) -> Tensor

Source

pub fn tanh(&self) -> Tensor

Source

pub fn trunc(&self) -> Tensor

Source

pub fn add(&self, o: &Tensor) -> Tensor

Source

pub fn sub(&self, o: &Tensor) -> Tensor

Source

pub fn mul(&self, o: &Tensor) -> Tensor

Source

pub fn div(&self, o: &Tensor) -> Tensor

Source

pub fn mm(&self, o: &Tensor) -> Tensor

Source

pub fn matmul(&self, o: &Tensor) -> Tensor

Source

pub fn outer(&self, o: &Tensor, avg: Option<bool>) -> Tensor

Source

pub fn argmax(&self, dim: Option<&[usize]>, keepdim: bool) -> Tensor

Source

pub fn argmin(&self, dim: Option<&[usize]>, keepdim: bool) -> Tensor

Source

pub fn logsumexp(&self, dim: Option<&[usize]>, keepdim: bool) -> Tensor

Source

pub fn mean(&self, dim: Option<&[usize]>, keepdim: bool) -> Tensor

Source

pub fn prod(&self, dim: Option<&[usize]>, keepdim: bool) -> Tensor

Source

pub fn std(&self, dim: Option<&[usize]>, keepdim: bool) -> Tensor

Source

pub fn sum(&self, dim: Option<&[usize]>, keepdim: bool) -> Tensor

Source

pub fn var(&self, dim: Option<&[usize]>, keepdim: bool) -> Tensor

Source

pub fn max(&self, dim: Option<&[usize]>, keepdim: bool) -> Tensor

Source

pub fn min(&self, dim: Option<&[usize]>, keepdim: bool) -> Tensor

Source

pub fn normalize(&self, mean: &Tensor, std: &Tensor) -> Tensor

mean and std are all scalars.

Source

pub fn normalize_unit(&self) -> Tensor

Source

pub fn lu(&self) -> Option<[Tensor; 2]>

Source

pub fn lu_solve(&self, o: &Tensor) -> Option<Tensor>

Source

pub fn qr(&self) -> Option<[Tensor; 2]>

Source

pub fn eigen(&self) -> Option<[Tensor; 2]>

Source

pub fn cholesky(&self) -> Option<Tensor>

Source

pub fn det(&self) -> Option<Tensor>

Source

pub fn svd(&self) -> Option<[Tensor; 3]>

Source

pub fn inv(&self) -> Option<Tensor>

Source

pub fn pinv(&self) -> Tensor

Source

pub fn tr(&self) -> Tensor

Source

pub fn all_close(&self, o: &Tensor) -> Tensor

Source

pub fn arg_sort(&self, dim: usize, descending: bool) -> Tensor

Source

pub fn eq_t(&self, o: &Tensor) -> Tensor

Source

pub fn equal(&self, o: &Tensor) -> bool

Source

pub fn ge(&self, o: &Tensor) -> Tensor

Source

pub fn gt(&self, o: &Tensor) -> Tensor

Source

pub fn le(&self, o: &Tensor) -> Tensor

Source

pub fn lt(&self, o: &Tensor) -> Tensor

Source

pub fn max_pair(&self, o: &Tensor) -> Tensor

Source

pub fn min_pair(&self, o: &Tensor) -> Tensor

Source

pub fn ne(&self, o: &Tensor) -> Tensor

Source

pub fn rand_usize( rng: &mut StdRng, dim: &[usize], left: usize, right: usize, ) -> Tensor

Source

pub fn normal_f64( rng: &mut StdRng, dim: &[usize], mean: f64, std: f64, ) -> Tensor

Source

pub fn normal_f32( rng: &mut StdRng, dim: &[usize], mean: f32, std: f32, ) -> Tensor

Source

pub fn uniform_f64( rng: &mut StdRng, dim: &[usize], from: f64, to: f64, ) -> Tensor

Source

pub fn uniform_f32( rng: &mut StdRng, dim: &[usize], from: f32, to: f32, ) -> Tensor

Source

pub fn conv2d( &self, weight: &Tensor, stride: (usize, usize), padding: (usize, usize), dilation: (usize, usize), padding_mode: PaddingMode, ) -> Tensor

Source

pub fn conv2d_grad( &self, weight: &Tensor, stride: (usize, usize), padding: (usize, usize), dilation: (usize, usize), padding_mode: PaddingMode, output_grad: &Tensor, ) -> (Tensor, Tensor)

Source

pub fn inner(&self) -> Rc<RefCell<TypedTensor>>

Source

pub fn set_inner(tt: TypedTensor) -> Tensor

Trait Implementations§

Source§

impl Clone for Tensor

Source§

fn clone(&self) -> Self

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 Debug for Tensor

Source§

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

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

impl Default for Tensor

Source§

fn default() -> Tensor

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

impl<'de> Deserialize<'de> for Tensor

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 Display for Tensor

Source§

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

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

impl PartialEq for Tensor

Source§

fn eq(&self, other: &Self) -> 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 Serialize for Tensor

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
Source§

impl Eq for Tensor

Auto Trait Implementations§

§

impl Freeze for Tensor

§

impl !RefUnwindSafe for Tensor

§

impl !Send for Tensor

§

impl !Sync for Tensor

§

impl Unpin for Tensor

§

impl !UnwindSafe for Tensor

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

Source§

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

Source§

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