2022-03-01 10:17:01 +00:00
|
|
|
import torch
|
2023-04-04 05:48:16 +00:00
|
|
|
|
2022-03-01 10:17:01 +00:00
|
|
|
from colossalai.registry import OPHOOKS
|
|
|
|
|
2022-03-04 03:49:02 +00:00
|
|
|
from . import BaseOpHook
|
|
|
|
|
|
|
|
|
2022-03-01 10:17:01 +00:00
|
|
|
@OPHOOKS.register_module
|
|
|
|
class ShardParamHook(BaseOpHook):
|
|
|
|
"""
|
2023-04-26 03:38:43 +00:00
|
|
|
A hook to process sharded param before and after FWD and BWD operator executing.
|
2022-03-01 10:17:01 +00:00
|
|
|
"""
|
2022-03-04 03:49:02 +00:00
|
|
|
|
2022-03-01 10:17:01 +00:00
|
|
|
def __init__(self):
|
|
|
|
super().__init__()
|
|
|
|
|
|
|
|
def niter(self):
|
|
|
|
return self._niter
|
|
|
|
|
|
|
|
def pre_fwd_exec(self, module: torch.nn.Module, *args):
|
|
|
|
for param in module.parameters():
|
|
|
|
assert hasattr(param, 'ca_attr')
|
|
|
|
param.ca_attr.gather()
|
2022-03-04 05:40:48 +00:00
|
|
|
param.data = param.ca_attr.payload()
|
2022-03-01 10:17:01 +00:00
|
|
|
|
|
|
|
def post_fwd_exec(self, module: torch.nn.Module, *args):
|
|
|
|
for param in module.parameters():
|
|
|
|
assert hasattr(param, 'ca_attr')
|
|
|
|
param.ca_attr.shard()
|
2022-03-04 05:40:48 +00:00
|
|
|
param.data = param.ca_attr.payload()
|
2022-03-01 10:17:01 +00:00
|
|
|
|
|
|
|
def pre_bwd_exec(self, module: torch.nn.Module, input, output):
|
|
|
|
for param in module.parameters():
|
|
|
|
assert hasattr(param, 'ca_attr')
|
|
|
|
param.ca_attr.gather()
|
2022-03-04 05:40:48 +00:00
|
|
|
param.data = param.ca_attr.payload()
|
2022-03-01 10:17:01 +00:00
|
|
|
|
|
|
|
def post_bwd_exec(self, module: torch.nn.Module, input):
|
|
|
|
for param in module.parameters():
|
|
|
|
assert hasattr(param, 'ca_attr')
|
|
|
|
param.ca_attr.shard()
|
2022-03-04 05:40:48 +00:00
|
|
|
param.data = param.ca_attr.payload()
|
2022-03-01 10:17:01 +00:00
|
|
|
|
|
|
|
def pre_iter(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
def post_iter(self):
|
|
|
|
pass
|