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 32 33
use crate::internal::*; use tract_core::ops::nn::Reduce; register_all!(Reduce: pulsify); fn pulsify( op: &Reduce, _source: &TypedModel, node: &TypedNode, target: &mut PulsedModel, mapping: &HashMap<OutletId, OutletId>, _pulse: usize, ) -> TractResult<TVec<OutletId>> { let input = mapping[&node.inputs[0]]; let axis = target.outlet_fact(input)?.axis; if op.axes.contains(&axis) { bail!("Can not reduce over streaming axis"); } target.wire_node(&*node.name, op.clone(), &[input]) } impl PulsedOp for Reduce { fn pulsed_output_facts(&self, inputs: &[&PulsedFact]) -> TractResult<TVec<PulsedFact>> { let mut fact = inputs[0].clone(); for &ax in &self.axes { fact.shape[ax] = 1.to_dim(); } Ok(tvec!(fact)) } as_op!(); pulsed_op_to_typed_op!(); }