pub enum TropicalPlan<T: Scalar> {
BatchedGemm {
batch_dims: Vec<usize>,
m: usize,
n: usize,
k: usize,
_marker: PhantomData<T>,
},
Reduce {
reduced_axes: Vec<usize>,
_marker: PhantomData<T>,
},
Trace {
paired_axes: Vec<(usize, usize)>,
free_axes: Vec<usize>,
_marker: PhantomData<T>,
},
AntiTrace {
paired_axes: Vec<(usize, usize)>,
free_axes: Vec<usize>,
_marker: PhantomData<T>,
},
AntiDiag {
paired_axes: Vec<(usize, usize)>,
free_axes: Vec<usize>,
_marker: PhantomData<T>,
},
MakeContiguous {
_marker: PhantomData<T>,
},
}Expand description
Execution plan for tropical primitive operations on CPU.
Analogous to CpuPlan but for tropical
algebras. The plan captures pre-computed kernel selection information.
§Examples
ⓘ
use tenferro_device::LogicalMemorySpace;
use tenferro_prims::{CpuBackend, CpuContext, SemiringCoreDescriptor, TensorSemiringCore};
use tenferro_tensor::{MemoryOrder, Tensor};
use tenferro_ext_tropical::{MaxPlus, MaxPlusAlgebra, TropicalPlan};
let mut ctx = CpuContext::new(1);
let col = MemoryOrder::ColumnMajor;
let mem = LogicalMemorySpace::MainMemory;
let a = Tensor::<MaxPlus<f64>>::zeros(&[3, 4], mem, col);
let mut c = Tensor::<MaxPlus<f64>>::zeros(&[3], mem, col);
let desc = SemiringCoreDescriptor::ReduceAdd {
modes_a: vec![0, 1],
modes_c: vec![0],
};
let plan =
<CpuBackend as TensorSemiringCore<MaxPlusAlgebra<f64>>>::plan(
&mut ctx,
&desc,
&[&[3, 4], &[3]],
)
.unwrap();
<CpuBackend as TensorSemiringCore<MaxPlusAlgebra<f64>>>::execute(
&mut ctx,
&plan,
MaxPlus::one(),
&[&a],
MaxPlus::zero(),
&mut c,
)
.unwrap();Variants§
BatchedGemm
Plan for batched GEMM under tropical algebra.
Fields
§
_marker: PhantomData<T>Reduce
Plan for reduction under tropical algebra.
Trace
Plan for trace under tropical algebra.
Fields
§
_marker: PhantomData<T>AntiTrace
Plan for anti-trace (AD backward).
Fields
§
_marker: PhantomData<T>AntiDiag
Plan for anti-diag (AD backward).
Fields
§
_marker: PhantomData<T>MakeContiguous
Plan for making a tensor contiguous.
Fields
§
_marker: PhantomData<T>Trait Implementations§
Auto Trait Implementations§
impl<T> Freeze for TropicalPlan<T>
impl<T> RefUnwindSafe for TropicalPlan<T>where
T: RefUnwindSafe,
impl<T> Send for TropicalPlan<T>
impl<T> Sync for TropicalPlan<T>
impl<T> Unpin for TropicalPlan<T>where
T: Unpin,
impl<T> UnwindSafe for TropicalPlan<T>where
T: 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
§impl<T> DistributionExt for Twhere
T: ?Sized,
impl<T> DistributionExt for Twhere
T: ?Sized,
fn rand<T>(&self, rng: &mut (impl Rng + ?Sized)) -> Twhere
Self: Distribution<T>,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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