Commit 3f561f5e authored by Adam Procter's avatar Adam Procter Committed by Scott Cyphers

Update l2_norm and std_dev builders to use op::Sqrt (#2040)

* Update l2_norm and std_dev builders to use op::Sqrt instead of op::Power(...,0.5)

* Removed unneeded power.hpp include
parent 2fc73b43
...@@ -22,8 +22,8 @@ ...@@ -22,8 +22,8 @@
#include "ngraph/op/constant.hpp" #include "ngraph/op/constant.hpp"
#include "ngraph/op/divide.hpp" #include "ngraph/op/divide.hpp"
#include "ngraph/op/multiply.hpp" #include "ngraph/op/multiply.hpp"
#include "ngraph/op/power.hpp"
#include "ngraph/op/reshape.hpp" #include "ngraph/op/reshape.hpp"
#include "ngraph/op/sqrt.hpp"
#include "ngraph/op/subtract.hpp" #include "ngraph/op/subtract.hpp"
#include "ngraph/op/sum.hpp" #include "ngraph/op/sum.hpp"
#include "ngraph/util.hpp" #include "ngraph/util.hpp"
...@@ -45,13 +45,10 @@ namespace ngraph ...@@ -45,13 +45,10 @@ namespace ngraph
std::shared_ptr<Node> l2_norm(const std::shared_ptr<Node>& node, std::shared_ptr<Node> l2_norm(const std::shared_ptr<Node>& node,
const AxisSet& reduction_axes) const AxisSet& reduction_axes)
{ {
const auto& et = node->get_element_type();
auto x2 = node * node; auto x2 = node * node;
auto x2sum = std::make_shared<op::Sum>(x2, reduction_axes); auto x2sum = std::make_shared<op::Sum>(x2, reduction_axes);
// TODO(mbrookhart): Use Sqrt instead of Power return std::make_shared<op::Sqrt>(x2sum);
auto half = op::Constant::create(et, x2sum->get_shape(), {0.5});
return std::make_shared<op::Power>(x2sum, half);
} }
std::shared_ptr<Node> mean(const std::shared_ptr<Node>& node, const AxisSet& reduction_axes) std::shared_ptr<Node> mean(const std::shared_ptr<Node>& node, const AxisSet& reduction_axes)
...@@ -70,12 +67,7 @@ namespace ngraph ...@@ -70,12 +67,7 @@ namespace ngraph
const AxisSet& reduction_axes, const AxisSet& reduction_axes,
const bool bessel_correction) const bool bessel_correction)
{ {
auto var = variance(node, reduction_axes, bessel_correction); return std::make_shared<op::Sqrt>(variance(node, reduction_axes, bessel_correction));
const auto& et = node->get_element_type();
// TODO(mbrookhart): Use Sqrt instead of Power
auto half = op::Constant::create(et, var->get_shape(), {0.5});
return std::make_shared<op::Power>(var, half);
} }
// This currently calculates [E[X^2] - E[X]^2] instead of [E[(X-\mu)^2]] // This currently calculates [E[X^2] - E[X]^2] instead of [E[(X-\mu)^2]]
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment