deepspeed
43 строки · 1.1 Кб
1# Copyright (c) Microsoft Corporation.
2# SPDX-License-Identifier: Apache-2.0
3
4# DeepSpeed Team
5
6import os7from .builder import TorchCPUOpBuilder8
9
10class CPUAdagradBuilder(TorchCPUOpBuilder):11BUILD_VAR = "DS_BUILD_CPU_ADAGRAD"12NAME = "cpu_adagrad"13
14def __init__(self):15super().__init__(name=self.NAME)16
17def absolute_name(self):18return f'deepspeed.ops.adagrad.{self.NAME}_op'19
20def sources(self):21if self.build_for_cpu:22return ['csrc/adagrad/cpu_adagrad.cpp']23
24return ['csrc/adagrad/cpu_adagrad.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']33return args34
35def include_paths(self):36import torch37if self.build_for_cpu:38CUDA_INCLUDE = []39elif not self.is_rocm_pytorch():40CUDA_INCLUDE = [os.path.join(torch.utils.cpp_extension.CUDA_HOME, "include")]41else:42CUDA_INCLUDE = []43return ['csrc/includes'] + CUDA_INCLUDE44