1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
use crate::prelude::*;
pub fn backward<T: Tensor<Dtype = f32, Tape = OwnedTape>>(t: T) -> Gradients {
let (t, mut tape) = t.split_tape();
tape.add_backward_op(move |grads| {
T::Device::fill(grads.mut_gradient(&t), &mut |v| *v = 1.0);
});
tape.0.execute()
}
macro_rules! tensor_impl {
($typename:ident, [$($Vs:tt),*]) => {
impl<$(const $Vs: usize, )*> $typename<$($Vs, )* OwnedTape> {
pub fn backward(self) -> Gradients {
backward(self)
}
}
};
}
tensor_impl!(Tensor0D, []);
tensor_impl!(Tensor1D, [M]);
tensor_impl!(Tensor2D, [M, N]);
tensor_impl!(Tensor3D, [M, N, O]);
tensor_impl!(Tensor4D, [M, N, O, P]);