deepspeed
44 строки · 1.2 Кб
1# Copyright (c) Microsoft Corporation.
2# SPDX-License-Identifier: Apache-2.0
3
4# DeepSpeed Team
5
6import os7from .builder import TorchCPUOpBuilder8
9
10class CPUAdamBuilder(TorchCPUOpBuilder):11BUILD_VAR = "DS_BUILD_CPU_ADAM"12NAME = "cpu_adam"13
14def __init__(self):15super().__init__(name=self.NAME)16
17def absolute_name(self):18return f'deepspeed.ops.adam.{self.NAME}_op'19
20def sources(self):21if self.build_for_cpu:22return ['csrc/adam/cpu_adam.cpp', 'csrc/adam/cpu_adam_impl.cpp']23
24return ['csrc/adam/cpu_adam.cpp', 'csrc/adam/cpu_adam_impl.cpp', 'csrc/common/custom_cuda_kernel.cu']25
26def libraries_args(self):27args = super().libraries_args()28if self.build_for_cpu:29return args30
31if not self.is_rocm_pytorch():32args += ['curand']33
34return args35
36def include_paths(self):37import torch38if self.build_for_cpu:39CUDA_INCLUDE = []40elif not self.is_rocm_pytorch():41CUDA_INCLUDE = [os.path.join(torch.utils.cpp_extension.CUDA_HOME, "include")]42else:43CUDA_INCLUDE = []44return ['csrc/includes'] + CUDA_INCLUDE45