12345678910111213141516171819202122232425262728293031323334353637383940 |
- """
- Copyright 2022 The Microsoft DeepSpeed Team
- """
- from .builder import CUDAOpBuilder
- class RandomLTDBuilder(CUDAOpBuilder):
- BUILD_VAR = "DS_BUILD_RANDOM_LTD"
- NAME = "random_ltd"
- def __init__(self, name=None):
- name = self.NAME if name is None else name
- super().__init__(name=name)
- def absolute_name(self):
- return f'deepspeed.ops.{self.NAME}_op'
- def extra_ldflags(self):
- if not self.is_rocm_pytorch():
- return ['-lcurand']
- else:
- return []
- def sources(self):
- return [
- 'csrc/random_ltd/pt_binding.cpp',
- 'csrc/random_ltd/gather_scatter.cu',
- 'csrc/random_ltd/slice_attn_masks.cu',
- 'csrc/random_ltd/token_sort.cu'
- ]
- def include_paths(self):
- includes = ['csrc/includes']
- if self.is_rocm_pytorch():
- from torch.utils.cpp_extension import ROCM_HOME
- includes += [
- '{}/hiprand/include'.format(ROCM_HOME),
- '{}/rocrand/include'.format(ROCM_HOME)
- ]
- return includes
|