Forked from
Eclipse Projects / aidge / aidge_backend_cuda
51 commits behind the upstream repository.
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
ErfImpl.hpp 1.77 KiB
/********************************************************************************
* Copyright (c) 2024 CEA-List
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License 2.0 which is available at
* http://www.eclipse.org/legal/epl-2.0.
*
* SPDX-License-Identifier: EPL-2.0
*
********************************************************************************/
#ifndef AIDGE_BACKEND_CUDA_OPERATOR_ERFIMPL_H_
#define AIDGE_BACKEND_CUDA_OPERATOR_ERFIMPL_H_
#include <array>
#include <memory>
#include <tuple>
#include <vector>
#include <cudnn.h>
#include "aidge/backend/OperatorImpl.hpp"
#include "aidge/operator/Erf.hpp"
#include "aidge/utils/Registrar.hpp"
#include "aidge/utils/Types.h"
#include "aidge/backend/cuda/utils/CudaUtils.hpp"
namespace Aidge {
// Operator implementation entry point for the backend
class ErfImpl_cuda : public OperatorImpl {
public:
ErfImpl_cuda(const Erf_Op& op) : OperatorImpl(op, "cuda") {}
static std::unique_ptr<ErfImpl_cuda> create(const Erf_Op& op) {
return std::make_unique<ErfImpl_cuda>(op);
}
virtual std::vector<ImplSpec> getAvailableImplSpecs() const override {
return {
{DataType::Float64},
{DataType::Float32},
{DataType::Float16},
};
}
void forward() override;
void backward() override;
private:
std::shared_ptr<Tensor> mInputFallback;
std::shared_ptr<Tensor> mOutputGradFallback;
template <class T> void forward_(const Tensor& input);
template <class T> void backward_(const Tensor& output_grad);
};
// Implementation entry point registration to Operator
REGISTRAR(Erf_Op, "cuda", Aidge::ErfImpl_cuda::create);
} // namespace Aidge
#endif /* AIDGE_BACKEND_CUDA_OPERATOR_ERFIMPL_H_ */