You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

GradientTest.cs 3.1 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. using Microsoft.VisualStudio.TestTools.UnitTesting;
  2. using NumSharp;
  3. using System.Linq;
  4. using Tensorflow;
  5. using static Tensorflow.Python;
  6. namespace TensorFlowNET.UnitTest
  7. {
  8. [TestClass]
  9. public class GradientTest
  10. {
  11. [TestMethod]
  12. public void Gradients()
  13. {
  14. var graph = tf.Graph().as_default();
  15. var a = tf.constant(0.0);
  16. var b = 2.0 * a;
  17. Assert.AreEqual(b.name, "mul:0");
  18. Assert.AreEqual(b.op.inputs[0].name, "mul/x:0");
  19. Assert.AreEqual(b.op.inputs[1].name, "Const:0");
  20. var ys = a + b;
  21. Assert.AreEqual(ys.name, "add:0");
  22. Assert.AreEqual(ys.op.inputs[0].name, "Const:0");
  23. Assert.AreEqual(ys.op.inputs[1].name, "mul:0");
  24. var g = tf.gradients(ys, new Tensor[] { a, b }, stop_gradients: new Tensor[] { a, b });
  25. Assert.AreEqual(g[0].name, "gradients/Fill:0");
  26. Assert.AreEqual(g[1].name, "gradients/Fill:0");
  27. }
  28. [TestMethod]
  29. public void Gradient2x()
  30. {
  31. var graph = tf.Graph().as_default();
  32. with(tf.Session(graph), sess => {
  33. var x = tf.constant(7.0f);
  34. var y = x * x * tf.constant(0.1f);
  35. var grad = tf.gradients(y, x);
  36. Assert.AreEqual(grad[0].name, "gradients/AddN:0");
  37. float r = sess.run(grad[0]);
  38. Assert.AreEqual(r, 1.4f);
  39. });
  40. }
  41. [TestMethod]
  42. public void Gradient3x()
  43. {
  44. var graph = tf.Graph().as_default();
  45. with(tf.Session(graph), sess => {
  46. var x = tf.constant(7.0f);
  47. var y = x * x * x * tf.constant(0.1f);
  48. var grad = tf.gradients(y, x);
  49. Assert.AreEqual(grad[0].name, "gradients/AddN:0");
  50. float r = sess.run(grad[0]);
  51. Assert.AreEqual(r, 14.700001f);
  52. });
  53. }
  54. [TestMethod]
  55. public void StridedSlice()
  56. {
  57. var graph = tf.Graph().as_default();
  58. var t = tf.constant(np.array(new int[,,]
  59. {
  60. {
  61. { 11, 12, 13 },
  62. { 21, 22, 23 }
  63. },
  64. {
  65. { 31, 32, 33 },
  66. { 41, 42, 43 }
  67. },
  68. {
  69. { 51, 52, 53 },
  70. { 61, 62, 63 }
  71. }
  72. }));
  73. var slice = tf.strided_slice(t,
  74. begin: new[] { 0, 0, 0 },
  75. end: new[] { 3, 2, 3 },
  76. strides: new[] { 2, 2, 2 });
  77. var y = slice + slice;
  78. var g = tf.gradients(y, new Tensor[] { slice, slice });
  79. var r = slice.eval();
  80. Assert.IsTrue(Enumerable.SequenceEqual(r.shape, new[] { 2, 1, 2 }));
  81. Assert.IsTrue(Enumerable.SequenceEqual(r[0].GetData<int>(), new[] { 11, 13 }));
  82. Assert.IsTrue(Enumerable.SequenceEqual(r[1].GetData<int>(), new[] { 51, 53 }));
  83. }
  84. }
  85. }