test.py 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. '''Copyright The Microsoft DeepSpeed Team'''
  2. import torch
  3. from deepspeed.runtime.zero.contiguous_memory_allocator import ContiguousMemoryAllocator
  4. def test1():
  5. mem = ContiguousMemoryAllocator(1024, torch.half, 'cpu')
  6. mem.print_allocation(resolution=100)
  7. a1 = mem.allocate_tensor(64).mul_(0.0).add_(1.0)
  8. mem.print_allocation(resolution=100)
  9. mem.release_tensor(a1)
  10. mem.print_allocation(resolution=100)
  11. a2 = mem.allocate_tensor(64).mul_(0.0).add_(2.0)
  12. a3 = mem.allocate_tensor(256).mul_(0.0).add_(3.0)
  13. a4 = mem.allocate_tensor(128).mul_(0.0).add_(4.0)
  14. mem.print_allocation(resolution=100)
  15. mem.release_tensor(a3)
  16. mem.print_allocation(resolution=100)
  17. a5 = mem.allocate_tensor(64).mul_(0.0).add_(5.0)
  18. a6 = mem.allocate_tensor(256).mul_(0.0).add_(6.0)
  19. a7 = mem.allocate_tensor(128).mul_(0.0).add_(7.0)
  20. mem.print_allocation(resolution=100)
  21. a8 = mem.allocate_tensor(256).mul_(0.0).add_(8.0)
  22. a9 = mem.allocate_tensor(128).mul_(0.0).add_(9.0)
  23. mem.print_allocation(resolution=100)
  24. mem.release_tensor(a9)
  25. mem.release_tensor(a6)
  26. mem.release_tensor(a2)
  27. mem.release_tensor(a5)
  28. a10 = mem.allocate_tensor(512).mul_(0.0).add_(10.0)
  29. mem.print_allocation(resolution=100)
  30. #print(f"a4:{a4}")
  31. #print(f"a7:{a7}")
  32. #print(f"a8:{a8}")
  33. #print(f"a10:{a10}")
  34. assert (a4.norm() + a7.norm() + a8.norm() + a10.norm()).item() == 474.50, "Test failed"
  35. def test2():
  36. mem = ContiguousMemoryAllocator(512, torch.half, 'cpu')
  37. a1 = mem.allocate_tensor(64).mul_(0.0).add_(1.0)
  38. a2 = mem.allocate_tensor(64).mul_(0.0).add_(2.0)
  39. a3 = mem.allocate_tensor(64).mul_(0.0).add_(3.0)
  40. a4 = mem.allocate_tensor(64).mul_(0.0).add_(4.0)
  41. a5 = mem.allocate_tensor(64).mul_(0.0).add_(5.0)
  42. a6 = mem.allocate_tensor(64).mul_(0.0).add_(6.0)
  43. a7 = mem.allocate_tensor(64).mul_(0.0).add_(7.0)
  44. a8 = mem.allocate_tensor(64).mul_(0.0).add_(8.0)
  45. mem.release_tensor(a2)
  46. mem.release_tensor(a4)
  47. mem.release_tensor(a6)
  48. mem.release_tensor(a8)
  49. mem.print_allocation(resolution=100)
  50. a9 = mem.allocate_tensor(128).mul_(0.0).add_(9.0)
  51. a10 = mem.allocate_tensor(64).mul_(0.0).add_(10.0)
  52. a11 = mem.allocate_tensor(64).mul_(0.0).add_(11.0)
  53. mem.release_tensor(a1)
  54. mem.release_tensor(a5)
  55. mem.print_allocation(resolution=100)
  56. a12 = mem.allocate_tensor(128).mul_(0.0).add_(12.0)
  57. mem.print_allocation(resolution=100)
  58. print(f"a7:{a7}")
  59. print(f"a9:{a9}")
  60. print(f"a10:{a10}")
  61. print(f"a11:{a11}")
  62. print(f"a12:{a12}")
  63. assert (a7.norm() + a9.norm() + a10.norm() + a11.norm() + a12.norm()) == 460.75, "TestFailed"
  64. test1()
  65. test2()