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.

CApi.Eager.TensorHandleDevices.cs 3.1 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. using Microsoft.VisualStudio.TestTools.UnitTesting;
  2. using System;
  3. using Tensorflow;
  4. using Tensorflow.Eager;
  5. namespace TensorFlowNET.UnitTest.NativeAPI
  6. {
  7. public partial class CApiEagerTest
  8. {
  9. /// <summary>
  10. /// TEST(CAPI, TensorHandleDevices)
  11. /// </summary>
  12. [TestMethod]
  13. public unsafe void TensorHandleDevices()
  14. {
  15. var status = c_api.TF_NewStatus();
  16. static SafeContextHandle NewContext(SafeStatusHandle status)
  17. {
  18. using var opts = c_api.TFE_NewContextOptions();
  19. return c_api.TFE_NewContext(opts, status);
  20. }
  21. using var ctx = NewContext(status);
  22. ASSERT_EQ(TF_OK, TF_GetCode(status), TF_Message(status));
  23. var hcpu = TestMatrixTensorHandle();
  24. var device_name = TFE_TensorHandleDeviceName(hcpu, status);
  25. ASSERT_EQ(TF_OK, TF_GetCode(status), TF_Message(status));
  26. ASSERT_TRUE(device_name.Contains("CPU:0"));
  27. var backing_device_name = TFE_TensorHandleBackingDeviceName(hcpu, status);
  28. ASSERT_EQ(TF_OK, TF_GetCode(status), TF_Message(status));
  29. ASSERT_TRUE(backing_device_name.Contains("CPU:0"));
  30. // Disable the test if no GPU is present.
  31. string gpu_device_name = "";
  32. if(GetDeviceName(ctx, ref gpu_device_name, "GPU"))
  33. {
  34. var hgpu = TFE_TensorHandleCopyToDevice(hcpu, ctx, gpu_device_name, status);
  35. ASSERT_TRUE(TF_GetCode(status) == TF_OK, TF_Message(status));
  36. var retvals = new IntPtr[1];
  37. using (var shape_op = ShapeOp(ctx, hgpu))
  38. {
  39. TFE_OpSetDevice(shape_op, gpu_device_name, status);
  40. ASSERT_TRUE(TF_GetCode(status) == TF_OK, TF_Message(status));
  41. int num_retvals = 1;
  42. c_api.TFE_Execute(shape_op, retvals, ref num_retvals, status);
  43. ASSERT_TRUE(TF_GetCode(status) == TF_OK, TF_Message(status));
  44. // .device of shape is GPU since the op is executed on GPU
  45. device_name = TFE_TensorHandleDeviceName(retvals[0], status);
  46. ASSERT_EQ(TF_OK, TF_GetCode(status), TF_Message(status));
  47. ASSERT_TRUE(device_name.Contains("GPU:0"));
  48. // .backing_device of shape is CPU since the tensor is backed by CPU
  49. backing_device_name = TFE_TensorHandleBackingDeviceName(retvals[0], status);
  50. ASSERT_EQ(TF_OK, TF_GetCode(status), TF_Message(status));
  51. ASSERT_TRUE(backing_device_name.Contains("CPU:0"));
  52. }
  53. TFE_DeleteTensorHandle(retvals[0]);
  54. TFE_DeleteTensorHandle(hgpu);
  55. }
  56. TFE_DeleteTensorHandle(hcpu);
  57. // not export api
  58. using var executor = TFE_ContextGetExecutorForThread(ctx);
  59. TFE_ExecutorWaitForAllPendingNodes(executor, status);
  60. ASSERT_EQ(TF_OK, TF_GetCode(status), TF_Message(status));
  61. }
  62. }
  63. }