STT-tensorflow/tensorflow/cc/gradients
2020-10-28 23:10:33 +03:00
..
array_grad_test.cc
array_grad.cc Create a V2 Op to stop the gradient when the input is out of range. 2020-10-12 10:39:36 -07:00
data_flow_grad_test.cc
data_flow_grad.cc
grad_testutil.cc
grad_testutil.h Adding space between C++ standard library headers and project headers 2020-09-17 11:17:01 +02:00
image_grad_test.cc
image_grad.cc
manip_grad_test.cc Implement manip gradient in cc. 2020-03-19 15:49:42 +03:30
manip_grad.cc Implement manip gradient in cc. 2020-03-19 15:49:42 +03:30
math_grad_test.cc
math_grad.cc
nn_grad_test.cc Adding 3d Pooling using latest MIOpen API 2020-06-09 15:11:45 +00:00
nn_grad.cc fix typos in cc dir 2020-10-28 23:10:33 +03:00
README.md

C++ gradients

Gradients are currently being ported from python to C++ (in this directory).

Contributions are welcome and much appreciated; please follow the instructions below.

  1. Create the op gradient function in foo_grad.cc corresponding to the foo_grad.py file where the op originated (i.e. array_grad.py op gradients should be written in array_grad.cc).

  2. Write the op gradient with the following naming scheme:

    Status OpNameGrad(const Scope& scope, const Operation& op,
                      const std::vector<Output>& grad_inputs,
                      std::vector<Output>* grad_outputs) {
      ...
      return scope.status();
    }
    REGISTER_GRADIENT_OP("OpName", OpNameGrad);
    
  3. Ops gradients are implemented by using the C++ API.

  4. Tests should be included in foo_grad_test.cc. Please see array_grad_test.cc for an many examples. Tests are as simple as, creating a placeholder input for the op's inputs and calling RunTest (RunTest uses a gradient checker to verify that the theoretical gradient matches the numeric gradient). For example:

    TEST_F(ArrayGradTest, IdentityGrad) {
      TensorShape shape({5, 2});
      auto x = Placeholder(scope_, DT_FLOAT, Placeholder::Shape(shape));
      auto y = Identity(scope_, x);
      RunTest(x, shape, y, shape);
    }
    

NOTE: There are some ops that require features from the C++ API that are not yet implemented.

  • Ops that require PartialTensorShape information cannot yet be implemented.

  • Ops that require SparseTensor or IndexSlices (currently only in python) cannot yet be implemented.

  • Maybe more.

For questions: Please create an issue assigned to suharshs.