test_1d.py 1.36 KB
Newer Older
zbian's avatar
zbian committed
1
2
3
#!/usr/bin/env python
# -*- encoding: utf-8 -*-

4
5
from functools import partial

zbian's avatar
zbian committed
6
import pytest
Frank Lee's avatar
Frank Lee committed
7
8
import torch
import torch.multiprocessing as mp
zbian's avatar
zbian committed
9
from colossalai.core import global_context as gpc
10
from colossalai.logging import disable_existing_loggers
アマデウス's avatar
アマデウス committed
11
from colossalai.initialize import launch
12
13
from colossalai.utils import free_port

Frank Lee's avatar
Frank Lee committed
14
from checks_1d.check_layer_1d import *
zbian's avatar
zbian committed
15
16
17
18
19

CONFIG = dict(
    parallel=dict(
        pipeline=dict(size=1),
        tensor=dict(
アマデウス's avatar
アマデウス committed
20
            size=4,
zbian's avatar
zbian committed
21
22
23
24
25
26
            mode='1d'
        )
    ),
)


27
def check_layer(rank, world_size, port):
28
    disable_existing_loggers()
Frank Lee's avatar
Frank Lee committed
29
30
31
32
    launch(config=CONFIG,
           rank=rank,
           world_size=world_size,
           host='localhost',
33
           port=port,
Frank Lee's avatar
Frank Lee committed
34
35
           backend='nccl')

zbian's avatar
zbian committed
36
37
    check_linear_col()
    check_linear_row()
38
39
40
41
42
43
44
    check_embed()
    check_vocab_parallel_embed()
    check_classifier_no_given_weight()
    check_vocab_parallel_classifier_no_given_weight()
    check_classifier_given_embed_weight()
    check_vocab_parallel_classifier_given_embed_weight()
    check_vocab_parallel_loss()
zbian's avatar
zbian committed
45

Frank Lee's avatar
Frank Lee committed
46
47
48
    gpc.destroy()
    torch.cuda.empty_cache()

zbian's avatar
zbian committed
49
50

@pytest.mark.dist
Frank Lee's avatar
Frank Lee committed
51
def test_1d():
アマデウス's avatar
アマデウス committed
52
    world_size = 4
53
    run_func = partial(check_layer, world_size=world_size, port=free_port())
Frank Lee's avatar
Frank Lee committed
54
    mp.spawn(run_func, nprocs=world_size)
zbian's avatar
zbian committed
55
56
57


if __name__ == '__main__':
Frank Lee's avatar
Frank Lee committed
58
    test_1d()