#ifndef SPROUT_COMPOST_EFFECTS_NOISE_GATED_HPP #define SPROUT_COMPOST_EFFECTS_NOISE_GATED_HPP #include #include #include namespace sprout { namespace compost { namespace detail { template SPROUT_CONSTEXPR T noise_gate_value(T const& x, Value const& threshold) { return x <= threshold && x >= -threshold ? 0 : x ; } } // namespace detail // // noise_gate_value // template struct noise_gate_value { public: typedef Value value_type; typedef T argument_type; typedef T result_type; private: value_type threshold_; public: explicit SPROUT_CONSTEXPR noise_gate_value(Value const& threshold) : threshold_(threshold) {} SPROUT_CONSTEXPR result_type operator()(T const& x) const { return sprout::compost::detail::noise_gate_value(x, threshold_); } }; template struct noise_gate_value { public: typedef Value value_type; private: value_type threshold_; public: explicit SPROUT_CONSTEXPR noise_gate_value(Value const& threshold) : threshold_(threshold) {} template SPROUT_CONSTEXPR T operator()(T const& x) const { return sprout::compost::detail::noise_gate_value(x, threshold_); } }; namespace effects { // // noise_gate_holder // template class noise_gate_holder { public: typedef T value_type; private: value_type threshold_; public: noise_gate_holder() = default; noise_gate_holder(noise_gate_holder const&) = default; explicit SPROUT_CONSTEXPR noise_gate_holder(value_type const& threshold) : threshold_(threshold) {} SPROUT_CONSTEXPR value_type const& threshold() const { return threshold_; } }; // // noise_gated_forwarder // class noise_gated_forwarder { public: template SPROUT_CONSTEXPR sprout::compost::effects::noise_gate_holder operator()(T const& threshold) { return sprout::compost::effects::noise_gate_holder(threshold); } }; // // noise_gated // namespace { SPROUT_STATIC_CONSTEXPR sprout::compost::effects::noise_gated_forwarder noise_gated = {}; } // anonymous-namespace // // operator| // template inline SPROUT_CONSTEXPR auto operator|(Range&& lhs, sprout::compost::effects::noise_gate_holder const& rhs) -> decltype( sprout::forward(lhs) | sprout::adaptors::transformed(sprout::compost::noise_gate_value(rhs.threshold())) ) { return sprout::forward(lhs) | sprout::adaptors::transformed(sprout::compost::noise_gate_value(rhs.threshold())) ; } } // namespace effects using sprout::compost::effects::noise_gated; } // namespace compost } // namespace sprout #endif // #ifndef SPROUT_COMPOST_EFFECTS_NOISE_GATED_HPP