tract_hir/ops/
downsample.rs1use crate::infer::*;
2use crate::internal::*;
3
4pub use tract_core::ops::downsample::Downsample;
5
6impl InferenceRulesOp for Downsample {
7 fn rules<'r, 'p: 'r, 's: 'r>(
8 &'s self,
9 s: &mut Solver<'r>,
10 inputs: &'p [TensorProxy],
11 outputs: &'p [TensorProxy],
12 ) -> InferenceResult {
13 check_input_arity(inputs, 1)?;
14 check_output_arity(outputs, 1)?;
15 s.equals(&inputs[0].rank, &outputs[0].rank)?;
16 s.equals(&inputs[0].datum_type, &outputs[0].datum_type)?;
17 s.given(&inputs[0].rank, move |s, r| {
18 for i in 0..(r as usize) {
19 if i == self.axis {
20 s.given(&inputs[0].shape[i], move |s, d| {
21 s.equals(
22 &outputs[0].shape[i],
23 (d - self.modulo).div_ceil(self.stride as u64),
24 )
25 })?
26 } else {
27 s.equals(&inputs[0].shape[i], &outputs[0].shape[i])?
28 }
29 }
30 Ok(())
31 })
32 }
33
34 as_op!();
35 to_typed!();
36}