2022-05-19 04:44:59 +00:00
|
|
|
import pytest
|
2022-04-22 10:03:35 +00:00
|
|
|
from colossalai.utils import ColoInitContext
|
|
|
|
|
|
|
|
from numpy import allclose, require
|
|
|
|
import torch
|
|
|
|
from colossalai.tensor import ColoTensor
|
|
|
|
from copy import deepcopy
|
|
|
|
|
2022-04-25 06:24:26 +00:00
|
|
|
from colossalai.utils.cuda import get_current_device
|
2022-04-22 10:03:35 +00:00
|
|
|
|
2022-04-25 06:24:26 +00:00
|
|
|
|
2022-05-19 04:44:59 +00:00
|
|
|
@pytest.mark.skip
|
|
|
|
# FIXME(ver217): support lazy init
|
2022-04-25 06:24:26 +00:00
|
|
|
def test_lazy_init():
|
2022-04-22 10:03:35 +00:00
|
|
|
in_dim = 4
|
|
|
|
out_dim = 5
|
|
|
|
|
|
|
|
with ColoInitContext(lazy_memory_allocate=True) as ctx:
|
|
|
|
fc = torch.nn.Linear(in_dim, out_dim, bias=True)
|
|
|
|
|
|
|
|
# lazy_memory_allocate=True, no payload is maintained
|
|
|
|
assert fc.weight._torch_tensor.numel() == 0
|
|
|
|
|
|
|
|
fc.weight.torch_tensor()
|
|
|
|
assert fc.weight._torch_tensor.numel() == in_dim * out_dim
|
|
|
|
|
|
|
|
|
2022-05-19 04:44:59 +00:00
|
|
|
@pytest.mark.skip
|
2022-04-25 06:24:26 +00:00
|
|
|
def test_device():
|
|
|
|
in_dim = 4
|
|
|
|
out_dim = 5
|
|
|
|
|
|
|
|
with ColoInitContext(lazy_memory_allocate=True, device=get_current_device()) as ctx:
|
|
|
|
fc = torch.nn.Linear(in_dim, out_dim, bias=True)
|
|
|
|
|
|
|
|
# eval an lazy parameter
|
|
|
|
fc.weight.torch_tensor()
|
|
|
|
assert fc.weight.device == get_current_device()
|
|
|
|
|
|
|
|
|
2022-04-22 10:03:35 +00:00
|
|
|
if __name__ == '__main__':
|
2022-04-25 06:24:26 +00:00
|
|
|
test_lazy_init()
|
|
|
|
test_device()
|