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.

Array.Indexing.Test.cs 6.5 kB

4 years ago
4 years ago
4 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. using Microsoft.VisualStudio.TestTools.UnitTesting;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Text;
  6. using Tensorflow;
  7. using Tensorflow.NumPy;
  8. using static Tensorflow.Binding;
  9. namespace TensorFlowNET.UnitTest.NumPy
  10. {
  11. /// <summary>
  12. /// https://numpy.org/doc/stable/user/basics.indexing.html
  13. /// </summary>
  14. [TestClass]
  15. public class ArrayIndexingTest : EagerModeTestBase
  16. {
  17. [TestMethod]
  18. public void int_params()
  19. {
  20. var x = np.arange(24).reshape((2, 3, 4));
  21. x[1, 2, 3] = 1;
  22. var y = x[1, 2, 3];
  23. Assert.AreEqual(y.shape, Shape.Scalar);
  24. Assert.AreEqual(y, 1);
  25. x[0, 0] = new[] { 3, 1, 1, 2 };
  26. y = x[0, 0];
  27. Assert.AreEqual(y.shape, 4);
  28. Assert.AreEqual(y, new[] { 3, 1, 1, 2 });
  29. y = x[0];
  30. Assert.AreEqual(y.shape, (3, 4));
  31. var z = np.arange(12).reshape((3, 4));
  32. x[1] = z;
  33. Assert.AreEqual(x[1], z);
  34. }
  35. [TestMethod]
  36. public void slice_newaxis()
  37. {
  38. var x = np.arange(20).reshape((4, 5));
  39. var y = x[np.newaxis, ":2"];
  40. Assert.AreEqual(y.shape, (1, 2, 5));
  41. }
  42. [TestMethod]
  43. public void slice_params()
  44. {
  45. var x = np.arange(12).reshape((3, 4));
  46. var y = x[new Slice(0, 1), new Slice(2)];
  47. Assert.AreEqual(y.shape, (1, 2));
  48. Assert.AreEqual(y, np.array(new[] { 2, 3 }).reshape((1, 2)));
  49. }
  50. [TestMethod]
  51. public void slice_string_params()
  52. {
  53. var x = np.arange(12).reshape((3, 4));
  54. var y = x[Slice.ParseSlices("0:1,2:")];
  55. Assert.AreEqual(y.shape, (1, 2));
  56. Assert.AreEqual(y, np.array(new[] { 2, 3 }).reshape((1, 2)));
  57. }
  58. [TestMethod]
  59. public void slice_out_bound()
  60. {
  61. var input_shape = tf.constant(new int[] { 1, 1 });
  62. var input_shape_val = input_shape.numpy();
  63. input_shape_val[(int)input_shape.size - 1] = 1;
  64. input_shape.Dispose();
  65. }
  66. [TestMethod]
  67. public void shape_helper_get_shape_3dim()
  68. {
  69. var x = np.arange(24).reshape((4, 3, 2));
  70. var shape1 = ShapeHelper.GetShape(x.shape, new Slice(1, isIndex: true));
  71. Assert.AreEqual(shape1, (3, 2));
  72. var shape2 = ShapeHelper.GetShape(x.shape, new Slice(1));
  73. Assert.AreEqual(shape2, (3, 3, 2));
  74. var shape3 = ShapeHelper.GetShape(x.shape, new Slice(2), Slice.All);
  75. Assert.AreEqual(shape3, (2, 3, 2));
  76. var shape4 = ShapeHelper.GetShape(x.shape, new Slice(1, isIndex: true), new Slice(2));
  77. Assert.AreEqual(shape4, (1, 2));
  78. var shape5 = ShapeHelper.GetShape(x.shape, new Slice(1, isIndex: true), new Slice(1));
  79. Assert.AreEqual(shape5, (2, 2));
  80. var shape6 = ShapeHelper.GetShape(x.shape, new Slice(1), new Slice(1, isIndex: true), new Slice(1));
  81. Assert.AreEqual(shape6, (3, 1));
  82. }
  83. [TestMethod]
  84. public void shape_helper_get_shape_4dim()
  85. {
  86. var x = np.arange(120).reshape((4, 3, 2, 5));
  87. var slices = new[] { new Slice(1, isIndex: true), new Slice(1), new Slice(0, isIndex: true), new Slice(1) };
  88. var shape1 = ShapeHelper.GetShape(x.shape, slices);
  89. Assert.AreEqual(shape1, (2, 4));
  90. var shape2 = ShapeHelper.GetShape(x.shape, Slice.All);
  91. Assert.AreEqual(shape2, (4, 3, 2, 5));
  92. var shape3 = ShapeHelper.GetShape(x.shape, Slice.All, new Slice(0, isIndex: true));
  93. Assert.AreEqual(shape3, (4, 3, 2));
  94. }
  95. [TestMethod]
  96. public void iterating()
  97. {
  98. var array = np.array(new[,] { { 0, 3 }, { 2, 2 }, { 3, 1 } });
  99. int i = 0;
  100. foreach(var x in array)
  101. {
  102. if (i == 0)
  103. Assert.AreEqual(x, new[] { 0, 3 });
  104. else
  105. Assert.AreEqual(x, array[i]);
  106. i++;
  107. }
  108. }
  109. [TestMethod]
  110. public void slice_step_setter()
  111. {
  112. var array = np.arange(32).reshape((4, 8));
  113. var s1 = array[Slice.All, new Slice(2, 5, 2)] + 1;
  114. Assert.AreEqual(s1.shape, (4, 2));
  115. var expected = new[] { 3, 5, 11, 13, 19, 21, 27, 29 };
  116. Assert.IsTrue(Enumerable.SequenceEqual(expected, s1.ToArray<int>()));
  117. array[Slice.All, new Slice(2, 5, 2)] = s1;
  118. Assert.AreEqual(array[0], new[] { 0, 1, 3, 3, 5, 5, 6, 7 });
  119. Assert.AreEqual(array[1], new[] { 8, 9, 11, 11, 13, 13, 14, 15 });
  120. Assert.AreEqual(array[2], new[] { 16, 17, 19, 19, 21, 21, 22, 23 });
  121. Assert.AreEqual(array[3], new[] { 24, 25, 27, 27, 29, 29, 30, 31 });
  122. }
  123. [TestMethod]
  124. public void slice_step_setter_diff_shape()
  125. {
  126. var array = np.arange(32).reshape((4, 8));
  127. var s1 = np.array(new[] { 100, 200 });
  128. array[Slice.All, new Slice(2, 5, 2)] = s1;
  129. Assert.AreEqual(array[0], new[] { 0, 1, 100, 3, 200, 5, 6, 7 });
  130. Assert.AreEqual(array[1], new[] { 8, 9, 100, 11, 200, 13, 14, 15 });
  131. Assert.AreEqual(array[2], new[] { 16, 17, 100, 19, 200, 21, 22, 23 });
  132. Assert.AreEqual(array[3], new[] { 24, 25, 100, 27, 200, 29, 30, 31 });
  133. }
  134. [TestMethod]
  135. public void mask_2d_get_value()
  136. {
  137. var x = np.arange(25).reshape((5, 5));
  138. var y = np.array(new[] { true, false, true, false, true });
  139. var z = x[y];
  140. Assert.AreEqual(z.shape, (3, 5));
  141. Assert.AreEqual(z[0], new[] { 0, 1, 2, 3, 4 });
  142. Assert.AreEqual(z[1], new[] { 10, 11, 12, 13, 14 });
  143. Assert.AreEqual(z[2], new[] { 20, 21, 22, 23, 24 });
  144. }
  145. [TestMethod]
  146. public void mask_2d_set_value()
  147. {
  148. var x = np.arange(25).reshape((5, 5));
  149. var y = np.array(new[] {true, false, true, false, false});
  150. x[y] = 0;
  151. Assert.AreEqual(x[0], new[] { 0, 0, 0, 0, 0 });
  152. Assert.AreEqual(x[1], new[] { 5, 6, 7, 8, 9 });
  153. Assert.AreEqual(x[2], new[] { 0, 0, 0, 0, 0 });
  154. Assert.AreEqual(x[3], new[] { 15, 16, 17, 18, 19 });
  155. }
  156. }
  157. }